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

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

?? uart.v

?? some example for verilog design
?? V
字號:
//// Copyright (c) 1992,1993,1994, Exemplar Logic Inc. All rights reserved.////// Description ://    This Verilog HDL description implements a UART.////     Version 1.1 : Original Creation//             2.1 : added comments//module uart (clkx16, read, write, rx, reset, tx, rxrdy, txrdy,              parityerr, framingerr, overrun, data);input          clkx16;		// Input clock. 16x bit clockinput            read;		// Received data read strobeinput           write;		// Transmit data write strobeinput	      rx;		// Receive  data lineinput	   reset;		// clear dependenciesoutput	      tx;		// Transmit data lineoutput           rxrdy;		// Received data ready to be readoutput           txrdy;		// Transmitter ready for next byteoutput       parityerr;		// Receiver parity erroroutput      framingerr;		// Receiver framing erroroutput         overrun;		// Receiver overrun error inout       [0:7] data; // Bidirectional data busreg	      tx;		// Transmit data linereg         overrun;		// Receiver overrun error reg      framingerr;		// Receiver framing errorreg       parityerr;		// Receiver parity error// Transmit data holding register    wire [0:7] txhold ;// Transmit shift register bits    reg [0:7] txreg;    reg      txtag2  ;		// tag bits for detecting     reg      txtag1  ;		//    empty shift reg    reg    txparity  ;		// Parity generation register// Transmit clock and control signals    reg       txclk  ;       	// Transmit clock: 1/16th of clkx16    wire      txdone  ;		// 1'b1 when shifting of byte is done    wire paritycycle  ;		// 1'b1 on next to last shift cycle    reg   txdatardy  ;       	// 1'b1 when data is ready in txhold// Receive shift register bits    reg [0:7] rxhold;   // Holds received data for read    reg [0:7] rxreg;   // Receive data shift register    reg    rxparity  ;		// Parity bit of received data    reg   paritygen  ;		// Generated parity of received data    reg      rxstop  ;		// Stop bit of received data// Receive clock and control signals    reg       rxclk  ;		// Receive data shift clock    reg      rxidle  ;       	// 1'b1 when receiver is idling    reg   rxdatardy  ;       	// 1'b1 when data is ready to be readreg [2:0] cnt;// Toggle txclk every 8 counts, which divides the clock by 16always @(posedge clkx16)   begin	if (reset)	    txclk = 1'b0;	else if (cnt == 3'b000)  	    txclk = !txclk; 	if (reset)	    cnt = 3'b000;	else	    cnt = cnt + 1;    endreg [0:3] rxcnt;      // Count of clock cyclesreg rx1, hunt;        //rx delayed one cycle,  Hunting for start bitalways @(posedge clkx16)begin// rxclk = clkx16 divided by 16         rxclk = rxcnt[0];// Hunt=1 when we are looking for a start bit://   A start bit is eight clock times with rx=0 after a falling edge 	if (reset)	    hunt = 1'b0;	else if (rxidle && !rx && rx1 ) // Start hunting when idle and falling edge is found	    hunt = 1'b1;	else if (!rxidle || rx ) // Stop hunting when shifting in data or a 1 is found on rx	    hunt = 1'b0;	rx1 = rx;	// rx delayed by one clock for edge detection			// (Must be assigned AFTER reference)// Increment count when not idling or when hunting	if (!rxidle || hunt) 	    // Count clocks when not rxidle or hunting for start bit	    rxcnt = rxcnt + 1;	else	    // hold at 1 when rxidle and waiting for falling edge	    rxcnt = 4'b0001;endalways @(posedge txclk)begin	if (txdone && txdatardy)	    begin	    // Initialize registers and load next byte of data	    txreg    = txhold;	// Load tx register from txhold	    txtag2   = 1'b1;	// Tag bits for detecting 	    txtag1   = 1'b1;	//    when shifting is done	    txparity = 1'b1;	// Parity bit. Initializing to 1 = odd parity	    tx       = 1'b0;	// Start bit            end	else	    begin	    // Shift data	    // bug in assigning to slices	    // txreg(0 TO 6) = txreg(1 TO 7);	    // txreg(7)      = txtag1;	    txreg 	= {txreg[1 : 7], txtag1};	    txtag1      = txtag2;	    txtag2	= 1'b0;	    // Form parity as each bit goes by	    txparity      = txparity ^ txreg[0];	    // Shift out data or parity bit or stop/idle bit	    if (txdone )		tx = 1'b1;	// stop/idle bit	    else if (paritycycle)		tx = txparity;	// Parity bit	    else		tx = txreg[0];	//Shift data bit	    endend// paritycycle = 1 on next to last cycle (When txtag2 has reached txreg(1))//   (Enables putting the parity bit out on tx)assign    paritycycle = txreg[1] && !(txtag2 || txtag1 || 				     txreg[7] || txreg[6] || txreg[5] || 				     txreg[4] || txreg[3] || txreg[2]);// txdone = 1 when done shifting [When txtag2 has reached tx]assign    txdone = !(txtag2 || txtag1 ||		  txreg[7] || txreg[6] || txreg[5] || txreg[4] || 		  txreg[3] || txreg[2] || txreg[1] || txreg[0]);// Shift data on each rxclk when not idlingalways @(posedge rxclk)  begin 	if (rxidle)	    // Load all ones when idling	    begin	    rxreg = 8'b11111111;	    rxparity = 1'b1;	    paritygen = 1'b1;	// Odd parity	    rxstop = 1'b0;	    end	else	    // Shift data when not idling	    // bug in assigning to slices	    // rxreg (0 TO 6) = rxreg (1 TO 7);	    // rxreg(7) = rxparity;	    begin	    rxreg = {rxreg [1 : 7], rxparity};	    rxparity = rxstop;	    paritygen = paritygen ^ rxstop;	// Form parity as data shifts by	    rxstop = rx;            end   end    // rxidle requires async preset since it is clocked by rxclk and  // its value determines whether rxclk gets generated always @(posedge rxclk or posedge reset)    begin        if (reset)           rxidle = 1'b0;        else            rxidle = !rxidle && !rxreg[0];    end// Load txhold and set txdatardy on falling edge of write// Clear txdatardy on falling edge of txdone	reg wr1,wr2;	// write signal delayed 1 and 2 cycles	reg txdone1;        // txdone signal delayed one cyclealways @(posedge clkx16)    begin	if (reset)	    txdatardy = 1'b0;	else if (!wr1 &&  wr2)	    // Falling edge on write signal. New data in txhold latches	    txdatardy  = 1'b1;	else if (!txdone &&  txdone1)	    // Falling edge on txdone signal. Txhold has been read.	    txdatardy  = 1'b0;	// Delayed versions of write and txdone signals for edge detection	wr2 = wr1;	wr1 = write;	txdone1 = txdone;    end 	reg rd1, rd2 ;	// Read input delayed 1 and 2 cycles	reg rxidle1  ;	// rxidle signal delayed 1 cyclealways @(posedge clkx16)    begin	// Look for rising edge on idle and update output registers	if (rxidle && !rxidle1)	begin	    if (rxdatardy)		// Overrun error if previous data is still there		overrun = 1'b1;	    else		begin		// No overrun error since holding register is empty		overrun = 1'b0;		// Update holding register		rxhold = rxreg;		// paritygen = 1 if parity error		parityerr = paritygen;		// Framingerror if stop bit is not 1		framingerr =  !rxstop;		// Signal that data is ready for reading		rxdatardy = 1'b1;	        end	end	rxidle1 = rxidle;	// rxidle delayed 1 cycle for edge detect	//  Clear error and data registers when data is read	if (!rd2 &&  rd1)	    begin 	    rxdatardy  = 1'b0;	    parityerr  = 1'b0;	    framingerr = 1'b0;	    overrun    = 1'b0;	    end 	rd2 = rd1;	// Edge detect for read	rd1 = read;	// (Must be assigned AFTER reference)	if (reset) 	    rxdatardy = 1'b0;    end// Drive data bus only during readassign    data = read ?  rxhold : 8'bzzzzzzzz;// Latch data bus during writeassign    txhold = write ? data : txhold;// Receive data ready output signalassign    rxrdy = rxdatardy;// Transmitter ready for write when no data is in txholdassign    txrdy = !txdatardy;endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩毛片在线免费观看| 午夜国产精品影院在线观看| 精品一二线国产| 在线观看91视频| 亚洲欧美一区二区视频| 国产一区二区三区四区在线观看| 欧美一区二区三区四区五区| 日本一区二区三区四区| 国产麻豆午夜三级精品| 中文字幕精品一区二区精品绿巨人| 国产精品影视天天线| 4hu四虎永久在线影院成人| 一区二区三区中文字幕在线观看| 国产69精品久久99不卡| 精品国产一区二区精华| 亚洲国产综合91精品麻豆| 国产成人亚洲综合色影视| 日韩一区二区三区av| 洋洋av久久久久久久一区| 91麻豆精品视频| 视频一区国产视频| 久久久久国产精品麻豆| 91在线视频观看| 免费成人在线影院| 国产精品视频在线看| caoporn国产精品| 亚洲欧美自拍偷拍色图| 国产v综合v亚洲欧| 亚洲国产乱码最新视频 | 综合av第一页| 欧美午夜视频网站| 免费在线观看一区二区三区| 337p亚洲精品色噜噜狠狠| 日韩国产欧美三级| 88在线观看91蜜桃国自产| 激情六月婷婷综合| 亚洲一区二区四区蜜桃| 中文字幕免费不卡在线| 欧美色视频在线| 日本欧美一区二区在线观看| 亚洲欧洲精品一区二区三区不卡| 日韩三级高清在线| 欧美丰满高潮xxxx喷水动漫 | 激情小说欧美图片| 日本美女一区二区| 亚洲免费伊人电影| 中文字幕免费不卡| 国产亚洲精品aa| 成人av动漫网站| 婷婷综合久久一区二区三区| 国产午夜精品在线观看| 欧美少妇bbb| 国产成人午夜精品影院观看视频| 亚洲一区二区综合| 亚洲激情在线激情| 亚洲成人免费视| 日韩二区三区在线观看| 免费人成黄页网站在线一区二区| 一区二区免费视频| 亚洲一区二区影院| 精品区一区二区| 在线观看一区不卡| 久久se精品一区二区| 日韩精品免费视频人成| 亚洲国产成人av| 中文字幕综合网| 亚洲国产另类精品专区| 亚洲国产成人精品视频| 日韩美女视频一区| 六月丁香综合在线视频| 久久国产精品免费| 国产·精品毛片| 日本久久精品电影| 色成年激情久久综合| 欧美日韩成人综合在线一区二区| 91成人免费在线| 日韩一区二区电影网| 91精品国产入口| 国产精品乱人伦| 青青草国产精品97视觉盛宴 | 欧美视频在线观看一区| 欧美一级高清片在线观看| 欧美一三区三区四区免费在线看 | 成人三级伦理片| 欧美日韩一区中文字幕| 精品av综合导航| 久久综合精品国产一区二区三区| 日韩欧美另类在线| 一区二区三区日韩欧美| 捆绑变态av一区二区三区| 日本韩国视频一区二区| 欧美电影精品一区二区| 亚洲综合色视频| 粉嫩久久99精品久久久久久夜| 欧美日韩不卡视频| 中文字幕中文在线不卡住| 日韩制服丝袜先锋影音| 欧美日韩亚洲综合一区二区三区| 久久综合99re88久久爱| 亚洲一区中文在线| 欧美伊人久久久久久午夜久久久久| 中文字幕在线一区二区三区| eeuss影院一区二区三区| 国产三级一区二区| 国产精品香蕉一区二区三区| 久久先锋资源网| 国产乱理伦片在线观看夜一区| 亚洲精品一线二线三线无人区| 精品一区二区三区在线播放 | av在线不卡电影| 一区二区三区免费在线观看| 欧美又粗又大又爽| 亚洲va韩国va欧美va精品| 欧美日韩视频一区二区| 亚洲18女电影在线观看| 91精品国产综合久久久久久 | 欧美不卡在线视频| 福利一区在线观看| 久久久99精品久久| 一本大道综合伊人精品热热| 伊人一区二区三区| 国产精品1024久久| 91精品国产综合久久久久| 日韩福利电影在线观看| 欧美国产精品v| 欧美一区二区三区人| 色激情天天射综合网| 免费在线观看视频一区| 中国av一区二区三区| 欧美午夜影院一区| 天天影视涩香欲综合网| 日韩一级免费观看| 丰满亚洲少妇av| 日韩经典中文字幕一区| 国产日韩精品一区二区三区在线| 国内精品免费**视频| 亚洲一区二区三区精品在线| 精品国产一区二区精华 | 在线观看国产精品网站| 另类中文字幕网| 亚洲一区二区三区爽爽爽爽爽| 亚洲另类中文字| 久久久久高清精品| 欧美日韩国产高清一区二区| 国产毛片精品视频| 亚洲精品中文字幕在线观看| 亚洲三级小视频| 中文字幕在线一区免费| 欧美电视剧在线看免费| 在线看日韩精品电影| 不卡电影一区二区三区| 九色|91porny| 国产精品自拍网站| 欧美影院一区二区| 国产一区福利在线| 91成人在线免费观看| 国产亚洲精品bt天堂精选| 美女一区二区三区| 色老综合老女人久久久| 一区二区三区高清| 亚洲欧美一区二区在线观看| 日本韩国精品在线| 精品一区二区久久久| 久久久www免费人成精品| 成人爱爱电影网址| 久久91精品国产91久久小草| 国产精品污污网站在线观看| 久久精品国产网站| 久久久综合九色合综国产精品| 在线综合+亚洲+欧美中文字幕| 91影视在线播放| 成人av免费观看| av在线播放一区二区三区| 7777精品伊人久久久大香线蕉最新版| 久久久91精品国产一区二区三区| 久久婷婷国产综合精品青草| 国产人成一区二区三区影院| 精品免费视频一区二区| 欧美精品免费视频| 欧美日韩亚洲高清一区二区| 不卡的av中国片| 国产精品一区二区在线观看网站| 久国产精品韩国三级视频| 日韩国产欧美在线播放| 精品国产自在久精品国产| 国产永久精品大片wwwapp | 香蕉影视欧美成人| 在线综合亚洲欧美在线视频| 久久草av在线| 中文字幕一区免费在线观看| 欧美日韩黄色影视| 日本不卡一区二区三区高清视频| 中文字幕中文字幕在线一区| 欧美撒尿777hd撒尿| 韩国女主播成人在线| 亚洲欧美一区二区三区孕妇| 欧美一区二区三区系列电影| 国模大尺度一区二区三区| 亚洲国产精品久久一线不卡| 久久品道一品道久久精品|