/**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 $] ***********************************************************************/ #include "bac.h" ABC_NAMESPACE_IMPL_START //////////////////////////////////////////////////////////////////////// /// DECLARATIONS /// //////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////// /// FUNCTION DEFINITIONS /// //////////////////////////////////////////////////////////////////////// /**Function************************************************************* Synopsis [Read CBA.] Description [] SideEffects [] SeeAlso [] ***********************************************************************/ int BacManReadBacLine( Vec_Str_t * vOut, int * pPos, char * pBuffer, char * pLimit ) { char c; while ( (c = Vec_StrEntry(vOut, (*pPos)++)) != '\n' && pBuffer < pLimit ) *pBuffer++ = c; *pBuffer = 0; return pBuffer < pLimit; } int BacManReadBacNameAndNums( char * pBuffer, int * Num1, int * Num2, int * Num3, int * Num4 ) { *Num1 = *Num2 = *Num3 = *Num4 = -1; // read name while ( *pBuffer && *pBuffer != ' ' ) pBuffer++; if ( !*pBuffer ) return 0; assert( *pBuffer == ' ' ); *pBuffer = 0; // read Num1 *Num1 = atoi(++pBuffer); while ( *pBuffer && *pBuffer != ' ' ) pBuffer++; if ( !*pBuffer ) return 0; // read Num2 assert( *pBuffer == ' ' ); *Num2 = atoi(++pBuffer); while ( *pBuffer && *pBuffer != ' ' ) pBuffer++; if ( !*pBuffer ) return 1; // read Num3 assert( *pBuffer == ' ' ); *Num3 = atoi(++pBuffer); while ( *pBuffer && *pBuffer != ' ' ) pBuffer++; if ( !*pBuffer ) return 1; // read Num4 assert( *pBuffer == ' ' ); *Num4 = atoi(++pBuffer); return 1; } void Bac_ManReadBacVecStr( Vec_Str_t * vOut, int * pPos, Vec_Str_t * p, int nSize ) { memcpy( Vec_StrArray(p), Vec_StrArray(vOut) + *pPos, nSize ); *pPos += nSize; p->nSize = nSize; assert( Vec_StrSize(p) == Vec_StrCap(p) ); } void Bac_ManReadBacVecInt( Vec_Str_t * vOut, int * pPos, Vec_Int_t * p, int nSize ) { memcpy( Vec_IntArray(p), Vec_StrArray(vOut) + *pPos, nSize ); *pPos += nSize; p->nSize = nSize / 4; assert( Vec_IntSize(p) == Vec_IntCap(p) ); } void Bac_ManReadBacNtk( Vec_Str_t * vOut, int * pPos, Bac_Ntk_t * pNtk ) { int i, Type; //char * pName; int iObj, NameId; Bac_ManReadBacVecStr( vOut, pPos, &pNtk->vType, Bac_NtkObjNumAlloc(pNtk) ); Bac_ManReadBacVecInt( vOut, pPos, &pNtk->vFanin, 4 * Bac_NtkObjNumAlloc(pNtk) ); Bac_ManReadBacVecInt( vOut, pPos, &pNtk->vInfo, 12 * Bac_NtkInfoNumAlloc(pNtk) ); Bac_NtkForEachObjType( pNtk, Type, i ) { if ( Type == BAC_OBJ_PI ) Vec_IntPush( &pNtk->vInputs, i ); if ( Type == BAC_OBJ_PO ) Vec_IntPush( &pNtk->vOutputs, i ); } assert( Bac_NtkPiNum(pNtk) == Bac_NtkPiNumAlloc(pNtk) ); assert( Bac_NtkPoNum(pNtk) == Bac_NtkPoNumAlloc(pNtk) ); assert( Bac_NtkObjNum(pNtk) == Bac_NtkObjNumAlloc(pNtk) ); assert( Bac_NtkInfoNum(pNtk) == Bac_NtkInfoNumAlloc(pNtk) ); /* // read input/output/box names Bac_NtkForEachPiMain( pNtk, iObj, i ) { pName = Vec_StrEntryP( vOut, Pos ); NameId = Abc_NamStrFindOrAdd( p->pStrs, pName, NULL ); Pos += strlen(pName) + 1; } Bac_NtkForEachPoMain( pNtk, iObj, i ) { pName = Vec_StrEntryP( vOut, Pos ); NameId = Abc_NamStrFindOrAdd( p->pStrs, pName, NULL ); Pos += strlen(pName) + 1; } Bac_NtkForEachBox( pNtk, iObj ) { pName = Vec_StrEntryP( vOut, Pos ); NameId = Abc_NamStrFindOrAdd( p->pStrs, pName, NULL ); Pos += strlen(pName) + 1; } */ } Bac_Man_t * Bac_ManReadBacInt( Vec_Str_t * vOut ) { Bac_Man_t * p; Bac_Ntk_t * pNtk; char Buffer[1000] = "#"; int i, NameId, Pos = 0, nNtks, Num1, Num2, Num3, Num4; while ( Buffer[0] == '#' ) if ( !BacManReadBacLine(vOut, &Pos, Buffer, Buffer+1000) ) return NULL; if ( !BacManReadBacNameAndNums(Buffer, &nNtks, &Num2, &Num3, &Num4) ) return NULL; // start manager assert( nNtks > 0 ); p = Bac_ManAlloc( Buffer, nNtks ); // start networks Bac_ManForEachNtk( p, pNtk, i ) { if ( !BacManReadBacLine(vOut, &Pos, Buffer, Buffer+1000) ) { Bac_ManFree( p ); return NULL; } if ( !BacManReadBacNameAndNums(Buffer, &Num1, &Num2, &Num3, &Num4) ) { Bac_ManFree( p ); return NULL; } assert( Num1 >= 0 && Num2 >= 0 && Num3 >= 0 ); NameId = Abc_NamStrFindOrAdd( p->pStrs, Buffer, NULL ); Bac_NtkAlloc( pNtk, NameId, Num1, Num2, Num3 ); Vec_IntFill( &pNtk->vInfo, 3 * Num4, -1 ); } // read networks Bac_ManForEachNtk( p, pNtk, i ) Bac_ManReadBacNtk( vOut, &Pos, pNtk ); assert( Bac_ManNtkNum(p) == nNtks ); assert( Pos == Vec_StrSize(vOut) ); return p; } Bac_Man_t * Bac_ManReadBac( char * pFileName ) { Bac_Man_t * p; FILE * pFile; Vec_Str_t * vOut; int nFileSize; pFile = fopen( pFileName, "rb" ); if ( pFile == NULL ) { printf( "Cannot open file \"%s\" for reading.\n", pFileName ); return NULL; } // get the file size, in bytes fseek( pFile, 0, SEEK_END ); nFileSize = ftell( pFile ); rewind( pFile ); // load the contents vOut = Vec_StrAlloc( nFileSize ); vOut->nSize = vOut->nCap; assert( nFileSize == Vec_StrSize(vOut) ); nFileSize = fread( Vec_StrArray(vOut), 1, Vec_StrSize(vOut), pFile ); assert( nFileSize == Vec_StrSize(vOut) ); fclose( pFile ); // read the networks p = Bac_ManReadBacInt( vOut ); if ( p != NULL ) { ABC_FREE( p->pSpec ); p->pSpec = Abc_UtilStrsav( pFileName ); } Vec_StrFree( vOut ); return p; } /**Function************************************************************* Synopsis [Write CBA.] Description [] SideEffects [] SeeAlso [] ***********************************************************************/ void Bac_ManWriteBacNtk( Vec_Str_t * vOut, Bac_Ntk_t * pNtk ) { //char * pName; int iObj, NameId; Vec_StrPushBuffer( vOut, (char *)Vec_StrArray(&pNtk->vType), Bac_NtkObjNum(pNtk) ); Vec_StrPushBuffer( vOut, (char *)Vec_IntArray(&pNtk->vFanin), 4 * Bac_NtkObjNum(pNtk) ); Vec_StrPushBuffer( vOut, (char *)Vec_IntArray(&pNtk->vInfo), 12 * Bac_NtkInfoNum(pNtk) ); /* // write input/output/box names Bac_NtkForEachPiMain( pNtk, iObj, i ) { pName = Bac_ObjNameStr( pNtk, iObj ); Vec_StrPrintStr( vOut, pName ); Vec_StrPush( vOut, '\0' ); } Bac_NtkForEachPoMain( pNtk, iObj, i ) { pName = Bac_ObjNameStr( pNtk, iObj ); Vec_StrPrintStr( vOut, pName ); Vec_StrPush( vOut, '\0' ); } Bac_NtkForEachBox( pNtk, iObj ) { pName = Bac_ObjNameStr( pNtk, iObj ); Vec_StrPrintStr( vOut, pName ); Vec_StrPush( vOut, '\0' ); } */ } void Bac_ManWriteBacInt( Vec_Str_t * vOut, Bac_Man_t * p ) { char Buffer[1000]; Bac_Ntk_t * pNtk; int i; sprintf( Buffer, "# Design \"%s\" written by ABC on %s\n", Bac_ManName(p), Extra_TimeStamp() ); Vec_StrPrintStr( vOut, Buffer ); // write short info sprintf( Buffer, "%s %d \n", Bac_ManName(p), Bac_ManNtkNum(p) ); Vec_StrPrintStr( vOut, Buffer ); Bac_ManForEachNtk( p, pNtk, i ) { sprintf( Buffer, "%s %d %d %d %d \n", Bac_NtkName(pNtk), Bac_NtkPiNum(pNtk), Bac_NtkPoNum(pNtk), Bac_NtkObjNum(pNtk), Bac_NtkInfoNum(pNtk) ); Vec_StrPrintStr( vOut, Buffer ); } Bac_ManForEachNtk( p, pNtk, i ) Bac_ManWriteBacNtk( vOut, pNtk ); } void Bac_ManWriteBac( char * pFileName, Bac_Man_t * p ) { Vec_Str_t * vOut; assert( p->pMioLib == NULL ); vOut = Vec_StrAlloc( 10000 ); Bac_ManWriteBacInt( vOut, p ); if ( Vec_StrSize(vOut) > 0 ) { FILE * pFile = fopen( pFileName, "wb" ); if ( pFile == NULL ) printf( "Cannot open file \"%s\" for writing.\n", pFileName ); else { fwrite( Vec_StrArray(vOut), 1, Vec_StrSize(vOut), pFile ); fclose( pFile ); } } Vec_StrFree( vOut ); } //////////////////////////////////////////////////////////////////////// /// END OF FILE /// //////////////////////////////////////////////////////////////////////// ABC_NAMESPACE_IMPL_END