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

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

?? uartvhrilog.txt

?? This Verilog HDL description implements a UART.
?? TXT
字號:
 
一個簡單的UART
//
// 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
//
// Download from: http://www.fpga.com.cn 
//


module uart (clkx16, read, write, rx, reset, tx, rxrdy, txrdy, 
             parityerr, framingerr, overrun, data);

input          clkx16;		// Input clock. 16x bit clock
input            read;		// Received data read strobe
input           write;		// Transmit data write strobe
input	      rx;		// Receive  data line
input	   reset;		// clear dependencies
output	      tx;		// Transmit data line
output           rxrdy;		// Received data ready to be read
output           txrdy;		// Transmitter ready for next byte
output       parityerr;		// Receiver parity error
output      framingerr;		// Receiver framing error
output         overrun;		// Receiver overrun error 
inout       [0:7] data; // Bidirectional data bus

reg	      tx;		// Transmit data line
reg         overrun;		// Receiver overrun error 
reg      framingerr;		// Receiver framing error
reg       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 read


reg [2:0] cnt;


// Toggle txclk every 8 counts, which divides the clock by 16

always @(posedge clkx16)
   begin
	if (reset)
	    txclk = 1'b0;
	else if (cnt == 3'b000)  
	    txclk = !txclk; 

	if (reset)
	    cnt = 3'b000;
	else
	    cnt = cnt + 1;
    end

reg [0:3] rxcnt;      // Count of clock cycles
reg rx1, hunt;        //rx delayed one cycle,  Hunting for start bit


always @(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;
end

always @(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
	    end
end

// 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 idling
always @(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 cycle
always @(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 cycle
always @(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 read
assign    data = read ?  rxhold : 8'bzzzzzzzz;

// Latch data bus during write
assign    txhold = write ? data : txhold;

// Receive data ready output signal
assign    rxrdy = rxdatardy;

// Transmitter ready for write when no data is in txhold
assign    txrdy = !txdatardy;


endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美成人一区二区三区在线观看| 1000精品久久久久久久久| 精品免费视频一区二区| 国产精品国产三级国产a| 蜜臂av日日欢夜夜爽一区| 97se亚洲国产综合自在线| 久久久久久久久蜜桃| 日韩精品一级中文字幕精品视频免费观看 | 亚洲成人精品在线观看| 国产精品77777竹菊影视小说| 欧美日韩精品一区二区| 亚洲日本va午夜在线影院| 高清成人在线观看| 精品久久久影院| 日本中文字幕一区二区视频| 91官网在线免费观看| 成人欧美一区二区三区在线播放| 激情深爱一区二区| 欧美电视剧免费观看| 日韩av在线免费观看不卡| 欧美在线影院一区二区| 亚洲色图制服丝袜| av亚洲精华国产精华| 国产精品欧美极品| 成人免费看片app下载| 国产欧美日韩麻豆91| 国产伦精品一区二区三区视频青涩 | 日韩美女精品在线| jlzzjlzz亚洲女人18| 亚洲精品高清在线观看| 一本色道久久综合亚洲aⅴ蜜桃 | 国产在线日韩欧美| 2023国产精华国产精品| 捆绑调教一区二区三区| 欧美一区二区三区白人| 蜜桃av一区二区三区电影| 欧美一级在线观看| 伦理电影国产精品| 久久免费的精品国产v∧| 国产揄拍国内精品对白| 国产人久久人人人人爽| www.亚洲激情.com| 亚洲黄色av一区| 欧美午夜精品一区二区蜜桃| 亚洲 欧美综合在线网络| 7777精品伊人久久久大香线蕉最新版 | 美日韩一区二区| 日韩精品资源二区在线| 国产伦精一区二区三区| 中文字幕欧美一区| 欧洲av一区二区嗯嗯嗯啊| 五月综合激情网| 精品国产乱码久久久久久久久 | 久久只精品国产| 大尺度一区二区| 亚洲精品国产精华液| 日韩一区二区在线观看视频| 久久99久久99精品免视看婷婷| 国产日韩欧美a| 91福利社在线观看| 久久精品国产免费| 国产精品久久久久久久岛一牛影视| 91亚洲精品乱码久久久久久蜜桃| 午夜视频在线观看一区二区| 亚洲国产精品精华液网站| 欧美一区日韩一区| 成人av动漫在线| 日韩黄色小视频| 欧美国产亚洲另类动漫| 精品视频一区三区九区| 国产精品一区二区在线看| 一卡二卡欧美日韩| 久久亚洲私人国产精品va媚药| 91色九色蝌蚪| 国产一区二区在线影院| 亚洲一级片在线观看| 国产亚洲欧美一区在线观看| 欧美色综合影院| 国产成人高清在线| 日韩av一二三| 一区二区三区加勒比av| 国产日韩av一区二区| 在线播放一区二区三区| 99re视频精品| 国产麻豆9l精品三级站| 日韩国产高清影视| 1000精品久久久久久久久| 精品福利一区二区三区| 欧美日韩国产精品成人| 91视频91自| 成人激情黄色小说| 国产综合色视频| 日本欧美肥老太交大片| 亚洲欧美区自拍先锋| 欧美国产日韩一二三区| 2024国产精品视频| 91精品国产入口| 欧美日韩中字一区| 欧美在线观看禁18| 色综合久久久网| 91精品国产欧美一区二区| 91丨porny丨国产入口| 国产白丝精品91爽爽久久| 久久99精品国产麻豆婷婷| 日韩国产一区二| 日韩精品一二三区| 婷婷综合五月天| 亚洲h在线观看| 亚洲成a人v欧美综合天堂| 亚洲另类色综合网站| 亚洲精品写真福利| 亚洲精品午夜久久久| 中文字幕一区二区三区乱码在线| 国产亚洲婷婷免费| 中文字幕成人网| 国产精品久久久久久久午夜片 | 欧美性受极品xxxx喷水| 欧美综合欧美视频| 欧美午夜一区二区三区免费大片| 在线观看亚洲精品| 欧美久久久久久蜜桃| 欧美群妇大交群中文字幕| 欧美乱妇23p| 精品入口麻豆88视频| 久久在线观看免费| 中文字幕成人av| 亚洲免费观看视频| 亚洲成人激情自拍| 蜜桃精品视频在线| 国产乱人伦精品一区二区在线观看| 国产福利一区在线观看| youjizz久久| 欧洲激情一区二区| 日韩欧美国产综合一区| 久久久亚洲综合| 成人免费一区二区三区视频| 亚洲综合区在线| 久久99精品久久久久久国产越南 | 国内成人精品2018免费看| 国产精品123区| 91麻豆精品在线观看| 欧美日韩在线播| 精品国产露脸精彩对白| 国产精品乱码一区二三区小蝌蚪| 亚洲日本电影在线| 日本女人一区二区三区| 高清视频一区二区| 欧洲精品在线观看| 亚洲精品在线观看网站| 亚洲图片你懂的| 蜜臀久久久99精品久久久久久| 成人综合在线观看| 欧美日韩视频在线第一区| 亚洲精品一区二区三区香蕉| 国产精品短视频| 奇米888四色在线精品| 成人一区在线观看| 3d动漫精品啪啪1区2区免费| 欧美国产亚洲另类动漫| 石原莉奈一区二区三区在线观看| 国产一区视频网站| 欧美影院一区二区三区| 国产婷婷色一区二区三区四区 | 在线观看国产精品网站| 欧美精品一区二区三区四区| 亚洲男女一区二区三区| 激情国产一区二区 | 99r国产精品| 久久嫩草精品久久久精品| 亚洲bdsm女犯bdsm网站| 国产成+人+日韩+欧美+亚洲| 欧美另类高清zo欧美| 国产精品国产三级国产专播品爱网 | 亚洲免费av观看| 韩国一区二区在线观看| 欧美日韩精品久久久| 亚洲乱码国产乱码精品精98午夜 | 国产suv精品一区二区6| 777a∨成人精品桃花网| 亚洲综合一区在线| 99国产精品视频免费观看| 久久久99精品久久| aaa国产一区| 中文字幕第一区二区| 精品一区二区三区日韩| 欧美一级日韩一级| 肉色丝袜一区二区| 欧美日韩aaaaa| 亚洲午夜免费视频| 欧美亚洲日本国产| 亚洲女同ⅹxx女同tv| a级高清视频欧美日韩| 日本一区二区三区在线观看| 国内精品伊人久久久久av影院| 91精品国产91综合久久蜜臀| 日日欢夜夜爽一区| 91麻豆精品国产91久久久| 日韩精品乱码免费| 欧美一级高清片| 青草国产精品久久久久久|