summaryrefslogtreecommitdiffstats
path: root/src/base/wlc/wlcBlast.c
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2014-09-17 15:14:17 -0700
committerAlan Mishchenko <alanmi@berkeley.edu>2014-09-17 15:14:17 -0700
commitffd77ffedda47d5ec5541c6a51bb9e80540fd3f7 (patch)
treeb65032a13ad3ba7f1ad2f7ec2861123b2aa7c17b /src/base/wlc/wlcBlast.c
parent43ee0cff254c13f98017387261f7bac4a43c4a3d (diff)
downloadabc-ffd77ffedda47d5ec5541c6a51bb9e80540fd3f7.tar.gz
abc-ffd77ffedda47d5ec5541c6a51bb9e80540fd3f7.tar.bz2
abc-ffd77ffedda47d5ec5541c6a51bb9e80540fd3f7.zip
Improvements to word-level Verilog parser.
Diffstat (limited to 'src/base/wlc/wlcBlast.c')
-rw-r--r--src/base/wlc/wlcBlast.c401
1 files changed, 282 insertions, 119 deletions
diff --git a/src/base/wlc/wlcBlast.c b/src/base/wlc/wlcBlast.c
index eb45773d..46947c55 100644
--- a/src/base/wlc/wlcBlast.c
+++ b/src/base/wlc/wlcBlast.c
@@ -33,7 +33,7 @@ ABC_NAMESPACE_IMPL_START
/**Function*************************************************************
- Synopsis []
+ Synopsis [Helper functions.]
Description []
@@ -54,7 +54,87 @@ int Wlc_NtkPrepareBits( Wlc_Ntk_t * p )
}
return nBits;
}
-int Wlc_NtkComputeReduction( Gia_Man_t * pNew, int * pFans, int nFans, int Type )
+int * Wlc_VecCopy( Vec_Int_t * vOut, int * pArray, int nSize )
+{
+ int i; Vec_IntClear( vOut );
+ for( i = 0; i < nSize; i++)
+ Vec_IntPush( vOut, pArray[i] );
+ return Vec_IntArray( vOut );
+}
+int * Wlc_VecLoadFanins( Vec_Int_t * vOut, int * pFanins, int nFanins, int nTotal, int fSigned )
+{
+ int Fill = fSigned ? pFanins[nFanins-1] : 0;
+ int i; Vec_IntClear( vOut );
+ assert( nFanins <= nTotal );
+ for( i = 0; i < nTotal; i++)
+ Vec_IntPush( vOut, i < nFanins ? pFanins[i] : Fill );
+ return Vec_IntArray( vOut );
+}
+
+/**Function*************************************************************
+
+ Synopsis [Bit blasting for specific operations.]
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+void Wlc_BlastShiftRight( Gia_Man_t * pNew, int * pNum, int nNum, int * pShift, int nShift, int fSticky, Vec_Int_t * vRes )
+{
+ int * pRes = Wlc_VecCopy( vRes, pNum, nNum );
+ int Fill = fSticky ? pNum[nNum-1] : 0;
+ int i, j, fShort = 0;
+ for( i = 0; i < nShift; i++ )
+ for( j = 0; j < nNum - fSticky; j++ )
+ {
+ if( fShort || j + (1<<i) >= nNum )
+ {
+ pRes[j] = Gia_ManHashMux( pNew, pShift[i], Fill, pRes[j] );
+ if ( (1<<i) > nNum )
+ fShort = 1;
+ }
+ else
+ pRes[j] = Gia_ManHashMux( pNew, pShift[i], pRes[j+(1<<i)], pRes[j] );
+ }
+}
+void Wlc_BlastShiftLeft( Gia_Man_t * pNew, int * pNum, int nNum, int * pShift, int nShift, int fSticky, Vec_Int_t * vRes )
+{
+ int * pRes = Wlc_VecCopy( vRes, pNum, nNum );
+ int Fill = fSticky ? pNum[0] : 0;
+ int i, j, fShort = 0;
+ for( i = 0; i < nShift; i++ )
+ for( j = nNum-1; j >= fSticky; j-- )
+ {
+ if( fShort || (1<<i) > j )
+ {
+ pRes[j] = Gia_ManHashMux( pNew, pShift[i], Fill, pRes[j] );
+ if ( (1<<i) > nNum )
+ fShort = 1;
+ }
+ else
+ pRes[j] = Gia_ManHashMux( pNew, pShift[i], pRes[j-(1<<i)], pRes[j] );
+ }
+}
+void Wlc_BlastRotateRight( Gia_Man_t * pNew, int * pNum, int nNum, int * pShift, int nShift, Vec_Int_t * vRes )
+{
+ int i, j, * pTemp = ABC_ALLOC( int, nNum );
+ for( i = 0; i < nShift; i++, Wlc_VecCopy(vRes, pTemp, nNum) )
+ for( j = 0; j < nNum; j++ )
+ pTemp[j] = Gia_ManHashMux( pNew, pShift[i], pNum[(j+(1<<i))%nNum], pNum[j] );
+ ABC_FREE( pTemp );
+}
+void Wlc_BlastRotateLeft( Gia_Man_t * pNew, int * pNum, int nNum, int * pShift, int nShift, Vec_Int_t * vRes )
+{
+ int i, j, * pTemp = ABC_ALLOC( int, nNum );
+ for( i = 0; i < nShift; i++, Wlc_VecCopy(vRes, pTemp, nNum) )
+ for( j = 0; j < nNum; j++ )
+ pTemp[j] = Gia_ManHashMux( pNew, pShift[i], pNum[(nNum-(1<<i)+j)%nNum], pNum[j] );
+ ABC_FREE( pTemp );
+}
+int Wlc_BlastReduction( Gia_Man_t * pNew, int * pFans, int nFans, int Type )
{
if ( Type == WLC_OBJ_REDUCT_AND )
{
@@ -80,16 +160,21 @@ int Wlc_NtkComputeReduction( Gia_Man_t * pNew, int * pFans, int nFans, int Type
assert( 0 );
return -1;
}
-int Wlc_NtkMuxTree_rec( Gia_Man_t * pNew, int * pCtrl, int nCtrl, Vec_Int_t * vData, int Shift )
+int Wlc_BlastLess( Gia_Man_t * pNew, int * pArg0, int * pArg1, int nBits )
{
- int iLit0, iLit1;
- if ( nCtrl == 0 )
- return Vec_IntEntry( vData, Shift );
- iLit0 = Wlc_NtkMuxTree_rec( pNew, pCtrl, nCtrl-1, vData, Shift );
- iLit1 = Wlc_NtkMuxTree_rec( pNew, pCtrl, nCtrl-1, vData, Shift + (1<<(nCtrl-1)) );
- return Gia_ManHashMux( pNew, pCtrl[nCtrl-1], iLit1, iLit0 );
+ int k, iTerm, iEqu = 1, iLit = 0;
+ for ( k = nBits - 1; k >= 0; k-- )
+ {
+ iTerm = Gia_ManHashAnd( pNew, Abc_LitNot(pArg0[k]), pArg1[k] );
+ iTerm = Gia_ManHashAnd( pNew, iTerm, iEqu );
+ if ( iTerm == 1 )
+ return 1;
+ iLit = Gia_ManHashOr( pNew, iLit, iTerm );
+ iEqu = Abc_LitNot( Gia_ManHashXor( pNew, pArg0[k], pArg1[k] ) );
+ }
+ return iLit;
}
-void Wlc_NtkAdderChain( Gia_Man_t * pNew, int * pAdd0, int * pAdd1, int nBits )
+void Wlc_BlastAdder( Gia_Man_t * pNew, int * pAdd0, int * pAdd1, int nBits ) // result is in pAdd0
{
int iCarry = 0, iTerm1, iTerm2, iTerm3, iSum, b;
for ( b = 0; b < nBits; b++ )
@@ -102,11 +187,119 @@ void Wlc_NtkAdderChain( Gia_Man_t * pNew, int * pAdd0, int * pAdd1, int nBits )
pAdd0[b] = iSum;
}
}
+void Wlc_BlastMultiplier( Gia_Man_t * pNew, int * pArg0, int * pArg1, int nBits, Vec_Int_t * vTemp, Vec_Int_t * vRes )
+{
+ int i, j;
+ Vec_IntFill( vRes, nBits, 0 );
+ for ( i = 0; i < nBits; i++ )
+ {
+ Vec_IntFill( vTemp, i, 0 );
+ for ( j = 0; Vec_IntSize(vTemp) < nBits; j++ )
+ Vec_IntPush( vTemp, Gia_ManHashAnd(pNew, pArg0[j], pArg1[i]) );
+ assert( Vec_IntSize(vTemp) == nBits );
+ Wlc_BlastAdder( pNew, Vec_IntArray(vRes), Vec_IntArray(vTemp), nBits );
+ }
+}
+void Wlc_BlastDivider( Gia_Man_t * pNew, int * pNum, int nNum, int * pDiv, int nDiv, int fQuo, Vec_Int_t * vRes )
+{
+ int * pRes = Wlc_VecCopy( vRes, pNum, nNum );
+ int * pQuo = ABC_ALLOC( int, nNum );
+ int * pTemp = ABC_ALLOC( int, nNum );
+ int i, j, known, borrow, y_bit, top_bit;
+ assert( nNum == nDiv );
+ for ( j = nNum - 1; j >= 0; j-- )
+ {
+ known = 0;
+ for ( i = nNum - 1; i > nNum - 1 - j; i-- )
+ {
+ known = Gia_ManHashOr( pNew, known, pDiv[i] );
+ if( known == 1 )
+ break;
+ }
+ pQuo[j] = known;
+ for ( i = nNum - 1; i >= 0; i-- )
+ {
+ if ( known == 1 )
+ break;
+ y_bit = (i >= j) ? pDiv[i-j] : 0;
+ pQuo[j] = Gia_ManHashMux( pNew, known, pQuo[j], Gia_ManHashAnd( pNew, y_bit, Abc_LitNot(pRes[i]) ) );
+ known = Gia_ManHashOr( pNew, known, Gia_ManHashXor(pNew, y_bit, pRes[i]));
+ }
+ pQuo[j] = Abc_LitNot(pQuo[j]);
+ if ( pQuo[j] == 0 )
+ continue;
+ borrow = 0;
+ for ( i = 0; i < nNum; i++ )
+ {
+ top_bit = Gia_ManHashMux( pNew, borrow, Abc_LitNot(pRes[i]), pRes[i] );
+ y_bit = (i >= j) ? pDiv[i-j] : 0;
+ borrow = Gia_ManHashMux( pNew, pRes[i], Gia_ManHashAnd(pNew, borrow, y_bit), Gia_ManHashOr(pNew, borrow, y_bit) );
+ pTemp[i] = Gia_ManHashXor( pNew, top_bit, y_bit );
+ }
+ if ( pQuo[j] == 1 )
+ Wlc_VecCopy( vRes, pTemp, nNum );
+ else
+ for( i = 0; i < nNum; i++ )
+ pRes[i] = Gia_ManHashMux( pNew, pQuo[j], pTemp[i], pRes[i] );
+ }
+ ABC_FREE( pTemp );
+ if ( fQuo )
+ Wlc_VecCopy( vRes, pQuo, nNum );
+ ABC_FREE( pQuo );
+}
+void Wlc_BlastMinus( Gia_Man_t * pNew, int * pNum, int nNum, Vec_Int_t * vRes )
+{
+ int i, * pRes, invert = 0;
+ Vec_IntFill( vRes, nNum, 0 );
+ pRes = Vec_IntArray( vRes );
+ for ( i = 0; i < nNum; i++ )
+ {
+ pRes[i] = Gia_ManHashMux( pNew, invert, Abc_LitNot(pRes[i]), pRes[i] );
+ invert = Gia_ManHashOr( pNew, invert, pNum[i] );
+ }
+}
+void Wlc_BlastTable( Gia_Man_t * pNew, word * pTable, int * pFans, int nFans, int nOuts, Vec_Int_t * vRes )
+{
+ extern int Kit_TruthToGia( Gia_Man_t * pMan, unsigned * pTruth, int nVars, Vec_Int_t * vMemory, Vec_Int_t * vLeaves, int fHash );
+ Vec_Int_t * vMemory = Vec_IntAlloc( 0 );
+ Vec_Int_t vLeaves = { nFans, nFans, pFans };
+ word * pTruth = ABC_ALLOC( word, Abc_TtWordNum(nFans) );
+ int o, i, m, iLit, nMints = (1 << nFans);
+ Vec_IntClear( vRes );
+ for ( o = 0; o < nOuts; o++ )
+ {
+ // derive truth table
+ memset( pTruth, 0, sizeof(word) * Abc_TtWordNum(nFans) );
+ for ( m = 0; m < nMints; m++ )
+ for ( i = 0; i < nFans; i++ )
+ if ( Abc_TtGetBit( pTable, m * nFans + i ) )
+ Abc_TtSetBit( pTruth, m );
+ // implement truth table
+ if ( nFans < 6 )
+ pTruth[0] = Abc_Tt6Stretch( pTruth[0], nFans );
+ iLit = Kit_TruthToGia( pNew, (unsigned *)pTruth, nFans, vMemory, &vLeaves, 1 );
+ Vec_IntPush( vRes, iLit );
+ }
+ Vec_IntFree( vMemory );
+ ABC_FREE( pTruth );
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
Gia_Man_t * Wlc_NtkBitBlast( Wlc_Ntk_t * p )
{
Gia_Man_t * pTemp, * pNew;
- Wlc_Obj_t * pObj;
- Vec_Int_t * vBits, * vTemp0, * vTemp1, * vTemp2, * vTemp3;
+ Wlc_Obj_t * pObj, * pPrev = NULL;
+ Vec_Int_t * vBits, * vTemp0, * vTemp1, * vTemp2, * vRes;
int nBits = Wlc_NtkPrepareBits( p );
int nRange, nRange0, nRange1, nRange2;
int i, k, b, iLit, * pFans0, * pFans1, * pFans2;
@@ -114,8 +307,8 @@ Gia_Man_t * Wlc_NtkBitBlast( Wlc_Ntk_t * p )
vTemp0 = Vec_IntAlloc( 1000 );
vTemp1 = Vec_IntAlloc( 1000 );
vTemp2 = Vec_IntAlloc( 1000 );
- vTemp3 = Vec_IntAlloc( 1000 );
- // craete AIG manager
+ vRes = Vec_IntAlloc( 1000 );
+ // create AIG manager
pNew = Gia_ManStart( 5 * Wlc_NtkObjNum(p) + 1000 );
pNew->pName = Abc_UtilStrsav( p->pName );
Gia_ManHashAlloc( pNew );
@@ -127,85 +320,79 @@ Gia_Man_t * Wlc_NtkBitBlast( Wlc_Ntk_t * p )
nRange0 = Wlc_ObjFaninNum(pObj) > 0 ? Wlc_ObjRange( Wlc_ObjFanin0(p, pObj) ) : -1;
nRange1 = Wlc_ObjFaninNum(pObj) > 1 ? Wlc_ObjRange( Wlc_ObjFanin1(p, pObj) ) : -1;
nRange2 = Wlc_ObjFaninNum(pObj) > 2 ? Wlc_ObjRange( Wlc_ObjFanin2(p, pObj) ) : -1;
- pFans0 = Wlc_ObjFaninNum(pObj) > 0 ? Vec_IntEntryP( vBits, Wlc_ObjCopy(p, Wlc_ObjFaninId0(pObj)) ) : NULL;
- pFans1 = Wlc_ObjFaninNum(pObj) > 1 ? Vec_IntEntryP( vBits, Wlc_ObjCopy(p, Wlc_ObjFaninId1(pObj)) ) : NULL;
- pFans2 = Wlc_ObjFaninNum(pObj) > 2 ? Vec_IntEntryP( vBits, Wlc_ObjCopy(p, Wlc_ObjFaninId2(pObj)) ) : NULL;
+ pFans0 = Wlc_ObjFaninNum(pObj) > 0 ? Vec_IntEntryP( vBits, Wlc_ObjCopy(p, Wlc_ObjFaninId0(pObj)) ) : NULL;
+ pFans1 = Wlc_ObjFaninNum(pObj) > 1 ? Vec_IntEntryP( vBits, Wlc_ObjCopy(p, Wlc_ObjFaninId1(pObj)) ) : NULL;
+ pFans2 = Wlc_ObjFaninNum(pObj) > 2 ? Vec_IntEntryP( vBits, Wlc_ObjCopy(p, Wlc_ObjFaninId2(pObj)) ) : NULL;
+ Vec_IntClear( vRes );
if ( pObj->Type == WLC_OBJ_PI )
{
for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, Gia_ManAppendCi(pNew) );
+ Vec_IntPush( vRes, Gia_ManAppendCi(pNew) );
}
else if ( pObj->Type == WLC_OBJ_PO || pObj->Type == WLC_OBJ_BUF )
{
// assert( nRange <= nRange0 );
for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, k < nRange0 ? pFans0[k] : 0 );
+ Vec_IntPush( vRes, k < nRange0 ? pFans0[k] : 0 );
}
else if ( pObj->Type == WLC_OBJ_CONST )
{
word * pTruth = (word *)Wlc_ObjFanins(pObj);
for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, Abc_TtGetBit(pTruth, k) );
+ Vec_IntPush( vRes, Abc_TtGetBit(pTruth, k) );
}
else if ( pObj->Type == WLC_OBJ_MUX )
{
- assert( nRange0 == 1 );
- assert( nRange1 == nRange );
- assert( nRange2 == nRange );
+ assert( nRange0 == 1 && nRange1 == nRange && nRange2 == nRange );
for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, Gia_ManHashMux(pNew, pFans0[0], pFans1[k], pFans2[k]) );
+ Vec_IntPush( vRes, Gia_ManHashMux(pNew, pFans0[0], pFans1[k], pFans2[k]) );
}
else if ( pObj->Type == WLC_OBJ_SHIFT_R || pObj->Type == WLC_OBJ_SHIFT_RA )
{
- // prepare data
- int Fill = pObj->Type == WLC_OBJ_SHIFT_R ? 0 : pFans0[nRange0-1];
- int nTotal = nRange + (1 << nRange1);
- Vec_IntClear( vTemp0 );
- for ( k = 0; k < nRange0; k++ )
- Vec_IntPush( vTemp0, pFans0[k] );
- for ( k = 0; k < nTotal; k++ )
- Vec_IntPush( vTemp0, Fill );
- // derive the result
- for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, Wlc_NtkMuxTree_rec(pNew, pFans1, nRange1, vTemp0, k) );
+ assert( nRange0 >= nRange );
+ Wlc_BlastShiftRight( pNew, pFans0, nRange0, pFans1, nRange1, pObj->Type == WLC_OBJ_SHIFT_RA, vRes );
+ if ( nRange0 > nRange )
+ Vec_IntShrink( vRes, nRange );
}
else if ( pObj->Type == WLC_OBJ_SHIFT_L || pObj->Type == WLC_OBJ_SHIFT_LA )
{
- // prepare data
- int Fill = pObj->Type == WLC_OBJ_SHIFT_L ? 0 : pFans0[0];
- int nTotal = nRange + (1 << nRange1);
- Vec_IntClear( vTemp0 );
- for ( k = 0; k < nRange0; k++ )
- Vec_IntPush( vTemp0, pFans0[k] );
- for ( k = 0; k < nTotal; k++ )
- Vec_IntPush( vTemp0, Fill );
- // derive the result
- for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, Wlc_NtkMuxTree_rec(pNew, pFans1, nRange1, vTemp0, k) );
+ int * pArg0 = Wlc_VecLoadFanins( vTemp0, pFans0, nRange0, nRange, Wlc_ObjFanin0(p, pObj)->Signed );
+ assert( nRange0 <= nRange );
+ Wlc_BlastShiftLeft( pNew, pArg0, nRange, pFans1, nRange1, pObj->Type == WLC_OBJ_SHIFT_LA, vRes );
+ }
+ else if ( pObj->Type == WLC_OBJ_ROTATE_R )
+ {
+ assert( nRange0 == nRange );
+ Wlc_BlastRotateRight( pNew, pFans0, nRange0, pFans1, nRange1, vRes );
+ }
+ else if ( pObj->Type == WLC_OBJ_ROTATE_L )
+ {
+ assert( nRange0 == nRange );
+ Wlc_BlastRotateLeft( pNew, pFans0, nRange0, pFans1, nRange1, vRes );
}
else if ( pObj->Type == WLC_OBJ_BIT_NOT )
{
assert( nRange == nRange0 );
for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, Abc_LitNot(pFans0[k]) );
+ Vec_IntPush( vRes, Abc_LitNot(pFans0[k]) );
}
else if ( pObj->Type == WLC_OBJ_BIT_AND )
{
assert( nRange0 == nRange && nRange1 == nRange );
for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, Gia_ManHashAnd(pNew, pFans0[k], pFans1[k]) );
+ Vec_IntPush( vRes, Gia_ManHashAnd(pNew, pFans0[k], pFans1[k]) );
}
else if ( pObj->Type == WLC_OBJ_BIT_OR )
{
assert( nRange0 == nRange && nRange1 == nRange );
for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, Gia_ManHashOr(pNew, pFans0[k], pFans1[k]) );
+ Vec_IntPush( vRes, Gia_ManHashOr(pNew, pFans0[k], pFans1[k]) );
}
else if ( pObj->Type == WLC_OBJ_BIT_XOR )
{
assert( nRange0 == nRange && nRange1 == nRange );
for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, Gia_ManHashXor(pNew, pFans0[k], pFans1[k]) );
+ Vec_IntPush( vRes, Gia_ManHashXor(pNew, pFans0[k], pFans1[k]) );
}
else if ( pObj->Type == WLC_OBJ_BIT_SELECT )
{
@@ -213,7 +400,7 @@ Gia_Man_t * Wlc_NtkBitBlast( Wlc_Ntk_t * p )
int Beg = Wlc_ObjRangeBeg(pObj);
assert( nRange == End - Beg + 1 );
for ( k = Beg; k <= End; k++ )
- Vec_IntPush( vBits, pFans0[k] );
+ Vec_IntPush( vRes, pFans0[k] );
}
else if ( pObj->Type == WLC_OBJ_BIT_CONCAT )
{
@@ -226,7 +413,7 @@ Gia_Man_t * Wlc_NtkBitBlast( Wlc_Ntk_t * p )
nRange0 = Wlc_ObjRange( Wlc_NtkObj(p, iFanin) );
pFans0 = Vec_IntEntryP( vBits, Wlc_ObjCopy(p, iFanin) );
for ( b = 0; b < nRange0; b++ )
- Vec_IntPush( vBits, pFans0[b] );
+ Vec_IntPush( vRes, pFans0[b] );
}
}
else if ( pObj->Type == WLC_OBJ_BIT_ZEROPAD || pObj->Type == WLC_OBJ_BIT_SIGNEXT )
@@ -234,113 +421,89 @@ Gia_Man_t * Wlc_NtkBitBlast( Wlc_Ntk_t * p )
int Pad = pObj->Type == WLC_OBJ_BIT_ZEROPAD ? 0 : pFans0[nRange0-1];
assert( nRange0 < nRange );
for ( k = 0; k < nRange0; k++ )
- Vec_IntPush( vBits, pFans0[k] );
+ Vec_IntPush( vRes, pFans0[k] );
for ( ; k < nRange; k++ )
- Vec_IntPush( vBits, Pad );
+ Vec_IntPush( vRes, Pad );
}
else if ( pObj->Type == WLC_OBJ_LOGIC_NOT )
{
- iLit = Wlc_NtkComputeReduction( pNew, pFans0, nRange, WLC_OBJ_REDUCT_OR );
+ iLit = Wlc_BlastReduction( pNew, pFans0, nRange, WLC_OBJ_REDUCT_OR );
assert( nRange == 1 );
- Vec_IntPush( vBits, Abc_LitNot(iLit) );
+ Vec_IntFill( vRes, 1, Abc_LitNot(iLit) );
}
else if ( pObj->Type == WLC_OBJ_LOGIC_AND )
{
- int iLit0 = Wlc_NtkComputeReduction( pNew, pFans0, nRange, WLC_OBJ_REDUCT_OR );
- int iLit1 = Wlc_NtkComputeReduction( pNew, pFans0, nRange, WLC_OBJ_REDUCT_OR );
+ int iLit0 = Wlc_BlastReduction( pNew, pFans0, nRange, WLC_OBJ_REDUCT_OR );
+ int iLit1 = Wlc_BlastReduction( pNew, pFans0, nRange, WLC_OBJ_REDUCT_OR );
assert( nRange == 1 );
- Vec_IntPush( vBits, Gia_ManHashAnd(pNew, iLit0, iLit1) );
+ Vec_IntFill( vRes, 1, Gia_ManHashAnd(pNew, iLit0, iLit1) );
}
else if ( pObj->Type == WLC_OBJ_LOGIC_OR )
{
- int iLit0 = Wlc_NtkComputeReduction( pNew, pFans0, nRange, WLC_OBJ_REDUCT_OR );
- int iLit1 = Wlc_NtkComputeReduction( pNew, pFans0, nRange, WLC_OBJ_REDUCT_OR );
+ int iLit0 = Wlc_BlastReduction( pNew, pFans0, nRange, WLC_OBJ_REDUCT_OR );
+ int iLit1 = Wlc_BlastReduction( pNew, pFans0, nRange, WLC_OBJ_REDUCT_OR );
assert( nRange == 1 );
- Vec_IntPush( vBits, Gia_ManHashOr(pNew, iLit0, iLit1) );
+ Vec_IntFill( vRes, 1, Gia_ManHashOr(pNew, iLit0, iLit1) );
}
- else if ( pObj->Type == WLC_OBJ_COMP_EQU || pObj->Type == WLC_OBJ_COMP_NOT )
+ else if ( pObj->Type == WLC_OBJ_COMP_EQU || pObj->Type == WLC_OBJ_COMP_NOTEQU )
{
int iLit = 0;
- assert( nRange == 1 );
- assert( nRange0 == nRange1 );
+ assert( nRange == 1 && nRange0 == nRange1 );
for ( k = 0; k < nRange0; k++ )
iLit = Gia_ManHashOr( pNew, iLit, Gia_ManHashXor(pNew, pFans0[k], pFans1[k]) );
- Vec_IntPush( vBits, Abc_LitNotCond(iLit, pObj->Type == WLC_OBJ_COMP_EQU) );
+ Vec_IntFill( vRes, 1, Abc_LitNotCond(iLit, pObj->Type == WLC_OBJ_COMP_EQU) );
}
else if ( pObj->Type == WLC_OBJ_COMP_LESS || pObj->Type == WLC_OBJ_COMP_MOREEQU ||
pObj->Type == WLC_OBJ_COMP_MORE || pObj->Type == WLC_OBJ_COMP_LESSEQU )
{
- int iTerm, iEqu = 1, iLit = 0;
+ int fSwap = (pObj->Type == WLC_OBJ_COMP_MORE || pObj->Type == WLC_OBJ_COMP_LESSEQU);
+ int fCompl = (pObj->Type == WLC_OBJ_COMP_MOREEQU || pObj->Type == WLC_OBJ_COMP_LESSEQU);
assert( nRange == 1 );
assert( nRange0 == nRange1 );
- if ( pObj->Type == WLC_OBJ_COMP_MORE || pObj->Type == WLC_OBJ_COMP_LESSEQU )
- ABC_SWAP( int *, pFans0, pFans1 );
- for ( k = nRange0 - 1; k >= 0; k-- )
- {
- iTerm = Gia_ManHashAnd( pNew, Abc_LitNot(pFans0[k]), pFans1[k] );
- iTerm = Gia_ManHashAnd( pNew, iTerm, iEqu );
- iLit = Gia_ManHashOr( pNew, iLit, iTerm );
- iEqu = Abc_LitNot( Gia_ManHashXor( pNew, pFans0[k], pFans1[k] ) );
- }
- Vec_IntPush( vBits, Abc_LitNotCond(iLit, pObj->Type == WLC_OBJ_COMP_MOREEQU) );
+ if ( fSwap ) ABC_SWAP( int *, pFans0, pFans1 );
+ iLit = Wlc_BlastLess( pNew, pFans0, pFans1, nRange0 );
+ iLit = Abc_LitNotCond( iLit, fCompl );
+ Vec_IntFill( vRes, 1, iLit );
}
else if ( pObj->Type == WLC_OBJ_REDUCT_AND || pObj->Type == WLC_OBJ_REDUCT_OR || pObj->Type == WLC_OBJ_REDUCT_XOR )
- Vec_IntPush( vBits, Wlc_NtkComputeReduction( pNew, pFans0, nRange, pObj->Type ) );
- else if ( pObj->Type == WLC_OBJ_ARI_ADD )
+ Vec_IntPush( vRes, Wlc_BlastReduction( pNew, pFans0, nRange, pObj->Type ) );
+ else if ( pObj->Type == WLC_OBJ_ARI_ADD || pObj->Type == WLC_OBJ_ARI_SUB ) // SUBTRACT is not implemented!
{
- int Pad0 = Wlc_ObjFanin0(p, pObj)->Signed ? pFans0[nRange0-1] : 0;
- int Pad1 = Wlc_ObjFanin1(p, pObj)->Signed ? pFans1[nRange1-1] : 0;
- assert( nRange0 <= nRange && nRange1 <= nRange );
- Vec_IntClear( vTemp0 );
- for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vTemp0, k < nRange0 ? pFans0[k] : Pad0 );
- Vec_IntClear( vTemp1 );
- for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vTemp1, k < nRange1 ? pFans1[k] : Pad1 );
- Wlc_NtkAdderChain( pNew, Vec_IntArray(vTemp0), Vec_IntArray(vTemp1), nRange );
- Vec_IntAppend( vBits, vTemp0 );
+ int * pArg0 = Wlc_VecLoadFanins( vRes, pFans0, nRange0, nRange, Wlc_ObjFanin0(p, pObj)->Signed );
+ int * pArg1 = Wlc_VecLoadFanins( vTemp1, pFans1, nRange1, nRange, Wlc_ObjFanin1(p, pObj)->Signed );
+ Wlc_BlastAdder( pNew, pArg0, pArg1, nRange ); // result is in pFan0 (vRes)
}
else if ( pObj->Type == WLC_OBJ_ARI_MULTI )
{
- int Pad0 = Wlc_ObjFanin0(p, pObj)->Signed ? pFans0[nRange0-1] : 0;
- int Pad1 = Wlc_ObjFanin1(p, pObj)->Signed ? pFans1[nRange1-1] : 0;
+ int * pArg0 = Wlc_VecLoadFanins( vTemp0, pFans0, nRange0, nRange, Wlc_ObjFanin0(p, pObj)->Signed );
+ int * pArg1 = Wlc_VecLoadFanins( vTemp1, pFans1, nRange1, nRange, Wlc_ObjFanin1(p, pObj)->Signed );
assert( nRange0 <= nRange && nRange1 <= nRange );
- Vec_IntClear( vTemp0 );
- for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vTemp0, k < nRange0 ? pFans0[k] : Pad0 );
- Vec_IntClear( vTemp1 );
- for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vTemp1, k < nRange1 ? pFans1[k] : Pad1 );
- // iterate
- Vec_IntFill( vTemp3, nRange, 0 );
- for ( k = 0; k < nRange; k++ )
- {
- Vec_IntFill( vTemp2, k, 0 );
- Vec_IntForEachEntry( vTemp0, iLit, b )
- {
- Vec_IntPush( vTemp2, Gia_ManHashAnd(pNew, iLit, Vec_IntEntry(vTemp1, k)) );
- if ( Vec_IntSize(vTemp2) == nRange )
- break;
- }
- assert( Vec_IntSize(vTemp2) == nRange );
- Wlc_NtkAdderChain( pNew, Vec_IntArray(vTemp3), Vec_IntArray(vTemp2), nRange );
- }
- assert( Vec_IntSize(vTemp3) == nRange );
- Vec_IntAppend( vBits, vTemp3 );
+ Wlc_BlastMultiplier( pNew, pArg0, pArg1, nRange, vTemp2, vRes );
}
- else if ( pObj->Type == WLC_OBJ_TABLE )
+ else if ( pObj->Type == WLC_OBJ_ARI_DIVIDE || pObj->Type == WLC_OBJ_ARI_MODULUS )
{
- assert( pObj->Type != WLC_OBJ_TABLE );
- for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vBits, 0 );
+ int * pArg0 = Wlc_VecLoadFanins( vTemp0, pFans0, nRange0, nRange, Wlc_ObjFanin0(p, pObj)->Signed );
+ int * pArg1 = Wlc_VecLoadFanins( vTemp1, pFans1, nRange1, nRange, Wlc_ObjFanin1(p, pObj)->Signed );
+ assert( nRange0 <= nRange && nRange1 <= nRange );
+ Wlc_BlastDivider( pNew, pArg0, nRange0, pArg1, nRange1, pObj->Type == WLC_OBJ_ARI_DIVIDE, vRes );
}
+ else if ( pObj->Type == WLC_OBJ_ARI_MINUS )
+ {
+ assert( nRange0 == nRange );
+ Wlc_BlastMinus( pNew, pFans0, nRange0, vRes );
+ }
+ else if ( pObj->Type == WLC_OBJ_TABLE )
+ Wlc_BlastTable( pNew, Wlc_ObjTable(p, pObj), pFans0, nRange0, nRange, vRes );
else assert( 0 );
+ assert( Vec_IntSize(vBits) == Wlc_ObjCopy(p, i) );
+ Vec_IntAppend( vBits, vRes );
+ pPrev = pObj;
}
assert( nBits == Vec_IntSize(vBits) );
Vec_IntFree( vTemp0 );
Vec_IntFree( vTemp1 );
Vec_IntFree( vTemp2 );
- Vec_IntFree( vTemp3 );
+ Vec_IntFree( vRes );
// create POs
Wlc_NtkForEachPo( p, pObj, i )
{