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

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

?? uart_rx_tb.vhd

?? lattice的串口仿真的程序
?? VHD
?? 第 1 頁 / 共 5 頁
字號:

    -- Test 18 ---------------------------------------------------
    --   8-bit data receiving test, stick even parity
    wait until rising_edge(okToReceiveSIN);
    sin_gen(8,"10101010",'0',1.0,true,true,CLK_PERIOD*16, SIN);
    sin_gen(8,"01010110",'0',1.0,true,true,CLK_PERIOD*16, SIN);

    -- Test 19 ---------------------------------------------------
    --   8-bit data receiving test, stick odd parity
    wait until rising_edge(okToReceiveSIN);
    sin_gen(8,"10101010",'1',1.0,true,true,CLK_PERIOD*16, SIN);
    sin_gen(8,"01010110",'1',1.0,true,true,CLK_PERIOD*16, SIN);

    -- Test 20 ---------------------------------------------------
    --   8-bit data receiving test, no parity
    wait until rising_edge(okToReceiveSIN);
    sin_gen(8,"10101010",'0',1.0,false,true,CLK_PERIOD*16, SIN);
    sin_gen(8,"01010110",'0',1.0,false,true,CLK_PERIOD*16, SIN);


    -- end of tests ----------------------------------------------
    wait;

  end process SIN_proc;


