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

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

?? tst_ds1621.vhd

?? 來自opencore網站的I2C總線模塊
?? VHD
字號:
------ State machine for reading data from Dallas 1621---- Testsystem for i2c controller----library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_arith.all;use work.i2c.all;entity DS1621_interface is	port (		clk : in std_logic;		nReset : in std_logic;		Dout : out std_logic_vector(7 downto 0);	-- data read from ds1621		error : out std_logic; -- no correct ack received		SCL : inout std_logic;		SDA : inout std_logic	);end entity DS1621_interface;architecture structural of DS1621_interface is	constant SLAVE_ADDR : std_logic_vector(6 downto 0) := "1001000";	constant CLK_CNT : unsigned(7 downto 0) := conv_unsigned(20, 8);	signal cmd_ack : std_logic;	signal D : std_logic_vector(7 downto 0);	signal lack, store_dout : std_logic;	signal start, read, write, ack, stop : std_logic;	signal i2c_dout : std_logic_vector(7 downto 0);begin	-- hookup I2C controller	u1: simple_i2c port map (clk => clk, ena => '1', clk_cnt => clk_cnt, nReset => nReset,			read => read, write => write, start => start, stop => stop, ack_in => ack, cmd_ack => cmd_ack, 			Din => D, Dout => i2c_dout, ack_out => lack, SCL => SCL, SDA => SDA);	init_statemachine : block		type states is (i1, i2, i3, i4, i5, t1, t2, t3, t4, t5);		signal state : states;	begin		nxt_state_decoder: process(clk, nReset, state)			variable nxt_state : states;			variable iD : std_logic_vector(7 downto 0);			variable ierr : std_logic;			variable istart, iread, iwrite, iack, istop : std_logic;			variable istore_dout : std_logic;		begin			nxt_state := state;			ierr := '0';			istore_dout := '0';			istart := start;			iread := read;			iwrite := write;			iack := ack;			istop := stop;			iD := D;			case (state) is				-- init DS1621				-- 1) send start condition				-- 2) send slave address + write				-- 3) check ack				-- 4) send "access config" command (0xAC)				-- 5) check ack				-- 6) send config register data (0x00)				-- 7) check ack				-- 8) send stop condition				-- 9) send start condition				-- 10) send slave address + write				-- 11) check ack				-- 12) send "start conversion" command (0xEE)				-- 13) check ack				-- 14) send stop condition				when i1 =>	-- send start condition, sent slave address + write					nxt_state := i2;					istart := '1';					iread := '0';					iwrite := '1';					iack := '0';					istop := '0';					iD := (slave_addr & '0'); -- write to slave (R/W = '0')				when i2 =>	-- send "access config" command					if (cmd_ack = '1') then						nxt_state := i3;						-- check aknowledge bit						if (lack = '1') then							ierr := '1'; -- no acknowledge received from last command, expected ACK						end if;						istart := '0';						iread := '0';						iwrite := '1';						iack := '0';						istop := '0';						iD := x"AC";					end if;				when i3 =>	-- send config register data, sent stop condition					if (cmd_ack = '1') then						nxt_state := i4;						-- check aknowledge bit						if (lack = '1') then							ierr := '1'; -- no acknowledge received from last command, expected ACK						end if;						istart := '0';						iread := '0';						iwrite := '1';						iack := '0';						istop := '1';						iD := x"00";					end if;				when i4 =>	-- send start condition, sent slave address + write					if (cmd_ack = '1') then						nxt_state := i5;							istart := '1';						iread := '0';						iwrite := '1';						iack := '0';						istop := '0';						iD := (slave_addr & '0'); -- write to slave (R/W = '0')					end if;				when i5 =>	-- send "start conversion" command + stop condition					if (cmd_ack = '1') then						nxt_state := t1;						-- check aknowledge bit						if (lack = '1') then							ierr := '1'; -- no acknowledge received from last command, expected ACK						end if;						istart := '0';						iread := '0';						iwrite := '1';						iack := '0';						istop := '1';						iD := x"EE";					end if;				-- read temperature				-- 1) sent start condition				-- 2) sent slave address + write				-- 3) check ack				-- 4) sent "read temperature" command (0xAA)				-- 5) check ack				-- 6) sent start condition				-- 7) sent slave address + read				-- 8) check ack				-- 9) read msb				-- 10) send ack				-- 11) read lsb				-- 12) send nack				-- 13) send stop condition				when t1 =>	-- send start condition, sent slave address + write					if (cmd_ack = '1') then						nxt_state := t2;						-- check aknowledge bit						if (lack = '1') then							ierr := '1'; -- no acknowledge received from last command, expected ACK						end if;						istart := '1';						iread := '0';						iwrite := '1';						iack := '0';						istop := '0';						iD := (slave_addr & '0'); -- write to slave (R/W = '0')					end if;				when t2 =>	-- send read temperature command					if (cmd_ack = '1') then						nxt_state := t3;						-- check aknowledge bit						if (lack = '1') then							ierr := '1'; -- no acknowledge received from last command, expected ACK						end if;						istart := '0';						iread := '0';						iwrite := '1';						iack := '0';						istop := '0';						iD := x"AA";					end if;				when t3 =>	-- send (repeated) start condition, send slave address + read					if (cmd_ack = '1') then						nxt_state := t4;						-- check aknowledge bit						if (lack = '1') then							ierr := '1'; -- no acknowledge received, expected ACK						end if;						istart := '1';						iread := '0';						iwrite := '1';						iack := '0';						istop := '0';						iD := (slave_addr & '1'); -- read from slave (R/W = '1')					end if;				when t4 =>	-- read MSB (hi-byte), send acknowledge					if (cmd_ack = '1') then						nxt_state := t5;						-- check aknowledge bit						if (lack = '1') then							ierr := '1'; -- no acknowledge received from last command, expected ACK						end if;						istart := '0';						iread := '1';						iwrite := '0';						iack := '0'; --ACK						istop := '0';					end if;				when t5 =>	-- read LSB (lo-byte), send acknowledge, sent stop					if (cmd_ack = '1') then						nxt_state := t1;						istart := '0';						iread := '1';						iwrite := '0';						iack := '1'; --NACK						istop := '1';						istore_dout := '1';					end if;			end case;			-- genregs			if (nReset = '0') then				state <= i1;				error <= '0';				store_dout <= '0';				start <= '0';				read <= '0';				write <= '0';				ack <= '0';				stop <= '0';				D <= (others => '0');			elsif (clk'event and clk = '1') then				state <= nxt_state;				error <= ierr;				store_dout <= istore_dout;				start <= istart;				read <= iread;				write <= iwrite;				ack <= iack;				stop <= istop;				D <= iD;			end if;		end process nxt_state_decoder;	end block init_statemachine;	-- store temp	gen_dout : process(clk)	begin		if (clk'event and clk = '1') then			if (store_dout = '1') then				Dout <= i2c_dout;			end if;		end if;	end process gen_dout;end architecture structural;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区0| 亚洲国产精品综合小说图片区| 国产综合色视频| 精品剧情在线观看| 国产激情一区二区三区| 中文字幕亚洲精品在线观看 | 欧美mv日韩mv亚洲| 国产一区二区三区高清播放| 国产亚洲一二三区| av一区二区三区黑人| 一区二区三区资源| 88在线观看91蜜桃国自产| 麻豆精品一区二区av白丝在线| 久久亚洲精华国产精华液 | 午夜精品福利视频网站| 日韩视频一区在线观看| 福利一区福利二区| 亚洲精品成人天堂一二三| 欧美一区二区三区四区久久| 国产一区视频网站| 樱花草国产18久久久久| 日韩欧美的一区二区| 成人精品国产免费网站| 亚洲午夜精品在线| 亚洲电影一区二区| 欧美sm极限捆绑bd| 亚洲国产欧美在线| 精品奇米国产一区二区三区| 成人app软件下载大全免费| 视频在线观看91| 国产在线精品一区二区三区不卡| 亚洲线精品一区二区三区| 亚洲欧洲日本在线| 18欧美乱大交hd1984| 日本一区二区综合亚洲| 久久精品亚洲乱码伦伦中文| 久久这里只有精品6| 欧美精品一区二区三区蜜臀| 精品日韩99亚洲| 26uuu国产日韩综合| 久久久久一区二区三区四区| 久久综合九色综合欧美98| 精品国产在天天线2019| 精品处破学生在线二十三| 久久奇米777| 国产欧美一区二区精品忘忧草| 国产午夜一区二区三区| 亚洲国产精品激情在线观看| 中文字幕av一区二区三区| 国产精品国产三级国产专播品爱网| 欧美高清在线视频| 亚洲视频一二区| 亚洲综合色丁香婷婷六月图片| 亚洲国产欧美一区二区三区丁香婷| 亚洲成人动漫在线观看| 美女一区二区在线观看| 国产乱码精品一区二区三区五月婷| 国产一区二区剧情av在线| 成人妖精视频yjsp地址| 成人免费看视频| 欧亚洲嫩模精品一区三区| 色哟哟国产精品免费观看| 欧美日韩一区不卡| 日韩视频免费观看高清完整版| 精品国产一区二区在线观看| 欧美大黄免费观看| 久久综合成人精品亚洲另类欧美| 精品日韩在线一区| 国产欧美综合色| 欧美国产一区二区在线观看| 国产精品美女久久久久aⅴ国产馆| 久久久夜色精品亚洲| 国产精品免费免费| 一区二区三区波多野结衣在线观看 | 中文幕一区二区三区久久蜜桃| 国产精品久久久久久久久搜平片| 亚洲综合色视频| 久久99国产精品免费| 成人精品视频一区二区三区| 欧美日韩国产高清一区二区| 久久综合狠狠综合久久激情| 亚洲男女毛片无遮挡| 免费成人在线网站| 99这里都是精品| 欧美一区二区在线看| 日韩美女视频一区| 美女高潮久久久| 一本色道亚洲精品aⅴ| 日韩精品在线一区二区| 亚洲精品日产精品乱码不卡| 国产在线播放一区| 欧美性大战xxxxx久久久| 久久久99久久精品欧美| 亚洲国产aⅴ天堂久久| 国产精品99久久久久久有的能看| 欧美日韩性生活| 中文字幕一区二区三区在线观看 | 中文字幕亚洲不卡| 老司机精品视频导航| 欧美在线free| 国产亚洲福利社区一区| 亚洲一区二区三区四区五区黄| 国产高清亚洲一区| 欧美一区二区三区在线观看 | 国产精品国产三级国产aⅴ原创| 亚洲午夜羞羞片| 亚洲国产精品成人综合色在线婷婷| 亚洲自拍偷拍麻豆| 国产一区激情在线| 欧美三级视频在线观看| 国产免费观看久久| 日韩成人免费电影| 欧美亚洲自拍偷拍| 亚洲视频免费看| 高清beeg欧美| 国产午夜精品一区二区三区四区| 美日韩一区二区三区| 欧美另类变人与禽xxxxx| 亚洲精品欧美专区| 91丨porny丨中文| 国产精品电影院| 成人免费毛片嘿嘿连载视频| 久久久久久久综合日本| 国产中文字幕精品| 欧美不卡在线视频| 精品一区二区久久| 精品久久人人做人人爰| 青椒成人免费视频| 91精品国产91久久综合桃花| 香蕉久久夜色精品国产使用方法| 色八戒一区二区三区| 亚洲精品国产成人久久av盗摄| 99v久久综合狠狠综合久久| 亚洲欧洲美洲综合色网| eeuss鲁片一区二区三区在线观看| 中文字幕不卡的av| 不卡的av电影| 亚洲乱码国产乱码精品精可以看| 91在线免费看| 亚洲六月丁香色婷婷综合久久 | 3atv在线一区二区三区| 婷婷成人激情在线网| 欧美精品高清视频| 日本sm残虐另类| 日韩欧美电影在线| 国产成人自拍在线| 国产精品超碰97尤物18| 色婷婷国产精品综合在线观看| 亚洲欧美成人一区二区三区| 色噜噜久久综合| 午夜精品爽啪视频| 精品少妇一区二区三区视频免付费| 国内外成人在线视频| 久久精品一二三| 91丨porny丨中文| 亚洲高清免费观看| 日韩情涩欧美日韩视频| 国产麻豆精品95视频| 国产精品国产自产拍在线| 欧美亚洲综合一区| 久久99精品国产.久久久久 | 337p粉嫩大胆色噜噜噜噜亚洲| 国产伦理精品不卡| 国产精品福利一区二区三区| 欧美丝袜丝nylons| 蜜桃传媒麻豆第一区在线观看| 国产婷婷一区二区| 91久久免费观看| 捆绑变态av一区二区三区| 国产精品毛片大码女人| 欧美亚洲综合网| 国产一区二区三区免费在线观看| 国产精品欧美综合在线| 欧美日韩和欧美的一区二区| 国产曰批免费观看久久久| 中文字幕日韩一区二区| 日韩一区二区三区四区| 成人国产精品免费观看| 日韩电影在线免费| 亚洲国产激情av| 91麻豆精品国产| 成人app软件下载大全免费| 婷婷中文字幕综合| 国产精品网站在线观看| 在线综合视频播放| 波波电影院一区二区三区| 男人的天堂亚洲一区| 国产精品丝袜一区| 日韩欧美一区二区在线视频| 99久久国产综合色|国产精品| 日韩在线播放一区二区| 国产精品女主播在线观看| 日韩一级二级三级精品视频| 91视视频在线观看入口直接观看www| 日欧美一区二区| 亚洲欧美二区三区| 国产欧美综合色| 精品国产免费人成电影在线观看四季| 一本久久a久久免费精品不卡| 国产在线精品一区二区夜色 |