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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? i2c_master_byte_ctrl.v

?? FPGA實(shí)現(xiàn)模擬I2C協(xié)議的過(guò)程
?? V
字號(hào):
// synopsys translate_off`include "timescale.v"// synopsys translate_on`include "i2c_master_defines.v"module i2c_master_byte_ctrl (	clk, rst, nReset, ena, clk_cnt, start, stop, read, write, ack_in, din,	cmd_ack, ack_out, dout, i2c_busy, i2c_al, scl_i, scl_o, scl_oen, sda_i, sda_o, sda_oen );	//	// inputs & outputs	//	input clk;     // master clock	input rst;     // synchronous active high reset	input nReset;  // asynchronous active low reset	input ena;     // core enable signal	input [15:0] clk_cnt; // 4x SCL	// control inputs	input       start;	input       stop;	input       read;	input       write;	input       ack_in;	input [7:0] din;	// status outputs	output       cmd_ack;	reg cmd_ack;	output       ack_out;	reg ack_out;	output       i2c_busy;	output       i2c_al;	output [7:0] dout;	// I2C signals	input  scl_i;	output scl_o;	output scl_oen;	input  sda_i;	output sda_o;	output sda_oen;	//	// Variable declarations	//	// statemachine	parameter [4:0] ST_IDLE  = 5'b0_0000;	parameter [4:0] ST_START = 5'b0_0001;	parameter [4:0] ST_READ  = 5'b0_0010;	parameter [4:0] ST_WRITE = 5'b0_0100;	parameter [4:0] ST_ACK   = 5'b0_1000;	parameter [4:0] ST_STOP  = 5'b1_0000;	// signals for bit_controller	reg  [3:0] core_cmd;	reg        core_txd;	wire       core_ack, core_rxd;	// signals for shift register	reg [7:0] sr; //8bit shift register	reg       shift, ld;	// signals for state machine	wire       go;	reg  [2:0] dcnt;	wire       cnt_done;	//	// Module body	//	// hookup bit_controller	i2c_master_bit_ctrl bit_controller (		.clk     ( clk      ),		.rst     ( rst      ),		.nReset  ( nReset   ),		.ena     ( ena      ),		.clk_cnt ( clk_cnt  ),		.cmd     ( core_cmd ),		.cmd_ack ( core_ack ),		.busy    ( i2c_busy ),		.al      ( i2c_al   ),		.din     ( core_txd ),		.dout    ( core_rxd ),		.scl_i   ( scl_i    ),		.scl_o   ( scl_o    ),		.scl_oen ( scl_oen  ),		.sda_i   ( sda_i    ),		.sda_o   ( sda_o    ),		.sda_oen ( sda_oen  )	);	// generate go-signal	assign go = (read | write | stop) & ~cmd_ack;	// assign dout output to shift-register	assign dout = sr;	// generate shift register	always @(posedge clk or negedge nReset)	  if (!nReset)	    sr <= #1 8'h0;	  else if (rst)	    sr <= #1 8'h0;	  else if (ld)	    sr <= #1 din;	  else if (shift)	    sr <= #1 {sr[6:0], core_rxd};	// generate counter	always @(posedge clk or negedge nReset)	  if (!nReset)	    dcnt <= #1 3'h0;	  else if (rst)	    dcnt <= #1 3'h0;	  else if (ld)	    dcnt <= #1 3'h7;	  else if (shift)	    dcnt <= #1 dcnt - 3'h1;	assign cnt_done = ~(|dcnt);	//	// state machine	//	reg [4:0] c_state; // synopsis enum_state	always @(posedge clk or negedge nReset)	  if (!nReset)	    begin	        core_cmd <= #1 `I2C_CMD_NOP;	        core_txd <= #1 1'b0;	        shift    <= #1 1'b0;	        ld       <= #1 1'b0;	        cmd_ack  <= #1 1'b0;	        c_state  <= #1 ST_IDLE;	        ack_out  <= #1 1'b0;	    end	  else if (rst | i2c_al)	   begin	       core_cmd <= #1 `I2C_CMD_NOP;	       core_txd <= #1 1'b0;	       shift    <= #1 1'b0;	       ld       <= #1 1'b0;	       cmd_ack  <= #1 1'b0;	       c_state  <= #1 ST_IDLE;	       ack_out  <= #1 1'b0;	   end	else	  begin	      // initially reset all signals	      core_txd <= #1 sr[7];	      shift    <= #1 1'b0;	      ld       <= #1 1'b0;	      cmd_ack  <= #1 1'b0;	      case (c_state) // synopsis full_case parallel_case	        ST_IDLE:	          if (go)	            begin	                if (start)	                  begin	                      c_state  <= #1 ST_START;	                      core_cmd <= #1 `I2C_CMD_START;	                  end	                else if (read)	                  begin	                      c_state  <= #1 ST_READ;	                      core_cmd <= #1 `I2C_CMD_READ;	                  end	                else if (write)	                  begin	                      c_state  <= #1 ST_WRITE;	                      core_cmd <= #1 `I2C_CMD_WRITE;	                  end	                else // stop	                  begin	                      c_state  <= #1 ST_STOP;	                      core_cmd <= #1 `I2C_CMD_STOP;	                      // generate command acknowledge signal	                      cmd_ack  <= #1 1'b1;	                  end	                ld <= #1 1'b1;	            end	        ST_START:	          if (core_ack)	            begin	                if (read)	                  begin	                      c_state  <= #1 ST_READ;	                      core_cmd <= #1 `I2C_CMD_READ;	                  end	                else	                  begin	                      c_state  <= #1 ST_WRITE;	                      core_cmd <= #1 `I2C_CMD_WRITE;	                  end	                ld <= #1 1'b1;	            end	        ST_WRITE:	          if (core_ack)	            if (cnt_done)	              begin	                  c_state  <= #1 ST_ACK;	                  core_cmd <= #1 `I2C_CMD_READ;	              end	            else	              begin	                  c_state  <= #1 ST_WRITE;       // stay in same state	                  core_cmd <= #1 `I2C_CMD_WRITE; // write next bit	                  shift    <= #1 1'b1;	              end	        ST_READ:	          if (core_ack)	            begin	                if (cnt_done)	                  begin	                      c_state  <= #1 ST_ACK;	                      core_cmd <= #1 `I2C_CMD_WRITE;	                  end	                else	                  begin	                      c_state  <= #1 ST_READ;       // stay in same state	                      core_cmd <= #1 `I2C_CMD_READ; // read next bit	                  end	                shift    <= #1 1'b1;	                core_txd <= #1 ack_in;	            end	        ST_ACK:	          if (core_ack)	            begin	               if (stop)	                 begin	                     c_state  <= #1 ST_STOP;	                     core_cmd <= #1 `I2C_CMD_STOP;	                 end	               else	                 begin	                     c_state  <= #1 ST_IDLE;	                     core_cmd <= #1 `I2C_CMD_NOP;	                 end	                 // assign ack_out output to bit_controller_rxd (contains last received bit)	                 ack_out <= #1 core_rxd;	                 // generate command acknowledge signal	                 cmd_ack  <= #1 1'b1;	                 core_txd <= #1 1'b1;	             end	           else	             core_txd <= #1 ack_in;	        ST_STOP:	          if (core_ack)	            begin	                c_state  <= #1 ST_IDLE;	                core_cmd <= #1 `I2C_CMD_NOP;	            end	      endcase	  endendmodule

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区福利在线| 精久久久久久久久久久| 国产精品久久久久久久久免费相片| 成人免费一区二区三区视频| 91亚洲资源网| 国产在线乱码一区二区三区| 亚洲欧美日韩系列| xnxx国产精品| 日韩三级高清在线| 欧洲日韩一区二区三区| 成人午夜视频在线观看| 亚洲综合男人的天堂| 国产精品久久福利| 亚洲国产高清在线| 欧美激情综合在线| 欧美激情一区二区三区四区| 日韩精品一区二区三区视频在线观看 | 99热这里都是精品| 丁香六月综合激情| 国产91精品在线观看| 国产综合成人久久大片91| 麻豆国产欧美日韩综合精品二区| 亚洲欧美日韩一区二区三区在线观看 | 亚洲色图视频网站| 亚洲欧美一区二区三区孕妇| 一区精品在线播放| 亚洲三级免费观看| 亚洲bdsm女犯bdsm网站| 亚洲电影在线播放| 青青草97国产精品免费观看无弹窗版| 亚洲高清在线精品| 韩国在线一区二区| 丰满少妇久久久久久久| 99国产精品久久久久久久久久| www.色精品| 666欧美在线视频| 国产成人av电影| 久久精品999| av资源网一区| 欧美在线播放高清精品| 91精品婷婷国产综合久久 | 欧美一区三区四区| 国产亚洲制服色| 国产精品视频在线看| 亚洲综合男人的天堂| 精品一区二区三区久久| 97精品久久久久中文字幕| 91精品久久久久久久99蜜桃 | 一区二区三区欧美日| 奇米影视7777精品一区二区| av男人天堂一区| 正在播放一区二区| 亚洲色欲色欲www在线观看| 日本中文一区二区三区| 99国产精品视频免费观看| 日韩欧美一区二区免费| 亚洲人成影院在线观看| 粉嫩av一区二区三区| 日韩一区二区精品| 亚洲大片在线观看| 91免费版在线看| 中文字幕在线不卡一区二区三区| 蜜臀av亚洲一区中文字幕| 91色在线porny| 中文字幕在线免费不卡| 亚洲妇女屁股眼交7| 色婷婷av久久久久久久| 国产视频在线观看一区二区三区| 久久国内精品自在自线400部| 欧美在线一二三四区| 一区二区欧美视频| 色婷婷av一区二区三区gif| 亚洲精品国产高清久久伦理二区| 成人高清在线视频| 国产欧美一区二区精品仙草咪| 精品写真视频在线观看| 麻豆精品在线观看| 在线观看国产一区二区| 亚洲永久精品国产| 欧美日韩一区二区三区在线 | 亚洲黄色小说网站| 色88888久久久久久影院按摩 | 亚洲欧美aⅴ...| 欧美日韩国产高清一区二区三区| 亚洲一区视频在线观看视频| 3d成人动漫网站| 日本免费在线视频不卡一不卡二| 91精品国产一区二区三区蜜臀 | 亚洲国产一区二区三区青草影视| 在线免费观看日韩欧美| 麻豆国产91在线播放| 国产视频一区二区在线| 色综合久久88色综合天天6| 视频一区中文字幕国产| 久久久久综合网| 欧美艳星brazzers| 国产一区二区免费看| 怡红院av一区二区三区| 26uuu国产电影一区二区| 色婷婷激情一区二区三区| 美女爽到高潮91| 亚洲裸体xxx| 久久色视频免费观看| 色综合天天性综合| 麻豆中文一区二区| 中文字幕av在线一区二区三区| 欧美日韩亚洲丝袜制服| 国产69精品久久久久777| 视频一区二区三区入口| 中文字幕一区二区三区在线观看| 9191久久久久久久久久久| 福利一区二区在线观看| 精品一区二区三区在线播放视频| 一区二区三区视频在线看| 久久精品一区蜜桃臀影院| 欧美一级欧美三级| 99精品欧美一区二区三区小说 | 一道本成人在线| 福利视频网站一区二区三区| 精品一区二区免费在线观看| 亚洲电影一区二区| 首页综合国产亚洲丝袜| 亚洲一级二级三级在线免费观看| 综合av第一页| 一区二区日韩av| 亚洲一二三四久久| 亚洲成a人v欧美综合天堂| 亚洲一区中文日韩| 五月综合激情婷婷六月色窝| 亚洲国产一区视频| 日本中文一区二区三区| 久久精品国产精品青草| 国产福利一区二区三区在线视频| 国产精品一级黄| 91欧美一区二区| 欧美视频在线不卡| 日韩精品一区二区三区四区视频| 精品成人免费观看| 国产精品国产三级国产aⅴ入口| 国产精品国产三级国产aⅴ入口 | 日韩一区二区三区电影在线观看| 日韩免费看的电影| 国产精品伦理一区二区| 亚洲一区中文日韩| 国产高清精品网站| 欧美唯美清纯偷拍| 久久久精品欧美丰满| 亚洲午夜视频在线观看| 国产一区二区三区免费在线观看| 国产激情偷乱视频一区二区三区| 91精品1区2区| 国产欧美日韩精品一区| 亚洲综合免费观看高清完整版| 激情欧美一区二区| 欧美日韩一区三区四区| 国产精品视频在线看| 精品一区二区三区在线播放视频| 国产精品99久久久久久久vr| 国产伦精品一区二区三区免费| 91精彩视频在线观看| 国产免费成人在线视频| 人人精品人人爱| 欧美在线999| 亚洲区小说区图片区qvod| 国产不卡在线一区| 精品国精品自拍自在线| 午夜伊人狠狠久久| 色吧成人激情小说| 亚洲人成在线播放网站岛国| 国产精品一区二区你懂的| 日韩一区二区在线观看| 亚洲123区在线观看| 欧美优质美女网站| 一区二区三区 在线观看视频| av一区二区不卡| 亚洲欧美影音先锋| 91在线国产观看| 亚洲欧美日韩国产一区二区三区| 成人av在线一区二区三区| 日本一区二区视频在线| 国产黄色91视频| 国产精品久久久久天堂| 懂色av中文一区二区三区| 国产精品毛片久久久久久久| 99久久er热在这里只有精品15| 国产精品久久久久久久蜜臀| av电影天堂一区二区在线| 亚洲男同1069视频| 欧美人xxxx| 国产主播一区二区三区| 中文字幕亚洲在| 欧美主播一区二区三区| 免费在线观看日韩欧美| 久久―日本道色综合久久| av不卡免费在线观看| 日韩不卡手机在线v区| 国产亚洲婷婷免费| 欧美日韩亚洲国产综合| 国内外精品视频| 亚洲国产乱码最新视频 |