-----------------------------------------------------------------------
-- Test UART Transmitter/Receiver Functions
-----------------------------------------------------------------------
  UART_Stim_Proc : process
    variable i : integer;
  begin

    -- Reset and Intialization
    MR <= '1';

    CS <= '0';
    ADSn <= '1';
    A <= "111";
    DIN <= "11111111";

    CTSn <= '1';
    DCDn <= '1';
    DSRn <= '1';
    RIn  <= '1';

    wait for (9.5*CLK_PERIOD);

    MR <= '0';

    wait for (0.5*CLK_PERIOD);


    wait until falling_edge(PCLK);
    -- Test 1 ----------------------------------------------------
    --   5-bit data receiving test, even parity
    TestID <= 1;

    -- IER Intialization
    --   bit 3 : 0, disable modem status interrupt
    --   bit 2 : 0, disable receiver line status interrupt
    --   bit 1 : 0, disable tranmitter holding register empty interrupt
    --   bit 0 : 1, enable received data available interrupt
    write_reg (IER,"00000001",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 : 0, 5 data bit (bit[1-0]="00")
    --   bit 0 : 0, 5 data bit (bit[1-0]="00")
    write_reg (LCR,"00011000",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;

    -- 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 = "01100001"
      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 = "01100001"
      report"Invalid LSR"
      severity failure;

    -- Check if INTR is still high
    assert INTR = '1'
      report"Interrupt negated"
      severity failure;

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

    -- Check if INTR is low
    wait for CLK_PERIOD;
    assert INTR = '0'
      report"Interrupt not negated"
      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 still high
    assert INTR = '1'
      report"Interrupt negated"
      severity failure;

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

    -- Check if INTR is low
    wait for CLK_PERIOD;
    assert INTR = '0'
      report"Interrupt not negated"
      severity failure;


    wait until falling_edge(PCLK);
    -- Test 2 ----------------------------------------------------
    --   5-bit data receiving test, odd parity
    TestID <= 2;

    -- IER Intialization
    --   bit 3 : 0, disable modem status interrupt
    --   bit 2 : 0, disable receiver line status interrupt
    --   bit 1 : 0, disable tranmitter holding register empty interrupt
    --   bit 0 : 1, enable received data available interrupt
    write_reg (IER,"00000001",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 : 0, 5 data bit (bit[1-0]="00")
    --   bit 0 : 0, 5 data bit (bit[1-0]="00")
    write_reg (LCR,"00001000",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;

    -- 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 = "01100001"
      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 = "01100001"
      report"Invalid LSR"
      severity failure;

    -- Check if INTR is still high
    assert INTR = '1'
      report"Interrupt negated"
      severity failure;

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

    -- Check if INTR is low
    wait for CLK_PERIOD;
    assert INTR = '0'
      report"Interrupt not negated"
      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 still high
    assert INTR = '1'
      report"Interrupt negated"
      severity failure;

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

    -- Check if INTR is low
    wait for CLK_PERIOD;
    assert INTR = '0'
      report"Interrupt not negated"
      severity failure;


    wait until falling_edge(PCLK);
    -- Test 3 ----------------------------------------------------
    --   5-bit data receiving test, stick even parity
    TestID <= 3;

    -- IER Intialization
    --   bit 3 : 0, disable modem status interrupt
    --   bit 2 : 0, disable receiver line status interrupt
    --   bit 1 : 0, disable tranmitter holding register empty interrupt
    --   bit 0 : 1, enable received data available interrupt
    write_reg (IER,"00000001",CS,ADSn,WRn,A,DIN);

    -- LCR Intialization
    --   bit 6 : 0, do not set break
    --   bit 5 : 1, stick parity
    --   bit 4 : 1, even parity selected
    --   bit 3 : 1, parity enabled
    --   bit 2 : 0, 1 stop bit
    --   bit 1 : 0, 5 data bit (bit[1-0]="00")
    --   bit 0 : 0, 5 data bit (bit[1-0]="00")
    write_reg (LCR,"00111000",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;

    -- 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 = "01100001"
      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 = "01100001"
      report"Invalid LSR"
      severity failure;

    -- Check if INTR is still high
    assert INTR = '1'
      report"Interrupt negated"
      severity failure;

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

    -- Check if INTR is low
    wait for CLK_PERIOD;
    assert INTR = '0'
      report"Interrupt not negated"
      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 still high
    assert INTR = '1'
      report"Interrupt negated"
      severity failure;

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

    -- Check if INTR is low
    wait for CLK_PERIOD;
    assert INTR = '0'
      report"Interrupt not negated"
      severity failure;


    wait until falling_edge(PCLK);
    -- Test 4 ----------------------------------------------------
    --   5-bit data receiving test, stick odd parity
    TestID <= 4;

    -- IER Intialization
    --   bit 3 : 0, disable modem status interrupt
    --   bit 2 : 0, disable receiver line status interrupt
    --   bit 1 : 0, disable tranmitter holding register empty interrupt
    --   bit 0 : 1, enable received data available interrupt
    write_reg (IER,"00000001",CS,ADSn,WRn,A,DIN);

    -- LCR Intialization
    --   bit 6 : 0, do not set break
    --   bit 5 : 1, stick parity
    --   bit 4 : 0, odd parity selected
    --   bit 3 : 1, parity enabled
    --   bit 2 : 0, 1 stop bit
    --   bit 1 : 0, 5 data bit (bit[1-0]="00")
    --   bit 0 : 0, 5 data bit (bit[1-0]="00")
    write_reg (LCR,"00101000",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;

    -- 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 = "01100001"
      report"Invalid LSR"
      severity failure;

    -- Read and check LSR (read again to see if it's changed by LSR read)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜不卡在线观看免费| 久久精品在线观看| 日本va欧美va精品| 日韩一级二级三级| 国产一区三区三区| 亚洲欧洲日韩在线| 欧美视频中文一区二区三区在线观看| 爽爽淫人综合网网站| 日韩欧美一区二区免费| 国产乱一区二区| 国产精品国产成人国产三级 | 久久久www成人免费无遮挡大片| 国产成人精品免费一区二区| 亚洲色图在线视频| 欧美日韩不卡视频| 国产在线视频精品一区| 综合激情网...| 4438成人网| 国产成人免费高清| 一区二区三区四区av| 日韩欧美中文一区二区| 成人一区二区在线观看| 依依成人精品视频| 日韩午夜激情视频| 99精品视频一区二区| 天天色图综合网| 国产亚洲成年网址在线观看| 日本韩国欧美在线| 老司机午夜精品| 亚洲欧美日韩在线播放| 日韩欧美激情四射| 99re视频精品| 老司机一区二区| 亚洲特黄一级片| 日韩亚洲欧美在线| jlzzjlzz亚洲女人18| 日本中文在线一区| 国产精品久久久久一区二区三区共 | 波波电影院一区二区三区| 亚洲国产欧美日韩另类综合 | xnxx国产精品| 91电影在线观看| 精品一区二区三区视频| 一区二区三区影院| 久久久五月婷婷| 欧美另类变人与禽xxxxx| 国产宾馆实践打屁股91| 五月天欧美精品| 国产精品久久777777| 日韩欧美一级精品久久| 色狠狠av一区二区三区| 国产乱理伦片在线观看夜一区 | 美国欧美日韩国产在线播放| 最新中文字幕一区二区三区 | 天堂成人国产精品一区| 国产精品妹子av| 日韩精品一区二区三区老鸭窝| 91麻豆免费在线观看| 国产一区二区三区香蕉| 午夜精品视频一区| 成人欧美一区二区三区视频网页| 精品裸体舞一区二区三区| 在线观看中文字幕不卡| 不卡av免费在线观看| 国产精品综合av一区二区国产馆| 午夜精品视频一区| 亚洲激情图片一区| 国产精品情趣视频| 精品久久一区二区三区| 欧美电影在哪看比较好| 一本久久综合亚洲鲁鲁五月天| 国产99久久久国产精品潘金网站| 久久国产欧美日韩精品| 亚洲综合免费观看高清在线观看| 国产精品久久久久影院| 国产亚洲精品7777| 久久久影院官网| 精品国产一二三| 欧美一区二区国产| 欧美日韩极品在线观看一区| 色欧美88888久久久久久影院| 成人av资源在线| 国产高清无密码一区二区三区| 另类专区欧美蜜桃臀第一页| 五月天亚洲婷婷| 午夜影视日本亚洲欧洲精品| 亚洲精品久久7777| 亚洲精品乱码久久久久久日本蜜臀| 国产精品看片你懂得| 国产农村妇女精品| 国产日韩欧美制服另类| 久久综合av免费| www久久精品| xfplay精品久久| 久久男人中文字幕资源站| www一区二区| 久久久99免费| 久久久久久久网| 国产无一区二区| 国产偷国产偷精品高清尤物| 久久精品一二三| 国产亚洲精品aa| 国产精品久久毛片a| 欧美激情中文字幕一区二区| 欧美国产日韩a欧美在线观看| 国产喂奶挤奶一区二区三区| 欧美激情在线看| 亚洲国产精品av| 中文字幕一区二区三区在线不卡| 国产精品免费久久| 亚洲情趣在线观看| 一区二区三区鲁丝不卡| 亚洲自拍都市欧美小说| 午夜影视日本亚洲欧洲精品| 免费欧美日韩国产三级电影| 精品一区二区三区在线视频| 国产九九视频一区二区三区| 成人一级视频在线观看| av网站一区二区三区| 一本到一区二区三区| 在线观看精品一区| 欧美一区二区三区免费在线看| 日韩欧美在线综合网| 久久久99精品免费观看不卡| 国产精品福利一区二区三区| 亚洲精品日韩综合观看成人91| 午夜不卡av在线| 国内精品写真在线观看 | 国产福利一区二区三区视频| 成人网男人的天堂| 一本一本大道香蕉久在线精品 | 日韩精品一区二| 欧美激情一区在线观看| 亚洲精品福利视频网站| 舔着乳尖日韩一区| 精品一区二区免费| 国产盗摄一区二区| 91日韩一区二区三区| 欧美日韩国产成人在线免费| 欧美变态tickling挠脚心| 欧美经典一区二区| 亚洲精选视频在线| 日本欧美肥老太交大片| 国产精品一区三区| 色欧美乱欧美15图片| 日韩丝袜美女视频| 国产精品久久毛片av大全日韩| 亚洲电影一区二区三区| 精品伊人久久久久7777人| 成人福利视频网站| 欧美日韩国产片| 久久久久久久电影| 洋洋成人永久网站入口| 免费精品视频在线| 成人v精品蜜桃久久一区| 欧美色图免费看| 国产欧美日韩另类一区| 夜夜爽夜夜爽精品视频| 激情国产一区二区| 一本大道久久a久久综合婷婷| 欧美一区三区四区| 国产精品亲子伦对白| 视频一区中文字幕国产| 粉嫩高潮美女一区二区三区| 欧美日韩国产综合视频在线观看| 国产欧美一区二区三区鸳鸯浴| 一区二区免费看| 国产一区二区日韩精品| 欧美少妇一区二区| 国产欧美一区二区精品性色超碰 | 国产在线精品一区二区| 一本大道久久精品懂色aⅴ| 精品成a人在线观看| 亚洲综合图片区| 成人精品免费看| 欧美一级片免费看| 亚洲欧美偷拍三级| 国产精品主播直播| 欧美久久久久中文字幕| 国产精品女同互慰在线看| 免费观看日韩电影| 日本韩国一区二区三区视频| 久久久精品国产免大香伊| 午夜精品福利一区二区三区蜜桃| 成人精品视频一区二区三区 | 91国在线观看| 国产欧美一区二区精品性| 喷水一区二区三区| 在线视频国内一区二区| 国产欧美日韩视频在线观看| 日韩激情一区二区| 色婷婷国产精品久久包臀| 久久久精品影视| 久久99热狠狠色一区二区| 欧美性大战xxxxx久久久| 国产精品三级久久久久三级| 国产在线精品一区二区| 91精品国产入口| 亚洲国产一区二区在线播放| www.欧美色图|