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

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

?? intface.vhd

?? UART的rs232通信接口VHDL語言
?? VHD
?? 第 1 頁 / 共 3 頁
字號:
  IirRDn_r <= '1' when (Reset='1') else RDn_cs when (ADDR_s=A_IIR) else '1';

  -- Delayed signals for rising edge dectection
  Delay_Signals_Proc: process(Clk16X, Reset)
  begin
    if (Reset='1') then
      ThrWRn1_r <= '1';
      ThrWRn2_r <= '1';
      RbrRDn1_r <= '1';
      RbrRDn2_r <= '1';
      LsrRDn1_r <= '1';
      LsrRDn2_r <= '1';
      MsrRDn1_r <= '1';
      MsrRDn2_r <= '1';
      IirRDn1_r <= '1';
      IirRDn2_r <= '1';
    elsif rising_edge(Clk16X) then
      -- Signals for rising edge detection of THR write strobe signal ThrWRn_r
      ThrWRn1_r <= ThrWRn_r;
      ThrWRn2_r <= ThrWRn1_r;
      -- Signals for rising edge detection of RBR read strobe signal RbrRDn_r
      RbrRDn1_r <= RbrRDn_r;
      RbrRDn2_r <= RbrRDn1_r;
      -- Signals for rising edge detection of LSR read strobe signal LsrRDn_r
      LsrRDn1_r <= LsrRDn_r;
      LsrRDn2_r <= LsrRDn1_r;
      -- Signals for rising edge detection of MSR read strobe signal MsrRDn_r
      MsrRDn1_r <= MsrRDn_r;
      MsrRDn2_r <= MsrRDn1_r;
      -- Signals for rising edge detection of IIR read strobe signal IirRDn_r
      IirRDn1_r <= IirRDn_r;
      IirRDn2_r <= IirRDn1_r;
    end if;
  end process Delay_Signals_Proc;

  -- Rising edge of registers read/write strobes
  ThrWRn_re <= ThrWRn1_r and (not ThrWRn2_r); -- rising edge of ThrWRn_r
  RbrRDn_re <= RbrRDn1_r and (not RbrRDn2_r); -- rising edge of RbrRDn_r
  LsrRDn_re <= LsrRDn1_r and (not LsrRDn2_r); -- rising edge of LsrRDn_r
  MsrRDn_re <= MsrRDn1_r and (not MsrRDn2_r); -- rising edge of MsrRDn_r
  IirRDn_re <= IirRDn1_r and (not IirRDn2_r); -- rising edge of IirRDn_r

--------------------------------------------------------------------------------
-- Registers Read/Write Operation
--------------------------------------------------------------------------------

  -- Register Read
  Rd_Register_Proc: 
  process (Reset, RDn_cs, ADDR_s, RBR, IIR, LSR, MSR)
  begin
    if (Reset='1') then
      DOUT <= (others => '1');
    elsif (RDn_cs ='0') then
      case ADDR_s is
        when A_RBR =>
          DOUT <= RBR;
        when A_IIR =>
          DOUT <= "0000" & IIR;
        when A_LSR =>
          DOUT <= '0' & LSR;
        when A_MSR =>
          DOUT <= MSR;
        when others =>
          DOUT <= (others => '1');
      end case;
    else
      DOUT <= (others=>'1');
    end if;
  end process Rd_Register_Proc;

  -- Register Write
  Wr_Register_Proc:
  process (Reset, WRn_cs)
  begin
    if (Reset='1') then
      THR <= (Others=>'0');
      IER <= (Others=>'0');
      LCR <= (Others=>'0');
      MCR <= (Others=>'0');
    elsif rising_edge(WRn_cs) then
      case ADDR_s is
        when A_THR =>
          -- the Databits are aligned to the right (LSB)
          THR <= DIN;
        when A_IER =>
          IER <= DIN(3 downto 0);
        when A_LCR =>
          LCR <= DIN(6 downto 0);
        when A_MCR =>
          MCR <= DIN(1 downto 0);
        when others =>
      end case;
    end if;
  end process Wr_Register_Proc;

--------------------------------------------------------------------------------
--  Line Control Register
--------------------------------------------------------------------------------

  -- Databits : "00"=5-bit, "01"=6-bit, "10"=7-bit, "11"=8-bit
  Databits <= LCR(1 downto 0);

  -- Stopbits : "00"=1-bit, "01"=1.5-bit(5-bit data), "10"=2-bit(6,7,8-bit data)
  Stopbits <= "00" when (LCR(2)='0') else
              "01" when (LCR(2)='1') and (LCR(1 downto 0)="00") else
              "10";
  -- ParityEnable : '0'=Parity Bit Enable, '1'=Parity Bit Disable
  ParityEnable <= LCR(3);

  -- ParityEven : '0'=Even Parity Selected, '1'=Odd Parity Selected
  ParityEven <= LCR(4);

  -- ParityStick : '0'=Stick Parity Disable, '1'=Stick Parity Enable
  ParityStick <= LCR(5);

  -- TxBreak : '0'=Disable BREAK assertion, '1'=Assert BREAK
  TxBreak <= LCR(6);

