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

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

?? uart_int_tb.vhd

?? UART的rs232通信接口VHDL語言
?? VHD
?? 第 1 頁 / 共 3 頁
字號:
    -- Wait for INTR high
    i := 1;
    loop
      if (i < WAIT_TIMEOUT) then
        wait for CLK_PERIOD;
        exit when INTR = '1';
        i := i + 1;
      else
        assert (false) report"Interrupt Generation Failed"
        severity failure;
      end if;
    end loop;

    -- Check if INTR is pending due to MODEM Status change
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000000"
      report"Invalid IIR"
      severity failure;

    -- Read MSR to reset the MODEM Status Interrupt
    read_reg (MSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "00010001"
      report"Invalid MSR"
      severity failure;

    -- Read MSR and check
    read_reg (MSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "00010000"
      report"Invalid MSR"
      severity failure;

    -- Check if INTR is reset to no interrupt pending
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000001"
      report"Invalid IIR"
      severity failure;

    CTSn <= '1'; -- MODEM signal changed again

    -- Wait for INTR high
    i := 1;
    loop
      if (i < WAIT_TIMEOUT) then
        wait for CLK_PERIOD;
        exit when INTR = '1';
        i := i + 1;
      else
        assert (false) report"Interrupt Generation Failed"
        severity failure;
      end if;
    end loop;

    -- Check if INTR is pending due to MODEM Status change
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000000"
      report"Invalid IIR"
      severity failure;

    -- Read MSR to reset the MODEM Status Interrupt
    read_reg (MSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "00000001"
      report"Invalid MSR"
      severity failure;

    -- Read MSR and check
    read_reg (MSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "00000000"
      report"Invalid MSR"
      severity failure;

    -- Check if INTR is reset to no interrupt pending
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000001"
      report"Invalid IIR"
      severity failure;


    -- Test 5 ----------------------------------------------------
    --   Mixed level 1,2 interrupt test
    if not EOT then
       wait until EOT;
    end if;
    TestID <= 5;
    
    -- IER Intialization
    --   bit 3 : 0, disable modem status interrupt
    --   bit 2 : 1, enable receiver line status interrupt
    --   bit 1 : 0, disable tranmitter holding register empty interrupt
    --   bit 0 : 1, enable received data available interrupt
    write_reg (IER,"00000101",CS,ADSn,WRn,A,DIN);

    -- LCR Intialization
    --   bit 6 : 0, do not set break
    --   bit 5 : 0, not stick parity
    --   bit 4 : 1, even parity selected
    --   bit 3 : 1, parity enabled
    --   bit 2 : 0, 1 stop bit
    --   bit 1 : 1, 8 data bit (bit[1-0]="11")
    --   bit 0 : 1, 8 data bit (bit[1-0]="11")
    write_reg (LCR,"00011011",CS,ADSn,WRn,A,DIN);

    -- trigger okToReceiveSIN to get character from SIN
    okToReceiveSIN <= '1',
                      '0' after 1 ns;

    -- Wait for INTR high
    i := 1;
    loop
      if (i < WAIT_TIMEOUT) then
        wait for CLK_PERIOD;
        exit when INTR = '1';
        i := i + 1;
      else
        assert (false) report"Interrupt Generation Failed"
        severity failure;
      end if;
    end loop;

    -- Check if INTR is pending due to Receiver Data Available
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000100"
      report"Invalid IIR"
      severity failure;

    -- Read and Check LSR (check if "Data Ready" flag at bit 0 is set)
    read_reg (LSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack(0) = '1'
      report"Receiver Data Ready bit in LSR is not set"
      severity failure;

    -- Read and check RBR
    read_reg (RBR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "10010010"
      report"Invalid RBR"
      severity failure;

    -- Read and check LSR (check if "Data Ready" flag at bit 0 is cleared)
    read_reg (LSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "01100000"
      report"Invalid LSR"
      severity failure;

    -- Wait for INTR high
    i := 1;
    loop
      if (i < WAIT_TIMEOUT) then
        wait for CLK_PERIOD;
        exit when INTR = '1';
        i := i + 1;
      else
        assert (false) report"Interrupt Generation Failed"
        severity failure;
      end if;
    end loop;

    -- Check if INTR is pending due to Parity Error
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000110"
      report"Invalid IIR"
      severity failure;

    -- Read and check RBR
    -- A RBR read clears this RxRDY flag in LSR bit 1.  Because of this, a
    -- Receiver Data Available interrupt will not be generated right after 
    -- the Parity Error interrupt is cleared by LSR read.
    read_reg (RBR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "10010010"
      report"Invalid RBR"
      severity failure;

    -- Read and check LSR (check if "Parity Error" flag at bit 2 is set)
    read_reg (LSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "01100100"
      report"Invalid LSR"
      severity failure;

    -- Read and check LSR (read again to see if it's changed by LSR read)
    read_reg (LSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "01100000"
      report"Invalid LSR"
      severity failure;


    -- Test 6 ----------------------------------------------------
    --   Mixed level 1,2,3 interrupt test
    if not EOT then
       wait until EOT;
    end if;
    TestID <= 6;
    
    -- IER Intialization
    --   bit 3 : 0, disable modem status interrupt
    --   bit 2 : 1, enable receiver line status interrupt
    --   bit 1 : 1, enable tranmitter holding register empty interrupt
    --   bit 0 : 1, enable received data available interrupt
    write_reg (IER,"00000111",CS,ADSn,WRn,A,DIN);

    -- LCR Intialization
    --   bit 6 : 0, do not set break
    --   bit 5 : 0, not stick parity
    --   bit 4 : 0, odd parity selected
    --   bit 3 : 1, parity enabled
    --   bit 2 : 0, 1 stop bit
    --   bit 1 : 1, 8 data bit (bit[1-0]="11")
    --   bit 0 : 1, 8 data bit (bit[1-0]="11")
    write_reg (LCR,"00001011",CS,ADSn,WRn,A,DIN);

    -- trigger okToReceiveSIN to get character from SIN
    okToReceiveSIN <= '1',
                      '0' after 1 ns;

    -- Wait for INTR high
    i := 1;
    loop
      if (i < WAIT_TIMEOUT) then
        wait for CLK_PERIOD;
        exit when INTR = '1';
        i := i + 1;
      else
        assert (false) report"Interrupt Generation Failed"
        severity failure;
      end if;
    end loop;

    -- Check if INTR is pending due to THR empty
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000010"
      report"Invalid IIR"
      severity failure;

    -- Write data into THR, 1st time
    write_reg (THR,"00001011",CS,ADSn,WRn,A,DIN);

    -- Wait for INTR high
    i := 1;
    loop
      if (i < WAIT_TIMEOUT) then
        wait for CLK_PERIOD;
        exit when INTR = '1';
        i := i + 1;
      else
        assert (false) report"Interrupt Generation Failed"
        severity failure;
      end if;
    end loop;

    -- Check if 2nd INTR is pending due to THR empty
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000010"
      report"Invalid IIR"
      severity failure;

    -- Write data into THR, 2nd time
    write_reg (THR,"00011011",CS,ADSn,WRn,A,DIN);
    
    -- Wait for INTR high
    i := 1;
    loop
      if (i < WAIT_TIMEOUT) then
        wait for CLK_PERIOD;
        exit when INTR = '1';
        i := i + 1;
      else
        assert (false) report"Interrupt Generation Failed"
        severity failure;
      end if;
    end loop;

    -- Check if 3rd INTR is pending due to Receiver Data Available
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000100"
      report"Invalid IIR"
      severity failure;

    -- Wait until THR empty
    i := 1;
    loop
      if (i < WAIT_TIMEOUT) then
        wait for CLK_PERIOD;
        -- Read LSR (check if "THRE" flag at bit 5 is set)
        read_reg (LSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
        exit when regData_readBack(5) = '1';
        i := i + 1;
      else
        assert (false) report"Data Transmission Failed"
        severity failure;
      end if;
    end loop;

    -- Read and check RBR
    read_reg (RBR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "10010010"
      report"Invalid RBR"
      severity failure;

    -- Check if IIR is reset due to THR empty
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000010"
      report"Invalid IIR"
      severity failure;

    -- Write data into THR, 3rd time
    write_reg (THR,"00101011",CS,ADSn,WRn,A,DIN);

    -- Wait for INTR high
    i := 1;
    loop
      if (i < WAIT_TIMEOUT) then
        wait for CLK_PERIOD;
        exit when INTR = '1';
        i := i + 1;
      else
        assert (false) report"Interrupt Generation Failed"
        severity failure;
      end if;
    end loop;

    -- Check if 3rd INTR is pending due to Parity Error
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack = "00000110"
      report"Invalid IIR"
      severity failure;

    -- Read and check RBR
    -- A RBR read clears this RxRDY flag in LSR bit 1.  Because of this, a
    -- Receiver Data Available interrupt will not be generated right after 
    -- the Parity Error interrupt is cleared by LSR read.
    read_reg (RBR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack = "10010010"
      report"Invalid RBR"
      severity failure;

    -- Read and check LSR (check if "Parity Error" flag at bit 2 is set)
    read_reg (LSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack(2) = '1'
      report"Invalid LSR"
      severity failure;

    -- Check if IIR is reset due to LSR read
    read_reg (IIR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    intLevel <= conv_integer(regData_readBack(2 downto 1));
    assert regData_readBack /= "00000110"
      report"Invalid IIR"
      severity failure;

    -- Read and check LSR (check if "Parity Error" flag is cleared by LSR read)
    read_reg (LSR,regData_readBack,CS,ADSn,RDn,A,DOUT);
    assert regData_readBack(2) = '0'
      report"Invalid LSR"
      severity failure;

    -- Clear IER
    write_reg (IER,"00000000",CS,ADSn,WRn,A,DIN);


    -- end of tests ----------------------------------------------
    assert (false)
      report"End of UART Interrupt Tests ....."
      severity failure;

   end process UART_Stim_Proc;


-- *** end of test bench ***

end;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美一二三| 91在线porny国产在线看| 欧美日韩国产美| 亚瑟在线精品视频| 欧美一区二区女人| 国产一区二区三区四| 久久综合久久综合九色| 国产乱一区二区| 国产精品素人一区二区| 色综合天天综合网国产成人综合天| 1024亚洲合集| 欧美日本一道本在线视频| 免费观看91视频大全| 久久久久国产精品免费免费搜索| 成人精品亚洲人成在线| 亚洲永久免费视频| 欧美大片日本大片免费观看| 成人综合日日夜夜| 亚洲第一福利视频在线| 精品久久久久久久久久久久包黑料 | 2023国产一二三区日本精品2022| 国产精品一区免费在线观看| 亚洲免费观看视频| 精品少妇一区二区三区视频免付费| 国产精品一区二区在线观看不卡| 亚洲日本在线看| 91麻豆精品国产91久久久久久| 国产sm精品调教视频网站| 一区二区激情小说| 久久久久9999亚洲精品| 欧美视频一区二区在线观看| 极品美女销魂一区二区三区免费| 亚洲日本一区二区三区| 精品粉嫩超白一线天av| 在线欧美日韩国产| 国产美女av一区二区三区| 亚洲综合视频在线观看| 欧美精品一区二区不卡 | 国产精品911| 午夜伊人狠狠久久| 欧美国产精品久久| 欧美一卡二卡在线观看| 色婷婷久久一区二区三区麻豆| 精品一区二区在线看| 亚洲国产精品久久久久秋霞影院| 国产日韩欧美一区二区三区乱码| 欧美精选午夜久久久乱码6080| 成人激情av网| 国产麻豆日韩欧美久久| 日韩和欧美一区二区三区| 亚洲欧洲制服丝袜| 日本一区二区免费在线| 日韩精品一区二区三区蜜臀| 欧美三日本三级三级在线播放| 成人丝袜视频网| 激情小说亚洲一区| 秋霞午夜av一区二区三区| 一区二区三区在线免费视频| 国产精品久久久久久久久久久免费看| 日韩精品一区二区三区四区 | 99精品视频在线播放观看| 精品午夜久久福利影院| 日本女优在线视频一区二区| 亚洲精品v日韩精品| 亚洲欧洲精品天堂一级| 国产精品天干天干在线综合| 国产精品美日韩| 国产欧美精品国产国产专区| 久久精品欧美一区二区三区麻豆| 欧美一区二区播放| 日韩亚洲欧美一区二区三区| 日韩一区二区在线观看| 欧美精品色一区二区三区| 欧美日本国产视频| 欧美巨大另类极品videosbest | 久久er99热精品一区二区| 三级在线观看一区二区| 午夜欧美电影在线观看| 日韩一区精品视频| 麻豆精品久久精品色综合| 麻豆免费看一区二区三区| 美女mm1313爽爽久久久蜜臀| 久久精品国产秦先生| 国产一二三精品| 成人av中文字幕| 色综合色狠狠综合色| 欧美系列日韩一区| 5月丁香婷婷综合| 精品免费视频一区二区| 久久精品夜夜夜夜久久| 国产精品久久久久久久久快鸭| 亚洲日穴在线视频| 午夜一区二区三区视频| 美女视频黄免费的久久 | 欧美四级电影在线观看| 91麻豆精品国产91久久久更新时间| 欧美一区二视频| 久久―日本道色综合久久| 中文字幕国产一区二区| 亚洲免费在线电影| 日本视频中文字幕一区二区三区| 国内外成人在线| youjizz国产精品| 欧美日韩视频专区在线播放| 日韩一级黄色大片| 中文字幕欧美日韩一区| 亚洲综合免费观看高清完整版在线 | 国产综合久久久久久久久久久久| 国产精品一区二区你懂的| 97se狠狠狠综合亚洲狠狠| 欧美亚洲综合久久| 久久久www成人免费无遮挡大片| 国产精品福利一区二区| 视频一区二区不卡| 成人高清视频免费观看| 69堂亚洲精品首页| 国产精品久久久久婷婷| 性感美女久久精品| 播五月开心婷婷综合| 欧美电影一区二区| 中文字幕亚洲一区二区av在线| 婷婷久久综合九色综合绿巨人 | 国产高清在线观看免费不卡| 色伊人久久综合中文字幕| 亚洲精品在线观看视频| 一区二区三区四区精品在线视频| 久久99久久久久| 色999日韩国产欧美一区二区| 日韩一区二区免费视频| 亚洲欧美色一区| 国产盗摄女厕一区二区三区| 777欧美精品| 国产精品福利影院| 国产乱码字幕精品高清av | 国产91精品精华液一区二区三区 | 欧美性受极品xxxx喷水| 久久精品夜色噜噜亚洲a∨| 日本欧美大码aⅴ在线播放| 色综合久久久久久久久| 久久精品无码一区二区三区| 日韩高清电影一区| 欧洲av一区二区嗯嗯嗯啊| 欧美极品少妇xxxxⅹ高跟鞋 | 波多野结衣视频一区| 精品剧情在线观看| 三级一区在线视频先锋 | 91精品国产一区二区| 亚洲靠逼com| 白白色 亚洲乱淫| 国产日韩v精品一区二区| 久久机这里只有精品| 欧美另类videos死尸| 亚洲电影视频在线| 91精品福利视频| 亚洲精品视频在线| av日韩在线网站| 一区视频在线播放| 波多野结衣中文字幕一区| 国产欧美日韩亚州综合| 国产一区二区h| 精品福利在线导航| 韩国欧美一区二区| 久久综合狠狠综合| 狠狠色伊人亚洲综合成人| 亚洲精品在线一区二区| 狠狠久久亚洲欧美| 久久久精品蜜桃| 粉嫩蜜臀av国产精品网站| 日韩欧美国产一区二区三区| 日本午夜精品视频在线观看| 日韩欧美电影一区| 国产一区二区女| 国产精品三级电影| 99热国产精品| 亚洲在线一区二区三区| 欧美日韩国产电影| 免费成人在线影院| 精品国产91久久久久久久妲己| 国产在线精品一区二区不卡了| 久久色成人在线| 99久久777色| 夜夜嗨av一区二区三区网页| 欧美日韩国产一二三| 日本美女视频一区二区| 精品国产乱码久久久久久闺蜜| 国产精品12区| 亚洲美女区一区| 91精品婷婷国产综合久久| 麻豆精品一二三| 欧美国产国产综合| 色婷婷激情一区二区三区| 婷婷丁香激情综合| 久久精品无码一区二区三区| 91性感美女视频| 日本成人在线看| 国产精品网曝门| 欧美精品视频www在线观看| 国产夫妻精品视频| 依依成人综合视频| 欧美zozo另类异族|