summaryrefslogtreecommitdiffstats
path: root/fpga/xilinx/programmer/bit2svf/dumpbit.c
blob: 5d7c634036ba0cea2c3cb64b22e3bf68310f5f0b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
 /**[txh]********************************************************************
                                                                                
  Copyright (c) 2005 Juan Pablo D. Borgna <jpborgna en inti gov ar>
  Copyright (c) 2005 Instituto Nacional de Tecnología Industrial                
                                                                                
 This program is free software; you can redistribute it and/or modify
 it under the terms of the GNU General Public License as published by
 the Free Software Foundation; version 2.

 This program is distributed in the hope that it will be useful,
 but WITHOUT ANY WARRANTY; without even the implied warranty of
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 GNU General Public License for more details.

 You should have received a copy of the GNU General Public License
 along with this program; if not, write to the Free Software
 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
 02111-1307, USA

  Description: Dumps the contents of a xilinx bit file in stdout.
                                                                                
***************************************************************************/    
/*****************************************************************************  
                                                                                
 Target:      Any                                                               
 Language:    C
 Compiler:    gcc 3.3.5 (Debian GNU/Linux)
 Text editor: SETEdit 0.5.5                                                     
                                                                                
*****************************************************************************/  

#include <stdio.h>
#include <stdlib.h>
#include "bitfile.h"

#define BSIZE 1048576  /* 1k */


/* read a bit file from stdin */
int main(int argc, char *argv[])
{
 struct bithead bh;
 FILE *bitfile, *outfile;
 int remaining,readed;
 char buff[BSIZE];
 
 fprintf(stderr,"\ndumpbit - bit file stream dumper - v1.0\n");
 fprintf(stderr,"Copyright (c) 2005 Juan Pablo D. Borgna/INTI\n\n");

 if (argc==1 || argc>3)
   {
    fprintf(stderr,"Insufficient args %s filename.bit filename\n",argv[0]);
    return 1;
   }

 if ((bitfile=fopen(argv[1],"rb"))==NULL)
   {
    perror("BITFILE");
    return 2;
   }

 if ((outfile=fopen(argv[2],"wb"))==NULL)
   {
    perror("OUTFILE");
    return 3;
   }

 initbh(&bh);
 if (readhead(&bh, bitfile))
   {
    fprintf(stderr,"Invalid bit file header.\n");
    return 3;
   }

 fprintf(stderr,"\n");
 fprintf(stderr,"Bit file created on %s at %s.\n", bh.date, bh.time);
 fprintf(stderr,"Created from file %s for Xilinx part %s.\n", bh.filename, bh.part);
 fprintf(stderr,"Bitstream length is %d bytes.\n", bh.length);
 fprintf(stderr,"\n");

 remaining=bh.length;

 while(remaining)
   {
    readed=fread(buff,1,BSIZE,bitfile);
    fwrite(buff,readed,1,outfile);
    remaining-=readed;
   }

 fclose(bitfile);
 freebh(&bh);
 return 0;
}