ABC: A System for Sequential Synthesis and Verification
 
Loading...
Searching...
No Matches
bacBac.c File Reference
#include "bac.h"
Include dependency graph for bacBac.c:

Go to the source code of this file.

Functions

ABC_NAMESPACE_IMPL_START int BacManReadBacLine (Vec_Str_t *vOut, int *pPos, char *pBuffer, char *pLimit)
 DECLARATIONS ///.
 
int BacManReadBacNameAndNums (char *pBuffer, int *Num1, int *Num2, int *Num3, int *Num4)
 
void Bac_ManReadBacVecStr (Vec_Str_t *vOut, int *pPos, Vec_Str_t *p, int nSize)
 
void Bac_ManReadBacVecInt (Vec_Str_t *vOut, int *pPos, Vec_Int_t *p, int nSize)
 
void Bac_ManReadBacNtk (Vec_Str_t *vOut, int *pPos, Bac_Ntk_t *pNtk)
 
Bac_Man_tBac_ManReadBacInt (Vec_Str_t *vOut)
 
Bac_Man_tBac_ManReadBac (char *pFileName)
 
void Bac_ManWriteBacNtk (Vec_Str_t *vOut, Bac_Ntk_t *pNtk)
 
void Bac_ManWriteBacInt (Vec_Str_t *vOut, Bac_Man_t *p)
 
void Bac_ManWriteBac (char *pFileName, Bac_Man_t *p)
 

Function Documentation

◆ Bac_ManReadBac()

Bac_Man_t * Bac_ManReadBac ( char * pFileName)

Definition at line 181 of file bacBac.c.

182{
183 Bac_Man_t * p;
184 FILE * pFile;
185 Vec_Str_t * vOut;
186 int nFileSize;
187 pFile = fopen( pFileName, "rb" );
188 if ( pFile == NULL )
189 {
190 printf( "Cannot open file \"%s\" for reading.\n", pFileName );
191 return NULL;
192 }
193 // get the file size, in bytes
194 fseek( pFile, 0, SEEK_END );
195 nFileSize = ftell( pFile );
196 rewind( pFile );
197 // load the contents
198 vOut = Vec_StrAlloc( nFileSize );
199 vOut->nSize = vOut->nCap;
200 assert( nFileSize == Vec_StrSize(vOut) );
201 nFileSize = fread( Vec_StrArray(vOut), 1, Vec_StrSize(vOut), pFile );
202 assert( nFileSize == Vec_StrSize(vOut) );
203 fclose( pFile );
204 // read the networks
205 p = Bac_ManReadBacInt( vOut );
206 if ( p != NULL )
207 {
208 ABC_FREE( p->pSpec );
209 p->pSpec = Abc_UtilStrsav( pFileName );
210 }
211 Vec_StrFree( vOut );
212 return p;
213}
#define ABC_FREE(obj)
Definition abc_global.h:267
Bac_Man_t * Bac_ManReadBacInt(Vec_Str_t *vOut)
Definition bacBac.c:142
struct Bac_Man_t_ Bac_Man_t
Definition bac.h:142
struct Vec_Str_t_ Vec_Str_t
Definition bblif.c:46
Cube * p
Definition exorList.c:222
int nCap
Definition bblif.c:49
int nSize
Definition bblif.c:50
#define assert(ex)
Definition util_old.h:213
VOID_HACK rewind()
#define SEEK_END
Definition zconf.h:392
Here is the call graph for this function:

◆ Bac_ManReadBacInt()

Bac_Man_t * Bac_ManReadBacInt ( Vec_Str_t * vOut)

Definition at line 142 of file bacBac.c.

