summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2016-01-31 16:38:49 -0800
committerAlan Mishchenko <alanmi@berkeley.edu>2016-01-31 16:38:49 -0800
commit81dade194e30b6fa5f98352a76459c062d27e66f (patch)
tree923d495c14b0dd42a55c623da9d3d155173eb7f9
parent367b20f04d2b42ab4c74fbb681e0d02f12de1ba6 (diff)
downloadabc-81dade194e30b6fa5f98352a76459c062d27e66f.tar.gz
abc-81dade194e30b6fa5f98352a76459c062d27e66f.tar.bz2
abc-81dade194e30b6fa5f98352a76459c062d27e66f.zip
Rare bug fix in 'dch' resulting in choice nodes having internal fanout.
-rw-r--r--src/proof/dch/dchChoice.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/src/proof/dch/dchChoice.c b/src/proof/dch/dchChoice.c
index e2473de6..b5ccb765 100644
--- a/src/proof/dch/dchChoice.c
+++ b/src/proof/dch/dchChoice.c
@@ -456,7 +456,14 @@ void Dch_DeriveChoiceAigNode( Aig_Man_t * pAigNew, Aig_Man_t * pAigOld, Aig_Obj_
pObjNew = Aig_And( pAigNew,
Aig_ObjChild0CopyRepr(pAigNew, pObj),
Aig_ObjChild1CopyRepr(pAigNew, pObj) );
- pObjNew = Aig_ObjGetRepr( pAigNew, pObjNew );
+// pObjNew = Aig_ObjGetRepr( pAigNew, pObjNew );
+ while ( 1 )
+ {
+ Aig_Obj_t * pObjNew2 = pObjNew;
+ pObjNew = Aig_ObjGetRepr( pAigNew, pObjNew2 );
+ if ( pObjNew == pObjNew2 )
+ break;
+ }
// assert( Aig_ObjRepr( pAigNew, pObjNew ) == NULL );
// assign the copy
assert( pObj->pData == NULL );