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

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

?? ps2.vhd

?? 與PS2的通信
?? VHD
字號:
-- The FPGA-evb-S2 Xilinx Spartan-II evaluation board example-- This example reads scan codes from a PS/2 keyboard and-- displays them on LEDs.-- (C)2001 Jan Pech, j.pech@sh.cvut.czlibrary IEEE;use IEEE.STD_LOGIC_1164.ALL;use IEEE.STD_LOGIC_ARITH.ALL;use IEEE.STD_LOGIC_UNSIGNED.ALL;entity ps2 is  port (resetn:  in  std_logic;                     -- active low reset        clock:   in  std_logic;                     -- system clock        ps2_clk: in  std_logic;                     -- PS/2 clock line        ps2_dta: in  std_logic;                     -- PS/2 data line        hit_1:     out std_logic;        ascii:    out std_logic_vector(7 downto 0)); -- LED outputsend ps2;architecture behavioral of ps2 is  type state_type is (IDLE, START, DATA, PARITY);   -- FSM states  signal ps2_dv: std_logic;                         -- PS/2 data valid  signal prv_ps2_clk, act_ps2_clk: std_logic;       -- auxiliary signals  signal recdata: std_logic_vector(7 downto 0);     -- read data  signal shift: std_logic;                          -- enable for shift reg.  signal n_shift: std_logic;                        -- auxiliary signal  signal latch: std_logic;                          -- latch read data  signal n_latch: std_logic;                        -- auxiliary signal  signal err: std_logic;                            -- parity or stop error  signal n_err: std_logic;                          -- auxiliary signal  signal parset: std_logic;                         -- preset for parity check  signal n_parset: std_logic;                       -- auxiliary signal  signal c_state, n_state: state_type;              -- current & next states  signal cntval: std_logic_vector(2 downto 0);      -- counter of data bits  signal zero: std_logic;                           -- counter is zero  signal parbit: std_logic;                         -- odd parity of data  signal leds:std_logic_vector(7 downto 0);  signal hit_cnt:std_logic_vector(8 downto 0);  signal hit:std_logic;begin  -- Provides a one-shot pulse after every falling edge of PS/2 clock  PS_CLK_SYNC: process(clock, resetn)  begin    if (resetn = '0') then      prv_ps2_clk <= '1';      act_ps2_clk <= '1';    elsif (clock'event and clock = '1') then      act_ps2_clk <= ps2_clk;      prv_ps2_clk <= act_ps2_clk;    end if;  end process;  ps2_dv <= (not act_ps2_clk) and prv_ps2_clk;  -- Serial input, parallel output shift register  SIPO: process(clock, resetn)  begin    if (resetn = '0') then      recdata <= (others => '0');    elsif (clock'event and clock = '1') then      if (shift = '1') then        recdata <= ps2_dta & recdata(7 downto 1);      end if;    end if;  end process;  -- Counter of data bits  COUNT8: process(resetn, clock)  begin    if (resetn = '0') then      cntval <= (others => '0');    elsif (clock'event and clock = '1') then      if (shift = '1') then        cntval <= cntval + 1;      end if;    end if;  end process;  zero <= not (cntval(0) or cntval(1) or cntval(2));  -- Parity check of received data  PARITY_CHECK: process(clock, parset)  begin    if (parset = '1') then      parbit <= '1';    elsif (clock'event and clock = '1') then      if (shift = '1' and ps2_dta = '1') then        parbit <= not parbit;      end if;    end if;  end process;  -- Synchronous process of control state machine  FSM_SYNC: process(clock, resetn)  begin    if (resetn = '0') then      c_state <= IDLE;      shift <= '0';      latch <= '0';      err <= '0';      parset <= '1';    elsif (clock'event and clock = '1') then      c_state <= n_state;      shift <= n_shift;      latch <= n_latch;      err <= n_err;      parset <= n_parset;    end if;  end process;  -- Combinatorial process of control state machine  FSM_COMB: process(c_state, ps2_dv, ps2_dta, zero)  begin                 -- default values    n_shift <= '0';    n_latch <= '0';    n_err <= '0';    n_parset <= '0';    case c_state is              -- wait to receive data      when IDLE =>   if ((ps2_dv and (not ps2_dta)) = '1') then                       n_state <= START;                       n_parset <= '1';                     else                       n_state <= IDLE;                     end if;      -- receive first data bit      when START =>  if (ps2_dv = '0') then                       n_state <= START;                     else                       n_state <= DATA;                       n_shift <= '1';                     end if;      -- receive remaining data bits and parity      when DATA =>   if (ps2_dv = '0') then                       n_state <= DATA;                     elsif (zero = '0') then                       n_state <= DATA;                       n_shift <= '1';                     else                       n_state <= PARITY;                       if (parbit /= ps2_dta) then                         n_err <= '1';                       end if;                     end if;      -- receive stop bit      when PARITY => if (ps2_dv = '0') then                       n_state <= PARITY;                     else                       n_state <= IDLE;                       n_latch <= '1';                       n_err <= not ps2_dta;                     end if;    end case;  end process;  -- Output latch  LED_OUTPUTS: process(resetn, clock)  begin    if (resetn = '0') then      leds <= (others => '1');    elsif (clock'event and clock = '1') then      if (err = '1') then        leds <= (others => '1');      elsif (latch = '1') then        leds <=  recdata;      end if;    end if;  end process; PROCESS(leds)   BEGIN	case leds is      when "01000101"=> ascii <= "00110000"; hit<='1';  --0      when "00010110"=> ascii <= "00110001"; hit<='1';  --1       when "00011110"=> ascii <= "00110010"; hit<='1';  --2       when "00100110"=> ascii <= "00110011"; hit<='1';  --3       when "00100101"=> ascii <= "00110100"; hit<='1';  --4       when "00101110"=> ascii <= "00110101"; hit<='1';  --5       when "00110110"=> ascii <= "00110110"; hit<='1';  --6       when "00111101"=> ascii <= "00110111"; hit<='1';  --7       when "00111110"=> ascii <= "00111000"; hit<='1';  --8       when "01000110"=> ascii <= "00111001"; hit<='1';  --9       when "00011100"=> ascii <= "01100001"; hit<='1';  --a      when "00110010"=> ascii <= "01100010"; hit<='1';  --b      when "00100001"=> ascii <= "01100011"; hit<='1';  --c      when "00100011"=> ascii <= "01100100"; hit<='1';  --d       when "00100100"=> ascii <= "01100101"; hit<='1';  --e       when "00101011"=> ascii <= "01100110"; hit<='1';  --f       when "00110100"=> ascii <= "01100111"; hit<='1';  --g       when "00110011"=> ascii <= "01101000"; hit<='1';  --h        when "01000011"=> ascii <= "01101001"; hit<='1';  --i        when "00111011"=> ascii <= "01101010"; hit<='1';  --j        when "01000010"=> ascii <= "01101011"; hit<='1';  --k        when "01001011"=> ascii <= "01101100"; hit<='1';  --l        when "00111010"=> ascii <= "01101101"; hit<='1';  --m        when "00110001"=> ascii <= "01101110"; hit<='1';  --n        when "01000100"=> ascii <= "01101111"; hit<='1';  --o        when "01001101"=> ascii <= "01110000"; hit<='1';  --p        when "00010101"=> ascii <= "01110001"; hit<='1';  --q        when "00101101"=> ascii <= "01110010"; hit<='1';  --r        when "00011011"=> ascii <= "01110011"; hit<='1';  --s        when "00101100"=> ascii <= "01110100"; hit<='1';  --t        when "00111100"=> ascii <= "01110101"; hit<='1';  --u        when "00101010"=> ascii <= "01110110"; hit<='1';  --v       when "00011101"=> ascii <= "01110111"; hit<='1';  --w       when "00100010"=> ascii <= "01111000"; hit<='1';  --x        when "00110101"=> ascii <= "01111001"; hit<='1';  --y        when "00011010"=> ascii <= "01111010"; hit<='1';  --z      when "00111001"=> ascii <= "00100000"; hit<='1';  --spacebar      when "01100110"=> ascii <= "00100000"; hit<='1';  --backspace      when "01110001"=> ascii <= "11100000"; hit<='1';  --del      when others =>    ascii <= "00100000"; hit<='0';  --' ' for unlisted characters.    end case;	    	  if hit='1' then	       if  hit_cnt="111111111" then	  	       hit_1<='1';		       hit_cnt<="000000000";		    else		       hit_cnt<=hit_cnt+1;		    end if;	     else		    hit_1<=hit;	     end if;	    END PROCESS;end behavioral;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区福利视频| 久久99最新地址| 色av成人天堂桃色av| 国产精品国产a级| 国产精品一区二区无线| 精品福利二区三区| 捆绑调教美女网站视频一区| 欧美一区二视频| 日韩国产一二三区| 5858s免费视频成人| 日韩影视精彩在线| 在线91免费看| 奇米在线7777在线精品| 日韩一区二区三区视频| 裸体健美xxxx欧美裸体表演| 日韩亚洲电影在线| 国产自产2019最新不卡| 国产精一品亚洲二区在线视频| 五月天亚洲精品| 亚洲大片在线观看| 午夜av一区二区| 亚洲人一二三区| 国产精品毛片无遮挡高清| 亚洲欧美福利一区二区| 奇米精品一区二区三区在线观看 | 一级做a爱片久久| 色综合天天综合网天天看片| 樱桃国产成人精品视频| 欧美亚洲一区三区| 肉丝袜脚交视频一区二区| 欧美一区二区视频在线观看2022| 精油按摩中文字幕久久| 欧美国产精品劲爆| 一本一道波多野结衣一区二区 | 国产精品青草久久| av爱爱亚洲一区| 日韩美女精品在线| 欧美色大人视频| 久草在线在线精品观看| 欧美国产亚洲另类动漫| 色婷婷综合久久| 免费在线观看一区| 国产蜜臀97一区二区三区| 91美女在线看| 日韩成人免费看| 久久亚洲精华国产精华液| 99视频精品全部免费在线| 亚洲成人7777| 久久久国产午夜精品| 色噜噜狠狠成人网p站| 蜜臀91精品一区二区三区| 国产欧美一区二区三区鸳鸯浴 | 欧美日韩国产电影| 国内精品视频一区二区三区八戒| 国产精品卡一卡二卡三| 欧美日韩一级片在线观看| 激情文学综合丁香| 中文字幕在线不卡一区| 欧美日韩国产系列| 国产精品一区在线观看乱码| 一区二区在线电影| 精品久久久久久久久久久久久久久久久 | 国产精品久久久久久久蜜臀| 欧美日韩激情一区二区三区| 国产在线精品不卡| 亚洲精品国产无天堂网2021| 制服.丝袜.亚洲.另类.中文| 国产成人8x视频一区二区| 亚洲国产精品天堂| 亚洲国产高清在线| 欧美精选午夜久久久乱码6080| 国产精品一二三四五| 午夜精品一区二区三区免费视频| 久久久高清一区二区三区| 欧美日韩激情在线| 9色porny自拍视频一区二区| 久久国产精品99精品国产| 亚洲一区在线播放| 日本一区二区三区免费乱视频| 欧美嫩在线观看| a在线播放不卡| 九一久久久久久| 亚洲影院久久精品| 中日韩av电影| 日韩你懂的在线观看| 91福利在线看| 成人精品视频一区二区三区尤物| 日韩高清中文字幕一区| 亚洲欧美日韩成人高清在线一区| 久久久不卡网国产精品一区| 欧美日韩视频第一区| 99精品视频在线免费观看| 紧缚捆绑精品一区二区| 日韩精品午夜视频| 亚洲自拍偷拍av| 亚洲欧洲精品天堂一级| 欧美精品一区视频| 在线播放中文字幕一区| 在线观看欧美日本| 成人app网站| 国产精品 欧美精品| 美腿丝袜在线亚洲一区| 亚洲风情在线资源站| 亚洲女同ⅹxx女同tv| 欧美激情一区二区在线| 久久综合九色综合97婷婷女人 | 99国产精品久久久久久久久久久| 日韩精品福利网| 一区二区三区不卡视频在线观看 | 成年人网站91| 国产精品中文字幕日韩精品| 精品sm捆绑视频| 成人精品国产福利| 亚洲国产日产av| 亚洲精品国产视频| 中文字幕亚洲在| 国产精品久线在线观看| 中文欧美字幕免费| 久久久99免费| 久久免费精品国产久精品久久久久| 日韩色视频在线观看| 日韩一区二区三区三四区视频在线观看| 精品视频一区 二区 三区| 欧美专区在线观看一区| 欧美在线一二三| 欧美日韩精品一区二区三区四区| 在线观看成人小视频| 色婷婷综合在线| 在线观看免费视频综合| 欧美在线播放高清精品| 欧美伊人久久大香线蕉综合69| 欧日韩精品视频| 欧美人与性动xxxx| 91精品在线一区二区| 欧美一区二区三区啪啪| 日韩一区二区不卡| 欧美大胆一级视频| 亚洲精品一区二区三区精华液| 精品国产成人在线影院| 久久久午夜精品| 国产精品视频免费| 1000部国产精品成人观看| 一区二区三区日韩在线观看| 一区二区三区.www| 日韩影视精彩在线| 国产自产v一区二区三区c| 成人做爰69片免费看网站| 91香蕉视频黄| 欧美性感一类影片在线播放| 欧美日韩精品一区二区在线播放| 91精品国产全国免费观看| 日韩精品一区二区三区三区免费| 精品日产卡一卡二卡麻豆| 国产人久久人人人人爽| 中文字幕一区二区三区不卡在线 | 久久99精品国产.久久久久| 国产精品羞羞答答xxdd| 波多野结衣的一区二区三区| 欧美综合天天夜夜久久| 欧美一卡在线观看| 久久麻豆一区二区| 亚洲欧洲国产日本综合| 亚洲成人一区二区在线观看| 青青草97国产精品免费观看无弹窗版| 九九**精品视频免费播放| 国产成人午夜视频| 色老汉一区二区三区| 欧美一区二区久久| 国产亚洲成年网址在线观看| 亚洲少妇屁股交4| 日韩福利电影在线观看| 国产精品一区二区三区99| 91女厕偷拍女厕偷拍高清| 欧美日韩成人在线一区| 久久久久久久电影| 亚洲最新视频在线播放| 久久电影网站中文字幕| 92国产精品观看| 欧美一级xxx| 中文字幕视频一区| 日韩国产高清影视| 成人av免费在线| 3atv在线一区二区三区| 欧美国产在线观看| 午夜精品免费在线观看| 丁香六月久久综合狠狠色| 欧美三级资源在线| 久久久精品欧美丰满| 亚洲午夜精品网| 风流少妇一区二区| 91精品国产麻豆国产自产在线 | 91高清在线观看| 久久先锋影音av鲁色资源| 亚洲精品va在线观看| 激情综合一区二区三区| 日本大香伊一区二区三区| 久久综合成人精品亚洲另类欧美 | 国产女同互慰高潮91漫画| 亚洲成人自拍一区| av一二三不卡影片|