diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2014-03-23 11:00:26 -0700 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2014-03-23 11:00:26 -0700 |
commit | c26f7cf331fb22dd8447109ba384358fb73ed148 (patch) | |
tree | bc598f534ae3a9fbe69b722cb027365527304f49 /src | |
parent | b13e65882de94db9f28b9819d9e3a184ee507f07 (diff) | |
download | abc-c26f7cf331fb22dd8447109ba384358fb73ed148.tar.gz abc-c26f7cf331fb22dd8447109ba384358fb73ed148.tar.bz2 abc-c26f7cf331fb22dd8447109ba384358fb73ed148.zip |
Experiments with mapping.
Diffstat (limited to 'src')
-rw-r--r-- | src/aig/gia/gia.h | 1 | ||||
-rw-r--r-- | src/aig/gia/giaKf.c | 33 | ||||
-rw-r--r-- | src/base/abci/abc.c | 28 |
3 files changed, 32 insertions, 30 deletions
diff --git a/src/aig/gia/gia.h b/src/aig/gia/gia.h index 13bed64b..0fb41153 100644 --- a/src/aig/gia/gia.h +++ b/src/aig/gia/gia.h @@ -246,6 +246,7 @@ struct Jf_Par_t_ { int nLutSize; int nCutNum; + int nProcNum; int nRounds; int nVerbLimit; int DelayTarget; diff --git a/src/aig/gia/giaKf.c b/src/aig/gia/giaKf.c index 34ee5eb7..f071bb72 100644 --- a/src/aig/gia/giaKf.c +++ b/src/aig/gia/giaKf.c @@ -38,11 +38,11 @@ ABC_NAMESPACE_IMPL_START /// DECLARATIONS /// //////////////////////////////////////////////////////////////////////// -#define KF_PROC_MAX 8 -#define KF_LEAF_MAX 8 +#define KF_LEAF_MAX 16 +#define KF_CUT_MAX 32 +#define KF_PROC_MAX 32 #define KF_WORD_MAX ((KF_LEAF_MAX > 6) ? 1 << (KF_LEAF_MAX-6) : 1) #define KF_LOG_TABLE 8 -#define KF_NUM_MAX 16 #define KF_ADD_ON1 2 // offset in cut storage for each node (cut count; best cut) #define KF_ADD_ON2 4 // offset in cut storage for each cut (leaf count; function, cut delay; cut area) @@ -76,10 +76,10 @@ struct Kf_Set_t_ int pValue[1 << KF_LOG_TABLE]; int pPlace[KF_LEAF_MAX]; int pList [KF_LEAF_MAX+1]; - Kf_Cut_t pCuts0[KF_NUM_MAX]; - Kf_Cut_t pCuts1[KF_NUM_MAX]; - Kf_Cut_t pCutsR[KF_NUM_MAX*KF_NUM_MAX]; - Kf_Cut_t * ppCuts[KF_NUM_MAX]; + Kf_Cut_t pCuts0[KF_CUT_MAX]; + Kf_Cut_t pCuts1[KF_CUT_MAX]; + Kf_Cut_t pCutsR[KF_CUT_MAX*KF_CUT_MAX]; + Kf_Cut_t * ppCuts[KF_CUT_MAX]; Kf_Cut_t * pCutBest; word CutCount[4]; // statistics }; @@ -196,7 +196,7 @@ static inline void Kf_ManStoreAddUnit( Vec_Int_t * vTemp, int iObj, int Time, fl static inline void Kf_ManSaveResults( Kf_Cut_t ** ppCuts, int nCuts, Kf_Cut_t * pCutBest, Vec_Int_t * vTemp ) { int i, k; - assert( nCuts > 0 && nCuts < KF_NUM_MAX ); + assert( nCuts > 0 && nCuts < KF_CUT_MAX ); Kf_ManStoreStart( vTemp, nCuts ); for ( i = 0; i < nCuts; i++ ) { @@ -823,7 +823,7 @@ void Kf_ManComputeCuts( Kf_Man_t * p ) Kf_ThData_t ThData[PAR_THR_MAX]; Vec_Int_t * vStack, * vFanins; Gia_Obj_t * pObj; - int nProcs = p->pPars->nProcNumMax; + int nProcs = p->pPars->nProcNum; int i, k, iFan, status, nCountFanins, fRunning; abctime clk, clkUsed = 0; assert( nProcs <= PAR_THR_MAX ); @@ -964,7 +964,7 @@ void Kf_ManComputeMapping( Kf_Man_t * p ) assert( Vec_IntSize(p->vTemp) == 1 + KF_ADD_ON1 + KF_ADD_ON2 ); Kf_ObjSetCuts( p, i, p->vTemp ); } - if ( p->pPars->nProcNumMax > 0 ) + if ( p->pPars->nProcNum > 0 ) Kf_ManComputeCuts( p ); else { @@ -1037,9 +1037,9 @@ void Kf_ManSetInitRefs( Gia_Man_t * p, Vec_Flt_t * vRefs ) Kf_Man_t * Kf_ManAlloc( Gia_Man_t * pGia, Jf_Par_t * pPars ) { Kf_Man_t * p; int i; - assert( pPars->nLutSizeMax <= KF_LEAF_MAX ); - assert( pPars->nCutNumMax <= KF_NUM_MAX ); - assert( pPars->nProcNumMax <= KF_PROC_MAX ); + assert( pPars->nLutSize <= KF_LEAF_MAX ); + assert( pPars->nCutNum <= KF_CUT_MAX ); + assert( pPars->nProcNum <= KF_PROC_MAX ); Vec_IntFreeP( &pGia->vMapping ); p = ABC_CALLOC( Kf_Man_t, 1 ); p->clkStart = Abc_Clock(); @@ -1053,7 +1053,7 @@ Kf_Man_t * Kf_ManAlloc( Gia_Man_t * pGia, Jf_Par_t * pPars ) p->vTemp = Vec_IntAlloc( 1000 ); pGia->pRefs = ABC_CALLOC( int, Gia_ManObjNum(pGia) ); // prepare cut sets - for ( i = 0; i < Abc_MaxInt(1, pPars->nProcNumMax); i++ ) + for ( i = 0; i < Abc_MaxInt(1, pPars->nProcNum); i++ ) { (p->pSett + i)->pMan = p; (p->pSett + i)->nLutSize = (unsigned short)pPars->nLutSize; @@ -1114,6 +1114,7 @@ void Kf_ManSetDefaultPars( Jf_Par_t * pPars ) memset( pPars, 0, sizeof(Jf_Par_t) ); pPars->nLutSize = 6; pPars->nCutNum = 8; + pPars->nProcNum = 0; pPars->nRounds = 1; pPars->nVerbLimit = 5; pPars->DelayTarget = -1; @@ -1128,8 +1129,8 @@ void Kf_ManSetDefaultPars( Jf_Par_t * pPars ) pPars->fVerbose = 0; pPars->fVeryVerbose = 0; pPars->nLutSizeMax = KF_LEAF_MAX; - pPars->nCutNumMax = KF_NUM_MAX; - pPars->nProcNumMax = 0; + pPars->nCutNumMax = KF_CUT_MAX; + pPars->nProcNumMax = KF_PROC_MAX; } Gia_Man_t * Kf_ManPerformMapping( Gia_Man_t * pGia, Jf_Par_t * pPars ) { diff --git a/src/base/abci/abc.c b/src/base/abci/abc.c index c01757b1..98bdb647 100644 --- a/src/base/abci/abc.c +++ b/src/base/abci/abc.c @@ -30369,7 +30369,7 @@ int Abc_CommandAbc9Kf( Abc_Frame_t * pAbc, int argc, char ** argv ) Gia_Man_t * pNew; int c; Kf_ManSetDefaultPars( pPars ); Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "KCRDWPaekmdcgtvwh" ) ) != EOF ) + while ( ( c = Extra_UtilGetopt( argc, argv, "KCPRDWaekmdcgtvwh" ) ) != EOF ) { switch ( c ) { @@ -30401,6 +30401,17 @@ int Abc_CommandAbc9Kf( Abc_Frame_t * pAbc, int argc, char ** argv ) goto usage; } break; + case 'P': + if ( globalUtilOptind >= argc ) + { + Abc_Print( -1, "Command line switch \"-P\" should be followed by a positive integer.\n" ); + goto usage; + } + pPars->nProcNumMax = atoi(argv[globalUtilOptind]); + globalUtilOptind++; + if ( pPars->nProcNumMax < 0 ) + goto usage; + break; case 'R': if ( globalUtilOptind >= argc ) { @@ -30434,17 +30445,6 @@ int Abc_CommandAbc9Kf( Abc_Frame_t * pAbc, int argc, char ** argv ) if ( pPars->nVerbLimit < 0 ) goto usage; break; - case 'P': - if ( globalUtilOptind >= argc ) - { - Abc_Print( -1, "Command line switch \"-P\" should be followed by a positive integer.\n" ); - goto usage; - } - pPars->nProcNumMax = atoi(argv[globalUtilOptind]); - globalUtilOptind++; - if ( pPars->nProcNumMax < 0 ) - goto usage; - break; case 'a': pPars->fAreaOnly ^= 1; break; @@ -30501,14 +30501,14 @@ usage: sprintf(Buffer, "best possible" ); else sprintf(Buffer, "%d", pPars->DelayTarget ); - Abc_Print( -2, "usage: &kf [-KCRDWP num] [-akmdcgtvwh]\n" ); + Abc_Print( -2, "usage: &kf [-KCPRDW num] [-akmdcgtvwh]\n" ); Abc_Print( -2, "\t performs technology mapping of the network\n" ); Abc_Print( -2, "\t-K num : LUT size for the mapping (2 <= K <= %d) [default = %d]\n", pPars->nLutSizeMax, pPars->nLutSize ); Abc_Print( -2, "\t-C num : the max number of priority cuts (1 <= C <= %d) [default = %d]\n", pPars->nCutNumMax, pPars->nCutNum ); + Abc_Print( -2, "\t-P num : the number of cut computation processes (0 <= P <= %d) [default = %d]\n", pPars->nProcNumMax, pPars->nProcNum ); Abc_Print( -2, "\t-R num : the number of mapping rounds [default = %d]\n", pPars->nRounds ); Abc_Print( -2, "\t-D num : sets the delay constraint for the mapping [default = %s]\n", Buffer ); Abc_Print( -2, "\t-W num : min frequency when printing functions with \"-w\" [default = %d]\n", pPars->nVerbLimit ); - Abc_Print( -2, "\t-P num : the number of cut computation processes [default = %d]\n", pPars->nProcNumMax ); Abc_Print( -2, "\t-a : toggles area-oriented mapping [default = %s]\n", pPars->fAreaOnly? "yes": "no" ); Abc_Print( -2, "\t-e : toggles edge vs node minimization [default = %s]\n", pPars->fOptEdge? "yes": "no" ); Abc_Print( -2, "\t-k : toggles coarsening the subject graph [default = %s]\n", pPars->fCoarsen? "yes": "no" ); |