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

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

?? i2c_slave_model.v

?? 用VHDL寫的I2C源程序
?? 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一区二区三区免费野_久草精品视频
国产日本欧美一区二区| 国产一区在线观看视频| 另类调教123区| 色婷婷综合中文久久一本| 精品国产百合女同互慰| 亚洲成人动漫在线免费观看| 福利一区二区在线观看| 欧美一区二区成人6969| 亚洲免费视频成人| 国产成人精品一区二| 4438成人网| 亚洲最快最全在线视频| 国产不卡视频在线播放| 欧美zozo另类异族| 日韩av网站在线观看| 欧美唯美清纯偷拍| 亚洲精品欧美专区| 91在线云播放| 国产精品高潮呻吟| 粉嫩aⅴ一区二区三区四区| 欧美mv和日韩mv国产网站| 日日夜夜精品免费视频| 欧美无人高清视频在线观看| 一区二区视频在线看| 一本色道久久加勒比精品| 亚洲欧洲成人自拍| 97se亚洲国产综合自在线观| 国产精品久久久一本精品| 国产成人在线视频播放| 久久久久久久国产精品影院| 狠狠色综合播放一区二区| 日韩欧美黄色影院| 精品一区二区三区蜜桃| 精品国产乱码久久久久久久久 | 另类小说视频一区二区| 91精品国产一区二区三区蜜臀| 一区二区视频在线看| 色综合久久久久久久久| 亚洲综合免费观看高清完整版在线| 成人app网站| 亚洲最色的网站| 在线电影国产精品| 麻豆成人久久精品二区三区红 | 中文字幕一区二区在线观看| 成人精品国产福利| 中文字幕一区在线| 欧美熟乱第一页| 蜜臀久久99精品久久久久久9| 欧美成人伊人久久综合网| 国产美女一区二区| 国产精品美女久久福利网站| 色婷婷国产精品综合在线观看| 亚洲综合偷拍欧美一区色| 欧美精品久久久久久久多人混战 | 日本精品一级二级| 无码av免费一区二区三区试看| 制服丝袜一区二区三区| 国产露脸91国语对白| 中日韩av电影| 欧美亚洲高清一区二区三区不卡| 日产国产高清一区二区三区| 2020国产精品自拍| 91看片淫黄大片一级| 日韩电影在线免费看| 亚洲国产成人在线| 欧美日韩精品欧美日韩精品一综合| 麻豆91在线播放| 国产精品久久久久婷婷| 欧美剧情片在线观看| 国产精品一二三区在线| 亚洲午夜激情av| 国产日韩影视精品| 欧美日韩日日骚| 成人午夜激情在线| 日韩不卡在线观看日韩不卡视频| 国产精品午夜在线| 日韩欧美成人激情| 色呦呦一区二区三区| 激情欧美日韩一区二区| 亚洲黄色录像片| 国产欧美精品一区二区色综合朱莉| 欧美在线免费观看视频| 成人小视频免费在线观看| 日韩成人精品在线观看| 亚洲激情校园春色| 国产日产欧产精品推荐色| 欧美精品一卡两卡| 91毛片在线观看| 国产xxx精品视频大全| 日韩黄色免费电影| 亚洲综合色自拍一区| 一色桃子久久精品亚洲| 久久综合久久综合久久| 日韩写真欧美这视频| 欧美亚洲日本国产| 91猫先生在线| 色综合天天综合色综合av| 国产成人综合网| 国产精品77777竹菊影视小说| 男女男精品视频网| 亚洲sss视频在线视频| 一区二区三区四区蜜桃 | av中文字幕不卡| 国内成人免费视频| 韩国成人福利片在线播放| 热久久久久久久| 视频一区二区三区入口| 亚洲国产乱码最新视频| 亚洲综合偷拍欧美一区色| 亚洲靠逼com| 亚洲一区在线视频| 五月综合激情婷婷六月色窝| 亚洲va欧美va天堂v国产综合| 亚洲国产人成综合网站| 亚洲成人在线网站| 日日夜夜一区二区| 久久精品国产亚洲a| 久久er99精品| 国产高清久久久久| 99这里都是精品| 91激情五月电影| 精品视频免费在线| 欧美一区二区三区系列电影| 欧美一区午夜视频在线观看| 91精品国产综合久久久久久| 日韩欧美国产高清| 国产午夜亚洲精品午夜鲁丝片 | 日韩欧美中文字幕制服| 精品国产a毛片| 欧美国产精品中文字幕| 亚洲国产成人在线| 亚洲综合在线视频| 日韩avvvv在线播放| 国产精品一区久久久久| 91在线视频播放| 欧美久久一区二区| 精品少妇一区二区三区免费观看| 精品国精品国产尤物美女| 国产午夜亚洲精品羞羞网站| 亚洲精品你懂的| 美女脱光内衣内裤视频久久影院| 国产精品中文字幕一区二区三区| 成人激情校园春色| 欧美日韩在线不卡| 久久亚洲精品国产精品紫薇| 国产精品国产三级国产有无不卡| 亚洲一区二区三区四区在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎| 韩国理伦片一区二区三区在线播放| 波多野结衣中文字幕一区二区三区 | 中文字幕一区二区三区在线播放| 一区二区在线观看免费视频播放 | 日韩欧美国产综合| 日韩理论片一区二区| 秋霞影院一区二区| 丰满少妇在线播放bd日韩电影| 欧美性大战久久| 国产人成一区二区三区影院| 亚洲mv大片欧洲mv大片精品| 成人丝袜视频网| 欧美一区日韩一区| 亚洲男人电影天堂| 国产一区二区三区精品视频| 在线观看免费视频综合| 国产欧美一区二区精品性色| 日韩精品一卡二卡三卡四卡无卡| 成人黄色a**站在线观看| 日韩女优毛片在线| 欧美日韩一二三| 色婷婷激情一区二区三区| 欧美成人精精品一区二区频| 亚洲欧美欧美一区二区三区| 韩国一区二区在线观看| 欧美日韩一级黄| 亚洲精品免费电影| 成人一道本在线| 精品sm在线观看| 五月天一区二区| 一本色道a无线码一区v| 中文字幕乱码日本亚洲一区二区 | 99久久亚洲一区二区三区青草| 26uuu国产日韩综合| 亚洲丰满少妇videoshd| 色国产综合视频| 国产精品每日更新在线播放网址| 精品一区二区免费| 欧美高清精品3d| 亚洲国产美女搞黄色| 91在线视频播放地址| 国产精品久久午夜夜伦鲁鲁| 国产成人av影院| 久久九九全国免费| 国产精品自拍网站| 精品99999| 久久99久久99小草精品免视看| 欧美日韩国产首页在线观看| 一区二区免费在线| 在线视频国产一区| 亚洲自拍偷拍九九九| 欧美色爱综合网|