diff options
Diffstat (limited to 'fpga/xilinx/programmer/bit2svf/bitshandle.c')
| -rw-r--r-- | fpga/xilinx/programmer/bit2svf/bitshandle.c | 144 | 
1 files changed, 144 insertions, 0 deletions
| diff --git a/fpga/xilinx/programmer/bit2svf/bitshandle.c b/fpga/xilinx/programmer/bit2svf/bitshandle.c new file mode 100644 index 0000000..7fb2f40 --- /dev/null +++ b/fpga/xilinx/programmer/bit2svf/bitshandle.c @@ -0,0 +1,144 @@ + /**[txh]******************************************************************** +                                                                                 +  Copyright (c) 2005 Juan Pablo D. Borgna <jpborgna en inti gov ar> +  Copyright (c) 2006-2007 Salvador E. Tropea <salvador en inti gov ar> +  Copyright (c) 2005-2007 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: Low level functions to output hexadecimal bitstreams. +                                                                                 +***************************************************************************/     +/*****************************************************************************   +                                                                                 + 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 <string.h> +#include "global.h" +#include "bitshandle.h" + +/* This function returns the inverted bits of its argument */ +unsigned char +inv_byte(unsigned char b) +{ + int i; + unsigned char t=0; + + for (i=0;i<7;i++) +    { +     t|= (b & 0x01); +     t = t << 1; +     b = b >> 1; +    } + t|=b & 0x01; + return t; +} + +/* This function is used to generate a string with the hex value of the +   inverted bits of from */ +void +pbi(char *to, char *from,long nbytes) +{ + int i; + int j; + char t[]="ZZ"; +  + if (to==NULL) return; + + j=nbytes*2; +  + for (i=0;i<nbytes;i++) +    { +     sprintf(t,"%02x",inv_byte(from[i])); +     j-=2; +     to[j]=t[0]; +     to[j+1]=t[1]; +    } +} + +/* This function is used to generate a string with the hex value of the +   bits of from */ +void +pb(char *to, char *from,long nbytes) +{ + int i; + int j; + char t[]="ZZ"; +  + if (to==NULL) return; + + j=0; +  + for (i=0;i<nbytes;i++) +    { +     sprintf(t,"%02x",from[i]); +     j+=2; +     to[j]=t[0]; +     to[j+1]=t[1]; +    } +} + +/*this function writes bytes to a file with a max nuber of +  chars per line */ /* it should not be here */ +int +cutputs(char *string, FILE *fp, long block, int *col) +{ + long remaining; + long wrote=0l; + int c=*col; + + remaining=strlen(string); + if (!cutlines) +   { +    fwrite(string,1,remaining,fp); +    col+=remaining; +    return 0; +   } + if (remaining<block) +    block=remaining; + + while (remaining) +      { +       long to_write=block-c; +       if (to_write<0) to_write=0; +       if (to_write & 1) to_write++; +       wrote=fwrite(string,1,to_write,fp); +       if (wrote!=to_write) +         { +          perror("CUTPUTS"); +          return 1; +         } +       c+=wrote; +       string+=wrote; +       remaining-=wrote; +       if (remaining) +         { +          fputs("\n",fp); +          c=0; +          if (remaining<block) +             block=remaining; +         } +      } + *col=c; + return 0; +} + | 