143{
144 Bac_Man_t * p;
145 Bac_Ntk_t * pNtk;
146 char Buffer[1000] = "#";
147 int i, NameId, Pos = 0, nNtks, Num1, Num2, Num3, Num4;
148 while ( Buffer[0] == '#' )
149 if ( !BacManReadBacLine(vOut, &Pos, Buffer, Buffer+1000) )
150 return NULL;
151 if ( !BacManReadBacNameAndNums(Buffer, &nNtks, &Num2, &Num3, &Num4) )
152 return NULL;
153 // start manager
154 assert( nNtks > 0 );
155 p = Bac_ManAlloc( Buffer, nNtks );
156 // start networks
157 Bac_ManForEachNtk( p, pNtk, i )
158 {
159 if ( !BacManReadBacLine(vOut, &Pos, Buffer, Buffer+1000) )
160 {
161 Bac_ManFree( p );
162 return NULL;
163 }
164 if ( !BacManReadBacNameAndNums(Buffer, &Num1, &Num2, &Num3, &Num4) )
165 {
166 Bac_ManFree( p );
167 return NULL;
168 }
169 assert( Num1 >= 0 && Num2 >= 0 && Num3 >= 0 );
170 NameId = Abc_NamStrFindOrAdd( p->pStrs, Buffer, NULL );
171 Bac_NtkAlloc( pNtk, NameId, Num1, Num2, Num3 );
172 Vec_IntFill( &pNtk->vInfo, 3 * Num4, -1 );
173 }
174 // read networks
175 Bac_ManForEachNtk( p, pNtk, i )
176 Bac_ManReadBacNtk( vOut, &Pos, pNtk );
177 assert( Bac_ManNtkNum(p) == nNtks );
178 assert( Pos == Vec_StrSize(vOut) );
179 return p;
180}
int BacManReadBacNameAndNums(char *pBuffer, int *Num1, int *Num2, int *Num3, int *Num4)
Definition bacBac.c:53
void Bac_ManReadBacNtk(Vec_Str_t *vOut, int *pPos, Bac_Ntk_t *pNtk)
Definition bacBac.c:102
ABC_NAMESPACE_IMPL_START int BacManReadBacLine(Vec_Str_t *vOut, int *pPos, char *pBuffer, char *pLimit)
DECLARATIONS ///.
Definition bacBac.c:45
struct Bac_Ntk_t_ Bac_Ntk_t
Definition bac.h:141
#define Bac_ManForEachNtk(p, pNtk, i)
MACRO DEFINITIONS ///.
Definition bac.h:334
ush Pos
Definition deflate.h:88
Vec_Int_t vInfo
Definition bac.h:157
int Abc_NamStrFindOrAdd(Abc_Nam_t *p, char *pStr, int *pfFound)
Definition utilNam.c:453
Here is the call graph for this function:
Here is the caller graph for this function:

◆ Bac_ManReadBacNtk()

void Bac_ManReadBacNtk ( Vec_Str_t * vOut,
int * pPos,
Bac_Ntk_t * pNtk )

Definition at line 102 of file bacBac.c.

103{
104 int i, Type;
105 //char * pName; int iObj, NameId;
106 Bac_ManReadBacVecStr( vOut, pPos, &pNtk->vType, Bac_NtkObjNumAlloc(pNtk) );
107 Bac_ManReadBacVecInt( vOut, pPos, &pNtk->vFanin, 4 * Bac_NtkObjNumAlloc(pNtk) );
108 Bac_ManReadBacVecInt( vOut, pPos, &pNtk->vInfo, 12 * Bac_NtkInfoNumAlloc(pNtk) );
109 Bac_NtkForEachObjType( pNtk, Type, i )
110 {
111 if ( Type == BAC_OBJ_PI )
112 Vec_IntPush( &pNtk->vInputs, i );
113 if ( Type == BAC_OBJ_PO )
114 Vec_IntPush( &pNtk->vOutputs, i );
115 }
116 assert( Bac_NtkPiNum(pNtk) == Bac_NtkPiNumAlloc(pNtk) );
117 assert( Bac_NtkPoNum(pNtk) == Bac_NtkPoNumAlloc(pNtk) );
118 assert( Bac_NtkObjNum(pNtk) == Bac_NtkObjNumAlloc(pNtk) );
119 assert( Bac_NtkInfoNum(pNtk) == Bac_NtkInfoNumAlloc(pNtk) );
120/*
121 // read input/output/box names
122 Bac_NtkForEachPiMain( pNtk, iObj, i )
123 {
124 pName = Vec_StrEntryP( vOut, Pos );
125 NameId = Abc_NamStrFindOrAdd( p->pStrs, pName, NULL );
126 Pos += strlen(pName) + 1;
127 }
128 Bac_NtkForEachPoMain( pNtk, iObj, i )
129 {
130 pName = Vec_StrEntryP( vOut, Pos );
131 NameId = Abc_NamStrFindOrAdd( p->pStrs, pName, NULL );
132 Pos += strlen(pName) + 1;
133 }
134 Bac_NtkForEachBox( pNtk, iObj )
135 {
136 pName = Vec_StrEntryP( vOut, Pos );
137 NameId = Abc_NamStrFindOrAdd( p->pStrs, pName, NULL );
138 Pos += strlen(pName) + 1;
139 }
140*/
141}
void Bac_ManReadBacVecInt(Vec_Str_t *vOut, int *pPos, Vec_Int_t *p, int nSize)
Definition bacBac.c:95
void Bac_ManReadBacVecStr(Vec_Str_t *vOut, int *pPos, Vec_Str_t *p, int nSize)
Definition bacBac.c:88
#define Bac_NtkForEachObjType(p, Type, i)
Definition bac.h:351
@ BAC_OBJ_PO
Definition bac.h:46
@ BAC_OBJ_PI
Definition bac.h:45
Vec_Str_t vType
Definition bac.h:159
Vec_Int_t vFanin
Definition bac.h:160
Vec_Int_t vOutputs
Definition bac.h:156
Vec_Int_t vInputs
Definition bac.h:155
Here is the call graph for this function:
Here is the caller graph for this function:

