亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? project2.c

?? computer Achitecture tomasulo simulator
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* Diming Lu   CDA 5155 Computer Architecture * * Pentium Pro * Compiled on a gcc * *CYCLES:   cycle time to complete program (cycle when halt is in commit)
 *FETCHED:  # of instruction fetched (including instructions squashed because of branch misprediction)
 *RETIRED:  # of instruction committed
 *BRANCHES: # of branches executed (i.e., resolved)
 *MISPRED:  # of branches incorrectly predicted * */#include <stdio.h>#include <string.h>#include <unistd.h>#include <errno.h>#include <stdlib.h>#define MAXLINELENGTH 1000  /* maximum size of machine language instr */#define MEMSIZE 10000       /* maximum number of data words in memory */#define NUMREGS 8	    #define RBSIZE 5#define OP_SHIFT 22         //shift right 22 bits for opcode#define A_SHIFT  19         //shift right 19 bits for regA#define B_SHIFT  16         //shift right 16 bits for regB/* * Opcodes and function values *  */#define ADD 0#define NAND 1#define LW 2#define SW 3#define BEQ 4#define MULT 5 #define HALT 6#define NOOP 7#define NOOPINSTRUCTION 0x1c00000/* * Execution unit in reservation station and reorder */	#define LOAD1	0#define LOAD2	1#define LOAD3   2#define STORE1	3#define STORE2	4#define STORE3	5#define MULT1   6#define MULT2   7#define MULT3   8#define NUMUNITS 12             /* number of units in reservation station is 12: 3 LOAD, 3 STORE, 3 ADD, 3 MULT  *//* * Execution times in cycles */#define MULTEXEC        4#define BRANCHEXEC	1#define LDEXEC		1#define STEXEC		1/* * Instruction status values */#define ISSUING		1#define EXECUTING	2#define WRITINGRESULT	3#define COMMITING       4/* LOAD1, LOAD2, LOAD3, STORE1, STORE2, STORE3, ADD1, ADD2, ADD 3, MULT1, MULT2, MULT3 */typedef struct _resStation {  int busy;             /* not busy = 0, busy = 1 */  int instr;              int Vj;		/* Vj, Vk will hold operand values */  int Vk;  int Qj;		/* Qj, Qk hold execution unit numbers that */  int Qk;		/* will produce the result */  int exTimeLeft;	/* Remaining execution time for instruction */  int reorderNum;       /* Number of reorder buffer for this instruction. */}resStation;typedef struct _reorderEntry {  int busy;             /* reorder buffer is in use */  int instr;	        /* instruction being executed */  int execUnit;	        /* execution unit in Rservation Station that producing result */  int instrStatus;      /* ISSUING, EXECUTING, WRITINGRESULT */  int valid;	        /* flat thag indicates that result value is valid */  int result;	        /* holds speculative result until commit */  int storeAddress;     /* holds the memory address for a store word */}reorderEntry;/* regResult[NUMREGS] in resStation  */typedef struct _regResultEntry {  int valid;	        /* 1 if regFile holds correct value, else 0 */  int unit;            /* reservation station that has the correct value */  int result;}regResultEntry;        /* reservation station entry ( add1, mult2, sw1 ) that has the correct value */typedef struct _machineState{  int		   pc;  int              cycles;  /* how many cycles have executed */  resStation	   reservation[NUMUNITS+1];  //last one unit for halt   reorderEntry	   reorderBuf[RBSIZE];  regResultEntry   regResult[NUMREGS];    int              memory[MEMSIZE];  int              regFile[NUMREGS];  int              issue[MEMSIZE];  int              rs[MEMSIZE];  int              rega[MEMSIZE];  int              regb[MEMSIZE];  int              exe[MEMSIZE];  int              write[MEMSIZE];}machineState;void printInstruction(int instr){    char opcodeString[10];    if (opcode(instr) == ADD) {      strcpy(opcodeString, "add");    }    else if (opcode(instr) == NAND) {      strcpy(opcodeString, "nand");    }     else if (opcode(instr) == LW) {      strcpy(opcodeString, "lw");    }     else if (opcode(instr) == SW) {      strcpy(opcodeString, "sw");    }     else if (opcode(instr) == BEQ) {      strcpy(opcodeString, "beq");    }     else if (opcode(instr) == HALT) {      strcpy(opcodeString,"halt");;    }     else if (opcode(instr) == NOOP) {      strcpy(opcodeString, "noop");    }     else if (opcode(instr) == MULT) {      strcpy(opcodeString, "mult");               }     else {      strcpy(opcodeString, "data");    }	printf("%s %d %d %d\n", opcodeString, field_ra(instr), field_rb(instr), field_imm(instr) );    }int opcode(int instruction){  return ( instruction >> OP_SHIFT );}voidprintState(statePtr, memorySize)  machineState *statePtr;  int memorySize;{  int i;  printf("Cycles: %d\n", statePtr->cycles);    int pc = 0;  while (pc < statePtr->pc){    printf("\n");    printInstruction(statePtr->memory[pc]);    printf("pc =%d", pc);      printf("   fetched =%d", pc+1);    if( pc == 0 )      printf("   issued=%d",  pc+2);    else      printf("   issued =%d", statePtr->issue[pc]);       // unit(0-11):  LOAD1, LOAD2, LOAD3, STORE1, STORE2, STORE3, ADD1, ADD2, ADD3, MULT1, MULT2, MULT3       if( opcode(statePtr->memory[pc]) != NOOP ) {      if( statePtr->rs[pc] <3 && statePtr->rs[pc] >=0 )	printf("   rs = LW");      if( statePtr->rs[pc] <6 && statePtr->rs[pc] >2 )	printf("   rs = SW");      if( statePtr->rs[pc] <9 && statePtr->rs[pc] >5 )	printf("   rs = ALU");      if( statePtr->rs[pc] <12 && statePtr->rs[pc] >8 )	printf("   rs = MULT");          if( statePtr->rega[pc] == -1 && statePtr->reservation[statePtr->rs[pc]].Vj != -1) 	statePtr->rega[pc] = statePtr->cycles;                  if( statePtr->regb[pc] == -1 && statePtr->reservation[statePtr->rs[pc]].Vk != -1)	statePtr->regb[pc] = statePtr->cycles;      if( pc == 0 ) {	printf("   regA available= %d", pc+2 );	printf("   regB available= %d", pc+2 );      }      else {          if( statePtr->rega[pc] != -1 )	printf("   regA available=%d", statePtr->rega[pc]);      else	printf("   regA available= No" );      if( statePtr->regb[pc] != -1)	printf("   regB available=%d", statePtr->regb[pc]);      else	printf("   reB available= No" );      }      if( statePtr->reorderBuf[statePtr->reservation[statePtr->rs[pc]].reorderNum].instrStatus == EXECUTING )	statePtr->exe[pc] = statePtr->cycles;            if( pc == 0)	printf("   execution=%d", statePtr->exe[pc]-2);      else if( statePtr->exe[pc] != -1 )	printf("   execution=%d", statePtr->exe[pc]);      else	printf("   execution=No");      if( statePtr->reorderBuf[statePtr->reservation[statePtr->rs[pc]].reorderNum].instrStatus == WRITINGRESULT)	statePtr->write[pc] = statePtr->cycles;      if( pc == 0) {	printf("   exec finished=%d", statePtr->write[pc]-2);	printf("   cdb= %d", statePtr->write[pc]-2);      }      else if( statePtr->write[pc] != -1 ) {	printf("   exec finished=%d", statePtr->write[pc]);	printf("   cdb= %d", statePtr->write[pc]);      }      else {	printf("   execution finish= No");	printf("   cdb= No");      }         }    printf("\n");    pc = pc + 1;        }  /*       printf("\t Reorder buffers:\n");  for (i=0; i<RBSIZE; i++){    if (statePtr->reorderBuf[i].busy == 1){      printf("\t \t Reorder buffer %d: ",i);      printf("instr %d  executionUnit %d  state %d  valid %d  result %d  storeAddr %d\n",	     statePtr->reorderBuf[i].instr, statePtr->reorderBuf[i].execUnit,	     statePtr->reorderBuf[i].instrStatus, 	     statePtr->reorderBuf[i].valid, statePtr->reorderBuf[i].result,	     statePtr->reorderBuf[i].storeAddress);     }  }        printf("\t Reservation stations:\n");  for (i=0; i<NUMUNITS; i++){    if (statePtr->reservation[i].busy == 1){      printf("\t \t Reservation station %d: ",i);      printf("Vj = %d ", statePtr->reservation[i].Vj);      printf("Qj = %d ", statePtr->reservation[i].Qj);          printf("Vk = %d ", statePtr->reservation[i].Vk);          printf("Qk = %d ", statePtr->reservation[i].Qk);           printf(" ExTimeLeft = %d  RBNum = %d\n",       statePtr->reservation[i].exTimeLeft,      statePtr->reservation[i].reorderNum);      }    }      printf("\t Register result status:\n");  for (i=1; i<NUMREGS; i++){    if ( statePtr->regResult[i].valid == 1) {      printf("\t \t Register %d: ",i);      printf("waiting for reservation number %d\n",	     statePtr->regResult[i].unit);    }  }    */  printf("\t Memory:\n");  for (i=0; i<memorySize; i++){    printf("\t \t memory[%d] = %d\n", i, statePtr->memory[i]);  }   printf("\t Registers:\n");  for (i=0; i<NUMREGS; i++){    printf("\t \t regFile[%d] = %d\n", i, statePtr->regFile[i]);  }}/* end printState(statePtr, memSize) */ int field_ra(int instruction){  return ((instruction >> A_SHIFT) & 0X7);}int field_rb(int instruction){    return (instruction >> B_SHIFT) & 0X7;}int field_imm(int instruction){    return (instruction & 0xFFFF);}/* return last 16 bits offsets in lw,sw,beg */int offset(int instruction){    return field_imm(instruction); /* only used for lw, sw, beq */}/* return last 3 bits in AND, NAND */ int destReg(int instruction){  return (instruction & 0x07);}voidupdateRes(reorderNum, statePtr, result)     int reorderNum;     machineState *statePtr;     int result;{  /*   * Add code to update reservation stations:   * Copy the value "on the common data bus" to   * any places that might be waiting for it in the    * reservation stations.   *   * statePtr points to current machine state   * unit is the reservation station unit number   * value is the value from regResult entry    *   */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区视频在线观看2020| 蜜臀av性久久久久蜜臀aⅴ | 亚洲国产精品麻豆| 中文字幕一区二区三区在线播放| 2020日本不卡一区二区视频| 日韩免费电影网站| 欧美电影免费观看高清完整版在线观看 | 欧美一区二区三区人| 欧美日韩电影在线| 日韩一级黄色片| 久久久亚洲欧洲日产国码αv| 国产欧美一区二区精品性色 | 91猫先生在线| 欧美日韩三级视频| 欧美日韩国产在线播放网站| 日韩一级完整毛片| 久久免费电影网| 亚洲人午夜精品天堂一二香蕉| 亚洲制服欧美中文字幕中文字幕| 亚洲高清不卡在线观看| 激情丁香综合五月| 97久久精品人人做人人爽| 欧美色图天堂网| wwwwww.欧美系列| 亚洲欧美日韩国产另类专区| 日韩av网站在线观看| 国产一区二区三区日韩 | 美女视频黄 久久| 精品亚洲成a人| 91欧美一区二区| 日韩欧美一级二级| 亚洲欧美在线视频观看| 丝袜诱惑制服诱惑色一区在线观看| 精品在线播放免费| 91视频在线观看| 精品精品欲导航| 又紧又大又爽精品一区二区| 久久精品国产99久久6| 色综合网站在线| 精品不卡在线视频| 亚洲国产综合在线| 成人污污视频在线观看| 91精品国产福利| 亚洲欧美偷拍另类a∨色屁股| 男女激情视频一区| 精品视频1区2区| 国产精品久久久久一区二区三区| 日韩va欧美va亚洲va久久| 91社区在线播放| 久久久精品综合| 三级不卡在线观看| 色八戒一区二区三区| 欧美精品一区二区久久久| 婷婷国产v国产偷v亚洲高清| 99精品久久久久久| 亚洲国产岛国毛片在线| 裸体一区二区三区| 91精品国产综合久久久久久久久久| 亚洲女人小视频在线观看| 国产成人午夜片在线观看高清观看| 欧美一区二区成人| 亚洲h动漫在线| 欧美特级限制片免费在线观看| 国产精品视频麻豆| 国产精品18久久久久久久网站| 欧美一区二区三区的| 亚洲综合成人网| 欧美在线观看禁18| 一区二区三区四区精品在线视频| 成人午夜碰碰视频| 国产精品亲子乱子伦xxxx裸| 国产不卡高清在线观看视频| 久久久久国产精品人| 久久国产综合精品| 精品国产制服丝袜高跟| 国产在线视频精品一区| 久久人人97超碰com| 国产精品一二三在| 中文字幕精品在线不卡| 不卡一区在线观看| 亚洲欧美色综合| 欧美亚洲国产一区二区三区va| 一区二区三区中文字幕在线观看| 91亚洲精品一区二区乱码| 一区二区三国产精华液| 欧美日韩精品欧美日韩精品一| 亚洲va国产天堂va久久en| 制服丝袜成人动漫| 韩国三级电影一区二区| 国产精品免费看片| 日本久久一区二区三区| 亚洲h在线观看| 精品国产网站在线观看| 国产精品一区二区视频| 亚洲人成影院在线观看| 欧美美女激情18p| 久久精品国产精品亚洲红杏 | 亚洲自拍偷拍九九九| 欧美性感一区二区三区| 美女视频网站久久| 国产欧美1区2区3区| 欧美最新大片在线看| 秋霞影院一区二区| 国产精品美女视频| 欧美精品丝袜久久久中文字幕| 精品在线播放午夜| 一区二区三区四区蜜桃| 日韩欧美久久一区| 一本色道久久综合精品竹菊| 日本最新不卡在线| 国产精品亲子乱子伦xxxx裸| 欧美区在线观看| av中文字幕一区| 奇米四色…亚洲| 亚洲欧美国产三级| 久久中文字幕电影| 精品视频在线看| 成人看片黄a免费看在线| 日韩av电影免费观看高清完整版 | 日韩午夜激情视频| av电影天堂一区二区在线观看| 日本特黄久久久高潮| 亚洲美腿欧美偷拍| 国产欧美一区二区在线观看| 欧美久久久久久久久| 97久久超碰国产精品电影| 九九久久精品视频| 亚洲成人你懂的| 亚洲视频一区在线| 国产清纯美女被跳蛋高潮一区二区久久w | 国产美女视频一区| 天涯成人国产亚洲精品一区av| 18欧美亚洲精品| 国产欧美精品一区二区色综合朱莉| 制服丝袜av成人在线看| 欧美三电影在线| 91久久久免费一区二区| zzijzzij亚洲日本少妇熟睡| 国产一区二区精品在线观看| 免费日韩伦理电影| 日韩成人免费在线| 日韩有码一区二区三区| 亚洲成人免费观看| 夜夜爽夜夜爽精品视频| 亚洲男人的天堂一区二区| 中文字幕一区二区三区乱码在线| 精品国产一区二区三区久久影院| 日韩一区二区免费高清| 91精品国产福利| 日韩一级大片在线| 欧美videos大乳护士334| 欧美大片在线观看| 精品99一区二区| 久久亚洲一区二区三区四区| 精品国产91九色蝌蚪| 久久久久久一二三区| www久久精品| 国产清纯美女被跳蛋高潮一区二区久久w| 56国语精品自产拍在线观看| 欧美一区二区视频在线观看| 欧美大片一区二区三区| 久久久精品一品道一区| 国产精品久久久久精k8| 亚洲精品免费看| 亚洲成人一区二区| 久久成人综合网| 国产精品一二三区| 成人sese在线| 欧美日韩在线亚洲一区蜜芽| 欧美一区二区三区喷汁尤物| 久久男人中文字幕资源站| 亚洲欧洲99久久| 亚洲国产精品欧美一二99| 老司机精品视频导航| 国产盗摄精品一区二区三区在线 | 蜜桃精品视频在线| 国产成人免费视频网站高清观看视频| 国产成人精品亚洲777人妖| 91亚洲精品乱码久久久久久蜜桃| 欧美色综合天天久久综合精品| 欧美一二三在线| 日本一区二区三区免费乱视频| 伊人色综合久久天天| 日本成人中文字幕在线视频 | 性欧美疯狂xxxxbbbb| 精品中文av资源站在线观看| 97精品久久久久中文字幕| 欧美福利电影网| 欧美国产激情一区二区三区蜜月| 亚洲一级片在线观看| 国产精品中文字幕一区二区三区| 色偷偷成人一区二区三区91| 日韩欧美黄色影院| 亚洲免费在线观看视频| 蜜臀av性久久久久蜜臀aⅴ流畅| 不卡在线观看av| 26uuu色噜噜精品一区二区| 亚洲精品亚洲人成人网在线播放| 九色综合狠狠综合久久| 欧美在线短视频|