--------------------------------------------------------------------------------
--  Line Status Register
--------------------------------------------------------------------------------

  LSR <= TEMT & THRE & BreakInt & FrameErr & ParityErr & OverrunErr & RxRDY;

--------------------------------------------------------------------------------
-- Interrupt Arbitrator
--------------------------------------------------------------------------------

  -- Int is the common interrupt line for all internal UART events
  INTR <= RxRDy_Int or THRE_Int or DataErr_Int or Modem_Int;

  -- Receiving Data Error Flags including Overrun, Parity, Framing and Break
  DataErr <= OverrunErr or ParityErr or FrameErr or BreakInt;

  -- Whenever bit0,1,2,or3 is set to '1', a Modem Status Interrupt is generated
  ModemStat <= MSR(0) or MSR(1) or MSR(2) or MSR(3);

  Int_Arbit_Proc: process(Reset, Clk16X)
  begin
    if (Reset='1') then
      Int_State <= idle;

    elsif rising_edge(Clk16X) then
      case Int_State is
        when idle =>

          if (IER(2)='1') and (DataErr='1') then
            Int_State <= int0;
          elsif (IER(0)='1') and (RxRDY='1') then
            Int_State <= int1;
          elsif (IER(1)='1') and (THRE='1') then
            Int_State <= int2;
          elsif (IER(3)='1') and (ModemStat='1') then
            Int_State <= int3;
          end if;

        when int0 =>
          if (LsrRDn_re='1') then
            -- Clear Receiver Line Status Interrupt after LSR read
            Int_State <= idle;
          end if;

        when int1 =>
          if (RxRDY='0') then
            -- Clear Received Data Available Interrupt after RBR read(RxRDY=0)
            Int_State <= idle;
          end if;

        when int2 =>
          if (IirRDn_re='1') or (THRE='0') then
            -- Clear THR Empty Interrupt after IIR read or THR write(THRE=0)
            Int_State <= idle;
          end if;

        when int3 =>
          if (MsrRDn_re='1') then
            -- Clear MODEM Status Interrupt after MSR read
            Int_State <= idle;
          end if;
        when others =>
          Int_State <= idle;
      end case;
    end if;
  end process Int_Arbit_Proc;

  -- Set Receiver Line Status Interrupt
  DataErr_Int <= '1' when Int_State = int0 else '0';

  -- Set Received Data Available Interrupt
  RxRDY_Int <= '1' when Int_State = int1 else '0';

  -- Set THR Empty Interrupt
  THRE_Int <= '1' when Int_State = int2 else '0';

  -- Set MODEM Status Interrupt
  Modem_Int <= '1' when Int_State = int3 else '0';

  -- Update IIR
  IIR <= "0110" when Int_State = int0 else -- 1st Priority Interrupt
         "0100" when Int_State = int1 else -- 2nd Priority Interrupt
         "0010" when Int_State = int2 else -- 3rd Priority Interrupt
         "0000" when Int_State = int3 else -- 4th Priority Interrupt
         "0001";                           -- No Interrupt Pending


  -- Driver Disable goes low whenever the CPU is reading data from the UART
  DDIS <= RDn_cs;

end Intface_a;





