MIDI
[mw/milkymist.git] / tools / bin2hex.c
1 /*
2  * Milkymist VJ SoC
3  * Copyright (C) 2007, 2008, 2009, 2010 Sebastien Bourdeauducq
4  *
5  * This program is free software: you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation, version 3 of the License.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
16  */
17
18 #include <stdlib.h>
19 #include <stdio.h>
20
21 int main(int argc, char *argv[])
22 {
23         int i;
24         int pad;
25         FILE *fdi, *fdo;
26         unsigned char w[4];
27         
28         if(argc != 4) {
29                 fprintf(stderr, "Usage: bin2hex <infile> <outfile> <size>\n");
30                 return 1;
31         }
32         pad = atoi(argv[3]);
33         if(pad <= 0) {
34                 fprintf(stderr, "Incorrect size\n");
35                 return 1;
36         }
37         fdi = fopen(argv[1], "rb");
38         if(!fdi) {
39                 perror("Unable to open input file");
40                 return 1;
41         }
42         fdo = fopen(argv[2], "w");
43         if(!fdo) {
44                 perror("Unable to open output file");
45                 fclose(fdi);
46                 return 1;
47         }
48         while(1) {
49                 if(fread(w, 4, 1, fdi) <= 0) break;
50                 fprintf(fdo, "%02hhx%02hhx%02hhx%02hhx\n", w[0], w[1], w[2], w[3]);
51                 pad--;
52         }
53         fclose(fdi);
54         if(pad<0)
55                 fprintf(stderr, "Warning: Input binary is larger than specified size\n");
56         for(i=0;i<pad;i++)
57                 fprintf(fdo, "00000000\n");
58         if(fclose(fdo) != 0) {
59                 perror("Unable to close output file");
60                 return 1;
61         }
62         return 0;
63 }