- Timestamp:
- Jan 3, 2012, 11:12:40 AM (13 years ago)
- Location:
- vis_dev/vis-2.3/src/debug
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
vis_dev/vis-2.3/src/debug/debug.c
r30 r35 7 7 Synopsis [Debug package initialization, ending, and the command debug] 8 8 9 Author [ Originated from SIS.]9 Author [Cecile B.] 10 10 11 11 Copyright [Copyright (c) 1994-1996 The Regents of the Univ. of California. … … 61 61 /*---------------------------------------------------------------------------*/ 62 62 63 static int CommandSatDebug(Hrc_Manager_t ** hmgr, int argc, char ** argv); 63 64 static int CommandDebug(Hrc_Manager_t ** hmgr, int argc, char ** argv); 64 65 static int CommandTransition(Hrc_Manager_t ** hmgr,int argc, char ** argv); 66 static int CommandCreateAbnormal(Hrc_Manager_t ** hmgr,int argc, char ** argv); 65 67 66 68 … … 88 90 * underscore, the command will be listed under "help -a" but not "help". 89 91 */ 90 Cmd_CommandAdd("_debug_test", CommandDebug, /* doesn't changes_network */ 0); 91 Cmd_CommandAdd("_transition", CommandTransition, 0); 92 Cmd_CommandAdd("_debug_test", CommandDebug, /* doesn't changes_network */ 0); 93 Cmd_CommandAdd("_transition", CommandTransition, 1); 94 Cmd_CommandAdd("_sat_debug", CommandSatDebug, 0); 95 Cmd_CommandAdd("_createAbn", CommandCreateAbnormal, 1); 92 96 93 97 } … … 122 126 /*---------------------------------------------------------------------------*/ 123 127 128 129 static int CommandCreateAbnormal(Hrc_Manager_t ** hmgr,int argc, char ** argv) 130 { 131 Ntk_Network_t * ntk; 132 ntk = Ntk_HrcManagerReadCurrentNetwork(*hmgr); 133 if (ntk == NIL(Ntk_Network_t)) { 134 (void) fprintf(vis_stdout, "** abn error: No network\n"); 135 return 1; 136 } 137 lsGen gen; 138 Ntk_Node_t* node; 139 140 (void) fprintf(vis_stdout, "** NODE **\n"); 141 Ntk_NetworkForEachNode(ntk,gen,node){ 142 if(Ntk_NodeTestIsCombinational(node)){ 143 if(Ntk_NodeReadNumFanins(node) > 1 && Ntk_NodeReadNumFanouts(node)> 0) 144 { 145 if(strcmp(Ntk_NodeReadName(node),"_n2")==0) 146 { 147 char * nodeName = util_strsav(Ntk_NodeReadName(node)); 148 printf("%s \n", nodeName); 149 (void) fprintf(vis_stdout, "** read table\n"); 150 Tbl_Table_t *table = Ntk_NodeReadTable(node); 151 152 Tbl_TableWriteBlifMvToFile(table,2,vis_stdout); 153 // Build new variables abnormal and input 154 //abn 155 char * abnName = (char *) malloc(strlen(nodeName) + 5); 156 sprintf(abnName,"abn_%s",Ntk_NodeReadName(node)); 157 Var_Variable_t * abn = Var_VariableAlloc(NIL(Hrc_Node_t),abnName); 158 Ntk_Node_t * newNode = Ntk_NodeCreateInNetwork(ntk, abnName,abn); 159 Ntk_NodeDeclareAsPrimaryInput(newNode); 160 //new free inputs 161 char * iName = (char *) malloc(strlen(nodeName) + 3); 162 sprintf(iName,"i_%s",Ntk_NodeReadName(node)); 163 Var_Variable_t * i = Var_VariableAlloc(NIL(Hrc_Node_t),iName); 164 Ntk_Node_t * newNode2 = Ntk_NodeCreateInNetwork(ntk, iName, i); 165 Ntk_NodeDeclareAsPrimaryInput(newNode2); 166 //Add in the table 167 Tbl_TableAddColumn(table,abn,0); 168 int abnIndex = Tbl_TableReadVarIndex(table, abn, 0); 169 Tbl_TableAddColumn(table,i,0); 170 int iIndex = Tbl_TableReadVarIndex(table, i, 0); 171 172 //For each row already there in the table 173 int rowNum; 174 for(rowNum = 0; rowNum < Tbl_TableReadNumRows(table);rowNum++){ 175 Tbl_Entry_t *abnEntry = Tbl_EntryAlloc(Tbl_EntryNormal_c); 176 Tbl_EntrySetValue(abnEntry,0,0); 177 Tbl_TableSetEntry(table, abnEntry, rowNum, abnIndex, 0); 178 Tbl_Entry_t *iEntry = Tbl_EntryAlloc(Tbl_EntryNormal_c); 179 Tbl_EntrySetValue(iEntry,0,1); 180 Tbl_TableSetEntry(table, iEntry, rowNum, iIndex, 0); 181 } 182 //the new row 183 int r = Tbl_TableAddRow(table); 184 185 int colNum; 186 for (colNum = 0; colNum < Tbl_TableReadNumInputs(table); colNum++) { 187 Tbl_Entry_t * entry = Tbl_EntryAlloc(Tbl_EntryNormal_c); 188 printf("entry : colNum %d \n",colNum); 189 if(colNum == abnIndex || colNum == iIndex) 190 Tbl_EntrySetValue(entry,1,1); 191 else 192 Tbl_EntrySetValue(entry,0,1); 193 Tbl_TableSetEntry(table, entry, r, colNum, 0); 194 } 195 for (colNum = 0; colNum < Tbl_TableReadNumOutputs(table); colNum++){ 196 Tbl_Entry_t * entry = Tbl_EntryAlloc(Tbl_EntryNormal_c); 197 Tbl_EntrySetValue(entry,1,1); 198 Tbl_TableSetEntry(table, entry, r, colNum, 1); 199 } 200 printf("---------------\n"); 201 Tbl_TablePrintStats(table, vis_stdout); 202 Tbl_TableWriteBlifMvToFile(table,0,vis_stdout); 203 free(abnName); 204 free(iName); 205 } 206 } 207 } 208 } 209 // TODO 210 //Remplacer l'ancien network par le nouveau 211 } 212 /**Function******************************************************************** 213 214 Synopsis [Implements the _sat_debug command.] 215 216 CommandName [_sat_debug] 217 218 CommandSynopsis [locate faulty candidates] 219 220 CommandArguments [\[-h\] \[-v\]] 221 222 CommandDescription [This command compute the fault candidates of a given 223 properties.<p> 224 225 Command options:<p> 226 227 <dl> 228 <dt> -h 229 <dd> Print the command usage. 230 </dl> 231 232 <dt> -v 233 <dd> Verbose mode. 234 </dl> 235 ] 236 237 SideEffects [] 238 239 ******************************************************************************/ 240 241 242 static int 243 CommandSatDebug( 244 Hrc_Manager_t ** hmgr, 245 int argc, 246 char ** argv){ 247 int c,i; 248 int verbose = 0; /* default value */ 249 BmcOption_t *options = BmcOptionAlloc(); 250 Ntk_Network_t * network; 251 bAig_Manager_t *manager; 252 253 254 /* 255 * Parse command line options. 256 */ 257 util_getopt_reset(); 258 while ((c = util_getopt(argc, argv, "vh:m:k:o:")) != EOF) { 259 switch(c) { 260 case 'v': 261 verbose = 1; 262 options->verbosityLevel = verbose; 263 break; 264 case 'h': 265 goto usage; 266 case 'm': 267 for (i = 0; i < strlen(util_optarg); i++) { 268 if (!isdigit((int)util_optarg[i])) { 269 goto usage; 270 } 271 } 272 options->minK = atoi(util_optarg); 273 break; 274 case 'k': 275 for (i = 0; i < strlen(util_optarg); i++) { 276 if (!isdigit((int)util_optarg[i])) { 277 goto usage; 278 } 279 } 280 options->maxK = atoi(util_optarg); 281 break; 282 case 'o': 283 options->cnfFileName = util_strsav(util_optarg); 284 break; 285 286 default: 287 goto usage; 288 } 289 } 290 if (options->minK > options->maxK){ 291 (void) fprintf(vis_stderr, "** bmc error: value for -m option must not be greater than vlaue for -k option\n"); 292 goto usage; 293 } 294 295 if (verbose) { 296 (void) fprintf(vis_stdout, "The _sat_debug command is under construction.\n"); 297 } 298 /* create SAT Solver input file */ 299 if (options->cnfFileName == NIL(char)) { 300 options->satInFile = BmcCreateTmpFile(); 301 } 302 else { 303 options->satInFile = options->cnfFileName; 304 } 305 306 /* create SAT Solver output file */ 307 options->satOutFile = BmcCreateTmpFile(); 308 if (options->satOutFile == NIL(char)){ 309 BmcOptionFree(options); 310 (void) fprintf(vis_stdout, "The _sat_debug problem.\n"); 311 return 1; 312 } 313 314 options->verbosityLevel = 1; 315 //options->satSolver 316 //options->clauses 317 318 /* 319 * Read the network 320 */ 321 network = Ntk_HrcManagerReadCurrentNetwork(*hmgr); 322 if (network == NIL(Ntk_Network_t)) { 323 (void) fprintf(vis_stdout, "** bmc error: No network\n"); 324 BmcOptionFree(options); 325 return 1; 326 } 327 manager = Ntk_NetworkReadMAigManager(network); 328 if (manager == NIL(mAig_Manager_t)) { 329 (void) fprintf(vis_stdout, "** bmc error: run build_partition_maigs command first\n"); 330 BmcOptionFree(options); 331 return 1; 332 } 333 /* 334 We need the bdd when building the transition relation of the automaton 335 */ 336 if(options->inductiveStep !=0){ 337 Fsm_Fsm_t *designFsm = NIL(Fsm_Fsm_t); 338 339 designFsm = Fsm_HrcManagerReadCurrentFsm(*hmgr); 340 if (designFsm == NIL(Fsm_Fsm_t)) { 341 (void) fprintf(vis_stdout, "The _sat_debug : Build FSM.\n"); 342 return 1; 343 } 344 } 345 346 /* 347 Compute the cone of influence 348 here a list of state variables (latches) 349 */ 350 st_table *CoiTable = generateAllLatches(network); 351 /* 352 Generate clauses for each time frame. This is the old way of generating 353 clauses in BMC. 354 */ 355 st_table *nodeToMvfAigTable = NIL(st_table); /* node to mvfAig */ 356 BmcCnfClauses_t *cnfClauses = NIL(BmcCnfClauses_t); 357 FILE *cnfFile = Cmd_FileOpen(options->satInFile, "w", NIL(char *), 0); 358 /* 359 nodeToMvfAigTable maps each node to its multi-function And/Inv graph 360 */ 361 nodeToMvfAigTable = 362 (st_table *) Ntk_NetworkReadApplInfo(network, MVFAIG_NETWORK_APPL_KEY); 363 assert(nodeToMvfAigTable != NIL(st_table)); 364 365 if(verbose) 366 { 367 (void) fprintf(vis_stdout, "------ node to mvfaig ----\n"); 368 printLatch(nodeToMvfAigTable); 369 (void) fprintf(vis_stdout, "------ COI ----\n"); 370 printLatch(CoiTable); 371 (void) fprintf(vis_stdout, "--------------------------\n"); 372 } 373 /* 374 Create a clause database 375 */ 376 cnfClauses = BmcCnfClausesAlloc(); 377 /* 378 Generate clauses for an initialized path of length k 379 */ 380 BmcCnfGenerateClausesForPath(network, 0, options->maxK, BMC_INITIAL_STATES, 381 cnfClauses, nodeToMvfAigTable, CoiTable); 382 if(verbose) 383 (void) fprintf(vis_stdout, "The _sat_debug generates %d clauses with %d\ 384 latches %d nodetomvf.\n",cnfClauses->noOfClauses,st_count(CoiTable),st_count(nodeToMvfAigTable)); 385 386 387 BmcWriteClauses(manager, cnfFile, cnfClauses, options); 388 fclose(cnfFile); 389 BmcCnfClausesFree(cnfClauses); 390 BmcOptionFree(options); 391 return 0; 392 usage: 393 (void) fprintf(vis_stderr, "usage: _sat_debug [-h] [-v] [-k max length] [-m \ 394 minimum length] [-o cnf_file]\n"); 395 (void) fprintf(vis_stderr, " -h\t\tprint the command usage\n"); 396 (void) fprintf(vis_stderr, " -v\t\tverbose\n"); 397 (void) fprintf(vis_stderr, " -m \tminimum length of counterexample to be checked (default is 0)\n"); 398 (void) fprintf(vis_stderr, " -k \tmaximum length of counterexample to be checked (default is 1)\n"); 399 (void) fprintf(vis_stderr, " -o <cnf_file> contains CNF of the counterexample\n"); 400 return 1; /* error exit */ 401 402 } 124 403 /**Function******************************************************************** 125 404 -
vis_dev/vis-2.3/src/debug/debug.h
r27 r35 83 83 /*---------------------------------------------------------------------------*/ 84 84 85 85 void printLatch(st_table* CoiTable); 86 st_table * generateAllLatches(Ntk_Network_t * ntk); 86 87 void mdd_GetState_Values(mdd_manager *mgr, mdd_t * top, FILE * f); 87 88 EXTERN void Debug_Init(void); -
vis_dev/vis-2.3/src/debug/debug.make
r27 r35 1 CSRC += debug.c 1 CSRC += debug.c debugUtilities.c 2 2 HEADERS += debug.h debugInt.h 3 3 -
vis_dev/vis-2.3/src/debug/debugUtilities.c
r30 r35 1 #include "Debug.h" 1 #include "debug.h" 2 void printLatch(st_table* CoiTable) 3 { 4 // COI contents 5 printf("*** COI ***\n"); 6 st_generator *stGen; 7 Ntk_Node_t * latch; 8 st_foreach_item(CoiTable, stGen, &latch, NULL) { 9 printf("%s\n",Ntk_NodeReadName(latch)); 10 } 11 } 12 13 14 st_table * generateAllLatches(Ntk_Network_t * ntk) 15 { 16 st_table *CoiTable = st_init_table(st_ptrcmp, st_ptrhash); 17 lsGen gen ; 18 Ntk_Node_t *node; 19 20 Ntk_NetworkForEachNode(ntk,gen, node){ 21 if (Ntk_NodeTestIsLatch(node)){ 22 st_insert(CoiTable, (char *) node, Ntk_NodeReadName(node)); 23 } 24 } 25 return CoiTable; 26 27 } 28 2 29 3 30 void mdd_GetState_Values(
Note: See TracChangeset
for help on using the changeset viewer.