◆ Bac_ManReadBacVecInt()

void Bac_ManReadBacVecInt ( Vec_Str_t * vOut,
int * pPos,
Vec_Int_t * p,
int nSize )

Definition at line 95 of file bacBac.c.

96{
97 memcpy( Vec_IntArray(p), Vec_StrArray(vOut) + *pPos, (size_t)nSize );
98 *pPos += nSize;
99 p->nSize = nSize / 4;
100 assert( Vec_IntSize(p) == Vec_IntCap(p) );
101}
char * memcpy()
Here is the call graph for this function:
Here is the caller graph for this function:

◆ Bac_ManReadBacVecStr()

void Bac_ManReadBacVecStr ( Vec_Str_t * vOut,
int * pPos,
Vec_Str_t * p,
int nSize )

Definition at line 88 of file bacBac.c.

89{
90 memcpy( Vec_StrArray(p), Vec_StrArray(vOut) + *pPos, (size_t)nSize );
91 *pPos += nSize;
92 p->nSize = nSize;
93 assert( Vec_StrSize(p) == Vec_StrCap(p) );
94}
Here is the call graph for this function:
Here is the caller graph for this function:

◆ Bac_ManWriteBac()

void Bac_ManWriteBac ( char * pFileName,
Bac_Man_t * p )

Definition at line 272 of file bacBac.c.

273{
274 Vec_Str_t * vOut;
275 assert( p->pMioLib == NULL );
276 vOut = Vec_StrAlloc( 10000 );
277 Bac_ManWriteBacInt( vOut, p );
278 if ( Vec_StrSize(vOut) > 0 )
279 {
280 FILE * pFile = fopen( pFileName, "wb" );
281 if ( pFile == NULL )
282 printf( "Cannot open file \"%s\" for writing.\n", pFileName );
283 else
284 {
285 fwrite( Vec_StrArray(vOut), 1, Vec_StrSize(vOut), pFile );
286 fclose( pFile );
287 }
288 }
289 Vec_StrFree( vOut );
290}
void Bac_ManWriteBacInt(Vec_Str_t *vOut, Bac_Man_t *p)
Definition bacBac.c:254
Here is the call graph for this function:

◆ Bac_ManWriteBacInt()

void Bac_ManWriteBacInt ( Vec_Str_t * vOut,
Bac_Man_t * p )

Definition at line 254 of file bacBac.c.

255{
256 char Buffer[1000];
257 Bac_Ntk_t * pNtk; int i;
258 sprintf( Buffer, "# Design \"%s\" written by ABC on %s\n", Bac_ManName(p), Extra_TimeStamp() );
259 Vec_StrPrintStr( vOut, Buffer );
260 // write short info
261 sprintf( Buffer, "%s %d \n", Bac_ManName(p), Bac_ManNtkNum(p) );
262 Vec_StrPrintStr( vOut, Buffer );
263 Bac_ManForEachNtk( p, pNtk, i )
264 {
265 sprintf( Buffer, "%s %d %d %d %d \n", Bac_NtkName(pNtk),
266 Bac_NtkPiNum(pNtk), Bac_NtkPoNum(pNtk), Bac_NtkObjNum(pNtk), Bac_NtkInfoNum(pNtk) );
267 Vec_StrPrintStr( vOut, Buffer );
268 }
269 Bac_ManForEachNtk( p, pNtk, i )
270 Bac_ManWriteBacNtk( vOut, pNtk );
271}
void Bac_ManWriteBacNtk(Vec_Str_t *vOut, Bac_Ntk_t *pNtk)
Definition bacBac.c:226
char * Extra_TimeStamp()
char * sprintf()
Here is the call graph for this function:
Here is the caller graph for this function:

