1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 【计算机体系结构】指令集并行(ILP)动态调度算法:Tomasulo实现代码(Tomasulo Alg

【计算机体系结构】指令集并行(ILP)动态调度算法:Tomasulo实现代码(Tomasulo Alg

时间:2021-10-20 12:44:42

相关推荐

【计算机体系结构】指令集并行(ILP)动态调度算法:Tomasulo实现代码(Tomasulo Alg

Tomasulo Algorithm Implementation

(本文章仅提供算法实现过程,具体算法思想请查阅教科书)

如果觉得这篇文章有用,请记得点个赞并收藏哦!

1.Introduction

Tomasulo算法用于指令的动态调度,允许乱序执行(Out Of Order, OOO),并允许更有效地使用多个执行单元。

'''==================================================================[Some Prerequisites]===================================================================(1) Functional units are not pipelined.(2) No forwarding, results are communicated by the common data bus (CDB). (3) Loads require two clock cycle(4) Issue (IS) and write-back (WB) result stages each require one clock cycle. (5) Branch on Not Equal to Zero (BNEZ) instruction requires one clock cycle.(6) There are 3 load buffer slots and 3 store buffer slots.(7) There are 3 FP adder and 2 FP multiplier reservation stations, respectively.----------------------------FP instruction | EX Cyclesfadd | 2fsub | 2fmult| 10fdiv | 20----------------------------output format(1) While progressing output Cycle_nReservation:(busy #yes or no), (address) # for load and storeReservation:(busy #yes or no), (op), (Vj), (Vk), (Qj), (Qk) # for othersF0(status), F2(status), F4(status),...., F12(status) # for register result status# where Vj, Vk indicate the existing source operands, Qj,Qk indicate which reservation station will producethe corresponding source operands(V and Q cannot both be set) (2) Algorithm Complete: (Instruction):(Issue cycle),(Exec comp cyclee),(Write result cycle)'''

Input1.txt

LD F6 34+ R2LD F2 45+ R3MULTD F0 F2 F4SUBD F8 F6 F2DIVD F10 F0 F6ADDD F6 F8 F2

input2.txt

LD F2 0 R2LD F4 0 R3DIVD F0 F4 F2MULTD F6 F0 F2ADDD F0 F4 F2SD F6 0 R3MULTD F6 F0 F2SD F6 0 R1

2.Implementation

算法流程:

(1)IF:从指令队列中取出指令(FIFO),如果指令对应的Reservation Station(RS)没有满,则可以发射(IS),否则等待;如果可以发射,则同时进行译码(ID),并将其放入对应的RS中,更新RS状态表,指令状态表(Instruction Status)和Register Result Status(2)EX:检查Load buffer、Store buffer、Add Reservation Station和Mult Reservation Station,若其中有指令可以执行(如操作数已经Ready),则更新其Reservation Station Status和指令状态表直到该指令执行完成后,可以进入下一阶段;(3)WB:若当前周期某指令可以写回,则更新指令状态表,若指令为DIVD、MULTD、ADDD或者LD,则更新其写入的寄存器堆,表示对应的操作数已经Ready,并更新Register Result Status,最后在对应的RS中移除该指令的记录。

每一个Cycle都会打印RS状态表及Register Result Status,在算法结束后,会打印指令状态表。

关键代码:

(更多代码注释请看源代码)

IF,ID,IS阶段

while not instructionQueue.empty() or not finish and not stall_reservationStation_Add and not stall_reservationStation_Mult:### Issue instruction (FIFO) #### 检测RS是否已满,如果未满且指令队列未空则继续取指令occupied_Add, _ = check_if_full_and_fetch(reservationStation_Add)occupied_Mult, _ = check_if_full_and_fetch(reservationStation_Mult)if not occupied_Add:stall_reservationStation_Add = Falseif not occupied_Mult:stall_reservationStation_Mult = Falseif not instructionQueue.empty() and not stall_reservationStation_Add and not stall_reservationStation_Mult:if len(stalled_instruction) != 0:cur_instruction = stalled_instruction[0]stalled_instruction.clear()ins_cnt -= 1else:cur_instruction = instructionQueue.get()if cur_instruction['opcode'] == 'ADDD' or cur_instruction['opcode'] == 'SUBD':occupied, loc = check_if_full_and_fetch(reservationStation_Add)if not occupied:reservationStation_Add[loc]['id'] = ins_cntreservationStation_Add[loc]['instruction'] = cur_instructionreservationStation_Add[loc]['occupied'] = reservationStation_Add[loc]['busy'] = TruereservationStation_Add[loc]['opcode'] = cur_instruction['opcode']if register_file[cur_instruction['rs1']]:reservationStation_Add[loc]['vj'] = register_status_dict[cur_instruction['rs1']]else:reservationStation_Add[loc]['qj'] = register_status_dict[cur_instruction['rs1']]if register_file[cur_instruction['rs2']]:reservationStation_Add[loc]['vk'] = register_status_dict[cur_instruction['rs2']]else:reservationStation_Add[loc]['qk'] = register_status_dict[cur_instruction['rs2']]# 记录该指令所依赖的RS# 用于解决数据依赖if ins_cnt not in dependency.keys():rs1 = register_status_dict[cur_instruction['rs1']]rs2 = register_status_dict[cur_instruction['rs2']] if cur_instruction['rs1'] in operand_from_load_fu.keys():rs1 = operand_from_load_fu[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_fu.keys():rs2 = operand_from_load_fu[cur_instruction['rs2']]if cur_instruction['rs1'] in operand_from_load_mult.keys():rs1 = operand_from_load_mult[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_mult.keys():rs2 = operand_from_load_mult[cur_instruction['rs2']]if cur_instruction['rs1'] in operand_from_load_add.keys():rs1 = operand_from_load_add[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_add.keys():rs2 = operand_from_load_add[cur_instruction['rs2']]# 记录该指令依赖dependency[ins_cnt] = {'rs1':rs1,'rs2':rs2}func_unit = 'Add'+str(loc+1)register_file[func_unit+cur_instruction['rt']] = Falseoperand_from_load_add[cur_instruction['rt']] = func_unitfinal_state_list[cur_instruction['id']]['issue_cycle'] = cycle# 如果Reservation Station是满的else:stall_reservationStation_Add = Truestalled_instruction.append(cur_instruction)if cur_instruction['opcode'] == 'MULTD' or cur_instruction['opcode'] == 'DIVD':occupied, loc = check_if_full_and_fetch(reservationStation_Mult)if not occupied:reservationStation_Mult[loc]['id'] = ins_cntreservationStation_Mult[loc]['instruction'] = cur_instructionreservationStation_Mult[loc]['occupied'] = reservationStation_Mult[loc]['busy'] = TruereservationStation_Mult[loc]['opcode'] = cur_instruction['opcode']if register_file[cur_instruction['rs1']]:reservationStation_Mult[loc]['vj'] = register_status_dict[cur_instruction['rs1']]else:reservationStation_Mult[loc]['qj'] = register_status_dict[cur_instruction['rs1']]if register_file[cur_instruction['rs2']]:reservationStation_Mult[loc]['vk'] = register_status_dict[cur_instruction['rs2']]else:reservationStation_Mult[loc]['qk'] = register_status_dict[cur_instruction['rs2']]# 记录该指令所依赖的RS# 用于解决数据依赖if ins_cnt not in dependency.keys():rs1 = register_status_dict[cur_instruction['rs1']]rs2 = register_status_dict[cur_instruction['rs2']] if cur_instruction['rs1'] in operand_from_load_fu.keys():rs1 = operand_from_load_fu[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_fu.keys():rs2 = operand_from_load_fu[cur_instruction['rs2']]if cur_instruction['rs1'] in operand_from_load_mult.keys():rs1 = operand_from_load_mult[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_mult.keys():rs2 = operand_from_load_mult[cur_instruction['rs2']]if cur_instruction['rs1'] in operand_from_load_add.keys():rs1 = operand_from_load_add[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_add.keys():rs2 = operand_from_load_add[cur_instruction['rs2']]# 记录该指令依赖dependency[ins_cnt] = {'rs1':rs1,'rs2':rs2}func_unit = 'Mult' + str(loc + 1)register_file[func_unit+cur_instruction['rt']] = Falseoperand_from_load_mult[cur_instruction['rt']] = func_unitregister_status_dict[cur_instruction['rt']] = func_unitfinal_state_list[cur_instruction['id']]['issue_cycle'] = cycle# 如果Reservation Station是满的else:stall_reservationStation_Mult = True# 将其放入被stall的指令列表stalled_instruction.append(cur_instruction)if cur_instruction['opcode'] == 'LD':occupied, loc = check_if_full_and_fetch(load_buffer)if not occupied:load_buffer[loc]['id'] = ins_cntload_buffer[loc]['instruction'] = cur_instructionload_buffer[loc]['occupied'] = load_buffer[loc]['busy'] = Truefinal_state_list[cur_instruction['id']]['issue_cycle'] = cycleop = cur_instruction['rs1']+cur_instruction['rs2']func_unit = 'Load' + str(loc + 1)register_file[func_unit+cur_instruction['rt']] = Falseoperand_from_load_fu[cur_instruction['rt']] = func_unitif cur_instruction['rs1'] == '0':op = cur_instruction['rs2']operand_from_load[cur_instruction['rt']] = register_status_dict[cur_instruction['rt']] = func_unitload_buffer[loc]['address'] = opif cur_instruction['opcode'] == 'SD':occupied, loc = check_if_full_and_fetch(store_buffer)if not occupied:store_buffer[loc]['id'] = ins_cntstore_buffer[loc]['instruction'] = cur_instructionstore_buffer[loc]['occupied'] = store_buffer[loc]['busy'] = Truestore_buffer[loc]['fu'] = register_status_dict[cur_instruction['rt']]final_state_list[cur_instruction['id']]['issue_cycle'] = cycleif ins_cnt not in dependency.keys():dependency[ins_cnt] = {'rt':register_status_dict[cur_instruction['rt']],}

代码描述:

在这里一共完成了算法的三个阶段,分别是IF,ID和IS,其中,IS指令发射取决于当前的队列是否未空,该指令对应的RS是否已满, 如果RS已满则将其stall,放入stalled_instruction列表,直到该RS中的指令已经执行完成,并从RS中移除后,该指令才能被发射并进入RS。

在发射时,为了解决之后可能会发生的冲突,还会记录该指令相关的信息,register_status_dict字典记录了结果操作数状态,在operand_from_load_add,operand_from_load_mult,operand_from_load字典中记录了该指令的结果操作数将会从哪个RS中的哪一项产生(之所以不使用register_status_dict是因为这个字典再操作数写回寄存器后会记录其从内存中具体位置所得的操作数的运算),此外,还使用了dependency字典,来记录该指令的源操作数由哪个RS中的哪一项所产生,如此可以解决数据依赖。

EX, WB阶段

### Execute instructions ###for i, load_ins in enumerate(load_buffer):if load_ins['busy']:if final_state_list[load_ins['id']]['issue_cycle'] + 2 == cycle:final_state_list[load_ins['id']]['exec_comp_cycle'] = cycle# Write Backif final_state_list[load_ins['id']]['exec_comp_cycle'] != '' \and final_state_list[load_ins['id']]['exec_comp_cycle'] + 1 == cycle:op = 'M(' + load_ins['instruction']['rs1'] + load_ins['instruction']['rs2'] + ')'if load_ins['instruction']['rs1'] == '0':op = 'M(' + load_ins['instruction']['rs2'] + ')'register_status_dict[load_ins['instruction']['rt']] = \operand_from_load[load_ins['instruction']['rt']] = opfinal_state_list[load_ins['id']]['write_result_cycle'] = cyclefunc_unit = 'Load' + str(i + 1)register_file[func_unit+load_ins['instruction']['rt']] = True# 清除表项load_ins['busy'] = load_ins['occupied'] = Falseload_ins['address'] = ''load_ins['id'] = -1for i, res_add in enumerate(reservationStation_Add):# 在每一个cycle都检查处于busy状态的指令需要的操作数是否已经Readyif res_add['busy']:if res_add['id'] in dependency.keys():rs1_reg = dependency[res_add['id']]['rs1'] + res_add['instruction']['rs1'] # FU + 源寄存器1if register_file[rs1_reg]: # 若源操作数rs1已经被写入寄存器堆res_add['qj'] = ''res_add['vj'] = register_status_dict[res_add['instruction']['rs1']]else:if register_status_dict[res_add['instruction']['rs1']] != '':res_add['qj'] = register_status_dict[res_add['instruction']['rs1']]if res_add['id'] in dependency.keys():rs2_reg = dependency[res_add['id']]['rs2'] + res_add['instruction']['rs2'] # FU + 源寄存器2if register_file[rs2_reg]: # 若源操作数rs2已经被写入寄存器堆res_add['qk'] = ''res_add['vk'] = register_status_dict[res_add['instruction']['rs2']]else:if register_status_dict[res_add['instruction']['rs2']] != '':res_add['qk'] = register_status_dict[res_add['instruction']['rs2']]# 如果两个源操作数都已经Ready,那么可以进入EX Stage, add, sub都需要2个cycle来执行if res_add['vj'] != '' and res_add['vk'] != '' and final_state_list[res_add['id']]['exec_comp_cycle'] == '':final_state_list[res_add['id']]['exec_comp_cycle'] = cycle + 2# Write Back, update FUif final_state_list[res_add['id']]['exec_comp_cycle'] != '' and \final_state_list[res_add['id']]['exec_comp_cycle'] + 1 == cycle:final_state_list[res_add['id']]['write_result_cycle'] = cyclefunc_unit = 'Add' + str(i + 1)rt = func_unit+res_add['instruction']['rt']register_file[rt] = Trueop1 = register_status_dict[res_add['instruction']['rs1']]op2 = register_status_dict[res_add['instruction']['rs2']]if res_add['instruction']['rs1'] in operand_from_load.keys():op1 = operand_from_load[res_add['instruction']['rs1']]if res_add['instruction']['rs2'] in operand_from_load.keys():op2 = operand_from_load[res_add['instruction']['rs2']]if res_add['opcode'] == "SUBD":register_status_dict[res_add['instruction']['rt']] = \op1 + '-' + op2if res_add['instruction']['rt'] not in dependency_res_status_dict.keys():dependency_res_status_dict[rt] = op1 + '-' + op2else:register_status_dict[res_add['instruction']['rt']] = \op1 + '+' + op2if res_add['instruction']['rt'] not in dependency_res_status_dict.keys():dependency_res_status_dict[rt] = op1 + '+' + op2remove_reservation_station(reservationStation_Add, i)for i, res_mult in enumerate(reservationStation_Mult):if res_mult['busy']:if res_mult['id'] in dependency.keys():rs1_reg = dependency[res_mult['id']]['rs1']+res_mult['instruction']['rs1'] # FU + 源寄存器1if register_file[rs1_reg]: # 若源操作数rs1已经被写入寄存器堆res_mult['qj'] = ''res_mult['vj'] = register_status_dict[res_mult['instruction']['rs1']]if rs1_reg in dependency_res_status_dict.keys():res_mult['vj'] = dependency_res_status_dict[rs1_reg] # 结果状态避免被其他写相同寄存器的指令覆盖else:if register_status_dict[res_mult['instruction']['rs1']] != '':res_mult['qj'] = register_status_dict[res_mult['instruction']['rs1']]if res_mult['id'] in dependency.keys():rs2_reg = dependency[res_mult['id']]['rs2']+res_mult['instruction']['rs2'] # FU + 源寄存器2if register_file[rs2_reg]: # 若源操作数rs2已经被写入寄存器堆res_mult['qk'] = ''res_mult['vk'] = register_status_dict[res_mult['instruction']['rs2']]else:if register_status_dict[res_mult['instruction']['rs2']] != '':res_mult['qk'] = register_status_dict[res_mult['instruction']['rs2']]# mult需要10个cycle, div需要20个cycleif res_mult['vj'] != '' and res_mult['vk'] != '' and final_state_list[res_mult['id']]['exec_comp_cycle'] == '':if res_mult['opcode'] == 'MULTD':final_state_list[res_mult['id']]['exec_comp_cycle'] = cycle + 10else:final_state_list[res_mult['id']]['exec_comp_cycle'] = cycle + 20# Write Backif final_state_list[res_mult['id']]['exec_comp_cycle'] != '' and \final_state_list[res_mult['id']]['exec_comp_cycle'] + 1 == cycle:final_state_list[res_mult['id']]['write_result_cycle'] = cyclefunc_unit = 'Mult' + str(i + 1)register_file[func_unit+res_mult['instruction']['rt']] = Trueop1 = register_status_dict[res_mult['instruction']['rs1']]op2 = register_status_dict[res_mult['instruction']['rs2']]if res_mult['instruction']['rs1'] in operand_from_load.keys():op1 = operand_from_load[res_mult['instruction']['rs1']]if res_mult['instruction']['rs2'] in operand_from_load.keys():op2 = operand_from_load[res_mult['instruction']['rs2']]if res_mult['opcode'] == "MULTD":register_status_dict[res_mult['instruction']['rt']] = op1 + '*' + op2else:register_status_dict[res_mult['instruction']['rt']] = op1 + '/' + op2remove_reservation_station(reservationStation_Mult, i)for i, store_ins in enumerate(store_buffer):if store_ins['busy']:if store_ins['id'] in dependency.keys():# Write Backrt_reg = dependency[store_ins['id']]['rt'] + store_ins['instruction']['rt']# FU + 目的寄存器if register_file[rt_reg]: # 若目的寄存器rt已经被写入寄存器堆final_state_list[store_ins['id']]['exec_comp_cycle'] = cycle + 2register_file[rt_reg] = False # 这里置成False,表示已经取到rt且避免因为下一个周期又将EX Comp的值再增加2if final_state_list[store_ins['id']]['exec_comp_cycle'] != '' and \final_state_list[store_ins['id']]['exec_comp_cycle'] + 1 == cycle:final_state_list[store_ins['id']]['write_result_cycle'] = cycle# 清除表项store_ins['busy'] = store_ins['occupied'] = Falsestore_ins['address'] = ''store_ins['fu'] = ''store_ins['id'] = -1

代码描述:

这部分代码完成了指令的EX和WB阶段的操作,final_state_list字典用于记录指令的状态(包括issue_cycle、exec_comp_cycle、write_result_cycle的具体周期数),通过遍历每一个RS,可以根据指令对应的源操作数来判断是否执行该指令,在register_file字典中(寄存器堆),保存了所有寄存器的状态(格式为:FU+目的寄存器: True/False,如:‘Mult1F0’: True’),如果某RS中所产生的操作数已经被写入寄存器堆则置为True,指令可以据此来判断是否可以执行。在执行完成后,进入WB阶段,指令可以判断当前Cycle是否可以写回,写回寄存器堆后,同时更新register_status_dict,register_filefinal_state_list,并将该指令从对应的RS中移除。

3.Result

Output1.txt

LD F6 34+ R2:1,3,4;LD F2 45+ R3:2,4,5;MULTD F0 F2 F4:3,15,16;SUBD F8 F6 F2:4,7,8;DIVD F10 F0 F6:5,36,37;ADDD F6 F8 F2:6,10,11;

结果分析:

从结果来看,这六条指令分别在前6个cycle依次issue,并且两条LD指令在第3,4个cycle和第4,5个cycle完成了执行和写回阶段,MULTD指令由于需要10个cycle来执行(在第6个cycle开始时可以执行)到第15个cycle执行结束,SUBD需要2个cycle执行(在第6个cycle开始时可以执行)到第7个cycle执行结束,DIVD指令依赖于MULTD指令的结果F0,所以等到第17个cycle才开始执行,需要执行20个cycle,因此在第36个cycle执行结束,ADDD指令依赖于SUBD指令的结果F8,所以在第9个cycle才开始执行,需要2个cycle执行。

Output2.txt

LD F2 0 R2:1,3,4;LD F4 0 R3:2,4,5;DIVD F0 F4 F2:3,25,26;MULTD F6 F0 F2:4,36,37;ADDD F0 F4 F2:5,7,8;SD F6 0 R3:6,39,40;MULTD F6 F0 F2:27,37,38;SD F6 0 R1:28,40,41;

结果分析:

从结果来看,前六条指令分别在前6个cycle依次issue,并且两条LD指令在第3,4个cycle和第4,5个cycle完成了执行和写回阶段,第7条的MULTD F6 F0 F2指令由于RS已满(被DIVD F0 F4 F2和MULTD F6 F0 F2指令占用)所以需要等到它们其中之一的指令执行完才能被issue,可以看到,DIVD指令在26个cycle写回,MULTD F6 F0 F2指令在第37个cycle写回(因为这条指令依赖于DIVD指令的结果F0),所以到第27个cycle,MULTD F6 F0 F2指令才被issue到对应的RS中,它需要执行10个cycle,所以在第27个cycle时执行完毕,最终,最后一条指令SD F6 0 R1将它的上一条指令MULTD F6 F0 F2所产生的结果F6保存到内存的对应位置中。

完整代码

import osfrom queue import Queuefrom collections import Counterfrom copy import deepcopycnt = 1register_file = []output_file1 = './output1.txt'output_file2 = './output2.txt'output_test = './test.txt'test1 = './input1.txt'test2 = './input2.txt' fu_adder_lock = False # 加法器资源锁(暂时不用)fu_mult_lock = False # 乘法器锁(暂时不用)constant_reg = ['F4']operand_from_load = {}operand_from_load_fu = {} # 保存LD指令对应的load_buffer(FU)operand_from_load_mult = {} # 保存DIVD/MULT指令对应的RS名字operand_from_load_add = {} # 保存ADDD/SUBD指令对应的RS名字stalled_instruction = [] # 保存因为结构冒险而stall的指令dependency = {} # 保存依赖关系(ID:{rs1:FU, rs2:FU}) or ID:{rt:FU})dependency_res_status_dict = {} # 保存指令所依赖的RS################# 在这里选择测例和输出文件 ################test = test1output_file = output_file1'''==================================================================[Some Prerequisites]===================================================================(1) Functional units are not pipelined.(2) No forwarding, results are communicated by the common data bus (CDB). (3) Loads require two clock cycle(4) Issue (IS) and write-back (WB) result stages each require one clock cycle. (5) Branch on Not Equal to Zero (BNEZ) instruction requires one clock cycle.(6) There are 3 load buffer slots and 3 store buffer slots.(7) There are 3 FP adder and 2 FP multiplier reservation stations, respectively.----------------------------FP instruction | EX Cyclesfadd | 2fsub | 2fmult| 10fdiv | 20----------------------------output format(1) While progressing output Cycle_nReservation:(busy #yes or no), (address) # for load and storeReservation:(busy #yes or no), (op), (Vj), (Vk), (Qj), (Qk) # for othersF0(status), F2(status), F4(status),...., F12(status) # for register result status# where Vj, Vk indicate the existing source operands, Qj,Qk indicate which reservation station will producethe corresponding source operands(V and Q cannot both be set) (2) Algorithm Complete: (Instruction):(Issue cycle),(Exec comp cyclee),(Write result cycle)'''def read_ins(filename=None):with open(filename, 'r') as f:ins = f.readlines()ins = [i.rstrip().split() for i in ins]return insdef check_if_full_and_fetch(reservationStation):'''如果Reservation Station中有空位,那么返回对应的index并且返回flag为False表示未满:param reservationStation: MultRS或AddRS:return: 如果相应的RS未满则返回flag = False和对应的loc表示index'''flag = Trueloc = Nonefor i, res in enumerate(reservationStation):if res['occupied'] is False:loc = iflag = Falsebreakreturn flag, locdef check_if_done(reservationStation):'''检查Reservation Station中是否还有没有执行完毕的指令:param reservationStation: MultRS或AddRS:return: 如果RS中存在未执行完的指令则返回flag = False'''flag = Truefor res in reservationStation:if res['occupied'] is True:flag = Falsebreakreturn flagdef remove_reservation_station(reservationStation, idx):'''移除RS中对应index的项:param reservationStation: MultRS或AddRS:param idx: MultRS或AddRS中项的index:return: None'''reservationStation[idx]['busy'] = reservationStation[idx]['occupied'] = FalsereservationStation[idx]['opcode'] = ''reservationStation[idx]['vj'] = reservationStation[idx]['vk'] = ''reservationStation[idx]['qj'] = reservationStation[idx]['qk'] = ''reservationStation[idx]['instruction'] = NonereservationStation[idx]['id'] = -1def print_state_table(cycle, reservationStation_Add,reservationStation_Mult, register_status_dict, load_buffer, store_buffer):'''打印当前cycle 所有RS的状态:param cycle: 当前周期数:param reservationStation_Add: AddRS:param reservationStation_Mult: MultRS:param register_status_dict: Register Result Status:param load_buffer: Load RS:param store_buffer: Store RS:return: None'''with open(output_file, 'a') as f:print('Cycle_'+str(cycle), file=f)for i, load_state in enumerate(load_buffer):if load_state['busy']:print('Load'+str(i+1) + ':Yes,' + load_state['address'] + ';', file=f)else:print('Load'+str(i+1) + ':No,' + ';', file=f)for i, store_state in enumerate(store_buffer):if store_state['busy']:print('Store'+str(i+1) + ':Yes,' + store_state['address'], store_state['fu']+';', file=f)else:print('Store'+str(i+1) + ':No,,'+';', file=f)for i, add_state in enumerate(reservationStation_Add):if add_state['busy']:print('Add' + str(i + 1) + ':Yes,' + add_state['opcode']+ ',' +add_state['vj'] + ',' + add_state['vk'] + ',' +add_state['qj'] + ',' + add_state['qk'] + ';', file=f)else:print('Add' + str(i + 1) + ':No,,,,,' + ';', file=f)for i, mult_state in enumerate(reservationStation_Mult):if mult_state['busy']:print('Mult' + str(i + 1) + ':Yes,' + mult_state['opcode'] + ',' +mult_state['vj'] + ',' + mult_state['vk'] + ',' +mult_state['qj'] + ',' + mult_state['qk'] + ';', file=f)else:print('Mult' + str(i + 1) + ':No,,,,,' + ';', file=f)for k, v in register_status_dict.items():val = v# 在input1中把F4当成了常量寄存器if test == test1:if k == 'F4':val = ''print(k + ':' + val + ';', end='', file=f)print('\n', file=f)def print_final_state(final_state_list):'''打印最终Instruction Status结果:param final_state_list: Instruction Status列表:return: None'''with open(output_file, 'a') as f:for state in final_state_list:print(state['instruction'] + ':' + str(state['issue_cycle']) + ','+ str(state['exec_comp_cycle']) + ',' + str(state['write_result_cycle']) + ';', file=f)print('RESULT INSTRUCTION STATUS')for state in final_state_list:print(state['instruction'] + ':' + str(state['issue_cycle']) + ','+ str(state['exec_comp_cycle']) + ',' + str(state['write_result_cycle']) + ';')def tomasulo_alg(instructionQueue, reservationStation_Add,reservationStation_Mult, register_status_dict, load_buffer, store_buffer, final_state_list):''':param instructionQueue: 指令队列:param reservationStation_Add: AddRS:param reservationStation_Mult: MultRS:param register_status_dict: Register Result Status:param load_buffer: LoadRS:param store_buffer: StoreRS:param final_state_list: Instruction Status列表:return: None'''cycle = 1 ins_cnt = 0 # 作为指令编号finish = Falsestall_reservationStation_Add = False # AddRS是否Stallstall_reservationStation_Mult = False # MultRS是否Stallif test == test1:register_file['R(F4)F4'] = Truewhile not instructionQueue.empty() or not finish and not stall_reservationStation_Add and not stall_reservationStation_Mult:### Issue instruction (FIFO) #### 检测RS是否已满,如果未满且指令队列未空则继续取指令occupied_Add, _ = check_if_full_and_fetch(reservationStation_Add)occupied_Mult, _ = check_if_full_and_fetch(reservationStation_Mult)if not occupied_Add:stall_reservationStation_Add = Falseif not occupied_Mult:stall_reservationStation_Mult = Falseif not instructionQueue.empty() and not stall_reservationStation_Add and not stall_reservationStation_Mult:if len(stalled_instruction) != 0:cur_instruction = stalled_instruction[0]stalled_instruction.clear()ins_cnt -= 1else:cur_instruction = instructionQueue.get()if cur_instruction['opcode'] == 'ADDD' or cur_instruction['opcode'] == 'SUBD':occupied, loc = check_if_full_and_fetch(reservationStation_Add)if not occupied:reservationStation_Add[loc]['id'] = ins_cntreservationStation_Add[loc]['instruction'] = cur_instructionreservationStation_Add[loc]['occupied'] = reservationStation_Add[loc]['busy'] = TruereservationStation_Add[loc]['opcode'] = cur_instruction['opcode']if register_file[cur_instruction['rs1']]:reservationStation_Add[loc]['vj'] = register_status_dict[cur_instruction['rs1']]else:reservationStation_Add[loc]['qj'] = register_status_dict[cur_instruction['rs1']]if register_file[cur_instruction['rs2']]:reservationStation_Add[loc]['vk'] = register_status_dict[cur_instruction['rs2']]else:reservationStation_Add[loc]['qk'] = register_status_dict[cur_instruction['rs2']]if ins_cnt not in dependency.keys():rs1 = register_status_dict[cur_instruction['rs1']]rs2 = register_status_dict[cur_instruction['rs2']] if cur_instruction['rs1'] in operand_from_load_fu.keys():rs1 = operand_from_load_fu[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_fu.keys():rs2 = operand_from_load_fu[cur_instruction['rs2']]if cur_instruction['rs1'] in operand_from_load_mult.keys():rs1 = operand_from_load_mult[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_mult.keys():rs2 = operand_from_load_mult[cur_instruction['rs2']]if cur_instruction['rs1'] in operand_from_load_add.keys():rs1 = operand_from_load_add[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_add.keys():rs2 = operand_from_load_add[cur_instruction['rs2']]# 记录该指令依赖dependency[ins_cnt] = {'rs1':rs1,'rs2':rs2}func_unit = 'Add'+str(loc+1)register_file[func_unit+cur_instruction['rt']] = Falseoperand_from_load_add[cur_instruction['rt']] = func_unitregister_status_dict[cur_instruction['rt']] = func_unitfinal_state_list[cur_instruction['id']]['issue_cycle'] = cycle# 如果Reservation Station是满的else:stall_reservationStation_Add = Truestalled_instruction.append(cur_instruction)if cur_instruction['opcode'] == 'MULTD' or cur_instruction['opcode'] == 'DIVD':occupied, loc = check_if_full_and_fetch(reservationStation_Mult)if not occupied:reservationStation_Mult[loc]['id'] = ins_cntreservationStation_Mult[loc]['instruction'] = cur_instructionreservationStation_Mult[loc]['occupied'] = reservationStation_Mult[loc]['busy'] = TruereservationStation_Mult[loc]['opcode'] = cur_instruction['opcode']if register_file[cur_instruction['rs1']]:reservationStation_Mult[loc]['vj'] = register_status_dict[cur_instruction['rs1']]else:reservationStation_Mult[loc]['qj'] = register_status_dict[cur_instruction['rs1']]if register_file[cur_instruction['rs2']]:reservationStation_Mult[loc]['vk'] = register_status_dict[cur_instruction['rs2']]else:reservationStation_Mult[loc]['qk'] = register_status_dict[cur_instruction['rs2']]# 记录该指令所依赖的RS# 用于解决数据依赖if ins_cnt not in dependency.keys():rs1 = register_status_dict[cur_instruction['rs1']]rs2 = register_status_dict[cur_instruction['rs2']] if cur_instruction['rs1'] in operand_from_load_fu.keys():rs1 = operand_from_load_fu[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_fu.keys():rs2 = operand_from_load_fu[cur_instruction['rs2']]if cur_instruction['rs1'] in operand_from_load_mult.keys():rs1 = operand_from_load_mult[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_mult.keys():rs2 = operand_from_load_mult[cur_instruction['rs2']]if cur_instruction['rs1'] in operand_from_load_add.keys():rs1 = operand_from_load_add[cur_instruction['rs1']]if cur_instruction['rs2'] in operand_from_load_add.keys():rs2 = operand_from_load_add[cur_instruction['rs2']]# 记录该指令依赖dependency[ins_cnt] = {'rs1':rs1,'rs2':rs2}func_unit = 'Mult' + str(loc + 1)register_file[func_unit+cur_instruction['rt']] = Falseoperand_from_load_mult[cur_instruction['rt']] = func_unitregister_status_dict[cur_instruction['rt']] = func_unitfinal_state_list[cur_instruction['id']]['issue_cycle'] = cycle# 如果Reservation Station是满的else:stall_reservationStation_Mult = True# 将其放入被stall的指令列表stalled_instruction.append(cur_instruction)if cur_instruction['opcode'] == 'LD':occupied, loc = check_if_full_and_fetch(load_buffer)if not occupied:load_buffer[loc]['id'] = ins_cntload_buffer[loc]['instruction'] = cur_instructionload_buffer[loc]['occupied'] = load_buffer[loc]['busy'] = Truefinal_state_list[cur_instruction['id']]['issue_cycle'] = cycleop = cur_instruction['rs1']+cur_instruction['rs2']func_unit = 'Load' + str(loc + 1)register_file[func_unit+cur_instruction['rt']] = Falseoperand_from_load_fu[cur_instruction['rt']] = func_unitif cur_instruction['rs1'] == '0':op = cur_instruction['rs2']operand_from_load[cur_instruction['rt']] = register_status_dict[cur_instruction['rt']] = func_unitload_buffer[loc]['address'] = opif cur_instruction['opcode'] == 'SD':occupied, loc = check_if_full_and_fetch(store_buffer)if not occupied:store_buffer[loc]['id'] = ins_cntstore_buffer[loc]['instruction'] = cur_instructionstore_buffer[loc]['occupied'] = store_buffer[loc]['busy'] = Truestore_buffer[loc]['fu'] = register_status_dict[cur_instruction['rt']]final_state_list[cur_instruction['id']]['issue_cycle'] = cycleif ins_cnt not in dependency.keys():dependency[ins_cnt] = {'rt':register_status_dict[cur_instruction['rt']],}ins_cnt += 1### Execute instructions ###for i, load_ins in enumerate(load_buffer):if load_ins['busy']:if final_state_list[load_ins['id']]['issue_cycle'] + 2 == cycle:final_state_list[load_ins['id']]['exec_comp_cycle'] = cycle# Write Backif final_state_list[load_ins['id']]['exec_comp_cycle'] != '' \and final_state_list[load_ins['id']]['exec_comp_cycle'] + 1 == cycle:op = 'M(' + load_ins['instruction']['rs1'] + load_ins['instruction']['rs2'] + ')'if load_ins['instruction']['rs1'] == '0':op = 'M(' + load_ins['instruction']['rs2'] + ')'register_status_dict[load_ins['instruction']['rt']] = \operand_from_load[load_ins['instruction']['rt']] = opfinal_state_list[load_ins['id']]['write_result_cycle'] = cyclefunc_unit = 'Load' + str(i + 1)register_file[func_unit+load_ins['instruction']['rt']] = True# 清除表项load_ins['busy'] = load_ins['occupied'] = Falseload_ins['address'] = ''load_ins['id'] = -1for i, res_add in enumerate(reservationStation_Add):# 在每一个cycle都检查处于busy状态的指令需要的操作数是否已经Readyif res_add['busy']:if res_add['id'] in dependency.keys():rs1_reg = dependency[res_add['id']]['rs1'] + res_add['instruction']['rs1'] # FU + 源寄存器1if register_file[rs1_reg]: # 若源操作数rs1已经被写入寄存器堆res_add['qj'] = ''res_add['vj'] = register_status_dict[res_add['instruction']['rs1']]else:if register_status_dict[res_add['instruction']['rs1']] != '':res_add['qj'] = register_status_dict[res_add['instruction']['rs1']]if res_add['id'] in dependency.keys():rs2_reg = dependency[res_add['id']]['rs2'] + res_add['instruction']['rs2'] # FU + 源寄存器2if register_file[rs2_reg]: # 若源操作数rs2已经被写入寄存器堆res_add['qk'] = ''res_add['vk'] = register_status_dict[res_add['instruction']['rs2']]else:if register_status_dict[res_add['instruction']['rs2']] != '':res_add['qk'] = register_status_dict[res_add['instruction']['rs2']]# 如果两个源操作数都已经Ready,那么可以进入EX Stage, add, sub都需要2个cycle来执行if res_add['vj'] != '' and res_add['vk'] != '' and final_state_list[res_add['id']]['exec_comp_cycle'] == '':final_state_list[res_add['id']]['exec_comp_cycle'] = cycle + 2# Write Back, update FUif final_state_list[res_add['id']]['exec_comp_cycle'] != '' and \final_state_list[res_add['id']]['exec_comp_cycle'] + 1 == cycle:final_state_list[res_add['id']]['write_result_cycle'] = cyclefunc_unit = 'Add' + str(i + 1)rt = func_unit+res_add['instruction']['rt']register_file[rt] = Trueop1 = register_status_dict[res_add['instruction']['rs1']]op2 = register_status_dict[res_add['instruction']['rs2']]if res_add['instruction']['rs1'] in operand_from_load.keys():op1 = operand_from_load[res_add['instruction']['rs1']]if res_add['instruction']['rs2'] in operand_from_load.keys():op2 = operand_from_load[res_add['instruction']['rs2']]if res_add['opcode'] == "SUBD":register_status_dict[res_add['instruction']['rt']] = \op1 + '-' + op2if res_add['instruction']['rt'] not in dependency_res_status_dict.keys():dependency_res_status_dict[rt] = op1 + '-' + op2else:register_status_dict[res_add['instruction']['rt']] = \op1 + '+' + op2if res_add['instruction']['rt'] not in dependency_res_status_dict.keys():dependency_res_status_dict[rt] = op1 + '+' + op2remove_reservation_station(reservationStation_Add, i)for i, res_mult in enumerate(reservationStation_Mult):if res_mult['busy']:if res_mult['id'] in dependency.keys():rs1_reg = dependency[res_mult['id']]['rs1']+res_mult['instruction']['rs1'] # FU + 源寄存器1if register_file[rs1_reg]: # 若源操作数rs1已经被写入寄存器堆res_mult['qj'] = ''res_mult['vj'] = register_status_dict[res_mult['instruction']['rs1']]if rs1_reg in dependency_res_status_dict.keys():res_mult['vj'] = dependency_res_status_dict[rs1_reg] # 结果状态避免被其他写相同寄存器的指令覆盖else:if register_status_dict[res_mult['instruction']['rs1']] != '':res_mult['qj'] = register_status_dict[res_mult['instruction']['rs1']]if res_mult['id'] in dependency.keys():rs2_reg = dependency[res_mult['id']]['rs2']+res_mult['instruction']['rs2'] # FU + 源寄存器2if register_file[rs2_reg]: # 若源操作数rs2已经被写入寄存器堆res_mult['qk'] = ''res_mult['vk'] = register_status_dict[res_mult['instruction']['rs2']]else:if register_status_dict[res_mult['instruction']['rs2']] != '':res_mult['qk'] = register_status_dict[res_mult['instruction']['rs2']]# mult需要10个cycle, div需要20个cycleif res_mult['vj'] != '' and res_mult['vk'] != '' and final_state_list[res_mult['id']]['exec_comp_cycle'] == '':if res_mult['opcode'] == 'MULTD':final_state_list[res_mult['id']]['exec_comp_cycle'] = cycle + 10else:final_state_list[res_mult['id']]['exec_comp_cycle'] = cycle + 20# Write Backif final_state_list[res_mult['id']]['exec_comp_cycle'] != '' and \final_state_list[res_mult['id']]['exec_comp_cycle'] + 1 == cycle:final_state_list[res_mult['id']]['write_result_cycle'] = cyclefunc_unit = 'Mult' + str(i + 1)register_file[func_unit+res_mult['instruction']['rt']] = Trueop1 = register_status_dict[res_mult['instruction']['rs1']]op2 = register_status_dict[res_mult['instruction']['rs2']]if res_mult['instruction']['rs1'] in operand_from_load.keys():op1 = operand_from_load[res_mult['instruction']['rs1']]if res_mult['instruction']['rs2'] in operand_from_load.keys():op2 = operand_from_load[res_mult['instruction']['rs2']]if res_mult['opcode'] == "MULTD":register_status_dict[res_mult['instruction']['rt']] = op1 + '*' + op2else:register_status_dict[res_mult['instruction']['rt']] = op1 + '/' + op2remove_reservation_station(reservationStation_Mult, i)for i, store_ins in enumerate(store_buffer):if store_ins['busy']:if store_ins['id'] in dependency.keys():# Write Backrt_reg = dependency[store_ins['id']]['rt'] + store_ins['instruction']['rt']# FU + 目的寄存器if register_file[rt_reg]: # 若目的寄存器rt已经被写入寄存器堆final_state_list[store_ins['id']]['exec_comp_cycle'] = cycle + 2register_file[rt_reg] = False # 这里置成False,表示已经取到rt且避免因为下一个周期又将EX Comp的值再增加2if final_state_list[store_ins['id']]['exec_comp_cycle'] != '' and \final_state_list[store_ins['id']]['exec_comp_cycle'] + 1 == cycle:final_state_list[store_ins['id']]['write_result_cycle'] = cycle# 清除表项store_ins['busy'] = store_ins['occupied'] = Falsestore_ins['address'] = ''store_ins['fu'] = ''store_ins['id'] = -1print_state_table(cycle, reservationStation_Add,reservationStation_Mult, register_status_dict, load_buffer, store_buffer)cycle += 1# if all works donedone1 = check_if_done(reservationStation_Add)done2 = check_if_done(reservationStation_Mult)done3 = check_if_done(load_buffer)done4 = check_if_done(store_buffer)if done1 and done2 and done3 and done4 is True:finish = Trueelse:finish = Falseif __name__ == '__main__':# Hyper-parameterssize_of_reservationStation_Add = 3size_of_reservationStation_Mult = 2size_of_register_status_list = 5size_of_load_buffer = 3size_of_store_buffer = 3# 字典itemsitem_of_reservationStation = {'id': -1,'instruction': None,'occupied': False,'busy': False,'opcode': '','vj': '','vk': '','qj': '','qk': ''}item_of_load_buffer = {'id': -1,'instruction': None,'occupied': False,'busy': False,'address':''}item_of_store_buffer = {'id': -1,'instruction': None,'occupied': False,'busy': False,'address': '','fu': ''}final_state = {'instruction': '','issue_cycle': -1,'exec_comp_cycle': '','write_result_cycle': ''}instructionQueue = Queue()reservationStation_Add = [deepcopy(item_of_reservationStation) for _ in range(size_of_reservationStation_Add)]reservationStation_Mult = [deepcopy(item_of_reservationStation) for _ in range(size_of_reservationStation_Mult)]register_status_dict = {'F'+str(i*2): '' for i in range(size_of_register_status_list)}register_file = {'F'+str(i*2): False for i in range(size_of_register_status_list)}if test == test1:register_status_dict['F4'] = 'R(F4)' # 在input1中把F4当成了常量寄存器register_file['F4'] = Trueload_buffer = [deepcopy(item_of_load_buffer) for _ in range(size_of_load_buffer)]store_buffer = [deepcopy(item_of_store_buffer) for _ in range(size_of_store_buffer)]# Read Instructions HereinstructionList = read_ins(test)final_state_list = [deepcopy(final_state) for _ in range(len(instructionList))]print('Tomasulo\'s algorithm dynamically scheduling the following %d instructions:' %(len(instructionList)))for i, ins in enumerate(instructionList):ins_dict = {'id': i,'opcode': ins[0],'rt': ins[1],'rs1': ins[2],'rs2': ins[3]}instructionQueue.put(ins_dict)instruction = ' '.join(ins)final_state_list[i]['instruction'] = instructionprint('(' + str(cnt) + ') ' + instruction)cnt += 1print('============================================\n')with open(output_file, 'w') as f:pass# 算法执行tomasulo_alg(instructionQueue, reservationStation_Add, reservationStation_Mult,register_status_dict, load_buffer, store_buffer, final_state_list)# 打印最终结果print_final_state(final_state_list)

完整output1.txt

Cycle_1Load1:Yes,34+R2;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:No,,,,,;F0:;F2:;F4:;F6:Load1;F8:;Cycle_2Load1:Yes,34+R2;Load2:Yes,45+R3;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:No,,,,,;F0:;F2:Load2;F4:;F6:Load1;F8:;Cycle_3Load1:Yes,34+R2;Load2:Yes,45+R3;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,,R(F4),Load2,;Mult2:No,,,,,;F0:Mult1;F2:Load2;F4:;F6:Load1;F8:;Cycle_4Load1:No,;Load2:Yes,45+R3;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:Yes,SUBD,M(34+R2),,,Load2;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,,R(F4),Load2,;Mult2:No,,,,,;F0:Mult1;F2:Load2;F4:;F6:M(34+R2);F8:Add1;Cycle_5Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:Yes,SUBD,M(34+R2),M(45+R3),,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,M(34+R2),Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:M(34+R2);F8:Add1;F10:Mult2;Cycle_6Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:Yes,SUBD,Add2,M(45+R3),,;Add2:Yes,ADDD,,M(45+R3),Add1,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,Add2,Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:Add2;F8:Add1;F10:Mult2;Cycle_7Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:Yes,SUBD,Add2,M(45+R3),,;Add2:Yes,ADDD,,M(45+R3),Add1,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,Add2,Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:Add2;F8:Add1;F10:Mult2;Cycle_8Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:Yes,ADDD,M(34+R2)-M(45+R3),M(45+R3),,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,Add2,Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:Add2;F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_9Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:Yes,ADDD,M(34+R2)-M(45+R3),M(45+R3),,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,Add2,Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:Add2;F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_10Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:Yes,ADDD,M(34+R2)-M(45+R3),M(45+R3),,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,Add2,Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:Add2;F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_11Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,M(34+R2)-M(45+R3)+M(45+R3),Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_12Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,M(34+R2)-M(45+R3)+M(45+R3),Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_13Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,M(34+R2)-M(45+R3)+M(45+R3),Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_14Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,M(34+R2)-M(45+R3)+M(45+R3),Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_15Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(45+R3),R(F4),,;Mult2:Yes,DIVD,,M(34+R2)-M(45+R3)+M(45+R3),Mult1,;F0:Mult1;F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_16Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_17Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_18Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_19Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_20Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_21Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_22Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_23Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_24Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_25Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_26Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_27Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_28Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_29Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_30Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_31Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_32Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_33Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_34Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_35Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_36Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,DIVD,M(45+R3)*R(F4),M(34+R2)-M(45+R3)+M(45+R3),,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:Mult2;Cycle_37Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:No,,,,,;F0:M(45+R3)*R(F4);F2:M(45+R3);F4:;F6:M(34+R2)-M(45+R3)+M(45+R3);F8:M(34+R2)-M(45+R3);F10:M(45+R3)*R(F4)/M(34+R2);LD F6 34+ R2:1,3,4;LD F2 45+ R3:2,4,5;MULTD F0 F2 F4:3,15,16;SUBD F8 F6 F2:4,7,8;DIVD F10 F0 F6:5,36,37;ADDD F6 F8 F2:6,10,11;

完整output2.txt

Cycle_1Load1:Yes,R2;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:No,,,,,;F0:;F2:Load1;F4:;F6:;F8:;Cycle_2Load1:Yes,R2;Load2:Yes,R3;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:No,,,,,;F0:;F2:Load1;F4:;F6:;F8:;Cycle_3Load1:Yes,R2;Load2:Yes,R3;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,,,Load2,Load1;Mult2:No,,,,,;F0:Mult1;F2:Load1;F4:;F6:;F8:;Cycle_4Load1:No,;Load2:Yes,R3;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,,M(R2),Load2,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:Mult1;F2:M(R2);F4:;F6:Mult2;F8:;Cycle_5Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:Yes,ADDD,M(R3),M(R2),,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:Mult1;F2:M(R2);F4:;F6:Mult2;F8:;Cycle_6Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:Yes,ADDD,M(R3),M(R2),,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:Mult1;F2:M(R2);F4:;F6:Mult2;F8:;Cycle_7Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:Yes,ADDD,M(R3),M(R2),,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:Mult1;F2:M(R2);F4:;F6:Mult2;F8:;Cycle_8Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_9Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_10Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_11Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_12Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_13Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_14Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_15Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_16Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_17Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_18Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_19Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_20Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_21Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_22Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_23Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_24Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_25Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,DIVD,M(R3),M(R2),,;Mult2:Yes,MULTD,,M(R2),Mult1,;F0:M(R3)+M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_26Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult2;F8:;Cycle_27Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult1;F8:;Cycle_28Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult1;F8:;Cycle_29Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult1;F8:;Cycle_30Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult1;F8:;Cycle_31Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult1;F8:;Cycle_32Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult1;F8:;Cycle_33Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult1;F8:;Cycle_34Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult1;F8:;Cycle_35Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult1;F8:;Cycle_36Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:Yes,MULTD,M(R3)/M(R2),M(R2),,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:Mult1;F8:;Cycle_37Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:Yes,MULTD,M(R3)+M(R2),M(R2),,;Mult2:No,,,,,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:M(R3)/M(R2)*M(R2);F8:;Cycle_38Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:No,,,,,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:M(R3)/M(R2)*M(R2);F8:;Cycle_39Load1:No,;Load2:No,;Load3:No,;Store1:Yes, Mult2;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:No,,,,,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:M(R3)/M(R2)*M(R2);F8:;Cycle_40Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:Yes, Mult1;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:No,,,,,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:M(R3)/M(R2)*M(R2);F8:;Cycle_41Load1:No,;Load2:No,;Load3:No,;Store1:No,,;Store2:No,,;Store3:No,,;Add1:No,,,,,;Add2:No,,,,,;Add3:No,,,,,;Mult1:No,,,,,;Mult2:No,,,,,;F0:M(R3)/M(R2);F2:M(R2);F4:;F6:M(R3)/M(R2)*M(R2);F8:;LD F2 0 R2:1,3,4;LD F4 0 R3:2,4,5;DIVD F0 F4 F2:3,25,26;MULTD F6 F0 F2:4,36,37;ADDD F0 F4 F2:5,7,8;SD F6 0 R3:6,39,40;MULTD F6 F0 F2:27,37,38;SD F6 0 R1:28,40,41;

【计算机体系结构】指令集并行(ILP)动态调度算法:Tomasulo实现代码(Tomasulo Algorithm Implementation)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。