- Timestamp:
- May 15, 2008, 9:23:42 PM (17 years ago)
- Location:
- trunk/IPs/systemC/processor/Morpheo
- Files:
-
- 2 added
- 22 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/SelfTest/config_mono_context.cfg
r81 r87 1 1 Decod 2 2 1 1 *4 # nb_context 3 1 4*4 # nb_inst_fetch [0] [nb_context]4 1 4 *4 # nb_inst_decod3 4 16 *4 # nb_inst_fetch [0] [nb_context] 4 1 4 *4 # nb_inst_decod 5 5 1 1 *2 # nb_branch_speculated 6 1 1 *2# size_branch_update_prediction6 0 2 +1 # size_branch_update_prediction 7 7 1 1 *2 # nb_context_select 8 8 32 32 *2 # size_general_data -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/SelfTest/config_multi_context.cfg
r81 r87 5 5 4 4 *4 # nb_inst_fetch [2] [nb_context] 6 6 8 8 *4 # nb_inst_fetch [3] [nb_context] 7 1 16 *4# nb_inst_decod7 1 8 *2 # nb_inst_decod 8 8 1 1 *2 # nb_branch_speculated 9 1 1*2 # size_branch_update_prediction9 2 2 *2 # size_branch_update_prediction 10 10 1 4 *2 # nb_context_select 11 11 32 32 *2 # size_general_data -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/SelfTest/src/main.cpp
r86 r87 81 81 _instruction_implemeted , 82 82 &(morpheo::behavioural::custom::example_get_custom_information) 83 );83 ); 84 84 85 85 msg(_("%s"),param->print(1).c_str()); -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/SelfTest/src/test.cpp
r86 r87 11 11 12 12 #include "Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/SelfTest/include/test.h" 13 #include "Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/SelfTest/include/Decod_request.h" 13 14 #include <list> 14 15 #include "Common/include/Test.h" 15 16 #include "Behavioural/include/Allocation.h" 16 17 class entry_t18 {19 //public : Tcontrol_t _val ;20 public : Tinstruction_t _instruction ;21 //public : Tcontext_t _context_id ;22 public : Tgeneral_address_t _address_previous ;23 public : Tgeneral_address_t _address ;24 public : Tgeneral_address_t _address_next ;25 public : Tbranch_state_t _branch_state ;26 public : Tprediction_ptr_t _branch_update_prediction_id;27 public : Tbranch_condition_t _branch_condition ;28 //public : Tcontrol_t _branch_stack_write ;29 public : Tcontrol_t _branch_direction ;30 public : Tgeneral_address_t _branch_address_dest ;31 public : Tdepth_t _depth ;32 public : Ttype_t _type ;33 public : Toperation_t _operation ;34 public : Tcontrol_t _is_delay_slot ;35 public : Tcontrol_t _has_immediat ;36 public : Tgeneral_data_t _immediat ;37 public : Tcontrol_t _read_ra ;38 public : Tgeneral_address_t _num_reg_ra ;39 public : Tcontrol_t _read_rb ;40 public : Tgeneral_address_t _num_reg_rb ;41 public : Tcontrol_t _read_rc ;42 public : Tspecial_address_t _num_reg_rc ;43 public : Tcontrol_t _write_rd ;44 public : Tgeneral_address_t _num_reg_rd ;45 public : Tcontrol_t _write_re ;46 public : Tspecial_address_t _num_reg_re ;47 public : Texception_t _exception_use ;48 public : Tevent_type_t _context_event_type ;49 50 public : entry_t (51 // Tcontrol_t val ,52 Tinstruction_t instruction ,53 // Tcontext_t context_id ,54 Tgeneral_address_t address_previous ,55 Tgeneral_address_t address ,56 Tgeneral_address_t address_next ,57 Tbranch_state_t branch_state ,58 Tprediction_ptr_t branch_update_prediction_id,59 Tbranch_condition_t branch_condition ,60 // Tcontrol_t branch_stack_write ,61 Tcontrol_t branch_direction ,62 Tgeneral_address_t branch_address_dest ,63 Tdepth_t depth ,64 Ttype_t type ,65 Toperation_t operation ,66 Tcontrol_t is_delay_slot ,67 Tcontrol_t has_immediat ,68 Tgeneral_data_t immediat ,69 Tcontrol_t read_ra ,70 Tgeneral_address_t num_reg_ra ,71 Tcontrol_t read_rb ,72 Tgeneral_address_t num_reg_rb ,73 Tcontrol_t read_rc ,74 Tspecial_address_t num_reg_rc ,75 Tcontrol_t write_rd ,76 Tgeneral_address_t num_reg_rd ,77 Tcontrol_t write_re ,78 Tspecial_address_t num_reg_re ,79 Texception_t exception_use ,80 Tevent_type_t context_event_type )81 {82 // _val = val ;83 _instruction = instruction ;84 // _context_id = context_id ;85 _address_previous = address_previous ;86 _address = address ;87 _address_next = address_next ;88 _branch_state = branch_state ;89 _branch_update_prediction_id = branch_update_prediction_id;90 _branch_condition = branch_condition ;91 // _branch_stack_write = branch_stack_write ;92 _branch_direction = branch_direction ;93 _branch_address_dest = branch_address_dest ;94 _depth = depth ;95 _type = type ;96 _operation = operation ;97 _is_delay_slot = is_delay_slot ;98 _has_immediat = has_immediat ;99 _immediat = immediat ;100 _read_ra = read_ra ;101 _num_reg_ra = num_reg_ra ;102 _read_rb = read_rb ;103 _num_reg_rb = num_reg_rb ;104 _read_rc = read_rc ;105 _num_reg_rc = num_reg_rc ;106 _write_rd = write_rd ;107 _num_reg_rd = num_reg_rd ;108 _write_re = write_re ;109 _num_reg_re = num_reg_re ;110 _exception_use = exception_use ;111 _context_event_type = context_event_type ;112 }113 };114 115 17 116 18 void test (string name, … … 296 198 LABEL("Iteration %d",iteration); 297 199 298 list<entry_t> request [_param->_nb_context]; 299 300 uint32_t w; 301 uint32_t x = (0x100>>2)-1; 302 uint32_t y = (0x100>>2); 303 uint32_t z = (0x100>>2)+1; 200 Decod_request request [_param->_nb_context]; 201 202 uint32_t nb_request = 0; 304 203 305 204 uint32_t delay_slot_previous [_param->_nb_context]; … … 307 206 uint32_t delay_slot_next [_param->_nb_context]; 308 207 309 #define SEQ do {x=y; y=z; z+=1; LABEL("%.8x - previous : 0x%x (%d), current : 0x%x (%d), next : 0x%x (%d)",request [0].back()._instruction, x,x,y,y,z,z);} while(0);310 #define JMP(j) do {x=y; y=z; z =j; LABEL("%.8x - previous : 0x%x (%d), current : 0x%x (%d), next : 0x%x (%d)",request [0].back()._instruction, x,x,y,y,z,z);} while(0);311 312 // ===== l.add r15, r4 , r8313 request [0].push_back (entry_t(314 //instruction,address_previous,address,address_next315 0xe1e44000,x,y,z,316 //branch_state,branch_update_prediction_id,branch_condition,branch_stack_write,branch_direction, branch_address_dest317 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0,0x0,318 //depth,type,operation,is_delay_slot319 0,TYPE_ALU,OPERATION_ALU_L_ADD,false,320 //has_immediat,immediat,read_ra,reg_ra,read_rb,reg_rb,read_rc,reg_rc,write_rd,reg_rd,write_re,reg_re321 0,0x00000000,1, 4,1, 8,0,0 ,1,15,1,SPR_LOGIC_SR_CY_OV,322 //exception_use,context_event_type323 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));324 SEQ;325 326 // ===== l.addc r15, r4 , r31327 request [0].push_back (entry_t(328 0xe1e4f801,x,y,z,329 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0,0x0,330 0,TYPE_ALU,OPERATION_ALU_L_ADD,false,331 0,0x00000000,1, 4,1,31,1,SPR_LOGIC_SR_CY_OV,1,15,1,SPR_LOGIC_SR_CY_OV,332 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));333 SEQ;334 335 // ===== l.addi r7 , r12, -1336 request [0].push_back (entry_t(337 0x9cecffff,x,y,z,338 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,339 0,TYPE_ALU,OPERATION_ALU_L_ADD,false,340 1,0xffffffff,1,12,0, 0,0,0 ,1,7 ,1,SPR_LOGIC_SR_CY_OV,341 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));342 SEQ;343 344 // ===== l.addi r8 , r17, 0345 request [0].push_back (entry_t(346 0x9d110000,x,y,z,347 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,348 0,TYPE_ALU,OPERATION_ALU_L_ADD,false,349 1,0x00000000,1,17,0, 0,0,0 ,1,8 ,1,SPR_LOGIC_SR_CY_OV,350 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));351 SEQ;352 353 // ===== l.addi r21, r7 , 1981354 request [0].push_back (entry_t(355 0x9ea707bd,x,y,z,356 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,357 0,TYPE_ALU,OPERATION_ALU_L_ADD,false,358 1,0x000007bd,1, 7,0, 0,0,0 ,1,21,1,SPR_LOGIC_SR_CY_OV,359 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));360 SEQ;361 362 // ===== l.addic r7 , r12, -1363 request [0].push_back (entry_t(364 0xa0ecffff,x,y,z,365 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,366 0,TYPE_ALU,OPERATION_ALU_L_ADD,false,367 1,0xffffffff,1,12,0, 0,1,SPR_LOGIC_SR_CY_OV,1,7 ,1,SPR_LOGIC_SR_CY_OV,368 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));369 SEQ;370 371 // ===== l.addic r8 , r17, 0372 request [0].push_back (entry_t(373 0xa1110000,x,y,z,374 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,375 0,TYPE_ALU,OPERATION_ALU_L_ADD,false,376 1,0x00000000,1,17,0, 0,1,SPR_LOGIC_SR_CY_OV,1,8 ,1,SPR_LOGIC_SR_CY_OV,377 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));378 SEQ;379 380 // ===== l.addic r21, r7 , 1981381 request [0].push_back (entry_t(382 0xa2a707bd,x,y,z,383 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,384 0,TYPE_ALU,OPERATION_ALU_L_ADD,false,385 1,0x000007bd,1, 7,0, 0,1,SPR_LOGIC_SR_CY_OV,1,21,1,SPR_LOGIC_SR_CY_OV,386 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));387 SEQ;388 389 // ===== l.and r24, r0 , r14390 request [0].push_back (entry_t(391 0xe3007003,x,y,z,392 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,393 0,TYPE_ALU,OPERATION_ALU_L_AND,false,394 0,0x0 ,1, 0,1,14,0,0 ,1,24,0,0 ,395 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));396 SEQ;397 398 // ===== l.andi r24, r4 , 1981399 request [0].push_back (entry_t(400 0xa70407bd,x,y,z,401 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,402 0,TYPE_ALU,OPERATION_ALU_L_AND,false,403 1,0x000007bd,1, 4,0,0 ,0,0 ,1,24,0,0 ,404 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));405 SEQ;406 407 // ===== l.bf 11408 w = y+(11<<2);409 request [0].push_back (entry_t(410 0x1000000b,x,y,z,411 BRANCH_STATE_NONE,0,BRANCH_CONDITION_FLAG_SET,0, w,412 0,TYPE_BRANCH,OPERATION_BRANCH_L_TEST_F,false,413 1,w,0, 0,0,0 ,1,SPR_LOGIC_SR_F ,0,0 ,0,0 ,414 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));415 JMP(w);416 417 // ===== l.cmov r30, r10, r20418 request [0].push_back (entry_t(419 0xe3caa00e,x,y,z,420 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,421 0,TYPE_MOVE,OPERATION_MOVE_L_CMOV,true,422 0,0x0,1,10,1,20,1,SPR_LOGIC_SR_F ,1,30,0,0 ,423 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));424 SEQ;425 426 // ===== l.div r30,r10,r20427 request [0].push_back (entry_t(428 0xe3caa309,x,y,z,429 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,430 0,TYPE_MUL_DIV,OPERATION_MUL_DIV_L_DIV,false,431 0,0x0,1,10,1,20,0,0 ,1,30,1,SPR_LOGIC_SR_CY_OV,432 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));433 SEQ;434 435 // ===== l.bf -9436 w = y+(-9<<2);437 request [0].push_back (entry_t(438 0x13fffff7,x,y,z,439 BRANCH_STATE_NONE,0,BRANCH_CONDITION_FLAG_SET,1, w,440 0,TYPE_BRANCH,OPERATION_BRANCH_L_TEST_F,false,441 1,w,0, 0,0,0 ,1,SPR_LOGIC_SR_F ,0,0 ,0,0 ,442 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));443 JMP(w);444 445 // ===== l.divu r30,r10,r20446 request [0].push_back (entry_t(447 0xe3caa30a,x,y,z,448 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,449 0,TYPE_MUL_DIV,OPERATION_MUL_DIV_L_DIVU,true,450 0,0x0,1,10,1,20,0,0 ,1,30,1,SPR_LOGIC_SR_CY_OV,451 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));452 SEQ;453 454 // ===== l.extbs r30,r10455 request [0].push_back (entry_t(456 0xe3ca004c,x,y,z,457 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,458 0,TYPE_EXTEND,OPERATION_EXTEND_L_EXTEND_S,false,459 1,8 ,1,10,0,0 ,0,0 ,1,30,0,0 ,460 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));461 SEQ;462 463 // ===== l.bnf 11464 w = y+(11<<2);465 request [0].push_back (entry_t(466 0x0c00000b,x,y,z,467 BRANCH_STATE_NONE,0,BRANCH_CONDITION_FLAG_UNSET,0, w,468 0,TYPE_BRANCH,OPERATION_BRANCH_L_TEST_NF,false,469 1,w,0, 0,0,0 ,1,SPR_LOGIC_SR_F ,0,0 ,0,0 ,470 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));471 JMP(w);472 473 // ===== l.extbz r30,r10474 request [0].push_back (entry_t(475 0xe3ca00cc,x,y,z,476 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,477 0,TYPE_EXTEND,OPERATION_EXTEND_L_EXTEND_Z,true ,478 1,8 ,1,10,0,0 ,0,0 ,1,30,0,0 ,479 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));480 SEQ;481 482 // ===== l.exths r30,r10483 request [0].push_back (entry_t(484 0xe3ca000c,x,y,z,485 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,486 0,TYPE_EXTEND,OPERATION_EXTEND_L_EXTEND_S,false,487 1,16 ,1,10,0,0 ,0,0 ,1,30,0,0 ,488 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));489 SEQ;490 491 // ===== l.bnf -9492 w = y+(-9<<2);493 request [0].push_back (entry_t(494 0x0ffffff7,x,y,z,495 BRANCH_STATE_NONE,0,BRANCH_CONDITION_FLAG_UNSET,1, w,496 0,TYPE_BRANCH,OPERATION_BRANCH_L_TEST_NF,false,497 1,w,0, 0,0,0 ,1,SPR_LOGIC_SR_F ,0,0 ,0,0 ,498 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));499 JMP(w);500 501 // ===== l.exthz r30,r10502 request [0].push_back (entry_t(503 0xe3ca008c,x,y,z,504 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,505 0,TYPE_EXTEND,OPERATION_EXTEND_L_EXTEND_Z,true ,506 1,16 ,1,10,0,0 ,0,0 ,1,30,0,0 ,507 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));508 SEQ;509 510 // ===== l.extws r30,r10511 request [0].push_back (entry_t(512 0xe3ca000d,x,y,z,513 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,514 0,TYPE_EXTEND,OPERATION_EXTEND_L_EXTEND_S,false,515 1,32 ,1,10,0,0 ,0,0 ,1,30,0,0 ,516 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));517 SEQ;518 519 // ===== l.extwz r30,r10520 request [0].push_back (entry_t(521 0xe3ca004d,x,y,z,522 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,523 0,TYPE_EXTEND,OPERATION_EXTEND_L_EXTEND_Z,false,524 1,32 ,1,10,0,0 ,0,0 ,1,30,0,0 ,525 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));526 SEQ;527 528 // ===== l.csync529 request [0].push_back (entry_t(530 0x23000000,x,y,z,531 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,532 0,TYPE_SPECIAL,OPERATION_SPECIAL_L_CSYNC,false,533 0,0 ,0,0 ,0,0 ,0,0 ,0,0 ,0,0 ,534 EXCEPTION_USE_NONE,EVENT_TYPE_CSYNC));535 SEQ;536 537 // ===== l.ff1 r30,r10538 request [0].push_back (entry_t(539 0xe3ca000f,x,y,z,540 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,541 0,TYPE_FIND,OPERATION_FIND_L_FF1,false,542 0,0 ,1,10,0,0 ,0,0 ,1,30,0,0 ,543 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));544 SEQ;545 546 // ===== l.fl1 r30,r10547 request [0].push_back (entry_t(548 0xe3ca010f,x,y,z,549 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,550 0,TYPE_FIND,OPERATION_FIND_L_FL1,false,551 0,0 ,1,10,0,0 ,0,0 ,1,30,0,0 ,552 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));553 SEQ;554 555 // ===== l.j 1018556 w = y+(1018<<2);557 request [0].push_back (entry_t(558 0x000003fa,x,y,z,559 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,1, w,560 0,TYPE_BRANCH,OPERATION_BRANCH_NONE,false,561 0,0,0, 0,0,0 ,0,0 ,0,0 ,0,0 ,562 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));563 JMP(w);564 565 // ===== l.lbs r30,0x3fa(r10)566 request [0].push_back (entry_t(567 0x93ca03fa,x,y,z,568 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,569 0,TYPE_MEMORY,OPERATION_MEMORY_LOAD_8_S,true,570 1,0x3fa,1,10,0,0 ,0,0,1,30,0,0,571 EXCEPTION_USE_MEMORY_WITHOUT_ALIGNMENT,EVENT_TYPE_NONE));572 SEQ;573 574 // ===== l.lbz r30,0x3fa(r10)575 request [0].push_back (entry_t(576 0x8fca03fa,x,y,z,577 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,578 0,TYPE_MEMORY,OPERATION_MEMORY_LOAD_8_Z,false,579 1,0x3fa,1,10,0,0 ,0,0,1,30,0,0,580 EXCEPTION_USE_MEMORY_WITHOUT_ALIGNMENT,EVENT_TYPE_NONE));581 SEQ;582 583 // ===== l.j -1018584 w = y+(-1018<<2);585 request [0].push_back (entry_t(586 0x03fffc06,x,y,z,587 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,1, w,588 0,TYPE_BRANCH,OPERATION_BRANCH_NONE,false,589 0,0,0, 0,0,0 ,0,0 ,0,0 ,0,0 ,590 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));591 JMP(w);592 593 // ===== l.lhs r30,0x3fa(r10)594 request [0].push_back (entry_t(595 0x9bca03fa,x,y,z,596 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,597 0,TYPE_MEMORY,OPERATION_MEMORY_LOAD_16_S,true,598 1,0x3fa,1,10,0,0 ,0,0,1,30,0,0,599 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));600 SEQ;601 602 // ===== l.lhz r30,0x3fa(r10)603 request [0].push_back (entry_t(604 0x97ca03fa,x,y,z,605 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,606 0,TYPE_MEMORY,OPERATION_MEMORY_LOAD_16_Z,false,607 1,0x3fa,1,10,0,0 ,0,0,1,30,0,0,608 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));609 SEQ;610 611 // ===== l.jal 1018612 w = y+(1018<<2);613 request [0].push_back (entry_t(614 0x040003fa,x,y,z,615 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITH_WRITE_STACK,1, w,616 0,TYPE_BRANCH,OPERATION_BRANCH_L_JALR,false,617 1,z+1,0, 0,0,0 ,0,0 ,1,9 ,0,0 ,618 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));619 JMP(w);620 621 // ===== l.lws r30,0x3fa(r10)622 request [0].push_back (entry_t(623 0x8bca03fa,x,y,z,624 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,625 0,TYPE_MEMORY,OPERATION_MEMORY_LOAD_32_S,true,626 1,0x3fa,1,10,0,0 ,0,0,1,30,0,0,627 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));628 SEQ;629 630 // ===== l.lwz r30,0x3fa(r10)631 request [0].push_back (entry_t(632 0x87ca03fa,x,y,z,633 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,634 0,TYPE_MEMORY,OPERATION_MEMORY_LOAD_32_Z,false,635 1,0x3fa,1,10,0,0 ,0,0,1,30,0,0,636 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));637 SEQ;638 639 // ===== l.jal -1018640 w = y+(-1018<<2);641 request [0].push_back (entry_t(642 0x07fffc06,x,y,z,643 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITH_WRITE_STACK,1, w,644 0,TYPE_BRANCH,OPERATION_BRANCH_L_JALR,false,645 1,z+1,0, 0,0,0 ,0,0 ,1,9 ,0,0 ,646 EXCEPTION_USE_NONE ,EVENT_TYPE_NONE));647 JMP(w);648 649 // ===== l.ld r30,1018(r10)650 request [0].push_back (entry_t(651 0x83ca03fa,x,y,z,652 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,653 0,TYPE_MEMORY,OPERATION_MEMORY_LOAD_64_S,true,654 1,1018,1,10,0,0 ,0,0,1,30,0,0,655 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));656 SEQ;657 658 // ===== l.ld r30,-1018(r10)659 request [0].push_back (entry_t(660 0x83cafc06,x,y,z,661 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,662 0,TYPE_MEMORY,OPERATION_MEMORY_LOAD_64_S,false,663 1,static_cast<Tgeneral_data_t>(-1018),1,10,0,0 ,0,0,1,30,0,0,664 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));665 SEQ;666 667 // ===== l.jalr r20668 request [0].push_back (entry_t(669 0x4800a000,x,y,z,670 BRANCH_STATE_NONE,0,BRANCH_CONDITION_READ_REGISTER_WITH_WRITE_STACK,1, z, // branch_address_dest can be determined if BRANCH_STATE != NONE (also : previous prediction)671 0,TYPE_BRANCH,OPERATION_BRANCH_L_JALR,false,672 0,0 ,0,0 ,1,20,0,0,1,9 ,0,0,673 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));674 SEQ;675 676 // ===== l.mac r10,r20677 request [0].push_back (entry_t(678 0xc40aa001,x,y,z,679 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,680 0,TYPE_SPECIAL,OPERATION_SPECIAL_L_MAC,true,681 0,0,1,10,1,20,0,0,0,0,0,0,682 EXCEPTION_USE_NONE,EVENT_TYPE_SPR_ACCESS));683 SEQ;684 685 // ===== l.maci r10,1018686 request [0].push_back (entry_t(687 0x4c0a03fa,x,y,z,688 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,689 0,TYPE_SPECIAL,OPERATION_SPECIAL_L_MAC,false,690 1,1018,1,10,0,0,0,0,0,0,0,0,691 EXCEPTION_USE_NONE,EVENT_TYPE_SPR_ACCESS));692 SEQ;693 694 // ===== l.maci r10,-1018695 request [0].push_back (entry_t(696 0x4fea0406,x,y,z,697 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,698 0,TYPE_SPECIAL,OPERATION_SPECIAL_L_MAC,false,699 1,static_cast<Tgeneral_data_t>(-1018),1,10,0,0,0,0,0,0,0,0,700 EXCEPTION_USE_NONE,EVENT_TYPE_SPR_ACCESS));701 SEQ;702 703 // ===== l.jr r10704 request [0].push_back (entry_t(705 0x44005000,x,y,z,706 BRANCH_STATE_NONE,0,BRANCH_CONDITION_READ_REGISTER_WITHOUT_WRITE_STACK,1, z,707 0,TYPE_BRANCH,OPERATION_BRANCH_L_JALR,false,708 0,0 ,0, 0,1,10,0,0,0,0 ,0,0,709 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));710 SEQ;711 712 // ===== l.macrc r30713 request [0].push_back (entry_t(714 0x1bc10000,x,y,z,715 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,716 0,TYPE_SPECIAL,OPERATION_SPECIAL_L_MACRC,true,717 0,0,0, 0,0, 0,0,0,1,30,0,0,718 EXCEPTION_USE_NONE,EVENT_TYPE_SPR_ACCESS));719 SEQ;720 721 // ===== l.mfspr r30,r10,1018722 request [0].push_back (entry_t(723 0xb7ca03fa,x,y,z,724 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,725 0,TYPE_SPECIAL,OPERATION_SPECIAL_L_MFSPR,false,726 1,1018,1,10,0, 0,0,0,1,30,0,0,727 EXCEPTION_USE_NONE,EVENT_TYPE_SPR_ACCESS));728 SEQ;729 730 // ===== l.mfspr r30,r10,-1018731 request [0].push_back (entry_t(732 0xb7cafc06,x,y,z,733 BRANCH_STATE_NONE,0,BRANCH_CONDITION_NONE_WITHOUT_WRITE_STACK,0, 0x0,734 0,TYPE_SPECIAL,OPERATION_SPECIAL_L_MFSPR,false,735 1,0xfc06,1,10,0, 0,0,0,1,30,0,0,736 EXCEPTION_USE_NONE,EVENT_TYPE_SPR_ACCESS));737 SEQ;738 739 // ===== l.jr r9740 request [0].push_back (entry_t(741 0x44004800,x,y,z,742 BRANCH_STATE_NONE,0,BRANCH_CONDITION_READ_STACK,1, z,743 0,TYPE_BRANCH,OPERATION_BRANCH_L_JALR,false,744 0,0 ,0, 0,1,9,0,0,0,0 ,0,0,745 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));746 SEQ;747 748 // ===== l.movhi r30,0x3fa749 request [0].push_back (entry_t(750 0x1bc003fa,x,y,z,751 0,0,0,0,0,0,752 TYPE_MOVE,OPERATION_MOVE_L_MOVHI,true,753 1,0x3fa,0,0, 0,0, 0,0, 1,30, 0,0,754 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));755 SEQ;756 757 // ===== l.movhi r30,0xfc06758 request [0].push_back (entry_t(759 0x1bc0fc06,x,y,z,760 0,0,0,0,0,0,761 TYPE_MOVE,OPERATION_MOVE_L_MOVHI,false,762 1,0xfc06,0,0, 0,0, 0,0, 1,30, 0,0,763 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));764 SEQ;765 766 // ===== l.msb r10,r20767 request [0].push_back (entry_t(768 0xc40aa002,x,y,z,769 0,0,0,0,0,0,770 TYPE_SPECIAL,OPERATION_SPECIAL_L_MSB,false,771 0,0, 1,10, 1,20, 0,0, 0,0, 0,0,772 EXCEPTION_USE_NONE,EVENT_TYPE_SPR_ACCESS));773 SEQ;774 775 // ===== l.msync776 request [0].push_back (entry_t(777 0x22000000,x,y,z,778 0,0,0,0,0,0,779 TYPE_SPECIAL,OPERATION_SPECIAL_L_MSYNC,false,780 0,0, 0,0, 0,0, 0,0, 0,0, 0,0,781 EXCEPTION_USE_NONE,EVENT_TYPE_MSYNC));782 SEQ;783 784 // ===== l.mtspr r10,r20,0x3fa785 request [0].push_back (entry_t(786 0xc00aa3fa,x,y,z,787 0,0,0,0,0,0,788 TYPE_SPECIAL,OPERATION_SPECIAL_L_MTSPR,false,789 1,0x3fa, 1,10, 1,20, 0,0, 0,0, 0,0,790 EXCEPTION_USE_NONE,EVENT_TYPE_SPR_ACCESS));791 SEQ;792 793 // ===== l.mtspr r10,r20,0xfc06794 request [0].push_back (entry_t(795 0xc3eaa406,x,y,z,796 0,0,0,0,0,0,797 TYPE_SPECIAL,OPERATION_SPECIAL_L_MTSPR,false,798 1,0xfc06, 1,10, 1,20, 0,0, 0,0, 0,0,799 EXCEPTION_USE_NONE,EVENT_TYPE_SPR_ACCESS));800 SEQ;801 802 // ===== l.mul r30,r10,r20803 request [0].push_back (entry_t(804 0xe3caa306,x,y,z,805 0,0,0,0,0,0,806 TYPE_MUL_DIV,OPERATION_MUL_DIV_L_MUL,false,807 0,0, 1,10, 1,20, 0,0, 1,30, 1,SPR_LOGIC_SR_CY_OV,808 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));809 SEQ;810 811 // ===== l.muli r30,r10,0x3fa812 request [0].push_back (entry_t(813 0xb3ca03fa,x,y,z,814 0,0,0,0,0,0,815 TYPE_MUL_DIV,OPERATION_MUL_DIV_L_MUL,false,816 1,0x3fa, 1,10, 0,0, 0,0, 1,30, 1,SPR_LOGIC_SR_CY_OV,817 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));818 SEQ;819 820 // ===== l.muli r30,r10,0xfffffc06821 request [0].push_back (entry_t(822 0xb3cafc06,x,y,z,823 0,0,0,0,0,0,824 TYPE_MUL_DIV,OPERATION_MUL_DIV_L_MUL,false,825 1,0xfffffc06, 1,10, 0,0, 0,0, 1,30, 1,SPR_LOGIC_SR_CY_OV,826 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));827 SEQ;828 829 // ===== l.mulu r30,r10,r20830 request [0].push_back (entry_t(831 0xe3caa30b,x,y,z,832 0,0,0,0,0,0,833 TYPE_MUL_DIV,OPERATION_MUL_DIV_L_MULU,false,834 0,0, 1,10, 1,20, 0,0, 1,30, 1,SPR_LOGIC_SR_CY_OV,835 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));836 SEQ;837 838 // ===== l.nop 0x3fa839 request [0].push_back (entry_t(840 0x150003fa,x,y,z,841 0,0,0,0,0,0,842 TYPE_SPECIAL,OPERATION_SPECIAL_L_NOP,false,843 0,0x3fa, 0,0, 0,0, 0,0, 0,0, 0,0,844 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));845 SEQ;846 847 // ===== l.nop 0xfc06848 request [0].push_back (entry_t(849 0x1500fc06,x,y,z,850 0,0,0,0,0,0,851 TYPE_SPECIAL,OPERATION_SPECIAL_L_NOP,false,852 0,0xfc06, 0,0, 0,0, 0,0, 0,0, 0,0,853 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));854 SEQ;855 856 // ===== l.or r30,r10,r20857 request [0].push_back (entry_t(858 0xe3caa004,x,y,z,859 0,0,0,0,0,0,860 TYPE_ALU,OPERATION_ALU_L_OR,false,861 0,0, 1,10, 1,20, 0,0, 1,30, 0,0,862 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));863 SEQ;864 865 // ===== l.ori r30,r10,0x3fa866 request [0].push_back (entry_t(867 0xabca03fa,x,y,z,868 0,0,0,0,0,0,869 TYPE_ALU,OPERATION_ALU_L_OR,false,870 1,0x3fa, 1,10, 0,0, 0,0, 1,30, 0,0,871 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));872 SEQ;873 874 // ===== l.ori r30,r10,0xfc06875 request [0].push_back (entry_t(876 0xabcafc06,x,y,z,877 0,0,0,0,0,0,878 TYPE_ALU,OPERATION_ALU_L_OR,false,879 1,0xfc06, 1,10, 0,0, 0,0, 1,30, 0,0,880 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));881 SEQ;882 883 // ===== l.psync884 request [0].push_back (entry_t(885 0x22800000,x,y,z,886 0,0,0,0,0,0,887 TYPE_SPECIAL,OPERATION_SPECIAL_L_PSYNC,false,888 0,0, 0,0, 0,0, 0,0, 0,0, 0,0,889 EXCEPTION_USE_NONE,EVENT_TYPE_PSYNC));890 SEQ;891 892 // ===== l.ror r30,r10,r20893 request [0].push_back (entry_t(894 0xe3caa0c8,x,y,z,895 0,0,0,0,0,0,896 TYPE_SHIFT,OPERATION_SHIFT_L_ROR,false,897 0,0, 1,10, 1,20, 0,0, 1,30, 0,0,898 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));899 SEQ;900 901 // ===== l.rori r30,r10,0x3f902 request [0].push_back (entry_t(903 0xbbca00ff,x,y,z,904 0,0,0,0,0,0,905 TYPE_SHIFT,OPERATION_SHIFT_L_ROR,false,906 1,0x3f, 1,10, 0,0, 0,0, 1,30, 0,0,907 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));908 SEQ;909 910 // ===== l.rori r30,r10,0x1911 request [0].push_back (entry_t(912 0xbbca00c1,x,y,z,913 0,0,0,0,0,0,914 TYPE_SHIFT,OPERATION_SHIFT_L_ROR,false,915 1,0x1, 1,10, 0,0, 0,0, 1,30, 0,0,916 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));917 SEQ;918 919 // ===== l.sb 0x3fa(r10),r20920 request [0].push_back (entry_t(921 0xd80aa3fa,x,y,z,922 0,0,0,0,0,0,923 TYPE_MEMORY,OPERATION_MEMORY_STORE_8,false,924 1,0x3fa, 1,10, 1,20, 0,0, 0,0, 0,0,925 EXCEPTION_USE_MEMORY_WITHOUT_ALIGNMENT,EVENT_TYPE_NONE));926 SEQ;927 928 // ===== l.sb 0xfffffc06(r10),r20929 request [0].push_back (entry_t(930 0xdbeaa406,x,y,z,931 0,0,0,0,0,0,932 TYPE_MEMORY,OPERATION_MEMORY_STORE_8,false,933 1,0xfffffc06, 1,10, 1,20, 0,0, 0,0, 0,0,934 EXCEPTION_USE_MEMORY_WITHOUT_ALIGNMENT,EVENT_TYPE_NONE));935 SEQ;936 937 // ===== l.sd 0x3fa(r10),r20938 request [0].push_back (entry_t(939 0xd00aa3fa,x,y,z,940 0,0,0,0,0,0,941 TYPE_MEMORY,OPERATION_MEMORY_STORE_64,false,942 1,0x3fa, 1,10, 1,20, 0,0, 0,0, 0,0,943 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));944 SEQ;945 946 // ===== l.sd 0xfffffc06(r10),r20947 request [0].push_back (entry_t(948 0xd3eaa406,x,y,z,949 0,0,0,0,0,0,950 TYPE_MEMORY,OPERATION_MEMORY_STORE_64,false,951 1,0xfffffc06, 1,10, 1,20, 0,0, 0,0, 0,0,952 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));953 SEQ;954 955 // ===== l.sh 0x3fa(r10),r20956 request [0].push_back (entry_t(957 0xdc0aa3fa,x,y,z,958 0,0,0,0,0,0,959 TYPE_MEMORY,OPERATION_MEMORY_STORE_16,false,960 1,0x3fa, 1,10, 1,20, 0,0, 0,0, 0,0,961 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));962 SEQ;963 964 // ===== l.sh 0xfffffc06(r10),r20965 request [0].push_back (entry_t(966 0xdfeaa406,x,y,z,967 0,0,0,0,0,0,968 TYPE_MEMORY,OPERATION_MEMORY_STORE_16,false,969 1,0xfffffc06, 1,10, 1,20, 0,0, 0,0, 0,0,970 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));971 SEQ;972 973 // ===== l.sw 0x3fa(r10),r20974 request [0].push_back (entry_t(975 0xd40aa3fa,x,y,z,976 0,0,0,0,0,0,977 TYPE_MEMORY,OPERATION_MEMORY_STORE_32,false,978 1,0x3fa, 1,10, 1,20, 0,0, 0,0, 0,0,979 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));980 SEQ;981 982 // ===== l.sw 0xfffffc06(r10),r20983 request [0].push_back (entry_t(984 0xd7eaa406,x,y,z,985 0,0,0,0,0,0,986 TYPE_MEMORY,OPERATION_MEMORY_STORE_32,false,987 1,0xfffffc06, 1,10, 1,20, 0,0, 0,0, 0,0,988 EXCEPTION_USE_MEMORY_WITH_ALIGNMENT,EVENT_TYPE_NONE));989 SEQ;990 991 // ===== l.sll r30,r10,r20992 request [0].push_back (entry_t(993 0xe3caa008,x,y,z,994 0,0,0,0,0,0,995 TYPE_SHIFT,OPERATION_SHIFT_L_SLL,false,996 0,0, 1,10, 1,20, 0,0, 1,30, 0,0,997 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));998 SEQ;999 1000 // ===== l.slli r30,r10,0x11001 request [0].push_back (entry_t(1002 0xbbca0001,x,y,z,1003 0,0,0,0,0,0,1004 TYPE_SHIFT,OPERATION_SHIFT_L_SLL,false,1005 1,0x1, 1,10, 0,0, 0,0, 1,30, 0,0,1006 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1007 SEQ;1008 1009 // ===== l.slli r30,r10,0x3f1010 request [0].push_back (entry_t(1011 0xbbca003f,x,y,z,1012 0,0,0,0,0,0,1013 TYPE_SHIFT,OPERATION_SHIFT_L_SLL,false,1014 1,0x3f, 1,10, 0,0, 0,0, 1,30, 0,0,1015 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1016 SEQ;1017 1018 // ===== l.sra r30,r10,r201019 request [0].push_back (entry_t(1020 0xe3caa088,x,y,z,1021 0,0,0,0,0,0,1022 TYPE_SHIFT,OPERATION_SHIFT_L_SRA,false,1023 0,0, 1,10, 1,20, 0,0, 1,30, 0,0,1024 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1025 SEQ;1026 1027 // ===== l.srai r30,r10,0x11028 request [0].push_back (entry_t(1029 0xbbca0081,x,y,z,1030 0,0,0,0,0,0,1031 TYPE_SHIFT,OPERATION_SHIFT_L_SRA,false,1032 1,0x1, 1,10, 0,0, 0,0, 1,30, 0,0,1033 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1034 SEQ;1035 1036 // ===== l.srai r30,r10,0x3f1037 request [0].push_back (entry_t(1038 0xbbca00bf,x,y,z,1039 0,0,0,0,0,0,1040 TYPE_SHIFT,OPERATION_SHIFT_L_SRA,false,1041 1,0x3f, 1,10, 0,0, 0,0, 1,30, 0,0,1042 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1043 SEQ;1044 1045 // ===== l.srl r30,r10,r201046 request [0].push_back (entry_t(1047 0xe3caa048,x,y,z,1048 0,0,0,0,0,0,1049 TYPE_SHIFT,OPERATION_SHIFT_L_SRL,false,1050 0,0, 1,10, 1,20, 0,0, 1,30, 0,0,1051 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1052 SEQ;1053 1054 // ===== l.srli r30,r10,0x11055 request [0].push_back (entry_t(1056 0xbbca0041,x,y,z,1057 0,0,0,0,0,0,1058 TYPE_SHIFT,OPERATION_SHIFT_L_SRL,false,1059 1,0x1, 1,10, 0,0, 0,0, 1,30, 0,0,1060 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1061 SEQ;1062 1063 // ===== l.srli r30,r10,0x3f1064 request [0].push_back (entry_t(1065 0xbbca007f,x,y,z,1066 0,0,0,0,0,0,1067 TYPE_SHIFT,OPERATION_SHIFT_L_SRL,false,1068 1,0x3f, 1,10, 0,0, 0,0, 1,30, 0,0,1069 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1070 SEQ;1071 1072 // ===== l.xor r30,r10,r201073 request [0].push_back (entry_t(1074 0xe3caa005,x,y,z,1075 0,0,0,0,0,0,1076 TYPE_ALU,OPERATION_ALU_L_XOR,false,1077 0,0, 1,10, 1,20, 0,0, 1,30, 0,0,1078 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1079 SEQ;1080 1081 // ===== l.xori r30,r10,0x3fa1082 request [0].push_back (entry_t(1083 0xafca03fa,x,y,z,1084 0,0,0,0,0,0,1085 TYPE_ALU,OPERATION_ALU_L_XOR,false,1086 1,0x3fa, 1,10, 0,0, 0,0, 1,30, 0,0,1087 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1088 SEQ;1089 1090 // ===== l.xori r30,r10,0xfffffc061091 request [0].push_back (entry_t(1092 0xafcafc06,x,y,z,1093 0,0,0,0,0,0,1094 TYPE_ALU,OPERATION_ALU_L_XOR,false,1095 1,0xfffffc06, 1,10, 0,0, 0,0, 1,30, 0,0,1096 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1097 SEQ;1098 1099 // ===== l.sub r30,r10,r201100 request [0].push_back (entry_t(1101 0xe3caa002,x,y,z,1102 0,0,0,0,0,0,1103 TYPE_ALU,OPERATION_ALU_L_SUB,false,1104 0,0, 1,10, 1,20, 0,0, 1,30, 1,SPR_LOGIC_SR_CY_OV,1105 EXCEPTION_USE_RANGE,EVENT_TYPE_NONE));1106 SEQ;1107 1108 // ===== l.sys 0x3fa1109 request [0].push_back (entry_t(1110 0x200003fa,x,y,z,1111 0,0,0,0,0,z,1112 TYPE_SPECIAL,OPERATION_SPECIAL_L_SYS,false,1113 0,0, 0,0, 0,0, 0,0, 0,0, 0,0,1114 EXCEPTION_USE_SYSCALL,EVENT_TYPE_EXCEPTION));1115 SEQ;1116 1117 // ===== l.sys 0xfc061118 request [0].push_back (entry_t(1119 0x2000fc06,x,y,z,1120 0,0,0,0,0,z,1121 TYPE_SPECIAL,OPERATION_SPECIAL_L_SYS,false,1122 0,0, 0,0, 0,0, 0,0, 0,0, 0,0,1123 EXCEPTION_USE_SYSCALL,EVENT_TYPE_EXCEPTION));1124 SEQ;1125 1126 // ===== l.trap 0x3fa1127 request [0].push_back (entry_t(1128 0x210003fa,x,y,z,1129 0,0,0,0,0,0,1130 TYPE_SPECIAL,OPERATION_SPECIAL_L_TRAP,false,1131 1,0x3fa, 0,0, 0,0, 0,0, 0,0, 0,0,1132 EXCEPTION_USE_TRAP,EVENT_TYPE_NONE));1133 SEQ;1134 1135 // ===== l.trap 0xfc061136 request [0].push_back (entry_t(1137 0x2100fc06,x,y,z,1138 0,0,0,0,0,0,1139 TYPE_SPECIAL,OPERATION_SPECIAL_L_TRAP,false,1140 1,0xfc06, 0,0, 0,0, 0,0, 0,0, 0,0,1141 EXCEPTION_USE_TRAP,EVENT_TYPE_NONE));1142 SEQ;1143 1144 // ===== l.rfe1145 request [0].push_back (entry_t(1146 0x24000000,x,y,z,1147 0,0,0,0,0,0,1148 TYPE_SPECIAL,OPERATION_SPECIAL_L_RFE,false,1149 0,0, 0,0, 0,0, 0,0, 0,0, 0,0,1150 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1151 SEQ;1152 1153 // ===== l.sfeq r10,r201154 request [0].push_back (entry_t(1155 0xe40aa000,x,y,z,1156 0,0,0,0,0,0,1157 TYPE_TEST,OPERATION_TEST_L_SFEQ,false,1158 0,0, 1,10, 1,20, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1159 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1160 SEQ;1161 1162 // ===== l.sfeqi r10,0x3fa1163 request [0].push_back (entry_t(1164 0xbc0a03fa,x,y,z,1165 0,0,0,0,0,0,1166 TYPE_TEST,OPERATION_TEST_L_SFEQ,false,1167 1,0x3fa, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1168 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1169 SEQ;1170 1171 // ===== l.sfeqi r10,0xfffffc061172 request [0].push_back (entry_t(1173 0xbc0afc06,x,y,z,1174 0,0,0,0,0,0,1175 TYPE_TEST,OPERATION_TEST_L_SFEQ,false,1176 1,0xfffffc06, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1177 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1178 SEQ;1179 1180 // ===== l.sfne r10,r201181 request [0].push_back (entry_t(1182 0xe42aa000,x,y,z,1183 0,0,0,0,0,0,1184 TYPE_TEST,OPERATION_TEST_L_SFNE,false,1185 0,0, 1,10, 1,20, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1186 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1187 SEQ;1188 1189 // ===== l.sfnei r10,0x3fa1190 request [0].push_back (entry_t(1191 0xbc2a03fa,x,y,z,1192 0,0,0,0,0,0,1193 TYPE_TEST,OPERATION_TEST_L_SFNE,false,1194 1,0x3fa, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1195 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1196 SEQ;1197 1198 // ===== l.sfnei r10,0xfffffc061199 request [0].push_back (entry_t(1200 0xbc2afc06,x,y,z,1201 0,0,0,0,0,0,1202 TYPE_TEST,OPERATION_TEST_L_SFNE,false,1203 1,0xfffffc06, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1204 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1205 SEQ;1206 1207 // ===== l.sfges r10,r201208 request [0].push_back (entry_t(1209 0xe56aa000,x,y,z,1210 0,0,0,0,0,0,1211 TYPE_TEST,OPERATION_TEST_L_SFGES,false,1212 0,0, 1,10, 1,20, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1213 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1214 SEQ;1215 1216 // ===== l.sfgesi r10,0x3fa1217 request [0].push_back (entry_t(1218 0xbd6a03fa,x,y,z,1219 0,0,0,0,0,0,1220 TYPE_TEST,OPERATION_TEST_L_SFGES,false,1221 1,0x3fa, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1222 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1223 SEQ;1224 1225 // ===== l.sfgesi r10,0xfffffc061226 request [0].push_back (entry_t(1227 0xbd6afc06,x,y,z,1228 0,0,0,0,0,0,1229 TYPE_TEST,OPERATION_TEST_L_SFGES,false,1230 1,0xfffffc06, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1231 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1232 SEQ;1233 1234 // ===== l.sfgeu r10,r201235 request [0].push_back (entry_t(1236 0xe46aa000,x,y,z,1237 0,0,0,0,0,0,1238 TYPE_TEST,OPERATION_TEST_L_SFGEU,false,1239 0,0, 1,10, 1,20, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1240 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1241 SEQ;1242 1243 // ===== l.sfgeui r10,0x3fa1244 request [0].push_back (entry_t(1245 0xbc6a03fa,x,y,z,1246 0,0,0,0,0,0,1247 TYPE_TEST,OPERATION_TEST_L_SFGEU,false,1248 1,0x3fa, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1249 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1250 SEQ;1251 1252 // ===== l.sfgeui r10,0xfffffc061253 request [0].push_back (entry_t(1254 0xbc6afc06,x,y,z,1255 0,0,0,0,0,0,1256 TYPE_TEST,OPERATION_TEST_L_SFGEU,false,1257 1,0xfffffc06, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1258 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1259 SEQ;1260 1261 // ===== l.sfgts r10,r201262 request [0].push_back (entry_t(1263 0xe54aa000,x,y,z,1264 0,0,0,0,0,0,1265 TYPE_TEST,OPERATION_TEST_L_SFGTS,false,1266 0,0, 1,10, 1,20, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1267 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1268 SEQ;1269 1270 // ===== l.sfgtsi r10,0x3fa1271 request [0].push_back (entry_t(1272 0xbd4a03fa,x,y,z,1273 0,0,0,0,0,0,1274 TYPE_TEST,OPERATION_TEST_L_SFGTS,false,1275 1,0x3fa, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1276 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1277 SEQ;1278 1279 // ===== l.sfgtsi r10,0xfffffc061280 request [0].push_back (entry_t(1281 0xbd4afc06,x,y,z,1282 0,0,0,0,0,0,1283 TYPE_TEST,OPERATION_TEST_L_SFGTS,false,1284 1,0xfffffc06, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1285 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1286 SEQ;1287 1288 // ===== l.sfgtu r10,r201289 request [0].push_back (entry_t(1290 0xe44aa000,x,y,z,1291 0,0,0,0,0,0,1292 TYPE_TEST,OPERATION_TEST_L_SFGTU,false,1293 0,0, 1,10, 1,20, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1294 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1295 SEQ;1296 1297 // ===== l.sfgtui r10,0x3fa1298 request [0].push_back (entry_t(1299 0xbc4a03fa,x,y,z,1300 0,0,0,0,0,0,1301 TYPE_TEST,OPERATION_TEST_L_SFGTU,false,1302 1,0x3fa, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1303 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1304 SEQ;1305 1306 // ===== l.sfgtui r10,0xfffffc061307 request [0].push_back (entry_t(1308 0xbc4afc06,x,y,z,1309 0,0,0,0,0,0,1310 TYPE_TEST,OPERATION_TEST_L_SFGTU,false,1311 1,0xfffffc06, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1312 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1313 SEQ;1314 1315 // ===== l.sfles r10,r201316 request [0].push_back (entry_t(1317 0xe5aaa000,x,y,z,1318 0,0,0,0,0,0,1319 TYPE_TEST,OPERATION_TEST_L_SFLES,false,1320 0,0, 1,10, 1,20, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1321 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1322 SEQ;1323 1324 // ===== l.sflesi r10,0x3fa1325 request [0].push_back (entry_t(1326 0xbdaa03fa,x,y,z,1327 0,0,0,0,0,0,1328 TYPE_TEST,OPERATION_TEST_L_SFLES,false,1329 1,0x3fa, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1330 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1331 SEQ;1332 1333 // ===== l.sflesi r10,0xfffffc061334 request [0].push_back (entry_t(1335 0xbdaafc06,x,y,z,1336 0,0,0,0,0,0,1337 TYPE_TEST,OPERATION_TEST_L_SFLES,false,1338 1,0xfffffc06, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1339 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1340 SEQ;1341 1342 // ===== l.sfleu r10,r201343 request [0].push_back (entry_t(1344 0xe4aaa000,x,y,z,1345 0,0,0,0,0,0,1346 TYPE_TEST,OPERATION_TEST_L_SFLEU,false,1347 0,0, 1,10, 1,20, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1348 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1349 SEQ;1350 1351 // ===== l.sfleui r10,0x3fa1352 request [0].push_back (entry_t(1353 0xbcaa03fa,x,y,z,1354 0,0,0,0,0,0,1355 TYPE_TEST,OPERATION_TEST_L_SFLEU,false,1356 1,0x3fa, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1357 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1358 SEQ;1359 1360 // ===== l.sfleui r10,0xfffffc061361 request [0].push_back (entry_t(1362 0xbcaafc06,x,y,z,1363 0,0,0,0,0,0,1364 TYPE_TEST,OPERATION_TEST_L_SFLEU,false,1365 1,0xfffffc06, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1366 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1367 SEQ;1368 1369 // ===== l.sflts r10,r201370 request [0].push_back (entry_t(1371 0xe58aa000,x,y,z,1372 0,0,0,0,0,0,1373 TYPE_TEST,OPERATION_TEST_L_SFLTS,false,1374 0,0, 1,10, 1,20, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1375 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1376 SEQ;1377 1378 // ===== l.sfltsi r10,0x3fa1379 request [0].push_back (entry_t(1380 0xbd8a03fa,x,y,z,1381 0,0,0,0,0,0,1382 TYPE_TEST,OPERATION_TEST_L_SFLTS,false,1383 1,0x3fa, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1384 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1385 SEQ;1386 1387 // ===== l.sfltsi r10,0xfffffc061388 request [0].push_back (entry_t(1389 0xbd8afc06,x,y,z,1390 0,0,0,0,0,0,1391 TYPE_TEST,OPERATION_TEST_L_SFLTS,false,1392 1,0xfffffc06, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1393 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1394 SEQ;1395 1396 // ===== l.sfltu r10,r201397 request [0].push_back (entry_t(1398 0xe48aa000,x,y,z,1399 0,0,0,0,0,0,1400 TYPE_TEST,OPERATION_TEST_L_SFLTU,false,1401 0,0, 1,10, 1,20, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1402 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1403 SEQ;1404 1405 // ===== l.sfltui r10,0x3fa1406 request [0].push_back (entry_t(1407 0xbc8a03fa,x,y,z,1408 0,0,0,0,0,0,1409 TYPE_TEST,OPERATION_TEST_L_SFLTU,false,1410 1,0x3fa, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1411 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1412 SEQ;1413 1414 // ===== l.sfltui r10,0xfffffc061415 request [0].push_back (entry_t(1416 0xbc8afc06,x,y,z,1417 0,0,0,0,0,0,1418 TYPE_TEST,OPERATION_TEST_L_SFLTU,false,1419 1,0xfffffc06, 1,10, 0,0, 0,0, 0,0, 1,SPR_LOGIC_SR_F,1420 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1421 SEQ;1422 1423 // ===== l.cust4 (encrypt)1424 request [0].push_back (entry_t(1425 0x7de80000,x,y,z,1426 0,0,0,0,0,0,1427 TYPE_CUSTOM,OPERATION_CUSTOM_L_4,false,1428 0,0x0, 1, 8, 0,0, 0,0, 1,15, 0,0,1429 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1430 SEQ;1431 1432 // ===== l.cust8 (decrypt)1433 request [0].push_back (entry_t(1434 0xfde80000,x,y,z,1435 0,0,0,0,0,0,1436 TYPE_CUSTOM,OPERATION_CUSTOM_L_8,false,1437 0,0x0, 1, 8, 0,0, 0,0, 1,15, 0,0,1438 EXCEPTION_USE_NONE,EVENT_TYPE_NONE));1439 SEQ;1440 1441 for (uint32_t i=1; i<_param->_nb_context; i++)1442 {1443 request[i] = request [0];1444 }1445 1446 208 for (uint32_t i=0; i<_param->_nb_context; i++) 1447 209 { 210 nb_request += request[i].size(); 1448 211 delay_slot_current [i] = false; 1449 212 delay_slot_next [i] = false; 1450 213 } 1451 1452 uint32_t nb_request = request[0].size() * _param->_nb_context;1453 214 1454 215 while (nb_request > 0) … … 1465 226 if ((rand()%100)<percent_transaction_ifetch) 1466 227 { 1467 list<entry_t>::iterator it = request 1468 228 list<entry_t>::iterator it = request[i].begin(); 229 1469 230 if (it!=request [i].end()) 1470 231 { … … 1672 433 delete [] out_PREDICT_BRANCH_UPDATE_PREDICTION_ID; 1673 434 delete [] out_PREDICT_BRANCH_CONDITION ; 1674 // 435 //delete [] out_PREDICT_BRANCH_STACK_WRITE ; 1675 436 delete [] out_PREDICT_BRANCH_DIRECTION ; 1676 437 delete [] out_PREDICT_ADDRESS_SRC ; 1677 438 delete [] out_PREDICT_ADDRESS_DEST ; 1678 // 439 //delete [] in_PREDICT_CAN_CONTINUE ; 1679 440 1680 441 delete [] in_CONTEXT_DECOD_ENABLE ; -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/src/Decod_genMealy.cpp
r86 r87 48 48 internal_CONTEXT_ADDRESS_PREVIOUS [i] = reg_CONTEXT_ADDRESS_PREVIOUS [i]; 49 49 internal_CONTEXT_IS_DELAY_SLOT [i] = reg_CONTEXT_IS_DELAY_SLOT [i]; 50 50 51 51 can_continue [i] = PORT_READ(in_CONTEXT_DECOD_ENABLE [i]); 52 52 can_continue_next [i] = PORT_READ(in_CONTEXT_DECOD_ENABLE [i]); … … 57 57 //----------------------------------- 58 58 // scan all decod "slot_out" 59 log_printf(TRACE,Decod,FUNCTION,"KANE LIVE"); 59 60 std::list<select_t>::iterator it=select.begin(); 60 61 for (uint32_t i=0; i<_param->_nb_inst_decod; i++) … … 64 65 (context_event_val == false)) // Have not a context_event (spr_access, exception, ...) 65 66 { 67 log_printf(TRACE,Decod,FUNCTION,"loop"); 68 66 69 predict_val [i] = false; 67 context_event_val = false;68 70 69 71 Tcontext_t x = it->_context ; … … 123 125 if (type == TYPE_BRANCH) 124 126 { 127 log_printf(TRACE,Decod,FUNCTION," * type is branch"); 128 125 129 predict_val [i] = ifetch_ack [x][y] // and decod_val [i] 126 130 ; … … 173 177 if (have_transaction) 174 178 { 175 #ifdef STATISTICS176 (*_stat_sum_inst_decod) ++;177 #endif178 179 internal_CONTEXT_ADDRESS_PREVIOUS [x] = addr; 179 180 internal_CONTEXT_IS_DELAY_SLOT [x] = (type == TYPE_BRANCH); // next is a delay slot if current have branch type … … 182 183 can_continue [x] &= have_transaction; // to have a in order decod !!! if a previous instruction can decod, also next instruction can't decod. 183 184 } 185 186 log_printf(TRACE,Decod,FUNCTION," - num_(decod, context, fetch) : %d %d %d",i, x, y); 187 log_printf(TRACE,Decod,FUNCTION," - ifetch_ack : %d",ifetch_ack [x][y]); 188 log_printf(TRACE,Decod,FUNCTION," - context_event_val : %d",context_event_val ); 189 log_printf(TRACE,Decod,FUNCTION," - predict_val : %d",predict_val [i] ); 190 log_printf(TRACE,Decod,FUNCTION," - decod_val : %d",decod_val [i] ); 184 191 185 192 it ++; 186 193 } 187 194 } 188 189 195 //----------------------------------- 190 196 // Write output -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/src/Decod_transition.cpp
r81 r87 29 29 30 30 for (uint32_t i=0; i<_param->_nb_context; i++) 31 reg_CONTEXT_ADDRESS_PREVIOUS [i] = 0xfc; // 0x100-4. (0x100 : reset address) 31 { 32 reg_CONTEXT_ADDRESS_PREVIOUS [i] = 0xfc; // 0x100-4. (0x100 : reset address) 33 reg_CONTEXT_IS_DELAY_SLOT [i] = 0; 34 } 32 35 } 33 36 else … … 94 97 if (internal_CONTEXT_HAVE_TRANSACTION[i]) 95 98 { 99 #ifdef STATISTICS 100 (*_stat_sum_inst_decod) ++; 101 #endif 102 96 103 reg_CONTEXT_ADDRESS_PREVIOUS [i] = internal_CONTEXT_ADDRESS_PREVIOUS [i]; 97 104 reg_CONTEXT_IS_DELAY_SLOT [i] = internal_CONTEXT_IS_DELAY_SLOT [i]; -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/src/Parameters.cpp
r86 r87 1 1 /* 2 2 3 * $Id$ 3 4 * … … 53 54 _max_nb_inst_fetch = max<uint32_t>(nb_inst_fetch,nb_context); 54 55 55 _size_address_inst = size_ address-2;56 _size_address_inst = size_general_data-2; 56 57 _size_context_id = log2(nb_context ); 57 58 _size_depth = log2(nb_branch_speculated); -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/src/Parameters_msg_error.cpp
r82 r87 8 8 #include "Behavioural/include/Types.h" 9 9 #include "Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/include/Parameters.h" 10 #include "Common/include/Max.h" 10 11 #include <sstream> 11 12 … … 42 43 test.error(_("nb_context_select must be in [1:nb_context].\n")); 43 44 45 uint32_t sum_inst_fetch = 0; 46 for (uint32_t i=0; i<_nb_context_select; i++) 47 sum_inst_fetch += max<uint32_t>(_nb_inst_fetch,_nb_context,i+1); 48 49 if (sum_inst_fetch < _nb_inst_decod) 50 test.error(_("The sum of the _nb_context_select most nb_inst_fetch must be greater that _nb_inst_decod")); 51 44 52 if ((_priority != PRIORITY_ROUND_ROBIN)) 45 53 test.error(toString(_("Unsupported priority scheme. Supported scheme are : %s.\n"),toString(PRIORITY_ROUND_ROBIN).c_str())); -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod_queue/SelfTest/config_mono_context.cfg
r82 r87 1 1 Decod_queue 2 2 1 1 +1 # nb_context 3 1 4 *4# nb_inst_decod4 4 16 *4# size_queue3 1 8 *2 # nb_inst_decod 4 8 16 *2 # size_queue 5 5 32 32 +1 # size_general_data 6 6 1 2 +1 # nb_branch_speculated [0] [nb_context] -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod_queue/src/Decod_queue.cpp
r82 r87 109 109 (*(out_DECOD_OUT_VAL [i])) (*(in_DECOD_OUT_ACK [i])); 110 110 if (_param->_have_port_depth) 111 for (uint32_t i=0; i<_param->_nb_context; i++)111 for (uint32_t j=0; j<_param->_nb_context; j++) 112 112 { 113 (*(out_DECOD_OUT_VAL [i])) (*(in_DEPTH_TAIL [ i]));114 (*(out_DECOD_OUT_VAL [i])) (*(in_DEPTH_NB_BRANCH [ i]));113 (*(out_DECOD_OUT_VAL [i])) (*(in_DEPTH_TAIL [j])); 114 (*(out_DECOD_OUT_VAL [i])) (*(in_DEPTH_NB_BRANCH [j])); 115 115 } 116 116 } -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod_queue/src/Decod_queue_transition.cpp
r82 r87 76 76 log_printf(TRACE,Decod_queue,FUNCTION,_(" * nb_inst : %d"),reg_NB_INST [context]); 77 77 log_printf(TRACE,Decod_queue,FUNCTION,_(" * PUSH queue")); 78 79 78 } 80 79 } … … 117 116 } 118 117 } 118 119 #if (DEBUG >= DEBUG_TRACE) and (DEBUG_Decod_queue) 120 uint32_t x=0; 121 for (std::list<decod_queue_entry_t*>::iterator it=reg_QUEUE->begin(); 122 it!=reg_QUEUE->end(); 123 it++) 124 { 125 log_printf(TRACE,Decod_queue,FUNCTION,"[%d] ",x); 126 127 for (uint32_t i=0; i<_param->_nb_inst_decod; i++) 128 { 129 if ((*it)->_val [i]) 130 log_printf(TRACE,Decod_queue,FUNCTION," * [%d] %d, %d %d, %d %d %d, 0x%x, %d 0x%x, %d %d, %d %d, %d %d, %d %d, %d %d, %d " 131 ,i 132 ,(*it)->_val [i] 133 ,(*it)->_context_id [i] 134 ,(*it)->_depth [i] 135 ,(*it)->_type [i] 136 ,(*it)->_operation [i] 137 ,(*it)->_is_delay_slot [i] 138 ,(*it)->_address [i] 139 ,(*it)->_has_immediat [i] 140 ,(*it)->_immediat [i] 141 ,(*it)->_read_ra [i] 142 ,(*it)->_num_reg_ra [i] 143 ,(*it)->_read_rb [i] 144 ,(*it)->_num_reg_rb [i] 145 ,(*it)->_read_rc [i] 146 ,(*it)->_num_reg_rc [i] 147 ,(*it)->_write_rd [i] 148 ,(*it)->_num_reg_rd [i] 149 ,(*it)->_write_re [i] 150 ,(*it)->_num_reg_re [i] 151 ,(*it)->_exception_use [i] 152 ); 153 else 154 log_printf(TRACE,Decod_queue,FUNCTION," * [%d] %d" 155 ,i 156 ,(*it)->_val [i] 157 ); 158 159 } 160 x++; 161 } 162 #endif 119 163 120 164 #ifdef STATISTICS -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/SelfTest/config_mono_context.cfg
r83 r87 1 1 Decod_unit 2 2 1 1 +1 # nb_context 3 1 4 *4# nb_inst_fetch [0][nb_context]3 4 8 *2 # nb_inst_fetch [0][nb_context] 4 4 1 4 *4 # nb_inst_decod 5 5 4 16 *4 # size_queue -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/SelfTest/config_multi_context.cfg
r83 r87 5 5 1 1 *4 # nb_inst_fetch [2][nb_context] 6 6 8 8 *4 # nb_inst_fetch [3][nb_context] 7 4 8 *2# nb_inst_decod7 1 8 *4 # nb_inst_decod 8 8 16 16 *4 # size_queue 9 9 32 32 +1 # size_general_data -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/SelfTest/src/main.cpp
r83 r87 7 7 8 8 #include "Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/SelfTest/include/test.h" 9 #include "Behavioural/Custom/include/Custom_example.h" 9 10 10 11 #define NB_PARAMS 8 … … 85 86 _select_load_balancing , 86 87 _instruction_implemeted , 87 NULL); 88 &(morpheo::behavioural::custom::example_get_custom_information) 89 ); 88 90 89 91 msg(_("%s"),param->print(1).c_str()); -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/SelfTest/src/test.cpp
r83 r87 8 8 9 9 #define NB_ITERATION 1 10 #define CYCLE_MAX (1 28*NB_ITERATION)10 #define CYCLE_MAX (10240*NB_ITERATION) 11 11 12 12 #include "Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/SelfTest/include/test.h" 13 #include "Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/Decod/SelfTest/include/Decod_request.h" 13 14 #include "Common/include/Test.h" 14 15 #include "Behavioural/include/Allocation.h" … … 20 21 21 22 #ifdef STATISTICS 22 morpheo::behavioural::Parameters_Statistics * _parameters_statistics = new morpheo::behavioural::Parameters_Statistics (5, 50);23 morpheo::behavioural::Parameters_Statistics * _parameters_statistics = new morpheo::behavioural::Parameters_Statistics (5,CYCLE_MAX); 23 24 #endif 24 25 … … 210 211 //const uint32_t seed = static_cast<uint32_t>(time(NULL)); 211 212 213 const int32_t percent_transaction_ifetch = 100; 214 const int32_t percent_transaction_decod = 100; 215 const int32_t percent_transaction_predict = 100; 216 const int32_t percent_transaction_event = 100; 217 212 218 srand(seed); 213 219 … … 226 232 LABEL("Iteration %d",iteration); 227 233 228 SC_START(1); 234 Decod_request request [_param->_nb_context]; 235 list<entry_t> respons [_param->_nb_context]; 236 237 uint32_t nb_request = 0; 238 239 uint32_t delay_slot_previous [_param->_nb_context]; 240 uint32_t delay_slot_current [_param->_nb_context]; 241 uint32_t delay_slot_next [_param->_nb_context]; 242 243 for (uint32_t i=0; i<_param->_nb_context; i++) 244 { 245 nb_request += request[i].size(); 246 delay_slot_current [i] = false; 247 delay_slot_next [i] = false; 248 249 in_DEPTH_TAIL [i]->write(0); 250 in_DEPTH_NB_BRANCH [i]->write(0); 251 in_CONTEXT_DEPTH [i]->write(0); 252 } 253 254 while (nb_request > 0) 255 { 256 for (uint32_t i=0; i<_param->_nb_context; i++) 257 { 258 delay_slot_previous [i] = false; 259 260 in_CONTEXT_DECOD_ENABLE [i]->write((rand()%100)<percent_transaction_decod); 261 262 for (uint32_t j=0; j<_param->_nb_inst_fetch[i]; j++) 263 in_IFETCH_VAL [i][j]->write(0); 264 265 if ((rand()%100)<percent_transaction_ifetch) 266 { 267 list<entry_t>::iterator it = request[i].begin(); 268 269 if (it!=request [i].end()) 270 { 271 uint32_t lsb = it->_address%_param->_nb_inst_fetch[i]; 272 273 in_IFETCH_ADDRESS [i]->write(it->_address-lsb); 274 in_IFETCH_BRANCH_STATE [i]->write(BRANCH_STATE_NONE); 275 if (_param->_have_port_inst_ifetch_ptr) 276 in_IFETCH_INST_IFETCH_PTR [i]->write(0); 277 278 // Alignement 279 for (uint32_t j=lsb; j<_param->_nb_inst_fetch[i]; j++) 280 { 281 in_IFETCH_VAL [i][j]->write(1); 282 in_IFETCH_INSTRUCTION [i][j]->write(it->_instruction); 283 // in_IFETCH_ADDRESS_NEXT [i]->write(it->_address_next); 284 if (it->_type == TYPE_BRANCH) 285 in_IFETCH_BRANCH_STATE [i]->write(it->_branch_state); 286 in_IFETCH_BRANCH_UPDATE_PREDICTION_ID [i]->write(it->_branch_update_prediction_id); 287 288 if ((it->_is_delay_slot) or 289 ((++it)==request [i].end())) 290 break; 291 } 292 } 293 } 294 } 295 296 { 297 bool previous_ack = true; 298 299 for (uint32_t i=0; i<_param->_nb_inst_decod; i++) 300 { 301 bool ack = previous_ack and ((rand()%100)<percent_transaction_decod); 302 in_DECOD_ACK [i]->write(ack); 303 304 previous_ack = ack; 305 306 in_PREDICT_ACK [i]->write((rand()%100)<percent_transaction_predict); 307 // in_PREDICT_CAN_CONTINUE [i]->write(0); 308 } 309 } 310 311 in_CONTEXT_EVENT_ACK->write((rand()%100)<percent_transaction_event); 312 313 SC_START(0); 314 315 uint32_t find_event = false; 316 for (uint32_t i=0; i<_param->_nb_context; i++) 317 for (uint32_t j=0; j<_param->_nb_inst_fetch[i]; j++) 318 if (in_IFETCH_VAL[i][j]->read() and out_IFETCH_ACK[i][j]->read()) 319 { 320 LABEL("IFETCH [%d][%d] : transaction",i,j); 321 322 entry_t entry = request [i].front(); 323 LABEL(" * address 0x%x",entry._address); 324 325 respons [i].push_back(entry); 326 request [i].pop_front(); 327 328 if (entry._type == TYPE_BRANCH) 329 { 330 delay_slot_next [i] = true; 331 332 // find good decod 333 uint32_t x; 334 335 for (x=0; x<=_param->_nb_inst_decod; x++) 336 { 337 if (x==_param->_nb_inst_decod) 338 TEST_KO("No find predict transaction"); 339 340 Tcontext_t ctxt = (_param->_have_port_context_id)?out_PREDICT_CONTEXT_ID[x]->read():0; 341 342 if ((ctxt == i) and 343 (out_PREDICT_VAL [x]->read() and in_PREDICT_ACK [x]->read())) 344 break; 345 } 346 347 LABEL("PREDICT [%d] : transaction",x ); 348 349 350 TEST(Tcontrol_t , out_PREDICT_MATCH_INST_IFETCH_PTR [x]->read(),((entry._address)%_param->_nb_inst_fetch[i]) == 0); 351 TEST(Tbranch_state_t , out_PREDICT_BRANCH_STATE [x]->read(), entry._branch_state ); 352 if (_param->_have_port_branch_update_prediction_id) 353 TEST(Tprediction_ptr_t , out_PREDICT_BRANCH_UPDATE_PREDICTION_ID [x]->read(), entry._branch_update_prediction_id); 354 TEST(Tbranch_condition_t, out_PREDICT_BRANCH_CONDITION [x]->read(), entry._branch_condition ); 355 // TEST(Tcontrol_t , out_PREDICT_BRANCH_STACK_WRITE [x]->read(), entry._branch_stack_write ); 356 TEST(Tcontrol_t , out_PREDICT_BRANCH_DIRECTION [x]->read(), entry._branch_direction ); 357 TEST(Tgeneral_data_t , out_PREDICT_ADDRESS_SRC [x]->read(), entry._address ); 358 TEST(Tgeneral_data_t , out_PREDICT_ADDRESS_DEST [x]->read(), entry._branch_address_dest ); 359 } 360 361 // TEST(bool, find_event, false); // can continue decod after event 362 if (entry._context_event_type != EVENT_TYPE_NONE) 363 { 364 find_event = true; 365 366 LABEL("CONTEXT_EVENT : transaction"); 367 368 if (_param->_have_port_context_id) 369 TEST(Tcontext_t ,out_CONTEXT_EVENT_CONTEXT_ID ->read(), i); 370 TEST(Tevent_type_t ,out_CONTEXT_EVENT_TYPE ->read(), entry._context_event_type); 371 TEST(Tcontrol_t ,out_CONTEXT_EVENT_IS_DELAY_SLOT->read(), entry._is_delay_slot); 372 TEST(Tgeneral_data_t,out_CONTEXT_EVENT_ADDRESS ->read(), entry._address ); 373 TEST(Tgeneral_data_t,out_CONTEXT_EVENT_ADDRESS_EPCR ->read(), entry._address_next ); 374 } 375 376 TEST(bool, delay_slot_previous [i], false); // can't continue 377 delay_slot_previous [i] = delay_slot_current [i]; 378 delay_slot_current [i] = delay_slot_next [i]; 379 delay_slot_next [i] = false; 380 } 381 382 for (uint32_t i=0; i<_param->_nb_inst_decod; i++) 383 if (out_DECOD_VAL[i]->read() and in_DECOD_ACK[i]->read()) 384 { 385 Tcontext_t context = (_param->_have_port_context_id)?out_DECOD_CONTEXT_ID[i]->read():0; 386 387 LABEL("DECOD [%d] : transaction",i ); 388 389 TEST(bool ,respons [context].empty(), false); 390 391 LABEL(" * context : %d",context); 392 LABEL(" * instruction : 0x%x",respons [context].front()._instruction); 393 394 if (_param->_have_port_depth) 395 TEST(Tdepth_t , out_DECOD_DEPTH [i]->read(), respons [context].front()._depth ); 396 TEST(Ttype_t , out_DECOD_TYPE [i]->read(), respons [context].front()._type ); 397 TEST(Toperation_t , out_DECOD_OPERATION [i]->read(), respons [context].front()._operation ); 398 TEST(Tcontrol_t , out_DECOD_IS_DELAY_SLOT [i]->read(), respons [context].front()._is_delay_slot); 399 TEST(Tgeneral_data_t , out_DECOD_ADDRESS [i]->read(), respons [context].front()._address ); 400 TEST(Tcontrol_t , out_DECOD_HAS_IMMEDIAT [i]->read(), respons [context].front()._has_immediat ); 401 if (respons [context].front()._has_immediat) 402 TEST(Tgeneral_data_t , out_DECOD_IMMEDIAT [i]->read(), respons [context].front()._immediat ); 403 TEST(Tcontrol_t , out_DECOD_READ_RA [i]->read(), respons [context].front()._read_ra ); 404 if (respons [context].front()._read_ra) 405 TEST(Tgeneral_address_t, out_DECOD_NUM_REG_RA [i]->read(), respons [context].front()._num_reg_ra ); 406 TEST(Tcontrol_t , out_DECOD_READ_RB [i]->read(), respons [context].front()._read_rb ); 407 if (respons [context].front()._read_rb) 408 TEST(Tgeneral_address_t, out_DECOD_NUM_REG_RB [i]->read(), respons [context].front()._num_reg_rb ); 409 TEST(Tcontrol_t , out_DECOD_READ_RC [i]->read(), respons [context].front()._read_rc ); 410 if (respons [context].front()._read_rc) 411 TEST(Tspecial_address_t, out_DECOD_NUM_REG_RC [i]->read(), respons [context].front()._num_reg_rc ); 412 TEST(Tcontrol_t , out_DECOD_WRITE_RD [i]->read(), respons [context].front()._write_rd ); 413 if (respons [context].front()._write_rd) 414 TEST(Tgeneral_address_t, out_DECOD_NUM_REG_RD [i]->read(), respons [context].front()._num_reg_rd ); 415 TEST(Tcontrol_t , out_DECOD_WRITE_RE [i]->read(), respons [context].front()._write_re ); 416 if (respons [context].front()._write_re) 417 TEST(Tspecial_address_t, out_DECOD_NUM_REG_RE [i]->read(), respons [context].front()._num_reg_re ); 418 TEST(Texception_t , out_DECOD_EXCEPTION_USE [i]->read(), respons [context].front()._exception_use); 419 420 respons [context].pop_front(); 421 nb_request --; 422 } 423 424 TEST(bool, (out_CONTEXT_EVENT_VAL->read() and in_CONTEXT_EVENT_ACK->read()), find_event); 425 426 SC_START(1); 427 } 428 429 for (uint32_t i=0; i<_param->_nb_context; i++) 430 { 431 TEST(Tcounter_t,out_NB_INST_DECOD_ALL [i]->read(), respons[i].size()); 432 433 } 229 434 } 230 435 … … 301 506 DELETE_SC_SIGNAL( out_CONTEXT_EVENT_ADDRESS ); 302 507 DELETE_SC_SIGNAL( out_CONTEXT_EVENT_ADDRESS_EPCR ); 303 304 508 } 305 509 #endif -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/include/Parameters.h
r83 r87 42 42 public : uint32_t _max_nb_inst_fetch ; 43 43 44 public : uint32_t _size_address_inst ; 44 45 public : uint32_t _size_context_id ; 45 46 public : uint32_t _size_depth ; -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/src/Decod_unit_allocation.cpp
r83 r87 69 69 70 70 ALLOC1_SIGNAL_IN (in_IFETCH_CONTEXT_ID ,"context_id" ,Tcontext_t ,_param->_size_context_id ); 71 ALLOC1_SIGNAL_IN (in_IFETCH_ADDRESS ,"address" ,Tgeneral_address_t ,_param->_size_ general_data);72 // ALLOC1_SIGNAL_IN (in_IFETCH_ADDRESS_NEXT ,"address_next" ,Tgeneral_address_t ,_param->_size_ general_data);71 ALLOC1_SIGNAL_IN (in_IFETCH_ADDRESS ,"address" ,Tgeneral_address_t ,_param->_size_address_inst ); 72 // ALLOC1_SIGNAL_IN (in_IFETCH_ADDRESS_NEXT ,"address_next" ,Tgeneral_address_t ,_param->_size_address_inst ); 73 73 ALLOC1_SIGNAL_IN (in_IFETCH_INST_IFETCH_PTR ,"inst_ifetch_ptr" ,Tinst_ifetch_ptr_t ,_param->_size_inst_ifetch_ptr ); 74 74 ALLOC1_SIGNAL_IN (in_IFETCH_BRANCH_STATE ,"branch_state" ,Tbranch_state_t ,_param->_size_branch_state ); … … 87 87 ALLOC1_SIGNAL_OUT(out_DECOD_OPERATION ,"operation" ,Toperation_t ,_param->_size_operation ); 88 88 ALLOC1_SIGNAL_OUT(out_DECOD_IS_DELAY_SLOT,"is_delay_slot",Tcontrol_t ,1 ); 89 ALLOC1_SIGNAL_OUT(out_DECOD_ADDRESS ,"address" ,Tgeneral_data_t ,_param->_size_ general_data);89 ALLOC1_SIGNAL_OUT(out_DECOD_ADDRESS ,"address" ,Tgeneral_data_t ,_param->_size_address_inst ); 90 90 ALLOC1_SIGNAL_OUT(out_DECOD_HAS_IMMEDIAT ,"has_immediat" ,Tcontrol_t ,1 ); 91 91 ALLOC1_SIGNAL_OUT(out_DECOD_IMMEDIAT ,"immediat" ,Tgeneral_data_t ,_param->_size_general_data ); … … 116 116 // ALLOC1_SIGNAL_OUT(out_PREDICT_BRANCH_STACK_WRITE ,"branch_stack_write" ,Tcontrol_t ,1 ); 117 117 ALLOC1_SIGNAL_OUT(out_PREDICT_BRANCH_DIRECTION ,"branch_direction" ,Tcontrol_t ,1 ); 118 ALLOC1_SIGNAL_OUT(out_PREDICT_ADDRESS_SRC ,"address_src" ,Tgeneral_data_t ,_param->_size_ general_data);119 ALLOC1_SIGNAL_OUT(out_PREDICT_ADDRESS_DEST ,"address_dest" ,Tgeneral_data_t ,_param->_size_ general_data);118 ALLOC1_SIGNAL_OUT(out_PREDICT_ADDRESS_SRC ,"address_src" ,Tgeneral_data_t ,_param->_size_address_inst ); 119 ALLOC1_SIGNAL_OUT(out_PREDICT_ADDRESS_DEST ,"address_dest" ,Tgeneral_data_t ,_param->_size_address_inst ); 120 120 // ALLOC1_SIGNAL_IN ( in_PREDICT_CAN_CONTINUE ,"can_continue" ,Tcontrol_t ,1 ); 121 121 } … … 154 154 ALLOC_SIGNAL_OUT(out_CONTEXT_EVENT_TYPE ,"type" ,Tevent_type_t ,_param->_size_event_type ); 155 155 ALLOC_SIGNAL_OUT(out_CONTEXT_EVENT_IS_DELAY_SLOT,"is_delay_slot",Tcontrol_t ,1 ); 156 ALLOC_SIGNAL_OUT(out_CONTEXT_EVENT_ADDRESS ,"address" ,Tgeneral_data_t,_param->_size_ general_data);157 ALLOC_SIGNAL_OUT(out_CONTEXT_EVENT_ADDRESS_EPCR ,"address_epcr" ,Tgeneral_data_t,_param->_size_ general_data);156 ALLOC_SIGNAL_OUT(out_CONTEXT_EVENT_ADDRESS ,"address" ,Tgeneral_data_t,_param->_size_address_inst); 157 ALLOC_SIGNAL_OUT(out_CONTEXT_EVENT_ADDRESS_EPCR ,"address_epcr" ,Tgeneral_data_t,_param->_size_address_inst); 158 158 } 159 159 … … 163 163 { 164 164 src = _name+"_decod"; 165 log_printf(INFO, Prediction_unit,FUNCTION,_("Create : %s"),src.c_str());165 log_printf(INFO,Decod_unit,FUNCTION,_("Create : %s"),src.c_str()); 166 166 167 167 _component_decod = new morpheo::behavioural::core::multi_front_end::front_end::decod_unit::decod::Decod … … 182 182 { 183 183 src = _name+"_decod_queue"; 184 log_printf(INFO, Prediction_unit,FUNCTION,_("Create : %s"),src.c_str());184 log_printf(INFO,Decod_unit,FUNCTION,_("Create : %s"),src.c_str()); 185 185 186 186 _component_decod_queue = new morpheo::behavioural::core::multi_front_end::front_end::decod_unit::decod_queue::Decod_queue … … 206 206 { 207 207 src = _name+"_decod"; 208 log_printf(INFO, Prediction_unit,FUNCTION,_("Instance : %s"),src.c_str());208 log_printf(INFO,Decod_unit,FUNCTION,_("Instance : %s"),src.c_str()); 209 209 210 210 { … … 241 241 dest,"ifetch_"+toString(i)); 242 242 #endif 243 244 243 245 244 if (_param->_have_port_context_id) 246 245 PORT_MAP(_component,src , "in_IFETCH_"+toString(i)+"_CONTEXT_ID" , … … 400 399 { 401 400 src = _name+"_decod_queue"; 402 log_printf(INFO, Prediction_unit,FUNCTION,_("Instance : %s"),src.c_str());401 log_printf(INFO,Decod_unit,FUNCTION,_("Instance : %s"),src.c_str()); 403 402 404 403 { … … 519 518 } 520 519 // ~~~~~[ Others ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 521 522 523 524 #ifdef POSITION 525 526 527 #endif 528 529 520 if (DEBUG_Decod_unit == true) 521 _component->test_map(); 522 523 #ifdef POSITION 524 if (usage_is_set(_usage,USE_POSITION)) 525 _component->generate_file(); 526 #endif 527 528 log_end(Decod_unit,FUNCTION); 530 529 }; 531 530 -
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Front_end/Front_end/Decod_unit/src/Parameters.cpp
r83 r87 49 49 _max_nb_inst_fetch = max<uint32_t>(_nb_inst_fetch,_nb_context); 50 50 51 _size_address_inst = size_general_data-2; 51 52 _size_context_id = log2(nb_context ); 52 53 _size_depth = log2(max<uint32_t>(_nb_branch_speculated,_nb_context)); -
trunk/IPs/systemC/processor/Morpheo/Behavioural/New_Component_vbe/SelfTest/src/test.cpp
r83 r87 16 16 17 17 #ifdef STATISTICS 18 morpheo::behavioural::Parameters_Statistics * _parameters_statistics = new morpheo::behavioural::Parameters_Statistics (5, 50);18 morpheo::behavioural::Parameters_Statistics * _parameters_statistics = new morpheo::behavioural::Parameters_Statistics (5,CYCLE_MAX); 19 19 #endif 20 20 -
trunk/IPs/systemC/processor/Morpheo/Behavioural/New_Component_vst/SelfTest/src/test.cpp
r83 r87 16 16 17 17 #ifdef STATISTICS 18 morpheo::behavioural::Parameters_Statistics * _parameters_statistics = new morpheo::behavioural::Parameters_Statistics (5, 50);18 morpheo::behavioural::Parameters_Statistics * _parameters_statistics = new morpheo::behavioural::Parameters_Statistics (5,CYCLE_MAX); 19 19 #endif 20 20 -
trunk/IPs/systemC/processor/Morpheo/Behavioural/include/Version.h
r86 r87 10 10 #define MORPHEO_MAJOR_VERSION 0 11 11 #define MORPHEO_MINOR_VERSION 2 12 #define MORPHEO_REVISION 8 612 #define MORPHEO_REVISION 87 13 13 14 14 #define MORPHEO_VERSION morpheo::toString(MORPHEO_MAJOR_VERSION)+"."+morpheo::toString(MORPHEO_MINOR_VERSION)+"."+morpheo::toString(MORPHEO_REVISION) -
trunk/IPs/systemC/processor/Morpheo/Common/include/Max.h
r81 r87 4 4 /* 5 5 * $Id$ 6 *7 * with a stephane dubuisson initial idea8 6 * 9 7 * [ Description ] … … 14 12 15 13 namespace morpheo { 16 17 template<typename T> inline T max (const T * x, uint32_t size 1)14 15 template<typename T> inline T max (const T * x, uint32_t size) 18 16 { 19 T res = 0;17 T res = x[0]; 20 18 21 for (uint32_t i= 0; i<size1; i++)19 for (uint32_t i=1; i<size; i++) 22 20 if (res<x[i]) 23 21 res = x[i]; … … 25 23 return res; 26 24 } 25 26 template<typename T> inline T max (const T * x, uint32_t size, uint32_t n) 27 { 28 if ((n==0) or (n>size)) 29 return max<T>(x,size); 30 31 // validity array 32 bool val [size]; 33 for (uint32_t i=0; i<size; i++) 34 val [i] = true; 35 36 // find min 37 T min = x[0]; 38 39 for (uint32_t i=1; i<size; i++) 40 if (min>x[i]) 41 min = x[i]; 42 43 // find n max 44 T res = min; 45 for (uint32_t i=0; i<n; i++) 46 { 47 48 uint32_t index = 0; 49 res = min; // always take the minor 50 for (uint32_t j=0; j<size; j++) 51 if ((res<x[j]) and val[j]) // find greater value, and slot is valid 52 { 53 res = x[j]; 54 index = j; 55 } 56 val [index] = false; // invalid this value 57 } 58 59 return res; 60 } 61 27 62 28 63 }; // end namespace morpheo
Note: See TracChangeset
for help on using the changeset viewer.