From 858be31d7ac6f16cb97000ca0974beae99b52d42 Mon Sep 17 00:00:00 2001 From: Ludovic Jacomme Date: Fri, 2 Aug 2002 15:17:23 +0000 Subject: [PATCH] Encore plus de plaisir ! une seule cuillere suffit ! --- alliance/src/mocha/src/Makefile.am | 6 +- alliance/src/mocha/src/mocha_check.c | 688 ++++++++++++++++++-------- alliance/src/mocha/src/mocha_fsm.c | 4 +- alliance/src/mocha/src/mocha_main.c | 7 +- alliance/src/mocha/src/mocha_shared.h | 2 + alliance/src/mocha/src/mocha_syf.c | 28 +- 6 files changed, 510 insertions(+), 225 deletions(-) diff --git a/alliance/src/mocha/src/Makefile.am b/alliance/src/mocha/src/Makefile.am index a7280aee..0f1b249d 100644 --- a/alliance/src/mocha/src/Makefile.am +++ b/alliance/src/mocha/src/Makefile.am @@ -1,15 +1,15 @@ ## Process this file with automake to produce Makefile.in -bin_PROGRAMS = mocha +bin_PROGRAMS = moka AM_CFLAGS = @ALLIANCE_CFLAGS@ -Wall -mocha_LDADD = @ALLIANCE_LIBS@ \ +moka_LDADD = @ALLIANCE_LIBS@ \ -lFtl -lFks -lFvh -lFsm \ -lCtp -lCtl -lVex -lAbt -lAbv -lAbe -lBtr -lBdd -lAbl -lAut -lMut -mocha_SOURCES = \ +moka_SOURCES = \ mocha_check.h mocha_debug.h mocha_main.h mocha_syf.h \ mocha_beh.c mocha_ctl.c mocha_fsm.c mocha_shared.c \ mocha_beh.h mocha_ctl.h mocha_fsm.h mocha_shared.h \ diff --git a/alliance/src/mocha/src/mocha_check.c b/alliance/src/mocha/src/mocha_check.c index 421634e4..d52d027c 100644 --- a/alliance/src/mocha/src/mocha_check.c +++ b/alliance/src/mocha/src/mocha_check.c @@ -117,6 +117,11 @@ | Functions | | | \------------------------------------------------------------*/ +/*------------------------------------------------------------\ +| | +| MochaCheckViewBddNode | +| | +\------------------------------------------------------------*/ static void MochaCheckViewBddNode( BddNode ) @@ -141,6 +146,112 @@ void MochaCheckViewTransFunc( VarFunc ) MochaCheckViewBddNode( VarFunc->FUNC ); } +/*------------------------------------------------------------\ +| | +| MochaCheckViewState | +| | +\------------------------------------------------------------*/ + +static int MochaCheckViewState( MochaFigure, BddNode ) + + mochafig_list *MochaFigure; + bddnode *BddNode; +{ + mochafsm_list *MochaFsm; + mochastate_list *MochaState; + bddnode *BddState; + bddnode *BddStateSet; + bddnode *BddReached; + bddnode *BddFirst; + bddnode *BddFsm; + bddnode *BddAssume; + bddnode *BddCheck; + bddassoc *BddAssoc; + bddassoc *BddRegAssoc; + int First; + + setbddlocalcircuit( MochaFigure->BDD_CIRCUIT ); + + BddRegAssoc = MochaFigure->BDD_ASSOC_REG; + BddReached = MochaFigure->BDD_REACHED_STATE; + BddFirst = MochaFigure->BDD_FIRST_STATE; + BddAssume = MochaFigure->BDD_ASSUME; + + BddStateSet = applybddnode( (bddsystem *)0, ABL_AND, BddNode , BddAssume ); + BddStateSet = existbddnodemissassoc( (bddsystem *)0, BddStateSet, BddRegAssoc ); + BddStateSet = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddStateSet ), BddReached ); + + if ( BddStateSet == BddLocalSystem->ZERO ) + { + fprintf( stdout, "\t > state set empty !\n" ); + return ( 0 ); + } + + if ( BddNode == BddReached ) + { + fprintf( stdout, "\t > all reachable states\n" ); + return ( 1 ); + } + + BddCheck = applybddnode( (bddsystem *)0, ABL_AND, BddStateSet, BddFirst ); + decbddrefext( BddCheck ); + + if ( BddCheck == BddFirst ) First = 1; + else First = 0; + + + if ( MochaFigure->FSM == (mochafsm_list *)0 ) + { + return( First ); + } + + fprintf( stdout, "\t > states set:\n" ); + + while ( BddStateSet != BddLocalSystem->ZERO ) + { + BddCheck = satisfybddnodeassoc( (bddsystem *)0, BddStateSet, BddRegAssoc ); + + fprintf( stdout, "\t " ); + + for ( MochaFsm = MochaFigure->FSM; + MochaFsm != (mochafsm_list *)0; + MochaFsm = MochaFsm->NEXT ) + { + BddAssoc = MochaFsm->BDD_ASSOC_STATE; + BddFsm = existbddnodemissassoc( (bddsystem *)0, BddCheck, BddAssoc ); + + for ( MochaState = MochaFsm->STATE; + MochaState != (mochastate_list *)0; + MochaState = MochaState->NEXT ) + { + BddState = applybddnode( (bddsystem *)0, ABL_AND, BddFsm, MochaState->BDD_STATE ); + decbddrefext( BddState ); + + if ( BddState == MochaState->BDD_STATE ) + { + fprintf( stdout, "%s[%s] ", MochaFsm->NAME, MochaState->NAME ); break; + } + } + } + + if ( BddCheck == BddFirst ) + { + fprintf( stdout, " (first state)\n" ); + } + else + { + fprintf( stdout, "\n" ); + } + + BddCheck = applybddnodenot( (bddsystem *)0, decbddrefext( BddCheck ) ); + BddStateSet = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddStateSet ), decbddrefext( BddCheck ) ); + } + + return( First ); +} + /*------------------------------------------------------------\ | | | MochaCheckBuildTransFunc | @@ -151,22 +262,27 @@ static void MochaCheckBuildTransFunc( MochaFigure ) mochafig_list *MochaFigure; { - mochafsm_list *MochaFsm; - befig_list *BehFigure; - ctlfig_list *CtlFigure; - btrtransfunc *BtrTransFunc; - bddassoc *BddStateAssoc; - bddassoc *BddRegAssoc; - bereg_list *BehReg; - binode_list *BiNode; - bddnode *BddNode; - bddvar Variable; - char Buffer[ 512 ]; - long NumberReg; - long Index; - long Index2; - long Step; - long Width; + mochafsm_list *MochaFsm; + mochastate_list *MochaState; + befig_list *BehFigure; + ctlfig_list *CtlFigure; + btrtransfunc *BtrTransFunc; + bddassoc *BddStateAssoc; + bddassoc *BddRegAssoc; + bereg_list *BehReg; + binode_list *BiNode; + chain_list *ScanList; + chain_list *HeadList; + bddnode *BddNode; + bddnode *BddState; + bddvar Variable; + char Buffer[ 512 ]; + long NumberReg; + long Index; + long Index2; + long Step; + long BitMask; + long Width; BehFigure = MochaFigure->BEH_FIGURE; CtlFigure = MochaFigure->CTL_FIGURE; @@ -206,6 +322,8 @@ static void MochaCheckBuildTransFunc( MochaFigure ) Index = MochaFsm->LEFT; Index2 = 0; + HeadList = (chain_list *)0; + for ( Width = MochaFsm->NUMBER_BIT; Width > 0; Width-- ) { sprintf( Buffer, "%s %ld", MochaFsm->CURRENT_STATE, Index ); @@ -216,7 +334,40 @@ static void MochaCheckBuildTransFunc( MochaFigure ) Index += Step; Index2 = Index2 + 1; + + HeadList = addchain( HeadList, (void *)BddNode ); } + + for ( MochaState = MochaFsm->STATE; + MochaState != (mochastate_list *)0; + MochaState = MochaState->NEXT ) + { + BddState = BddLocalSystem->ONE; + BitMask = 1; + ScanList = HeadList; + + for ( Width = MochaFsm->NUMBER_BIT; Width > 0; Width-- ) + { + BddNode = (bddnode *)( ScanList->DATA ); + + if ( ! ( MochaState->CODE & BitMask ) ) + { + BddNode = applybddnodenot( (bddsystem *)0, BddNode ); + decbddrefext( BddNode ); + } + + BddState = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddState ), BddNode ); + + BitMask = BitMask << 1; + ScanList = ScanList->NEXT; + } + + MochaState->BDD_STATE = BddState; + } + + freechain( HeadList ); + HeadList = (chain_list *)0; } # ifdef DEBUG @@ -391,166 +542,14 @@ static void MochaCheckComputeReachableStates( MochaFigure ) addbddcircuitout( (bddcircuit *)0, "reached", BddReachedSet ); testbddcircuit( (bddcircuit *)0 ); # endif - fprintf( stdout, "First state " ); - MochaCheckViewBddNode( MochaFigure->BDD_FIRST_STATE ); - fprintf( stdout, "Reachable states " ); - MochaCheckViewBddNode( BddReachedSet ); -} -/*------------------------------------------------------------\ -| | -| MochaCheckCtlBddEX | -| | -\------------------------------------------------------------*/ - -static bddnode *MochaCheckCtlBddEX( BddNode ) - - bddnode *BddNode; -{ - bddnode *BddNew; - bddnode *BddReached; - bddnode *BddAssume; - btrtransfunc *BtrTransFunc; - bddassoc *BddAssoc; - - BtrTransFunc = MochaMochaFigure->BTR_TRANS_FUNC; - BddAssoc = MochaMochaFigure->BDD_ASSOC_REG; - BddReached = MochaMochaFigure->BDD_REACHED_STATE; - BddAssume = MochaMochaFigure->BDD_ASSUME; - - BddNew = preimagebtrtransfunc( BtrTransFunc, BddNode ); - - BddNew = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNew ), BddAssume ); - - BddNew = existbddnodemissassoc( (bddsystem *)0, - decbddrefext( BddNew ), BddAssoc ); - - BddNew = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNew ), BddReached ); - -# if 1 - fprintf( stdout, "MochaCheckCtlBddEX -> " ); - MochaCheckViewBddNode( BddNew ); -# endif - - return( BddNew ); -} - -/*------------------------------------------------------------\ -| | -| MochaCheckCtlBddEG | -| | -\------------------------------------------------------------*/ - -static bddnode *MochaCheckCtlBddEG( BddNode ) - - bddnode *BddNode; -{ - bddnode *BddOld; - bddnode *BddNew; - bddnode *BddReached; - bddnode *BddAssume; - btrtransfunc *BtrTransFunc; - bddassoc *BddAssoc; - - BtrTransFunc = MochaMochaFigure->BTR_TRANS_FUNC; - BddAssoc = MochaMochaFigure->BDD_ASSOC_REG; - BddReached = MochaMochaFigure->BDD_REACHED_STATE; - BddAssume = MochaMochaFigure->BDD_ASSUME; - BddOld = BddLocalSystem->ONE; - BddNew = incbddrefext( BddNode ); - - fprintf( stdout, "> MochaCheckCtlBddEG\n" ); - fprintf( stdout, "EG:\n" ); - MochaCheckViewBddNode( BddNode ); -# ifdef DEBUG - fprintf( stdout, "REACHED:\n" ); - MochaCheckViewBddNode( BddReached ); -# endif - - while ( BddNew != BddOld ) + if ( MochaFigure->DEBUG ) { - BddOld = BddNew; - - BddNew = preimagebtrtransfunc( BtrTransFunc, BddOld ); - - BddNew = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNew ), BddAssume ); - - BddNew = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNew ), BddNode ); - - BddNew = existbddnodemissassoc( (bddsystem *)0, - decbddrefext( BddNew ), BddAssoc ); - - BddNew = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNew ), BddReached ); - - fprintf( stdout, "MochaCheckCtlBddEG:\n" ); - MochaCheckViewBddNode( BddNew ); - - decbddrefext( BddOld ); + fprintf( stdout, "First state " ); + MochaCheckViewBddNode( MochaFigure->BDD_FIRST_STATE ); + fprintf( stdout, "Reachable states " ); + MochaCheckViewBddNode( BddReachedSet ); } - - fprintf( stdout, "< MochaCheckCtlBddEG\n" ); - - return( BddNew ); -} - -/*------------------------------------------------------------\ -| | -| MochaCheckCtlBddEU | -| | -\------------------------------------------------------------*/ - -static bddnode *MochaCheckCtlBddEU( BddNodeP, BddNodeQ ) - - bddnode *BddNodeP; - bddnode *BddNodeQ; -{ - bddnode *BddOld; - bddnode *BddNew; - bddnode *BddReached; - bddnode *BddAssume; - btrtransfunc *BtrTransFunc; - bddassoc *BddAssoc; - - BtrTransFunc = MochaMochaFigure->BTR_TRANS_FUNC; - BddAssoc = MochaMochaFigure->BDD_ASSOC_REG; - BddReached = MochaMochaFigure->BDD_REACHED_STATE; - BddAssume = MochaMochaFigure->BDD_ASSUME; - BddOld = BddLocalSystem->ZERO; - BddNew = incbddrefext( BddNodeQ ); - - while ( BddNew != BddOld ) - { - BddOld = BddNew; - - BddNew = preimagebtrtransfunc( BtrTransFunc, BddOld ); - - BddNew = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNew ), BddAssume ); - - BddNew = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNew ), BddNodeP ); - - BddNew = applybddnode( (bddsystem *)0, ABL_OR, - decbddrefext( BddNew ), BddNodeQ ); - - BddNew = existbddnodemissassoc( (bddsystem *)0, - decbddrefext( BddNew ), BddAssoc ); - - BddNew = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNew ), BddReached ); - - fprintf( stdout, "MochaCheckCtlBddEU:\n" ); - MochaCheckViewBddNode( BddNew ); - - decbddrefext( BddOld ); - } - - return( BddNew ); } /*------------------------------------------------------------\ @@ -601,6 +600,190 @@ static bddnode *MochaCheckCtlAblBoolean( Expr ) return( BddFirst ); } + +/*------------------------------------------------------------\ +| | +| MochaCheckCtlBddEX | +| | +\------------------------------------------------------------*/ + +static bddnode *MochaCheckCtlBddEX( BddNode ) + + bddnode *BddNode; +{ + bddnode *BddNew; + bddnode *BddReached; + bddnode *BddAssume; + btrtransfunc *BtrTransFunc; + bddassoc *BddAssoc; + + BtrTransFunc = MochaMochaFigure->BTR_TRANS_FUNC; + BddAssoc = MochaMochaFigure->BDD_ASSOC_REG; + BddReached = MochaMochaFigure->BDD_REACHED_STATE; + BddAssume = MochaMochaFigure->BDD_ASSUME; + + BddNew = preimagebtrtransfunc( BtrTransFunc, BddNode ); + +# if 0 + fprintf( stdout, "EX[\n" ); + MochaCheckViewBddNode( BddNode ); + fprintf( stdout, "]\n" ); +# endif + + BddNew = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddNew ), BddAssume ); + + BddNew = existbddnodemissassoc( (bddsystem *)0, + decbddrefext( BddNew ), BddAssoc ); + + BddNew = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddNew ), BddReached ); + +# if 0 + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddNew ); + fprintf( stdout, "\n" ); +# endif + + return( BddNew ); +} + +/*------------------------------------------------------------\ +| | +| MochaCheckCtlBddEG | +| | +\------------------------------------------------------------*/ + +static bddnode *MochaCheckCtlBddEG( BddNode ) + + bddnode *BddNode; +{ + bddnode *BddOld; + bddnode *BddNew; + bddnode *BddReached; + bddnode *BddAssume; + btrtransfunc *BtrTransFunc; + bddassoc *BddAssoc; + + BtrTransFunc = MochaMochaFigure->BTR_TRANS_FUNC; + BddAssoc = MochaMochaFigure->BDD_ASSOC_REG; + BddReached = MochaMochaFigure->BDD_REACHED_STATE; + BddAssume = MochaMochaFigure->BDD_ASSUME; + BddOld = BddLocalSystem->ONE; + BddNew = incbddrefext( BddNode ); + +# if 0 + fprintf( stdout, "EX[\n" ); + MochaCheckViewBddNode( BddNode ); + fprintf( stdout, "]\n" ); +# endif + + while ( BddNew != BddOld ) + { + BddOld = BddNew; + + BddNew = preimagebtrtransfunc( BtrTransFunc, BddOld ); + + BddNew = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddNew ), BddAssume ); + + BddNew = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddNew ), BddNode ); + + BddNew = existbddnodemissassoc( (bddsystem *)0, + decbddrefext( BddNew ), BddAssoc ); + + BddNew = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddNew ), BddReached ); + +# if 0 + fprintf( stdout, "MochaCheckCtlBddEG:\n" ); + MochaCheckViewBddNode( BddNew ); +# endif + + decbddrefext( BddOld ); + } + +# if 0 + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddNew ); + fprintf( stdout, "\n" ); +# endif + + return( BddNew ); +} + +/*------------------------------------------------------------\ +| | +| MochaCheckCtlBddEU | +| | +\------------------------------------------------------------*/ + +static bddnode *MochaCheckCtlBddEU( BddNodeP, BddNodeQ ) + + bddnode *BddNodeP; + bddnode *BddNodeQ; +{ + bddnode *BddOld; + bddnode *BddNew; + bddnode *BddReached; + bddnode *BddAssume; + btrtransfunc *BtrTransFunc; + bddassoc *BddAssoc; + + BtrTransFunc = MochaMochaFigure->BTR_TRANS_FUNC; + BddAssoc = MochaMochaFigure->BDD_ASSOC_REG; + BddReached = MochaMochaFigure->BDD_REACHED_STATE; + BddAssume = MochaMochaFigure->BDD_ASSUME; + BddOld = BddLocalSystem->ZERO; + BddNew = incbddrefext( BddNodeQ ); + +# if 0 + fprintf( stdout, "EU[\n" ); + MochaCheckViewBddNode( BddNodeP ); + fprintf( stdout, ", \n" ); + MochaCheckViewBddNode( BddNodeQ ); + fprintf( stdout, "]\n" ); +# endif + + while ( BddNew != BddOld ) + { + BddOld = BddNew; + + BddNew = preimagebtrtransfunc( BtrTransFunc, BddOld ); + + BddNew = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddNew ), BddAssume ); + + BddNew = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddNew ), BddNodeP ); + + BddNew = applybddnode( (bddsystem *)0, ABL_OR, + decbddrefext( BddNew ), BddNodeQ ); + + BddNew = existbddnodemissassoc( (bddsystem *)0, + decbddrefext( BddNew ), BddAssoc ); + + BddNew = applybddnode( (bddsystem *)0, ABL_AND, + decbddrefext( BddNew ), BddReached ); + +# if 0 + fprintf( stdout, "MochaCheckCtlBddEU:\n" ); + MochaCheckViewBddNode( BddNew ); +# endif + + decbddrefext( BddOld ); + } + +# if 0 + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddNew ); + fprintf( stdout, "\n" ); +# endif + + return( BddNew ); +} + /*------------------------------------------------------------\ | | | MochaCheckCtlAblAF | @@ -620,6 +803,14 @@ static bddnode *MochaCheckCtlAblAF( Expr ) Expr = ABL_CDR( Expr ); BddNode = MochaCheckCtlAbl( ABL_CAR( Expr ) ); + + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "AF[\n" ); + MochaCheckViewBddNode( BddNode ); + fprintf( stdout, "]\n" ); + } + BddNode = applybddnodenot( (bddsystem *)0, decbddrefext( BddNode ) ); BddResult = MochaCheckCtlBddEG( BddNode ); decbddrefext( BddNode ); @@ -629,6 +820,13 @@ static bddnode *MochaCheckCtlAblAF( Expr ) BddResult = applybddnode( (bddsystem *)0, ABL_AND, decbddrefext( BddResult ), BddReached ); + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddResult ); + fprintf( stdout, "\n" ); + } + return( BddResult ); } @@ -651,6 +849,14 @@ static bddnode *MochaCheckCtlAblAG( Expr ) Expr = ABL_CDR( Expr ); BddNode = MochaCheckCtlAbl( ABL_CAR( Expr ) ); + + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "AG[\n" ); + MochaCheckViewBddNode( BddNode ); + fprintf( stdout, "]\n" ); + } + BddNode = applybddnodenot( (bddsystem *)0, decbddrefext( BddNode ) ); BddResult = MochaCheckCtlBddEU( BddLocalSystem->ONE, BddNode ); decbddrefext( BddNode ); @@ -660,6 +866,13 @@ static bddnode *MochaCheckCtlAblAG( Expr ) BddResult = applybddnode( (bddsystem *)0, ABL_AND, decbddrefext( BddResult ), BddReached ); + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddResult ); + fprintf( stdout, "\n" ); + } + return( BddResult ); } @@ -682,6 +895,14 @@ static bddnode *MochaCheckCtlAblAX( Expr ) Expr = ABL_CDR( Expr ); BddNode = MochaCheckCtlAbl( ABL_CAR( Expr ) ); + + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "AX[\n" ); + MochaCheckViewBddNode( BddNode ); + fprintf( stdout, "]\n" ); + } + BddNode = applybddnodenot( (bddsystem *)0, decbddrefext( BddNode ) ); BddResult = MochaCheckCtlBddEX( BddNode ); decbddrefext( BddNode ); @@ -691,6 +912,13 @@ static bddnode *MochaCheckCtlAblAX( Expr ) BddResult = applybddnode( (bddsystem *)0, ABL_AND, decbddrefext( BddResult ), BddReached ); + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddResult ); + fprintf( stdout, "\n" ); + } + return( BddResult ); } @@ -719,6 +947,15 @@ static bddnode *MochaCheckCtlAblAU( Expr ) Expr = ABL_CDR( Expr ); BddNode2 = MochaCheckCtlAbl( ABL_CAR( Expr ) ); + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "AU[\n" ); + MochaCheckViewBddNode( BddNode1 ); + fprintf( stdout, ",\n" ); + MochaCheckViewBddNode( BddNode2 ); + fprintf( stdout, "]\n" ); + } + BddNode1 = applybddnodenot( (bddsystem *)0, decbddrefext( BddNode1 ) ); BddNode2 = applybddnodenot( (bddsystem *)0, decbddrefext( BddNode2 ) ); @@ -743,6 +980,13 @@ static bddnode *MochaCheckCtlAblAU( Expr ) BddResult = applybddnode( (bddsystem *)0, ABL_AND, decbddrefext( BddResult ), BddReached ); + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddResult ); + fprintf( stdout, "\n" ); + } + return( BddResult ); } @@ -764,9 +1008,24 @@ static bddnode *MochaCheckCtlAblEF( Expr ) Expr = ABL_CDR( Expr ); BddNode = MochaCheckCtlAbl( ABL_CAR( Expr ) ); + + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "EF[\n" ); + MochaCheckViewBddNode( BddNode ); + fprintf( stdout, "]\n" ); + } + BddResult = MochaCheckCtlBddEU( BddLocalSystem->ONE, BddNode ); decbddrefext( BddNode ); + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddResult ); + fprintf( stdout, "\n" ); + } + return( BddResult ); } @@ -786,9 +1045,24 @@ static bddnode *MochaCheckCtlAblEX( Expr ) Expr = ABL_CDR( Expr ); BddNode = MochaCheckCtlAbl( ABL_CAR( Expr ) ); + + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "EX[\n" ); + MochaCheckViewBddNode( BddNode ); + fprintf( stdout, "]\n" ); + } + BddResult = MochaCheckCtlBddEX( BddNode ); decbddrefext( BddNode ); + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddResult ); + fprintf( stdout, "\n" ); + } + return( BddResult ); } @@ -805,17 +1079,27 @@ static bddnode *MochaCheckCtlAblEG( Expr ) bddnode *BddNode; bddnode *BddResult; -# ifdef DEBUG - fprintf( stdout, "MochaCheckCtlAblEG: " ); - viewablexprln( Expr, ABL_VIEW_VHDL ); -# endif - Expr = ABL_CDR( Expr ); BddNode = MochaCheckCtlAbl( ABL_CAR( Expr ) ); + + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "EG[\n" ); + MochaCheckViewBddNode( BddNode ); + fprintf( stdout, "]\n" ); + } + BddResult = MochaCheckCtlBddEG( BddNode ); decbddrefext( BddNode ); + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddResult ); + fprintf( stdout, "\n" ); + } + return( BddResult ); } @@ -838,11 +1122,27 @@ static bddnode *MochaCheckCtlAblEU( Expr ) Expr = ABL_CDR( Expr ); BddNode2 = MochaCheckCtlAbl( ABL_CAR( Expr ) ); + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "EU[\n" ); + MochaCheckViewBddNode( BddNode1 ); + fprintf( stdout, ",\n" ); + MochaCheckViewBddNode( BddNode2 ); + fprintf( stdout, "]\n" ); + } + BddResult = MochaCheckCtlBddEU( BddNode1, BddNode2 ); decbddrefext( BddNode1 ); decbddrefext( BddNode2 ); + if ( MochaMochaFigure->DEBUG ) + { + fprintf( stdout, "-> " ); + MochaCheckViewBddNode( BddResult ); + fprintf( stdout, "\n" ); + } + return( BddResult ); } @@ -971,42 +1271,16 @@ static void MochaCheckCtlFormulae( MochaFigure, FlagVerbose ) CtlForm != (ctlform_list *)0; CtlForm = CtlForm->NEXT ) { - if ( FlagVerbose ) - { - fprintf( stdout, "\t Verifying formula %s\n", CtlForm->NAME ); - } + fprintf( stdout, "\t Checking formula %s\n", CtlForm->NAME ); BiAblArray = MOCHA_CTL_BIABLA( CtlForm ); AblArray = BiAblArray->EXPR; BddNode = MochaCheckCtlAbl( AblArray->ARRAY[ 0 ] ); - BddNode = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNode ), BddAssume ); - BddNode = existbddnodemissassoc( (bddsystem *)0, - decbddrefext( BddNode ), BddAssoc ); - - BddNode = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNode ), BddReached ); - - BddNode = applybddnode( (bddsystem *)0, ABL_AND, - decbddrefext( BddNode ), BddFirst ); - - decbddrefext( BddNode ); - -# ifdef DEBUG - MochaCheckViewBddNode( BddNode ); -# endif - - if ( BddNode != BddFirst ) + if ( ! MochaCheckViewState( MochaFigure, BddNode ) ) { - fprintf( stdout, "\t Formula %s IS FALSE !\n", CtlForm->NAME ); - MochaCheckViewBddNode( BddNode ); - } - else - if ( FlagVerbose ) - { - fprintf( stdout, "\t OK\n" ); + fprintf( stdout, "\t Not verified for the first state !\n" ); } } } diff --git a/alliance/src/mocha/src/mocha_fsm.c b/alliance/src/mocha/src/mocha_fsm.c index 4de148e1..caadfeab 100644 --- a/alliance/src/mocha/src/mocha_fsm.c +++ b/alliance/src/mocha/src/mocha_fsm.c @@ -110,8 +110,8 @@ void MochaCompileFsm( MochaFigure, FileName, FlagVerbose ) ScanChain != (chain_list *)0; ScanChain = ScanChain->NEXT ) { - FsmFigure = (fsmfig_list *)ScanChain->DATA; - MochaSyfFsmSimplify( FsmFigure ); + ScanFigure = (fsmfig_list *)ScanChain->DATA; + MochaSyfFsmSimplify( ScanFigure ); } if ( FlagVerbose ) diff --git a/alliance/src/mocha/src/mocha_main.c b/alliance/src/mocha/src/mocha_main.c index a9fc647e..ca8bea3f 100644 --- a/alliance/src/mocha/src/mocha_main.c +++ b/alliance/src/mocha/src/mocha_main.c @@ -97,7 +97,7 @@ void MochaUsage() { - fprintf( stderr, "\t\tmocha [Options] fsm_filename ctl_filename\n\n" ); + fprintf( stderr, "\t\tmoka [Options] fsm_filename ctl_filename\n\n" ); fprintf( stdout, "\t\tOptions : -V Sets Verbose mode on\n" ); fprintf( stdout, "\t\t -D Sets Debug mode on\n" ); @@ -128,8 +128,8 @@ int main( argc, argv ) int FlagDebug = 0; int FlagFsm = 1; - alliancebanner_with_authors( "MoChA", - VERSION, "Model Checker Ancestor", "2002", + alliancebanner_with_authors( "MoKA", + VERSION, "MOdel checKer Ancestor", "2002", ALLIANCE_VERSION, "Ludovic Jacomme" ); mbkenv(); @@ -179,6 +179,7 @@ int main( argc, argv ) ( CtlFileName == (char *)0 ) ) MochaUsage(); MochaFigure = MochaAddFigure( DescFileName ); + MochaFigure->DEBUG = FlagDebug; if ( FlagFsm ) { diff --git a/alliance/src/mocha/src/mocha_shared.h b/alliance/src/mocha/src/mocha_shared.h index 942242f8..aad238ab 100644 --- a/alliance/src/mocha/src/mocha_shared.h +++ b/alliance/src/mocha/src/mocha_shared.h @@ -64,6 +64,7 @@ { struct mochastate_list *NEXT; char *NAME; + bddnode *BDD_STATE; long CODE; } mochastate_list; @@ -104,6 +105,7 @@ bddnode *BDD_FIRST_STATE; bddnode *BDD_ASSUME; bddnode *BDD_REACHED_STATE; + short DEBUG; } mochafig_list; diff --git a/alliance/src/mocha/src/mocha_syf.c b/alliance/src/mocha/src/mocha_syf.c index 9938e7f6..3138e756 100644 --- a/alliance/src/mocha/src/mocha_syf.c +++ b/alliance/src/mocha/src/mocha_syf.c @@ -501,9 +501,6 @@ void MochaSyfFsmEncode( FsmFigure, FlagVerbose ) CodeArray[ NumberState - Index - 1 ].USED = 1; - fprintf( stdout, "ScanState %s Code %ld\n", - ScanState->NAME, CodeArray[ NumberState - Index - 1 ].VALUE ); - ScanState = ScanState->NEXT; Index = Index + 1; } @@ -1237,19 +1234,16 @@ void MochaSyfFsmTreatOutput( FsmFigure, FbhFigure ) { mochasyfinfo *MochaSyfInfo; fsmout_list *ScanOut; + fbaux_list *ScanAux; mochasyfout *ScanSyfOut; mochasyfregout *OutArray; fbout_list *FbhOut; - fbrin_list *FbhRin; - fbreg_list *FbhReg; ablexpr *AblExpr; MochaSyfInfo = MOCHA_SYF_INFO( FsmFigure ); OutArray = MochaSyfInfo->OUT_ARRAY; - FbhOut = FbhFigure->BEOUT; - FbhRin = FbhFigure->BERIN; - FbhReg = FbhFigure->BEREG; + FbhOut = FbhFigure->BEOUT; for ( ScanOut = FsmFigure->OUT; ScanOut != (fsmout_list *)0; @@ -1260,11 +1254,25 @@ void MochaSyfFsmTreatOutput( FsmFigure, FbhFigure ) if ( ScanSyfOut->ABL != (chain_list *)0 ) { AblExpr = dupablexpr( ScanSyfOut->ABL ); - FbhOut = fbh_addfbout( FbhOut, ScanOut->NAME, AblExpr, (bddnode *)0, 0 ); + + for ( ScanAux = FbhFigure->BEAUX; + ScanAux != (fbaux_list *)0; + ScanAux = ScanAux->NEXT ) + { + if ( ScanAux->NAME == ScanOut->NAME ) break; + } + + if ( ScanAux == (fbaux_list *)0 ) + { + FbhOut = fbh_addfbout( FbhOut, ScanOut->NAME, AblExpr, (bddnode *)0, 0 ); + } + else + { + ScanAux->ABL = AblExpr; + } } } - FbhFigure->BERIN = FbhRin; FbhFigure->BEOUT = FbhOut; }