summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2012-09-19 11:53:40 -0700
committerAlan Mishchenko <alanmi@berkeley.edu>2012-09-19 11:53:40 -0700
commit60c661488507d3ff5866e795979bdef64b10f58f (patch)
treec92a3c908d9dc45314dc42904a272a94de51c1b4
parent48996f7a3698a3f3f8d3d03ffba5c51e9065649d (diff)
downloadabc-60c661488507d3ff5866e795979bdef64b10f58f.tar.gz
abc-60c661488507d3ff5866e795979bdef64b10f58f.tar.bz2
abc-60c661488507d3ff5866e795979bdef64b10f58f.zip
Extending Genlib to hangle multi-output cells.
-rw-r--r--src/map/mio/mioInt.h1
-rw-r--r--src/map/mio/mioRead.c7
-rw-r--r--src/map/mio/mioUtils.c154
3 files changed, 105 insertions, 57 deletions
diff --git a/src/map/mio/mioInt.h b/src/map/mio/mioInt.h
index 3e843366..6f82309e 100644
--- a/src/map/mio/mioInt.h
+++ b/src/map/mio/mioInt.h
@@ -88,6 +88,7 @@ struct Mio_GateStruct_t_
Mio_Library_t * pLib;
// the next gate in the list
Mio_Gate_t * pNext;
+ Mio_Gate_t * pTwin;
// the derived information
int nInputs; // the number of inputs
diff --git a/src/map/mio/mioRead.c b/src/map/mio/mioRead.c
index 3632e3a7..87fb68e2 100644
--- a/src/map/mio/mioRead.c
+++ b/src/map/mio/mioRead.c
@@ -232,7 +232,12 @@ int Mio_LibraryReadInternal( Mio_Library_t * pLib, char * pBuffer, int fExtended
if ( !st_is_member( pLib->tName2Gate, pGate->pName ) )
st_insert( pLib->tName2Gate, pGate->pName, (char *)pGate );
else
- printf( "The gate with name \"%s\" appears more than once.\n", pGate->pName );
+ {
+ Mio_Gate_t * pBase = Mio_LibraryReadGateByName( pLib, pGate->pName );
+ pBase->pTwin = pGate;
+ pGate->pTwin = pBase;
+ printf( "Gate \"%s\" appears more than once. Creating multi-output gate.\n", pGate->pName );
+ }
}
}
if ( fVerbose )
diff --git a/src/map/mio/mioUtils.c b/src/map/mio/mioUtils.c
index 0583276a..fcc59dcc 100644
--- a/src/map/mio/mioUtils.c
+++ b/src/map/mio/mioUtils.c
@@ -28,10 +28,6 @@ ABC_NAMESPACE_IMPL_START
/// DECLARATIONS ///
////////////////////////////////////////////////////////////////////////
-static void Mio_WriteGate( FILE * pFile, Mio_Gate_t * pGate, int fPrintSops );
-static void Mio_WritePin( FILE * pFile, Mio_Pin_t * pPin );
-static int Mio_DelayCompare( Mio_Gate_t ** ppG1, Mio_Gate_t ** ppG2 );
-
////////////////////////////////////////////////////////////////////////
/// FUNCTION DEFINITIONS ///
////////////////////////////////////////////////////////////////////////
@@ -141,7 +137,7 @@ Mio_Pin_t * Mio_PinDup( Mio_Pin_t * pPin )
/**Function*************************************************************
- Synopsis []
+ Synopsis [Check if pin characteristics are the same.]
Description []
@@ -150,16 +146,23 @@ Mio_Pin_t * Mio_PinDup( Mio_Pin_t * pPin )
SeeAlso []
***********************************************************************/
-void Mio_WriteLibrary( FILE * pFile, Mio_Library_t * pLib, int fPrintSops )
+int Mio_CheckPins( Mio_Pin_t * pPin1, Mio_Pin_t * pPin2 )
{
-// Mio_Gate_t * pGate;
- int i;
-
- fprintf( pFile, "# The genlib library \"%s\".\n", pLib->pName );
-// Mio_LibraryForEachGate( pLib, pGate )
-// Mio_WriteGate( pFile, pGate, fPrintSops );
- for ( i = 0; i < pLib->nGates; i++ )
- Mio_WriteGate( pFile, pLib->ppGates0[i], fPrintSops );
+ if ( pPin1 == NULL || pPin2 == NULL )
+ return 1;
+ if ( pPin1->dLoadInput != pPin2->dLoadInput )
+ return 0;
+ if ( pPin1->dLoadMax != pPin2->dLoadMax )
+ return 0;
+ if ( pPin1->dDelayBlockRise != pPin2->dDelayBlockRise )
+ return 0;
+ if ( pPin1->dDelayFanoutRise != pPin2->dDelayFanoutRise )
+ return 0;
+ if ( pPin1->dDelayBlockFall != pPin2->dDelayBlockFall )
+ return 0;
+ if ( pPin1->dDelayFanoutFall != pPin2->dDelayFanoutFall )
+ return 0;
+ return 1;
}
/**Function*************************************************************
@@ -173,21 +176,57 @@ void Mio_WriteLibrary( FILE * pFile, Mio_Library_t * pLib, int fPrintSops )
SeeAlso []
***********************************************************************/
-void Mio_WriteGate( FILE * pFile, Mio_Gate_t * pGate, int fPrintSops )
+void Mio_WritePin( FILE * pFile, Mio_Pin_t * pPin, int NameLen, int fAllPins )
{
- Mio_Pin_t * pPin;
+ char * pPhaseNames[10] = { "UNKNOWN", "INV", "NONINV" };
+ if ( fAllPins )
+ fprintf( pFile, "PIN * " );
+ else
+ fprintf( pFile, "\n PIN %*s ", NameLen, pPin->pName );
+ fprintf( pFile, "%7s ", pPhaseNames[pPin->Phase] );
+ fprintf( pFile, "%3d ", (int)pPin->dLoadInput );
+ fprintf( pFile, "%3d ", (int)pPin->dLoadMax );
+ fprintf( pFile, "%6.2f ", pPin->dDelayBlockRise );
+ fprintf( pFile, "%6.2f ", pPin->dDelayFanoutRise );
+ fprintf( pFile, "%6.2f ", pPin->dDelayBlockFall );
+ fprintf( pFile, "%6.2f", pPin->dDelayFanoutFall );
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
- fprintf( pFile, "GATE " );
- fprintf( pFile, "%12s ", pGate->pName );
- fprintf( pFile, "%10.2f ", pGate->dArea );
- fprintf( pFile, "%s=%s;\n", pGate->pOutName, pGate->pForm );
+ SeeAlso []
+
+***********************************************************************/
+void Mio_WriteGate( FILE * pFile, Mio_Gate_t * pGate, int GateLen, int NameLen, int FormLen, int fPrintSops )
+{
+ char Buffer[5000];
+ Mio_Pin_t * pPin = NULL, * pPin0 = NULL;
+ assert( NameLen+FormLen+2 < 5000 );
+ sprintf( Buffer, "%s=%s;", pGate->pOutName, pGate->pForm );
+ fprintf( pFile, "GATE %-*s ", GateLen, pGate->pName );
+ fprintf( pFile, "%8.2f ", pGate->dArea );
+ fprintf( pFile, "%-*s ", NameLen+FormLen+2, Buffer );
+ // compare pins and decide if their properties are the same
+ Mio_GateForEachPin( pGate, pPin )
+ if ( Mio_CheckPins( pPin0, pPin ) )
+ pPin0 = pPin;
+ else
+ break;
// print the pins
if ( fPrintSops )
fprintf( pFile, "%s", pGate->pSop? pGate->pSop : "unspecified\n" );
-// Extra_bddPrint( pGate->pLib->dd, pGate->bFunc );
-// fprintf( pFile, "\n" );
- Mio_GateForEachPin( pGate, pPin )
- Mio_WritePin( pFile, pPin );
+ if ( pPin != NULL ) // different pins
+ Mio_GateForEachPin( pGate, pPin )
+ Mio_WritePin( pFile, pPin, NameLen, 0 );
+ else if ( pPin0 != NULL ) // equal pins
+ Mio_WritePin( pFile, pPin0, NameLen, 1 );
+ fprintf( pFile, "\n" );
}
/**Function*************************************************************
@@ -201,19 +240,42 @@ void Mio_WriteGate( FILE * pFile, Mio_Gate_t * pGate, int fPrintSops )
SeeAlso []
***********************************************************************/
-void Mio_WritePin( FILE * pFile, Mio_Pin_t * pPin )
+void Mio_WriteLibrary( FILE * pFile, Mio_Library_t * pLib, int fPrintSops )
{
- char * pPhaseNames[10] = { "UNKNOWN", "INV", "NONINV" };
- fprintf( pFile, " PIN " );
- fprintf( pFile, "%9s ", pPin->pName );
- fprintf( pFile, "%10s ", pPhaseNames[pPin->Phase] );
- fprintf( pFile, "%6d ", (int)pPin->dLoadInput );
- fprintf( pFile, "%6d ", (int)pPin->dLoadMax );
- fprintf( pFile, "%6.2f ", pPin->dDelayBlockRise );
- fprintf( pFile, "%6.2f ", pPin->dDelayFanoutRise );
- fprintf( pFile, "%6.2f ", pPin->dDelayBlockFall );
- fprintf( pFile, "%6.2f", pPin->dDelayFanoutFall );
- fprintf( pFile, "\n" );
+ Mio_Gate_t * pGate;
+ Mio_Pin_t * pPin;
+ int i, GateLen = 0, NameLen = 0, FormLen = 0;
+ Mio_LibraryForEachGate( pLib, pGate )
+ {
+ GateLen = Abc_MaxInt( GateLen, strlen(pGate->pName) );
+ NameLen = Abc_MaxInt( NameLen, strlen(pGate->pOutName) );
+ FormLen = Abc_MaxInt( FormLen, strlen(pGate->pForm) );
+ Mio_GateForEachPin( pGate, pPin )
+ NameLen = Abc_MaxInt( NameLen, strlen(pPin->pName) );
+ }
+ fprintf( pFile, "# The genlib library \"%s\".\n", pLib->pName );
+ for ( i = 0; i < pLib->nGates; i++ )
+ Mio_WriteGate( pFile, pLib->ppGates0[i], GateLen, NameLen, FormLen, fPrintSops );
+}
+
+/**Function*************************************************************
+
+ Synopsis [Compares the max delay of two gates.]
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+int Mio_DelayCompare( Mio_Gate_t ** ppG1, Mio_Gate_t ** ppG2 )
+{
+ if ( (*ppG1)->dDelayMax < (*ppG2)->dDelayMax )
+ return -1;
+ if ( (*ppG1)->dDelayMax > (*ppG2)->dDelayMax )
+ return 1;
+ return 0;
}
/**Function*************************************************************
@@ -278,26 +340,6 @@ Mio_Gate_t ** Mio_CollectRoots( Mio_Library_t * pLib, int nInputs, float tDelay,
/**Function*************************************************************
- Synopsis [Compares the max delay of two gates.]
-
- Description []
-
- SideEffects []
-
- SeeAlso []
-
-***********************************************************************/
-int Mio_DelayCompare( Mio_Gate_t ** ppG1, Mio_Gate_t ** ppG2 )
-{
- if ( (*ppG1)->dDelayMax < (*ppG2)->dDelayMax )
- return -1;
- if ( (*ppG1)->dDelayMax > (*ppG2)->dDelayMax )
- return 1;
- return 0;
-}
-
-/**Function*************************************************************
-
Synopsis [Derives the truth table of the gate.]
Description []