?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产资源在线一区| 一区二区三区免费| 99精品桃花视频在线观看| 一区二区三区成人| 久久精品视频在线免费观看| 欧美视频中文一区二区三区在线观看| 国产一区福利在线| 亚洲一区二区高清| 中文字幕一区二区三区蜜月| 精品久久久久久综合日本欧美| 欧洲精品在线观看| 成人毛片视频在线观看| 九一九一国产精品| 午夜精品福利视频网站 | 亚洲欧美在线aaa| 日韩视频免费观看高清在线视频| 色综合久久综合网| 丁香啪啪综合成人亚洲小说| 久久精品噜噜噜成人88aⅴ| 亚洲午夜精品一区二区三区他趣| 国产精品情趣视频| 国产日韩欧美精品一区| 精品久久久久久无| 日韩欧美在线网站| 欧美一区二区三区四区高清 | 99精品欧美一区二区三区小说| 国产一区二区在线免费观看| 美女一区二区视频| 毛片不卡一区二区| 青青草视频一区| 日本欧美在线看| 日韩影视精彩在线| 午夜精品福利久久久| 午夜精品爽啪视频| 日日摸夜夜添夜夜添精品视频| 亚洲图片有声小说| 三级一区在线视频先锋| 天天av天天翘天天综合网色鬼国产| 一区二区三区欧美| 五月天丁香久久| 婷婷久久综合九色国产成人| 亚洲第一二三四区| 日韩精品三区四区| 蜜桃av一区二区在线观看| 日本午夜一本久久久综合| 日本不卡视频在线观看| 久久国产乱子精品免费女| 久久99精品国产.久久久久久| 韩国在线一区二区| 国产不卡视频一区| 91免费观看视频在线| 在线观看免费亚洲| 91精品在线免费| 精品久久久久久久人人人人传媒| 欧美r级电影在线观看| 久久久久久免费毛片精品| 中文字幕av不卡| 亚洲精品日韩一| 日韩国产欧美在线播放| 久久99精品国产.久久久久久| 国产成人免费网站| 日本高清无吗v一区| 欧美丰满美乳xxx高潮www| 日韩精品一区二区三区中文不卡| 久久久精品国产免大香伊| 综合分类小说区另类春色亚洲小说欧美| 亚洲人成精品久久久久久| 亚洲第一电影网| 国产精品一色哟哟哟| heyzo一本久久综合| 欧美在线观看一二区| 日韩美女主播在线视频一区二区三区| 久久免费美女视频| 亚洲精品成a人| 麻豆一区二区三区| 99国内精品久久| 欧美一级视频精品观看| 国产校园另类小说区| 亚洲国产成人高清精品| 国产精品一区一区三区| jlzzjlzz国产精品久久| 91精品国产色综合久久不卡电影| 欧美激情一区二区三区不卡| 亚洲午夜久久久久久久久电影网| 国产一区二区不卡在线| 欧美体内she精视频| 国产亚洲污的网站| 亚洲电影在线免费观看| 国产成人免费高清| 精品视频在线看| 国产女同互慰高潮91漫画| 亚洲va在线va天堂| 成人综合婷婷国产精品久久蜜臀 | 日韩一区中文字幕| 免费在线观看日韩欧美| 99久久综合国产精品| 日韩欧美一卡二卡| 亚洲一区二区综合| 成人性生交大片免费看在线播放 | 亚洲国产日日夜夜| 粉嫩蜜臀av国产精品网站| 欧美男男青年gay1069videost| 国产日韩欧美精品综合| 久久精品国产久精国产爱| 在线观看免费一区| 中文字幕日韩一区| 国产美女精品在线| 日韩你懂的电影在线观看| 亚洲高清三级视频| 99re热视频这里只精品| 国产色一区二区| 蜜桃视频在线一区| 欧美男女性生活在线直播观看| 亚洲精品网站在线观看| 国产精品69毛片高清亚洲| 日韩一级成人av| 亚洲国产日韩综合久久精品| 一本一道综合狠狠老| 欧美国产日韩a欧美在线观看| 久久疯狂做爰流白浆xx| 欧美丰满美乳xxx高潮www| 亚洲电影一区二区三区| 色88888久久久久久影院按摩| 综合久久综合久久| av毛片久久久久**hd| 国产精品丝袜一区| 国产aⅴ精品一区二区三区色成熟| 精品剧情v国产在线观看在线| 日韩av一区二区三区| 91超碰这里只有精品国产| 亚洲午夜在线观看视频在线| 欧洲一区二区三区免费视频| 自拍偷拍欧美激情| 91在线视频在线| 亚洲欧美日韩综合aⅴ视频| 91小宝寻花一区二区三区| 亚洲乱码国产乱码精品精98午夜| av高清久久久| 樱桃视频在线观看一区| 在线视频观看一区| 亚洲福利电影网| 91精品国产91久久久久久一区二区| 丝袜诱惑制服诱惑色一区在线观看| 欧美私人免费视频| 天堂精品中文字幕在线| 欧美一区二区三区白人| 久久爱www久久做| 久久久久久久国产精品影院| 国产不卡视频一区二区三区| 国产精品福利一区二区三区| 91年精品国产| 亚洲国产va精品久久久不卡综合| 欧美一区二区视频在线观看| 经典三级一区二区| 国产精品三级av在线播放| 99久久免费视频.com| 洋洋av久久久久久久一区| 91麻豆精品国产自产在线| 久久疯狂做爰流白浆xx| 国产精品丝袜一区| 欧美日韩一区中文字幕| 久久99精品国产麻豆婷婷| 中文字幕精品综合| 欧美在线一二三四区| 免费成人av在线播放| 中文字幕乱码亚洲精品一区| 欧洲激情一区二区| 久久精品国产99国产精品| 国产欧美日韩三级| 欧美亚洲一区三区| 久久精品国产久精国产爱| 国产精品国产三级国产a| 欧美日韩aaaaa| 国产精品一区二区黑丝| 亚洲乱码国产乱码精品精98午夜| 日韩一区二区三区电影在线观看 | 成人av网站在线| 五月婷婷激情综合网| 国产日产欧美一区| 欧美日韩亚洲综合在线 | 久久se精品一区二区| 国产精品乱子久久久久| 欧美精品乱码久久久久久| 国产成人免费在线观看不卡| 亚洲成人中文在线| 亚洲国产精品ⅴa在线观看| 6080亚洲精品一区二区| 不卡的电视剧免费网站有什么| 日韩精品亚洲一区| 亚洲免费观看高清完整版在线观看熊| 欧美一区二区三区免费视频 | 日韩一区二区视频| 91在线视频在线| 国产精品一区在线| 污片在线观看一区二区| 亚洲女人的天堂| 欧美高清在线精品一区| 日韩欧美另类在线| 欧美日韩精品一区二区三区| 成人a区在线观看|