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

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

?? i2c_slave_model.v

?? i2c code for the verilog
?? V
字號:


`include "timescale.v"

module i2c_slave_model (scl, sda);

	//
	// parameters
	//
	parameter I2C_ADR = 7'b001_0000;

	//
	// input && outpus
	//
	input scl;
	inout sda;

	//
	// Variable declaration
	//
	wire debug = 1'b1;

	reg [7:0] mem [3:0]; // initiate memory
	reg [7:0] mem_adr;   // memory address
	reg [7:0] mem_do;    // memory data output

	reg sta, d_sta;
	reg sto, d_sto;

	reg [7:0] sr;        // 8bit shift register
	reg       rw;        // read/write direction

	wire      my_adr;    // my address called ??
	wire      i2c_reset; // i2c-statemachine reset
	reg [2:0] bit_cnt;   // 3bit downcounter
	wire      acc_done;  // 8bits transfered
	reg       ld;        // load downcounter

	reg       sda_o;     // sda-drive level
	wire      sda_dly;   // delayed version of sda

	// statemachine declaration
	parameter idle        = 3'b000;
	parameter slave_ack   = 3'b001;
	parameter get_mem_adr = 3'b010;
	parameter gma_ack     = 3'b011;
	parameter data        = 3'b100;
	parameter data_ack    = 3'b101;

	reg [2:0] state; // synopsys enum_state

	//
	// module body
	//

	initial
	begin
	   sda_o = 1'b1;
	   state = idle;
	end

	// generate shift register
	always @(posedge scl)
	  sr <= #1 {sr[6:0],sda};

	//detect my_address
	assign my_adr = (sr[7:1] == I2C_ADR);
	// FIXME: This should not be a generic assign, but rather
	// qualified on address transfer phase and probably reset by stop

	//generate bit-counter
	always @(posedge scl)
	  if(ld)
	    bit_cnt <= #1 3'b111;
	  else
	    bit_cnt <= #1 bit_cnt - 3'h1;

	//generate access done signal
	assign acc_done = !(|bit_cnt);

	// generate delayed version of sda
	// this model assumes a hold time for sda after the falling edge of scl.
	// According to the Phillips i2c spec, there s/b a 0 ns hold time for sda
	// with regards to scl. If the data changes coincident with the clock, the
	// acknowledge is missed
	// Fix by Michael Sosnoski
	assign #1 sda_dly = sda;


	//detect start condition
	always @(negedge sda)
	  if(scl)
	    begin
	        sta <= #1 1'b1;

	        if(debug)
	          $display("DEBUG i2c_slave; start condition detected at %t", $time);
	    end
	  else
	    sta <= #1 1'b0;

	always @(posedge scl)
	  d_sta <= #1 sta;

	// detect stop condition
	always @(posedge sda)
	  if(scl)
	    begin
	       sto <= #1 1'b1;

	       if(debug)
	         $display("DEBUG i2c_slave; stop condition detected at %t", $time);
	    end
	  else
	    sto <= #1 1'b0;

	//generate i2c_reset signal
	assign i2c_reset = sta || sto;

	// generate statemachine
	always @(negedge scl or posedge sto)
	  if (sto || (sta && !d_sta) )
	    begin
	        state <= #1 idle; // reset statemachine

	        sda_o <= #1 1'b1;
	        ld    <= #1 1'b1;
	    end
	  else
	    begin
	        // initial settings
	        sda_o <= #1 1'b1;
	        ld    <= #1 1'b0;

	        case(state) // synopsys full_case parallel_case
	            idle: // idle state
	              if (acc_done && my_adr)
	                begin
	                    state <= #1 slave_ack;
	                    rw <= #1 sr[0];
	                    sda_o <= #1 1'b0; // generate i2c_ack

	                    #2;
	                    if(debug && rw)
	                      $display("DEBUG i2c_slave; command byte received (read) at %t", $time);
	                    if(debug && !rw)
	                      $display("DEBUG i2c_slave; command byte received (write) at %t", $time);

	                    if(rw)
	                      begin
	                          mem_do <= #1 mem[mem_adr];

	                          if(debug)
	                            begin
	                                #2 $display("DEBUG i2c_slave; data block read %x from address %x (1)", mem_do, mem_adr);
	                                #2 $display("DEBUG i2c_slave; memcheck [0]=%x, [1]=%x, [2]=%x", mem[4'h0], mem[4'h1], mem[4'h2]);
	                            end
	                      end
	                end

	            slave_ack:
	              begin
	                  if(rw)
	                    begin
	                        state <= #1 data;
	                        sda_o <= #1 mem_do[7];
	                    end
	                  else
	                    state <= #1 get_mem_adr;

	                  ld    <= #1 1'b1;
	              end

	            get_mem_adr: // wait for memory address
	              if(acc_done)
	                begin
	                    state <= #1 gma_ack;
	                    mem_adr <= #1 sr; // store memory address
	                    sda_o <= #1 !(sr <= 15); // generate i2c_ack, for valid address

	                    if(debug)
	                      #1 $display("DEBUG i2c_slave; address received. adr=%x, ack=%b", sr, sda_o);
	                end

	            gma_ack:
	              begin
	                  state <= #1 data;
	                  ld    <= #1 1'b1;
	              end

	            data: // receive or drive data
	              begin
	                  if(rw)
	                    sda_o <= #1 mem_do[7];

	                  if(acc_done)
	                    begin
	                        state <= #1 data_ack;
	                        mem_adr <= #2 mem_adr + 8'h1;
	                        sda_o <= #1 (rw && (mem_adr <= 15) ); // send ack on write, receive ack on read

	                        if(rw)
	                          begin
	                              #3 mem_do <= mem[mem_adr];

	                              if(debug)
	                                #5 $display("DEBUG i2c_slave; data block read %x from address %x (2)", mem_do, mem_adr);
	                          end

	                        if(!rw)
	                          begin
	                              mem[ mem_adr[3:0] ] <= #1 sr; // store data in memory

	                              if(debug)
	                                #2 $display("DEBUG i2c_slave; data block write %x to address %x", sr, mem_adr);
	                          end
	                    end
	              end

	            data_ack:
	              begin
	                  ld <= #1 1'b1;

	                  if(rw)
	                    if(sda) // read operation && master send NACK
	                      begin
	                          state <= #1 idle;
	                          sda_o <= #1 1'b1;
	                      end
	                    else
	                      begin
	                          state <= #1 data;
	                          sda_o <= #1 mem_do[7];
	                      end
	                  else
	                    begin
	                        state <= #1 data;
	                        sda_o <= #1 1'b1;
	                    end
	              end

	        endcase
	    end

	// read data from memory
	always @(posedge scl)
	  if(!acc_done && rw)
	    mem_do <= #1 {mem_do[6:0], 1'b1}; // insert 1'b1 for host ack generation

	// generate tri-states
	assign sda = sda_o ? 1'bz : 1'b0;


	//
	// Timing checks
	//

	wire tst_sto = sto;
	wire tst_sta = sta;
	wire tst_scl = scl;

	specify
	  specparam normal_scl_low  = 4700,
	            normal_scl_high = 4000,
	            normal_tsu_sta  = 4700,
	            normal_tsu_sto  = 4000,
	            normal_sta_sto  = 4700,

	            fast_scl_low  = 1300,
	            fast_scl_high =  600,
	            fast_tsu_sta  = 1300,
	            fast_tsu_sto  =  600,
	            fast_sta_sto  = 1300;

	  $width(negedge scl, normal_scl_low);  // scl high time
	  $width(posedge scl, normal_scl_high); // scl low time

	  $setup(negedge sda &&& scl, negedge scl, normal_tsu_sta); // start condition
	  $setup(posedge scl, posedge sda &&& scl, normal_tsu_sto); // stop condition

	  $setup(posedge tst_sta, posedge tst_scl, normal_sta_sto); // stop to start time
	endspecify

endmodule


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区在线观看免费观看电影高清| 国产亲近乱来精品视频| 亚洲大片一区二区三区| 欧美日本国产视频| 欧美aaa在线| 久久久99久久| 99久久免费精品高清特色大片| 综合久久久久综合| 欧美视频中文字幕| 美日韩一区二区| 久久伊人蜜桃av一区二区| 国产高清精品网站| 亚洲精品日产精品乱码不卡| 欧美日本精品一区二区三区| 精品一区二区久久久| 国产精品色在线| 欧美日韩精品专区| 国产麻豆91精品| 一区二区三区产品免费精品久久75| 欧美日精品一区视频| 国产真实乱子伦精品视频| 国产精品电影一区二区| 欧美老年两性高潮| 国产91精品久久久久久久网曝门 | 美女网站一区二区| 国产拍揄自揄精品视频麻豆| 色综合久久久久| 国产原创一区二区三区| 最好看的中文字幕久久| 日韩一区国产二区欧美三区| 不卡一区中文字幕| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产精品黄色在线观看| 欧美一级欧美一级在线播放| www.激情成人| 蜜乳av一区二区| 亚洲图片欧美视频| 久久亚洲一级片| 欧美性猛片xxxx免费看久爱| 国产v日产∨综合v精品视频| 亚洲gay无套男同| 国产精品嫩草99a| 欧美一二三四区在线| 日本韩国欧美三级| 丁香激情综合五月| 国产一区二区三区在线观看免费视频 | 中文字幕免费不卡| 日韩欧美一级二级三级久久久| 色综合久久六月婷婷中文字幕| 狠狠网亚洲精品| 亚洲成av人影院在线观看网| 中文字幕在线观看一区二区| 欧美tk丨vk视频| 欧美欧美欧美欧美首页| 91亚洲国产成人精品一区二区三 | 成人网在线播放| 久久不见久久见免费视频1| 亚洲成人一区在线| 亚洲男人的天堂av| 国产精品久久久久影院色老大| 精品日韩欧美一区二区| 制服丝袜中文字幕一区| 欧美亚洲一区三区| 欧美综合色免费| 在线亚洲免费视频| 一本大道久久a久久综合| 成人黄色av电影| 丁香桃色午夜亚洲一区二区三区| 麻豆91精品91久久久的内涵| 人妖欧美一区二区| 日韩有码一区二区三区| 亚洲电影视频在线| 天天亚洲美女在线视频| 五月综合激情婷婷六月色窝| 亚洲福利视频导航| 亚洲va欧美va人人爽| 亚洲高清免费视频| 日本aⅴ免费视频一区二区三区 | 国产在线观看一区二区| 精品无码三级在线观看视频| 精品一区二区三区av| 国产在线精品不卡| 成人激情黄色小说| 99久久综合国产精品| 91网站在线观看视频| 日本乱人伦aⅴ精品| 91黄色免费网站| 欧美日韩精品专区| 日韩欧美国产一二三区| 久久亚洲综合av| 亚洲国产精品ⅴa在线观看| 国产精品高清亚洲| 亚洲一区中文在线| 美国十次了思思久久精品导航| 韩国欧美国产一区| www.日韩在线| 欧美亚洲综合久久| 精品国产露脸精彩对白| 国产欧美精品国产国产专区| 综合久久久久久| 午夜日韩在线观看| 久久99这里只有精品| 国产成人av一区二区三区在线 | 亚洲一区视频在线观看视频| 亚洲大型综合色站| 国产乱淫av一区二区三区| av不卡在线观看| 777色狠狠一区二区三区| 26uuu另类欧美亚洲曰本| 综合久久国产九一剧情麻豆| 天堂蜜桃一区二区三区| 国产精品77777竹菊影视小说| 日本韩国欧美国产| 久久天天做天天爱综合色| 亚洲欧美另类久久久精品| 男女性色大片免费观看一区二区| 国产一区久久久| 欧美无砖砖区免费| 久久久亚洲国产美女国产盗摄 | 91在线一区二区三区| 欧美高清性hdvideosex| 国产精品视频线看| 免费看日韩a级影片| av日韩在线网站| 日韩欧美中文字幕一区| 中文字幕乱码一区二区免费| 日本vs亚洲vs韩国一区三区二区| 成人理论电影网| 日韩精品一区二区在线| 亚洲综合网站在线观看| 成人免费视频一区二区| 日韩欧美专区在线| 亚洲综合无码一区二区| a亚洲天堂av| 国产视频在线观看一区二区三区| 首页综合国产亚洲丝袜| 色88888久久久久久影院按摩| 国产日产精品一区| 精品在线免费视频| 欧美乱妇23p| 亚洲成年人网站在线观看| 99国产精品国产精品毛片| 国产午夜精品理论片a级大结局| 婷婷久久综合九色综合绿巨人| 91蜜桃婷婷狠狠久久综合9色| 久久久精品蜜桃| 韩国三级在线一区| 日韩免费看的电影| 日韩电影在线观看网站| 欧美日韩一区二区三区不卡| 亚洲伦理在线免费看| 成人a免费在线看| 国产精品丝袜久久久久久app| 国内外精品视频| 欧美va日韩va| 激情欧美一区二区| 精品国精品自拍自在线| 久久99精品久久久久久 | 久久精品视频免费| 黄色日韩三级电影| 久久品道一品道久久精品| 狠狠色丁香九九婷婷综合五月| 制服丝袜成人动漫| 亚洲成精国产精品女| 555www色欧美视频| 日本不卡的三区四区五区| 日韩精品中文字幕一区二区三区| 日日摸夜夜添夜夜添国产精品 | 免费精品视频最新在线| 日韩欧美视频在线| 国产自产高清不卡| 欧美国产乱子伦| 成人自拍视频在线观看| 亚洲欧洲精品一区二区三区 | 美日韩一级片在线观看| 精品国精品自拍自在线| 国产乱一区二区| 国产精品麻豆99久久久久久| av日韩在线网站| 亚洲国产成人高清精品| 91精品国产91久久综合桃花| 蜜臀av在线播放一区二区三区| 欧美精品一区二区三区蜜臀| 国产成人av一区二区| 亚洲欧美国产毛片在线| 在线视频欧美区| 日韩国产欧美在线观看| 精品精品国产高清a毛片牛牛| 国产一二精品视频| 亚洲婷婷在线视频| 欧美日韩国产首页在线观看| 麻豆91在线播放| 欧美国产欧美综合| 欧美视频精品在线观看| 久久99精品久久久久久国产越南| 国产区在线观看成人精品| 欧美最猛性xxxxx直播| 国内精品第一页| 亚洲色图视频网站| 日韩欧美一区二区久久婷婷|