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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? it51_alu.v

?? 流片過的risc_8051源代碼 verilog語言描述的~
?? V
?? 第 1 頁 / 共 3 頁
字號:
            // 10101rrr 2 MOV   Rn,data addr
            // 11110000 1 MOVX  @DPTR,A
            // 1111001i 1 MOVX  @Ri,A
            // 11110101 2 MOV   data addr,A
            // 1111011i 1 MOV   @Ri,A
            // 11111rrr 1 MOV   Rn,A
            // 11000000 2 PUSH  data addr		INC SP: MOV "@SP",<src>
            // 11010000 2 POP   data addr		MOV <dest>,"@SP": DEC SP
            Do_I_MOV <= 1'b1 ; 
         end 
         if (OpCode == 8'b10000101)
         begin
            // 10000101 3 MOV   data addr,data addr
            Do_I_MOVD <= 1'b1 ; 
         end 
         // 030714 >>>
         if (OpCode[7:3] == 5'b10111)
         begin
            // 10111rrr 3 CJNE  Rn,#data,code addr
            Do_I_CJNE <= 1'b1 ; 
         end 
         if (OpCode[7:1] == 7'b1011011 & ~PCPause)
         begin
            // 1011011i 3 CJNE  @Ri,#data,code addr
            Do_I_CJNE <= 1'b1 ; 
         end 
         // <<<
         // Bit Operations
         Do_B_Inv <= 1'b0 ; 
         Do_B_C_BA <= 1'b0 ; 
         Do_B_C_Dir <= 1'b0 ; 
         Do_B_BA_Dir <= 1'b0 ; 
         Do_B_MOV <= 1'b0 ; 
         Do_B_JBC <= 1'b0 ; 
         Do_B_Op <= OpCode[5:4] ; 
         if (OpCode[1:0] == 2'b00)
         begin
            Do_B_Inv <= 1'b1 ; 
         end 
         if (OpCode == 8'b01110010 | OpCode == 8'b10000010 | OpCode == 8'b10100000 | OpCode == 8'b10100010 | OpCode == 8'b10110000)
         begin
            // 01110010 2 ORL   C, bit addr
            // 10000010 2 ANL   C,bit addr
            // 10100000 2 ORL   C,/bit addr
            // 10100010 2 MOV   C,bit addr
            // 10110000 2 ANL   C,/bit addr
            Do_B_C_BA <= 1'b1 ; 
         end 
         if (OpCode == 8'b10110011 | OpCode == 8'b11000011 | OpCode == 8'b11010011)
         begin
            // 10110011 1 CPL   C
            // 11000011 1 CLR   C
            // 11010011 1 SETB  C
            Do_B_C_Dir <= 1'b1 ; 
         end 
         if (OpCode == 8'b10110010 | OpCode == 8'b11000010 | OpCode == 8'b11010010)
         begin
            // 10110010 2 CPL   bit addr
            // 11000010 2 CLR   bit addr
            // 11010010 2 SETB  bit addr
            Do_B_BA_Dir <= 1'b1 ; 
         end 
         if (OpCode == 8'b10010010)
         begin
            // 10010010 2 MOV   bit addr,C
            Do_B_MOV <= 1'b1 ; 
         end 
         if (OpCode == 8'b00010000)
         begin
            // 00010000 3 JBC   bit addr, code addr
            Do_B_JBC <= 1'b1 ; 
         end 
         Last_r <= Last ; 
      end 
   end 

   // YFC >>>
   // BUG op_d4
   always @(ACC or CY_In or AC_In)
   begin : DA
      reg[8:0] accu; 
      reg lc; 
      //accu = unsigned({1'b0, ACC}); 
      accu = {1'b0, ACC}; 
      if (AC_In == 1'b1 | accu[3:0] > 9)
      begin
         accu = accu + 6; 
      end 
      lc = accu[8]; 
      //		if CY_In = '1' or accu(7 downto 4) > 9 then
      if (CY_In == 1'b1 | accu[8:4] > 9)
      begin
         accu = accu + 96; 
      end 
      accu[8] = accu[8] | lc | CY_In; 
      //ADA = std_logic_vector(accu) ; 
      ADA = accu ; 
   end 

   // <<<
   always @(MOV_Op or IB or ACC or IA_d)
   begin : MOV
      case (MOV_Op)
         4'b0111 :
                  begin
                     // 01110101 3 MOV   data addr,#data
                     // 0111011i 2 MOV   @Ri,#data
                     // 01111rrr 2 MOV   Rn,#data
                     MOV_Q = IB ; 
                  end
         4'b1000 :
                  begin
                     // 10000101 3 MOV   data addr,data addr
                     // 1000011i 2 MOV   data addr,@Ri
                     // 10001rrr 2 MOV   data addr,Rn
                     MOV_Q = IA_d ; 
                  end
         4'b1010 :
                  begin
                     // 1010011i 2 MOV   @Ri,data addr
                     // 10101rrr 2 MOV   Rn,data addr
                     MOV_Q = IA_d ; 
                  end
         4'b1111 :
                  begin
                     // 11110000 1 MOVX  @DPTR,A
                     // 1111001i 1 MOVX  @Ri,A
                     // 11110101 2 MOV   data addr,A
                     // 1111011i 1 MOV   @Ri,A
                     // 11111rrr 1 MOV   Rn,A
                     MOV_Q = ACC ; 
                  end
         4'b1100, 4'b1101 :
                  begin
                     // 11000000 2 PUSH  data addr		INC SP: MOV "@SP",<src>
                     // 11010000 2 POP   data addr		MOV <dest>,"@SP": DEC SP
                     MOV_Q = IA_d ; 
                  end
         default :
                  begin
                     MOV_Q = 8'bxxxxxxxx ; 
                  end
      endcase 
   end 
   AddSub4 I1 (ACC[3:0], AOP2[3:0], Do_A_SUBB, Do_A_SUBB ^ (Do_A_Carry & CY_In), AS_Q[3:0], AS_AC); 
   AddSub3 I2 (ACC[6:4], AOP2[6:4], Do_A_SUBB, AS_AC, AS_Q[6:4], AS_Carry7); 
   AddSub1 I3 (ACC[7], AOP2[7], Do_A_SUBB, AS_Carry7, AS_Q[7], AS_CY); 
   AddSub8 I4 (IA, IB, 1'b1, 1'b1, CJNE_Q, CJNE_CY_n); 
   // Accumulator ALU
   assign AOP2 = (Do_A_Imm == 1'b1) ? IB : IA ;
   assign ACC_Q = ACC_Q_0 & ACC_Q_1 & ACC_Q_2 & ACC_Q_3 & ACC_Q_3 & ACC_Q_4 & ACC_Q_5 & ACC_Q_6 & ACC_Q_7 & ACC_Q_8 & ACC_Q_9 & ACC_Q_10 & ACC_Q_11 & ACC_Q_12 & ACC_Q_13 & ACC_Q_14 & ACC_Q_15 & ACC_Q_16 & ACC_Q_17 & ACC_Q_18 & ACC_Q_19 ;
   assign ACC_Q_0 = (Do_A_CLR == 1'b1) ? 8'b00000000 : {8{1'b1}} ;
   assign ACC_Q_1 = (Do_A_RR == 1'b1) ? {ACC[0], ACC[7:1]} : {7{1'b1}} ;
   assign ACC_Q_2 = (Do_A_RRC == 1'b1) ? {CY_In, ACC[7:1]} : {7{1'b1}} ;
   assign ACC_Q_3 = (Do_A_RL == 1'b1) ? {ACC[6:0], ACC[7]} : {7{1'b1}} ;
   assign ACC_Q_4 = (Do_A_RLC == 1'b1) ? {ACC[6:0], CY_In} : {7{1'b1}} ;
   assign ACC_Q_5 = (Do_A_INC == 1'b1) ? (ACC + 1) : {8{1'b1}} ;
   assign ACC_Q_6 = (Do_A_DEC == 1'b1) ? (ACC - 1) : {8{1'b1}} ;
   assign ACC_Q_7 = (Do_A_CPL == 1'b1) ? ~ACC : {8{1'b1}} ;
   assign ACC_Q_8 = (Do_A_ORL == 1'b1) ? ACC | AOP2 : {8{1'b1}} ;
   assign ACC_Q_9 = (Do_A_ANL == 1'b1) ? ACC & AOP2 : {8{1'b1}} ;
   assign ACC_Q_10 = (Do_A_XRL == 1'b1) ? ACC ^ AOP2 : {8{1'b1}} ;
   assign ACC_Q_11 = (Do_A_SWAP == 1'b1) ? {ACC[3:0], ACC[7:4]} : {4{1'b1}} ;
   assign ACC_Q_12 = (Do_A_XCH == 1'b1) ? IA : {8{1'b1}} ;
   assign ACC_Q_13 = (Do_A_XCHD == 1'b1) ? {ACC[7:4], IA[3:0]} : {4{1'b1}} ;
   assign ACC_Q_14 = (Do_A_MOV == 1'b1) ? AOP2 : {8{1'b1}} ;
   assign ACC_Q_15 = (Do_A_DA == 1'b1) ? ADA[7:0] : {8{1'b1}} ;
   assign ACC_Q_16 = (Do_A_ADD == 1'b1) ? AS_Q : {8{1'b1}} ;
   assign ACC_Q_17 = (Do_A_SUBB == 1'b1) ? AS_Q : {8{1'b1}} ;
   assign ACC_Q_18 = (Do_A_MUL == 1'b1) ? Mul_Q[7:0] : {8{1'b1}} ;
   assign ACC_Q_19 = (Do_A_DIV == 1'b1) ? Div_Q[7:0] : {8{1'b1}} ;
   //	ACC_Q_20 <= "--------";
   assign CY_Out = (Do_A_RRC == 1'b1) ? ACC[0] : (Do_A_RLC == 1'b1) ? ACC[7] : (Do_A_DA == 1'b1) ? ADA[8] : (Do_A_ADD == 1'b1 | Do_A_SUBB == 1'b1) ? AS_CY ^ Do_A_SUBB : (Do_I_CJNE == 1'b1) ? ~CJNE_CY_n : (Do_B_C_Dir == 1'b1 & Do_B_Op == 2'b11) ? ~CY_In : (Do_B_C_Dir == 1'b1 & Do_B_Op == 2'b00) ? 1'b0 : (Do_B_C_Dir == 1'b1 & Do_B_Op == 2'b01) ? 1'b1 : (Do_B_C_BA == 1'b1 & Do_B_Op == 2'b11 & Do_B_Inv == 1'b0) ? CY_In | Bit_IsOne : (Do_B_C_BA == 1'b1 & Do_B_Op == 2'b00 & Do_B_Inv == 1'b0) ? CY_In & Bit_IsOne : (Do_B_C_BA == 1'b1 & Do_B_Op == 2'b10 & Do_B_Inv == 1'b1) ? CY_In | Bit_IsOne : (Do_B_C_BA == 1'b1 & Do_B_Op == 2'b10 & Do_B_Inv == 1'b0) ? Bit_IsOne : (Do_B_C_BA == 1'b1 & Do_B_Op == 2'b11 & Do_B_Inv == 1'b1) ? CY_In & Bit_IsOne : (Do_A_DIV == 1'b1 | Do_A_MUL == 1'b1) ? 1'b0 : 1'bx ;
   assign OV_Out = (Do_A_ADD == 1'b1 | Do_A_SUBB == 1'b1) ? AS_CY ^ AS_Carry7 : (Do_A_MUL == 1'b1) ? Mul_OV : (Do_A_DIV == 1'b1) ? Div_OV : 1'bx ;
   assign AC_Out = (Do_A_ADD == 1'b1 | Do_A_SUBB == 1'b1) ? AS_AC ^ Do_A_SUBB : 1'bz ;
   // Auxiliary ALU
   assign IOP = (Do_I_Imm == 1'b1) ? IB : ACC ;

   //    IDCPBL_Q <= (IA + 1)                         when Do_I_INC  = '1' else -- No flags
   //                (IA - 1)                         when Do_I_DEC  = '1' else -- No flags
   //                IOP or IA                        when Do_I_ORL  = '1' else -- No flags
   //	            IOP and IA                       when Do_I_ANL  = '1' else -- No flags
   //	            IOP xor IA                       when Do_I_XRL  = '1' else -- No flags
   //	            ACC                              when Do_A_XCH  = '1' else -- No flags
   //	            IA(7 downto 4) & ACC(3 downto 0) when Do_A_XCHD = '1' else -- No flags
   //	            MOV_Q                            when Do_I_MOV  = '1' else -- No flags
   //	            IA_d                             when Do_I_MOVD = '1' else -- No flags
   //	            Bit_Result                       when Do_B_JBC  = '1'   or
   //	                                                  Do_B_BA_Dir = '1' or
   //                                                      Do_B_MOV = '1'  else
   //	            "--------";
   always @(Do_B_JBC or Do_B_BA_Dir or Do_B_MOV or Bit_Result or Do_I_MOV or 
            Do_I_MOVD or MOV_Q or IA_d or Do_A_XCH or Do_A_XCHD or ACC or IA or 
            Do_I_INC or Do_I_DEC or Do_I_ORL or Do_I_ANL or Do_I_XRL or IOP)
   begin : IDCPBL
      reg[1:0] X1; 
      reg[1:0] X2; 
      reg[4:0] X3; 
      X1 = {Do_I_MOV, Do_I_MOVD}; 
      X2 = {Do_A_XCH, Do_A_XCHD}; 
      X3 = {Do_I_INC, Do_I_DEC, Do_I_ORL, Do_I_ANL, Do_I_XRL}; 
      IDCPBL_Q = 8'bxxxxxxxx ; 
      if (Do_B_JBC == 1'b1 | Do_B_BA_Dir == 1'b1 | Do_B_MOV == 1'b1)
      begin
         IDCPBL_Q = Bit_Result ; 
      end 
      case (X1)
         2'b10 :
                  begin
                     IDCPBL_Q = MOV_Q ; 
                  end
         2'b01 :
                  begin
                     IDCPBL_Q = IA_d ; 
                  end
         default :
                  begin
                     IDCPBL_Q = 0 ; 
                  end
      endcase 
      case (X2)
         2'b10 :
                  begin
                     IDCPBL_Q = ACC ; 
                  end
         2'b01 :
                  begin
                     IDCPBL_Q = {IA[7:4], ACC[3:0]} ; 
                  end
         default :
                  begin
                     IDCPBL_Q = 0 ; 
                  end
      endcase 
      case (X3)
         5'b10000 :
                  begin
                     IDCPBL_Q = (IA + 1) ; 
                  end
         5'b01000 :
                  begin
                     IDCPBL_Q = (IA - 1) ; 
                  end
         5'b00100 :
                  begin
                     IDCPBL_Q = IOP | IA ; 
                  end
         5'b00010 :
                  begin
                     IDCPBL_Q = IOP & IA ; 
                  end
         5'b00001 :
                  begin
                     IDCPBL_Q = IOP ^ IA ; 
                  end
         default :
                  begin
                     IDCPBL_Q = 0 ; 
                  end
      endcase 
   end 
   assign DJNZ = ((IA - 1) != 8'b00000000) ? 1'b1 : 1'b0 ;
   assign CJNE = (Do_I_CJNE == 1'b1 & CJNE_Q != 8'b00000000) ? 1'b1 : (Do_I_CJNE == 1'b1) ? 1'b0 : (AS_Q != 8'b00000000) ? 1'b1 : 1'b0 ;
   // Bit operations
   assign Bit_Op1 = IA & ~Bit_Pattern ;
   assign Bit_Op2 = (Do_B_Inv == 1'b1) ? Bit_Pattern & ~IA : Bit_Pattern & IA ;
   assign Bit_IsOne = (Bit_Op2 == 8'b00000000) ? 1'b0 : 1'b1 ;
   assign Bit_Result = (Do_B_BA_Dir == 1'b1 & Do_B_Op == 2'b11) ? IA ^ Bit_Pattern : ((Do_B_BA_Dir == 1'b1 & Do_B_Op == 2'b00) | Do_B_JBC == 1'b1) ? Bit_Op1 : (Do_B_BA_Dir == 1'b1 & Do_B_Op == 2'b01) ? IA | Bit_Pattern : (Do_B_MOV == 1'b1) ? Bit_Op1 | (Bit_Pattern & {CY_In, CY_In, CY_In, CY_In, CY_In, CY_In, CY_In, CY_In}) : 8'bxxxxxxxx ;
   // Mul / Div
   IT51_MD md (
      Clk, 
      Rst_n, 
      ACC, 
      B, 
      Mul_Q, 
      Mul_OV, 
      Div_Q, 
      Div_OV, 
      Div_Rdy
   ); 
   // Sets OV
   assign B_Q = (Do_A_MUL == 1'b1) ? Mul_Q[15:8] : (Do_A_DIV == 1'b1) ? Div_Q[15:8] : 8'bxxxxxxxx ;
   // Flags
   assign AC_Wr = ((Do_A_ADD == 1'b1 | Do_A_SUBB == 1'b1) & Do_A_CJNE == 1'b0) ? Last_r : 1'b0 ;
   assign OV_Wr = (((Do_A_ADD == 1'b1 | Do_A_SUBB == 1'b1) & Do_A_CJNE == 1'b0) | Do_A_DIV == 1'b1 | Do_A_MUL == 1'b1) ? Last_r : 1'b0 ;
   assign CY_Wr = (Do_A_ADD == 1'b1 | Do_A_SUBB == 1'b1 | Do_A_RRC == 1'b1 | Do_A_RLC == 1'b1 | Do_I_CJNE == 1'b1 | Do_A_DA == 1'b1 | Do_B_C_BA == 1'b1 | Do_B_C_Dir == 1'b1 | Do_A_DIV == 1'b1 | Do_A_MUL == 1'b1) ? Last_r : 1'b0 ;
endmodule

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91成人免费在线| 亚洲一区二区三区四区五区黄| 日韩精品亚洲一区| 亚洲综合色网站| 一区二区三区中文免费| 亚洲国产成人自拍| 欧美喷水一区二区| 7777精品伊人久久久大香线蕉 | 国产精品久久久久影视| 久久先锋资源网| 国产欧美精品一区二区色综合 | 国产精品久久久久久久岛一牛影视| 欧美一区二区免费| 欧美福利一区二区| 欧美一区二区三区日韩视频| 欧美日韩国产经典色站一区二区三区| 一本一道久久a久久精品| 91精品福利视频| 精品久久久网站| 国产精品久久久久四虎| 国产精品久久久久毛片软件| 国产精品二三区| 亚洲一级在线观看| 日韩av不卡一区二区| 高清免费成人av| 在线亚洲人成电影网站色www| 色综合一区二区三区| 欧美日韩一区二区三区视频| 欧美一级一区二区| 中文字幕综合网| 日本欧美在线看| 91丨porny丨最新| 精品国产一区二区精华| 亚洲一区在线观看视频| 成人黄色电影在线| 久久老女人爱爱| 久久国产人妖系列| 欧美女孩性生活视频| 亚洲国产精品v| 精品一区二区精品| 国产三级精品在线| 狠狠v欧美v日韩v亚洲ⅴ| 欧美一级二级三级蜜桃| 一区二区三区在线观看动漫 | 中文字幕亚洲一区二区av在线| 午夜欧美视频在线观看| 色天天综合久久久久综合片| 国产精品乱码妇女bbbb| 国产综合色视频| 欧美一区二区三区四区视频 | 日韩亚洲欧美成人一区| 最新中文字幕一区二区三区| 国产成人精品影院| 26uuu国产日韩综合| 国产真实乱偷精品视频免| 精品福利av导航| 黄色小说综合网站| 日韩一区二区电影| 久久精品免费观看| 日韩三级视频在线看| 久久99蜜桃精品| 久久嫩草精品久久久精品一| 蓝色福利精品导航| 久久久99精品免费观看| www.av亚洲| 午夜激情综合网| 精品国产乱码久久久久久蜜臀 | 黑人巨大精品欧美一区| 欧美激情在线观看视频免费| 成人免费视频免费观看| 国产真实乱子伦精品视频| 国产拍揄自揄精品视频麻豆| 91亚洲国产成人精品一区二三 | 欧美二区三区91| 久久国产免费看| 一区二区三区av电影 | 日本高清不卡aⅴ免费网站| 婷婷成人激情在线网| 国产网站一区二区| 678五月天丁香亚洲综合网| 国产成人午夜高潮毛片| 亚洲sss视频在线视频| 久久久精品欧美丰满| 欧美精品久久久久久久久老牛影院| av在线免费不卡| 国产一区二区影院| 国产剧情一区二区三区| 亚洲综合无码一区二区| 久久婷婷色综合| 91精品国产综合久久蜜臀| 91福利在线导航| 色诱视频网站一区| 欧美欧美欧美欧美首页| 欧美撒尿777hd撒尿| a在线欧美一区| 国产一区二区久久| 国产suv精品一区二区883| 风间由美一区二区三区在线观看| 亚洲h动漫在线| 丝瓜av网站精品一区二区| 日本成人超碰在线观看| 麻豆91在线观看| 激情六月婷婷久久| 国产一区二区三区国产| 99精品1区2区| 久久这里只有精品首页| 久久精品在这里| 依依成人综合视频| 美日韩一级片在线观看| 国产一区久久久| 成人黄色综合网站| 99re在线精品| 正在播放亚洲一区| 国产精品伦理一区二区| 性做久久久久久久免费看| 精品一区二区三区久久| 国产99久久久国产精品| 一本色道亚洲精品aⅴ| 欧美一区二区三级| 中文在线资源观看网站视频免费不卡| 亚洲与欧洲av电影| 国产成人8x视频一区二区| 久久亚洲综合av| 亚洲麻豆国产自偷在线| 亚洲成人动漫av| 日本午夜精品视频在线观看| 免费黄网站欧美| 欧美精品在欧美一区二区少妇| 亚洲婷婷国产精品电影人久久| 久久精品国产99国产| 国产成人aaaa| 精品少妇一区二区三区在线播放 | 日本精品视频一区二区| 欧美伊人精品成人久久综合97| 久久看人人爽人人| 国产一区二区成人久久免费影院| 91精品国产色综合久久ai换脸 | 亚洲午夜久久久久久久久电影院| 激情小说欧美图片| 欧美色偷偷大香| 精品99999| 九九视频精品免费| 欧美一级精品在线| 日本成人在线电影网| 日韩亚洲国产中文字幕欧美| 丝袜亚洲另类欧美| 91精品婷婷国产综合久久竹菊| 免费在线观看视频一区| 精品国产乱码久久久久久老虎| 一区二区三区免费网站| 在线亚洲一区二区| 午夜免费欧美电影| 日韩欧美123| 国产不卡视频在线播放| 国产性天天综合网| 成人影视亚洲图片在线| 中文字幕av在线一区二区三区| 色综合色综合色综合色综合色综合| 国产精品白丝在线| 欧美日韩国产综合一区二区| 日韩电影在线观看网站| 欧美mv日韩mv国产| 91在线免费播放| 亚洲高清三级视频| 欧美成人video| 不卡视频在线观看| 久久精品国产秦先生| 午夜精彩视频在线观看不卡| 欧美一区二区三区视频在线观看 | 国产成人综合在线| 日韩高清欧美激情| 午夜视频在线观看一区二区| 欧美激情一区在线| 国产精品久久久久久久久果冻传媒| 91香蕉视频黄| 激情另类小说区图片区视频区| 欧美日韩精品三区| 亚洲成人av资源| 男人的j进女人的j一区| 寂寞少妇一区二区三区| 成人午夜又粗又硬又大| 91同城在线观看| 91福利视频网站| 欧美日韩中文精品| 欧美日韩情趣电影| 欧美精品日韩综合在线| 91精品麻豆日日躁夜夜躁| 在线不卡a资源高清| 欧美日韩卡一卡二| 欧美一区二区三区在线视频 | 欧美大片在线观看一区二区| 欧美日韩国产影片| 欧美一区二区黄色| 国产午夜精品一区二区三区视频 | 国产精品美女www爽爽爽| 久久久精品一品道一区| 国产亚洲综合色| 亚洲成人久久影院| 懂色av中文字幕一区二区三区| 一本大道久久a久久综合婷婷|