◆ Bac_ManWriteBacNtk()

void Bac_ManWriteBacNtk ( Vec_Str_t * vOut,
Bac_Ntk_t * pNtk )

Function*************************************************************

Synopsis [Write CBA.]

Description []

SideEffects []

SeeAlso []

Definition at line 226 of file bacBac.c.

227{
228 //char * pName; int iObj, NameId;
229 Vec_StrPushBuffer( vOut, (char *)Vec_StrArray(&pNtk->vType), Bac_NtkObjNum(pNtk) );
230 Vec_StrPushBuffer( vOut, (char *)Vec_IntArray(&pNtk->vFanin), 4 * Bac_NtkObjNum(pNtk) );
231 Vec_StrPushBuffer( vOut, (char *)Vec_IntArray(&pNtk->vInfo), 12 * Bac_NtkInfoNum(pNtk) );
232/*
233 // write input/output/box names
234 Bac_NtkForEachPiMain( pNtk, iObj, i )
235 {
236 pName = Bac_ObjNameStr( pNtk, iObj );
237 Vec_StrPrintStr( vOut, pName );
238 Vec_StrPush( vOut, '\0' );
239 }
240 Bac_NtkForEachPoMain( pNtk, iObj, i )
241 {
242 pName = Bac_ObjNameStr( pNtk, iObj );
243 Vec_StrPrintStr( vOut, pName );
244 Vec_StrPush( vOut, '\0' );
245 }
246 Bac_NtkForEachBox( pNtk, iObj )
247 {
248 pName = Bac_ObjNameStr( pNtk, iObj );
249 Vec_StrPrintStr( vOut, pName );
250 Vec_StrPush( vOut, '\0' );
251 }
252*/
253}
Here is the caller graph for this function:

◆ BacManReadBacLine()

ABC_NAMESPACE_IMPL_START int BacManReadBacLine ( Vec_Str_t * vOut,
int * pPos,
char * pBuffer,
char * pLimit )

DECLARATIONS ///.

CFile****************************************************************

FileName [bacBac.c]

SystemName [ABC: Logic synthesis and verification system.]

PackageName [Hierarchical word-level netlist.]

Synopsis [Verilog parser.]

Author [Alan Mishchenko]

Affiliation [UC Berkeley]

Date [Ver. 1.0. Started - November 29, 2014.]

Revision [

Id
bacBac.c,v 1.00 2014/11/29 00:00:00 alanmi Exp

] FUNCTION DEFINITIONS /// Function*************************************************************

Synopsis [Read CBA.]

Description []

SideEffects []

SeeAlso []

Definition at line 45 of file bacBac.c.

46{
47 char c;
48 while ( (c = Vec_StrEntry(vOut, (*pPos)++)) != '\n' && pBuffer < pLimit )
49 *pBuffer++ = c;
50 *pBuffer = 0;
51 return pBuffer < pLimit;
52}
Here is the caller graph for this function:

◆ BacManReadBacNameAndNums()

int BacManReadBacNameAndNums ( char * pBuffer,
int * Num1,
int * Num2,
int * Num3,
int * Num4 )

Definition at line 53 of file bacBac.c.

54{
55 *Num1 = *Num2 = *Num3 = *Num4 = -1;
56 // read name
57 while ( *pBuffer && *pBuffer != ' ' )
58 pBuffer++;
59 if ( !*pBuffer )
60 return 0;
61 assert( *pBuffer == ' ' );
62 *pBuffer = 0;
63 // read Num1
64 *Num1 = atoi(++pBuffer);
65 while ( *pBuffer && *pBuffer != ' ' )
66 pBuffer++;
67 if ( !*pBuffer )
68 return 0;
69 // read Num2
70 assert( *pBuffer == ' ' );
71 *Num2 = atoi(++pBuffer);
72 while ( *pBuffer && *pBuffer != ' ' )
73 pBuffer++;
74 if ( !*pBuffer )
75 return 1;
76 // read Num3
77 assert( *pBuffer == ' ' );
78 *Num3 = atoi(++pBuffer);
79 while ( *pBuffer && *pBuffer != ' ' )
80 pBuffer++;
81 if ( !*pBuffer )
82 return 1;
83 // read Num4
84 assert( *pBuffer == ' ' );
85 *Num4 = atoi(++pBuffer);
86 return 1;
87}
Here is the caller graph for this function: