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

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

?? pcpu.v

?? 可以實現CPU的VHDL源碼
?? V
字號:
// Project #2: 16-bit pipeline processor// Verilog source file for "System LSI design"//                                                  2007.6  T. Ikenaga// // Operation code (please add operaions!)`define NOP   5'b00000`define HALT  5'b00001`define LOAD  5'b00010`define STORE 5'b00011`define ADD   5'b01000`define CMP   5'b01100`define BZ    5'b11010`define BN    5'b11100// FSM for CPU control`define idle 1'b0`define exec 1'b1module pcpu (reset, clock, enable, start, i_addr, i_datain, d_addr,             d_datain, d_dataout, d_we, select_y, y);input reset, clock, enable, start;input  [15:0] i_datain;output [7:0] i_addr;output [7:0] d_addr;input  [15:0] d_datain;output [15:0] d_dataout;output d_we;// for debugginginput  [3:0] select_y;output [15:0] y;// definition of registersreg [7:0] pc;reg [15:0] id_ir, ex_ir, mem_ir, wb_ir;reg [15:0] gr [0:7];reg [15:0] reg_A, reg_B, reg_C, reg_C1, smdr, smdr1;reg zf, nf, dw;reg state;// definition of variablesreg [15:0] ALUo;reg [15:0] y;reg next_state;assign i_addr = pc;assign d_we  = dw;assign d_addr = reg_C[7:0];assign d_dataout = smdr1;// CPU control (FSM)always @(posedge clock or negedge reset)    begin      if (!reset)         state <= `idle;      else         state <= next_state;    endalways @(state or enable or start or wb_ir[15:11])    begin      case (state)        `idle : if ((enable == 1'b1) && (start == 1'b1))                   next_state <= `exec;                else                   next_state <= `idle;        `exec : if ((enable == 1'b0) || (wb_ir[15:11] == `HALT))                   next_state <= `idle;                else                   next_state <= `exec;      endcase     end// IF_module (stage 1)always @(posedge clock or negedge reset)    begin     if(!reset)       begin         id_ir <= 16'b0000000000000000;         pc    <= 8'b00000000;       end     else if(state==`exec)       begin         id_ir <= i_datain;         if (((mem_ir[15:11] == `BZ) && (zf == 1'b1)) ||             ((mem_ir[15:11] == `BN) && (nf == 1'b1)))            pc <= reg_C[7:0];         else            pc <= pc + 1;       end    end// ID_module (stage 2)always @(posedge clock or negedge reset)    begin     if(!reset)       begin         ex_ir <= 16'b0000000000000000;         reg_A <= 16'b0000000000000000;         reg_B <= 16'b0000000000000000;         smdr  <= 16'b0000000000000000;       end     else if(state==`exec)       begin         ex_ir <= id_ir;         if ((id_ir[15:11] == `BZ) || (id_ir[15:11] == `BN))           reg_A <= gr[(id_ir[10:8])];         else           reg_A <= gr[(id_ir[6:4])];         if (id_ir[15:11] == `LOAD)           reg_B <= {12'b000000000000, id_ir[3:0]};         else if (id_ir[15:11] == `STORE)           begin             reg_B <= {12'b000000000000, id_ir[3:0]};             smdr  <= gr[id_ir[10:8]];           end         else if ((id_ir[15:11] == `BZ) || (id_ir[15:11] == `BN))           reg_B <= {8'b00000000, id_ir[7:0]};         else           reg_B <= gr[id_ir[2:0]];       end    end// EX_module (stage 3)always @(posedge clock or negedge reset)    begin     if(!reset)       begin         mem_ir <= 16'b0000000000000000;         reg_C <= 16'b0000000000000000;         smdr1 <= 16'b0000000000000000;         zf <= 1'b0;          nf <= 1'b0;          dw <= 1'b0;       end     else if(state==`exec)       begin         mem_ir <= ex_ir;         reg_C  <= ALUo;         if ((ex_ir[15:11] == `ADD) ||             (ex_ir[15:11] == `CMP))           begin             if (ALUo == 16'b0000000000000000)                zf <= 1'b1;             else                zf <= 1'b0;             if (ALUo [15] == 1'b1)                nf <= 1'b1;             else                nf <= 1'b0;           end         if (ex_ir[15:11] == `STORE)            begin              dw <= 1'b1;              smdr1 <= smdr;            end         else            dw <= 1'b0;       end    end// MEM_module (stage 4)always @(posedge clock or negedge reset)    begin     if(!reset)       begin         wb_ir  <= 16'b0000000000000000;         reg_C1 <= 16'b0000000000000000;       end     else if(state==`exec)       begin         wb_ir  <= mem_ir;         if (mem_ir[15:11] == `LOAD)            reg_C1 <= d_datain;	else            reg_C1 <= reg_C;       end    end// WB_module (stage 5)always @(posedge clock or negedge reset)    begin     if(!reset)       begin         gr[0] <= 16'b0000000000000000;         gr[1] <= 16'b0000000000000000;         gr[2] <= 16'b0000000000000000;         gr[3] <= 16'b0000000000000000;         gr[4] <= 16'b0000000000000000;         gr[5] <= 16'b0000000000000000;         gr[6] <= 16'b0000000000000000;         gr[7] <= 16'b0000000000000000;       end     else if(state==`exec)       begin         if (wb_ir[10:8] != 3'b000)            if ((wb_ir[15:11] == `LOAD) ||                (wb_ir[15:11] == `ADD))               gr[wb_ir[10:8]] <= reg_C1;       end    end// ALU_modulealways @(reg_A or reg_B or ex_ir[15:11])   case (ex_ir[15:11])     `LOAD  : ALUo = reg_A + reg_B;     `STORE : ALUo = reg_A + reg_B;     `ADD   : ALUo = reg_A + reg_B;     `CMP   : ALUo = reg_A - reg_B;     `BZ    : ALUo = reg_A + reg_B;     `BN    : ALUo = reg_A + reg_B;     default : ALUo = 16'bXXXXXXXXXXXXXXXX;   endcase// for debuggingalways @(select_y or gr[1] or gr[2] or gr[3] or gr[4] or gr[5] or gr[6]         or gr[7] or reg_A or reg_B or reg_C or reg_C1 or smdr or id_ir         or dw or zf or nf or pc)   begin     case (select_y)       4'b0000 : y = {3'b000, dw, 2'b00, zf, nf, pc};       4'b0001 : y = gr[1];       4'b0010 : y = gr[2];       4'b0011 : y = gr[3];       4'b0100 : y = gr[4];       4'b0101 : y = gr[5];       4'b0110 : y = gr[6];       4'b0111 : y = gr[7];       4'b1000 : y = reg_A;       4'b1001 : y = reg_B;       4'b1011 : y = reg_C;       4'b1100 : y = reg_C1;       4'b1101 : y = smdr;       4'b1110 : y = id_ir;       default : y = 16'bXXXXXXXXXXXXXXXX;     endcase   endendmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
三级亚洲高清视频| 最近日韩中文字幕| 麻豆国产精品视频| 日韩欧美久久一区| 国产裸体歌舞团一区二区| 久久一二三国产| 国产激情偷乱视频一区二区三区| 久久影音资源网| jizzjizzjizz欧美| 一个色在线综合| 欧美日韩大陆一区二区| 久久精品理论片| 国产精品拍天天在线| 日本国产一区二区| 麻豆精品久久精品色综合| 久久久久久久久久久黄色| 成人av资源站| 爽好久久久欧美精品| 久久婷婷一区二区三区| 99re热这里只有精品免费视频| 一区二区在线电影| 欧美一级高清大全免费观看| 国产福利一区在线观看| 亚洲精品伦理在线| 精品久久一二三区| 99精品桃花视频在线观看| 天堂va蜜桃一区二区三区 | 91最新地址在线播放| 一区二区久久久久久| 精品欧美久久久| av不卡免费在线观看| 美腿丝袜亚洲色图| 亚洲欧洲另类国产综合| 日韩午夜在线观看| 91女人视频在线观看| 经典一区二区三区| 亚洲最大成人网4388xx| 国产色综合一区| 欧美喷潮久久久xxxxx| 懂色av一区二区三区免费观看| 亚洲国产日韩在线一区模特| 国产午夜亚洲精品羞羞网站| 欧美日韩aaaaaa| av成人免费在线观看| 久久国产精品免费| 亚洲第一精品在线| 亚洲天堂2016| 国产精品三级在线观看| 制服视频三区第一页精品| 91视频一区二区三区| 国产一区 二区| 日韩精品久久理论片| 亚洲人被黑人高潮完整版| 久久青草欧美一区二区三区| 9191久久久久久久久久久| 一本到三区不卡视频| 国产成人精品网址| 国产一区二区三区| 免费视频最近日韩| 日韩不卡一区二区三区| 亚洲一区二区三区四区的| 亚洲丝袜自拍清纯另类| 日本一区免费视频| 国产视频一区在线播放| 精品国产不卡一区二区三区| 91精品国产一区二区三区蜜臀| 在线观看中文字幕不卡| 色就色 综合激情| 99久久精品免费看| 99热这里都是精品| 99精品久久免费看蜜臀剧情介绍| 国产成人夜色高潮福利影视| 国产福利不卡视频| 成人午夜在线播放| 成人影视亚洲图片在线| 成人激情小说乱人伦| 成人午夜av电影| 成人晚上爱看视频| 成人永久免费视频| 99久久精品费精品国产一区二区| jizzjizzjizz欧美| 在线精品视频免费播放| 在线精品国精品国产尤物884a| 色综合久久久网| 91麻豆蜜桃一区二区三区| 在线免费观看日韩欧美| 欧美日韩国产大片| 日韩一区和二区| 久久婷婷一区二区三区| 欧美激情自拍偷拍| 久久成人免费网站| 国产精品亚洲一区二区三区妖精 | 中文字幕一区在线观看| 亚洲视频在线一区观看| 亚洲日本欧美天堂| 亚洲国产美国国产综合一区二区| 午夜影视日本亚洲欧洲精品| 免费精品视频最新在线| 国产在线精品一区二区夜色 | av在线播放一区二区三区| 色综合久久精品| 欧美精品久久天天躁| 精品国产乱码久久| 亚洲欧洲另类国产综合| 亚洲成人av一区二区三区| 麻豆freexxxx性91精品| 成人一级片网址| 在线观看日韩国产| 欧美精品一区二区三区久久久| 国产欧美精品区一区二区三区| 亚洲欧洲成人精品av97| 日韩国产成人精品| 国产成人免费xxxxxxxx| 在线日韩av片| 欧美精品一区视频| 一区二区三区中文在线观看| 毛片av中文字幕一区二区| 成人爽a毛片一区二区免费| 欧美日精品一区视频| 久久视频一区二区| 亚洲小说欧美激情另类| 国产成人精品免费| 欧美另类z0zxhd电影| 国产精品亲子乱子伦xxxx裸| 香蕉成人伊视频在线观看| 成人网页在线观看| 日韩视频一区二区在线观看| 亚洲人成网站在线| 国产在线视视频有精品| 欧美美女网站色| 中文字幕一区二区三区不卡在线 | 成人国产一区二区三区精品| 欧美高清激情brazzers| 中文字幕在线一区免费| 久88久久88久久久| 欧美区在线观看| 日韩理论片网站| 国产成人在线观看免费网站| 91精品国产综合久久蜜臀| 成人免费一区二区三区在线观看| 欧美日韩在线播放三区四区| 中文一区二区在线观看| 久久91精品久久久久久秒播| 欧美日韩视频专区在线播放| **网站欧美大片在线观看| 国内国产精品久久| 91麻豆精品国产91久久久使用方法| 自拍偷拍国产精品| 粉嫩aⅴ一区二区三区四区五区| 欧美日韩一区国产| 一区二区三区在线视频观看58| 成人午夜视频在线| 国产日韩欧美电影| 国产激情视频一区二区三区欧美 | 欧美精品一区二区三区久久久| 丝袜a∨在线一区二区三区不卡| 91看片淫黄大片一级| 国产精品欧美经典| 国产福利视频一区二区三区| 久久久美女艺术照精彩视频福利播放| 日本不卡一二三| 欧美一卡2卡三卡4卡5免费| 亚洲成在线观看| 欧美日韩国产成人在线91| 亚洲成人动漫在线免费观看| 欧美日韩中文另类| 亚洲国产精品自拍| 欧美老人xxxx18| 日本午夜精品视频在线观看 | 麻豆精品视频在线观看| 日韩一卡二卡三卡国产欧美| 日本成人中文字幕| 69久久99精品久久久久婷婷| 日韩精品久久理论片| 日韩一本二本av| 激情都市一区二区| 免费看精品久久片| 久久久久久久性| 99综合电影在线视频| 亚洲视频一区在线| 欧美性受xxxx| 日韩综合小视频| 欧美mv和日韩mv国产网站| 国产精品综合视频| 国产精品区一区二区三区| 99视频有精品| 午夜精品福利一区二区蜜股av| 日韩午夜在线影院| 国产91丝袜在线观看| 亚洲欧美日韩国产综合| 色素色在线综合| 日韩高清不卡一区| 久久奇米777| 色综合视频一区二区三区高清| 亚洲一区二区视频在线| 日韩欧美中文字幕精品| 成人激情免费电影网址| 一区二区三区在线视频观看| 91精品福利在线一区二区三区 | av影院午夜一区|