diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2015-04-04 16:15:07 +0700 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2015-04-04 16:15:07 +0700 |
commit | 3a15f343070e617edb97ebe197f292ff3a4e50f1 (patch) | |
tree | 1b66fb7e535c2ce75ddcbb255548fc755742688d /src/base/io | |
parent | 7c3eab6eb469d4c4324fa900e0249d7ab6f0f35e (diff) | |
download | abc-3a15f343070e617edb97ebe197f292ff3a4e50f1.tar.gz abc-3a15f343070e617edb97ebe197f292ff3a4e50f1.tar.bz2 abc-3a15f343070e617edb97ebe197f292ff3a4e50f1.zip |
Properly copying and saving the timing info in &get and &put.
Diffstat (limited to 'src/base/io')
-rw-r--r-- | src/base/io/ioWriteBlif.c | 37 |
1 files changed, 17 insertions, 20 deletions
diff --git a/src/base/io/ioWriteBlif.c b/src/base/io/ioWriteBlif.c index 66664ddc..57624b75 100644 --- a/src/base/io/ioWriteBlif.c +++ b/src/base/io/ioWriteBlif.c @@ -674,62 +674,59 @@ int Io_NtkWriteNodeSubckt( FILE * pFile, Abc_Obj_t * pNode, int Length ) void Io_WriteTimingInfo( FILE * pFile, Abc_Ntk_t * pNtk ) { Abc_Obj_t * pNode; - Abc_Time_t * pTime, * pTimeDef; + Abc_Time_t * pTime, * pTimeDefIn, * pTimeDefOut; int i; if ( pNtk->pManTime == NULL ) return; fprintf( pFile, "\n" ); - if ( pNtk->AndGateDelay != 0.0 ) fprintf( pFile, ".and_gate_delay %g\n", pNtk->AndGateDelay ); - - pTimeDef = Abc_NtkReadDefaultArrival( pNtk ); - if ( pTimeDef->Rise != 0.0 || pTimeDef->Fall != 0.0 ) - fprintf( pFile, ".default_input_arrival %g %g\n", pTimeDef->Rise, pTimeDef->Fall ); - pTimeDef = Abc_NtkReadDefaultRequired( pNtk ); - if ( pTimeDef->Rise != ABC_INFINITY || pTimeDef->Fall != ABC_INFINITY ) - fprintf( pFile, ".default_output_required %g %g\n", pTimeDef->Rise, pTimeDef->Fall ); + pTimeDefIn = Abc_NtkReadDefaultArrival( pNtk ); + if ( pTimeDefIn->Rise != 0.0 || pTimeDefIn->Fall != 0.0 ) + fprintf( pFile, ".default_input_arrival %g %g\n", pTimeDefIn->Rise, pTimeDefIn->Fall ); + pTimeDefOut = Abc_NtkReadDefaultRequired( pNtk ); + if ( pTimeDefOut->Rise != ABC_INFINITY || pTimeDefOut->Fall != ABC_INFINITY ) + fprintf( pFile, ".default_output_required %g %g\n", pTimeDefOut->Rise, pTimeDefOut->Fall ); fprintf( pFile, "\n" ); Abc_NtkForEachPi( pNtk, pNode, i ) { pTime = Abc_NodeReadArrival(pNode); - if ( pTime->Rise == pTimeDef->Rise && pTime->Fall == pTimeDef->Fall ) + if ( pTime->Rise == pTimeDefIn->Rise && pTime->Fall == pTimeDefIn->Fall ) continue; fprintf( pFile, ".input_arrival %s %g %g\n", Abc_ObjName(Abc_ObjFanout0(pNode)), pTime->Rise, pTime->Fall ); } Abc_NtkForEachPo( pNtk, pNode, i ) { pTime = Abc_NodeReadRequired(pNode); - if ( pTime->Rise == pTimeDef->Rise && pTime->Fall == pTimeDef->Fall ) + if ( pTime->Rise == pTimeDefOut->Rise && pTime->Fall == pTimeDefOut->Fall ) continue; fprintf( pFile, ".output_required %s %g %g\n", Abc_ObjName(Abc_ObjFanin0(pNode)), pTime->Rise, pTime->Fall ); } fprintf( pFile, "\n" ); - - pTimeDef = Abc_NtkReadDefaultInputDrive( pNtk ); - if ( pTimeDef->Rise != 0.0 || pTimeDef->Fall != 0.0 ) - fprintf( pFile, ".default_input_drive %g %g\n", pTimeDef->Rise, pTimeDef->Fall ); + pTimeDefIn = Abc_NtkReadDefaultInputDrive( pNtk ); + if ( pTimeDefIn->Rise != 0.0 || pTimeDefIn->Fall != 0.0 ) + fprintf( pFile, ".default_input_drive %g %g\n", pTimeDefIn->Rise, pTimeDefIn->Fall ); if ( Abc_NodeReadInputDrive( pNtk, 0 ) ) Abc_NtkForEachPi( pNtk, pNode, i ) { pTime = Abc_NodeReadInputDrive( pNtk, i ); - if ( pTime->Rise == pTimeDef->Rise && pTime->Fall == pTimeDef->Fall ) + if ( pTime->Rise == pTimeDefIn->Rise && pTime->Fall == pTimeDefIn->Fall ) continue; fprintf( pFile, ".input_drive %s %g %g\n", Abc_ObjName(Abc_ObjFanout0(pNode)), pTime->Rise, pTime->Fall ); } - pTimeDef = Abc_NtkReadDefaultOutputLoad( pNtk ); - if ( pTimeDef->Rise != 0.0 || pTimeDef->Fall != 0.0 ) - fprintf( pFile, ".default_output_load %g %g\n", pTimeDef->Rise, pTimeDef->Fall ); + pTimeDefOut = Abc_NtkReadDefaultOutputLoad( pNtk ); + if ( pTimeDefOut->Rise != 0.0 || pTimeDefOut->Fall != 0.0 ) + fprintf( pFile, ".default_output_load %g %g\n", pTimeDefOut->Rise, pTimeDefOut->Fall ); if ( Abc_NodeReadOutputLoad( pNtk, 0 ) ) Abc_NtkForEachPo( pNtk, pNode, i ) { pTime = Abc_NodeReadOutputLoad( pNtk, i ); - if ( pTime->Rise == pTimeDef->Rise && pTime->Fall == pTimeDef->Fall ) + if ( pTime->Rise == pTimeDefOut->Rise && pTime->Fall == pTimeDefOut->Fall ) continue; fprintf( pFile, ".output_load %s %g %g\n", Abc_ObjName(Abc_ObjFanin0(pNode)), pTime->Rise, pTime->Fall ); } |