diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2016-01-05 18:40:38 -0800 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2016-01-05 18:40:38 -0800 |
commit | 30d09e2cbe68ca6138513703dad94d6b295e0625 (patch) | |
tree | f443ac5e0457ffd108483731bdbde6741a7ecb81 /src/aig | |
parent | c158dd5a94294e297bd8561b72897bcfb53f03f9 (diff) | |
download | abc-30d09e2cbe68ca6138513703dad94d6b295e0625.tar.gz abc-30d09e2cbe68ca6138513703dad94d6b295e0625.tar.bz2 abc-30d09e2cbe68ca6138513703dad94d6b295e0625.zip |
Fix in &nf for the case when PO can be driven by an inverter.
Diffstat (limited to 'src/aig')
-rw-r--r-- | src/aig/gia/giaNf.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/aig/gia/giaNf.c b/src/aig/gia/giaNf.c index abbf0ac1..89944c7d 100644 --- a/src/aig/gia/giaNf.c +++ b/src/aig/gia/giaNf.c @@ -2020,6 +2020,35 @@ void Nf_ManComputeMappingEla( Nf_Man_t * p ) Nf_ObjUpdateRequired( p, Id, 0, Required - p->InvDelayI ); } } +void Nf_ManFixPoDrivers( Nf_Man_t * p ) +{ + Gia_Obj_t * pObj; + Nf_Mat_t * pM, * pMc; + int i, iDriver, Count = 0; + Gia_ManForEachCo( p->pGia, pObj, i ) + { + iDriver = Gia_ObjFaninId0p(p->pGia, pObj); + if ( !Gia_ObjIsAnd(Gia_ManObj(p->pGia, iDriver)) ) + continue; + // skip unless both are used + if ( !Nf_ObjMapRefNum(p, iDriver, 0) || !Nf_ObjMapRefNum(p, iDriver, 1) ) + continue; + pM = Nf_ObjMatchD( p, iDriver, Gia_ObjFaninC0(pObj) ); + pMc = Nf_ObjMatchD( p, iDriver, !Gia_ObjFaninC0(pObj) ); + // skip unless both are non-complemented + if ( pM->fCompl || pMc->fCompl ) + continue; + // skip if arrival time exceeds the required time + if ( pMc->D + p->InvDelayI > p->pPars->MapDelay ) + continue; + // add inverter + *pM = *pMc; + pM->D += p->InvDelayI; + pM->fCompl = 1; + Count++; + } + //printf( "Fixed %d PO drivers.\n", Count ); +} /**Function************************************************************* @@ -2213,6 +2242,7 @@ Gia_Man_t * Nf_ManPerformMapping( Gia_Man_t * pGia, Jf_Par_t * pPars ) Nf_ManUpdateStats( p ); Nf_ManPrintStats( p, "Ela " ); } + Nf_ManFixPoDrivers( p ); pNew = Nf_ManDeriveMapping( p ); Nf_StoDelete( p ); return pNew; |