日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(dǎo)讀]基于FPGA的UART、USB接口協(xié)議設(shè)計(jì)

一、PC終端概述

PC終端,Personal Computer 智能終端,通俗的講,就是利用電腦GUI界面控制我們的外部硬件電路。

因此設(shè)計(jì)到了PC與外部硬件電路的通信接口。對于臺式電腦、個(gè)人筆記本,最常用的接口就是USB接口、串口、并口、PS2接口、網(wǎng)口。在我們電子設(shè)計(jì)中的PC終端軟件的通信,應(yīng)用最多的就是串口、其次是USB接口、再就是網(wǎng)口。(對于現(xiàn)在大部分筆記本沒有了串口,我們可以用USB專串口線來代替。)這三種接口速度和性質(zhì)不同,各有千秋:

(1)電子產(chǎn)品中,很多低速的數(shù)據(jù)采集,一些點(diǎn)陣系統(tǒng)的配置,GPRS模塊的調(diào)試等,都用串口來實(shí)現(xiàn)跟PC的通信。甚至一些單片機(jī)(宏晶STC)的配置都用串口實(shí)現(xiàn)通信。串口最高可以達(dá)到128000bps的速率,在低速場合下,完全能夠?qū)崿F(xiàn)與PC的通信,來滿足我們各種要求,來實(shí)現(xiàn)對數(shù)據(jù)的實(shí)時(shí)處理。

(2)設(shè)計(jì)到高速的數(shù)據(jù)傳輸、視頻圖像傳輸?shù)鹊?,一般用USB接口來交換數(shù)據(jù)。比方說我們的硬盤、U盤、各種硬件下載器(USB BLUSTERO(∩_∩)O哈哈~)、以及實(shí)時(shí)圖像采集、視頻采集等,都是用USB接口來實(shí)現(xiàn)的。目前USB已經(jīng)發(fā)展到了USB 3.0,但還是以USB 2.0為主,最高能夠達(dá)到480Mbps(60MB/s)高速,足夠的帶寬滿足我們對高速、海量數(shù)據(jù)的采集處理。

(3)最后就是網(wǎng)口的通信,一般網(wǎng)口用來上網(wǎng)傳輸數(shù)據(jù),但是也可以用來硬件和PC之間的數(shù)據(jù)傳輸。一般網(wǎng)絡(luò),千兆的能力,NetFPGA,用FPGA實(shí)現(xiàn)的通信協(xié)議,早已不是夢想。近年來流行的網(wǎng)絡(luò)攝像頭,就是通過網(wǎng)絡(luò)來傳輸(當(dāng)然也有通過WiFi飛);現(xiàn)在超市、廣場的超大真彩點(diǎn)陣是數(shù)據(jù)傳輸,由于數(shù)據(jù)量之大,一般采用網(wǎng)絡(luò)傳輸,來達(dá)到顯示的實(shí)時(shí)性。

最后,我們的PC終端軟件,就是通過C++、MFC、C#等語言編寫軟件,對這些接口的驅(qū)動(dòng),來對數(shù)據(jù)的采集處理,從而達(dá)到用戶預(yù)期的要求。本章中主要講解FPGA硬件平臺的UART、USB通信接口的軟硬件設(shè)計(jì),并且對Bingo的代碼設(shè)計(jì)稍作分析,希望對你有用。

二、UART通信接口設(shè)計(jì)

1、UART通信協(xié)議

UART:Universal Asynchronous Receiver/Transmitter,通用異步接收/發(fā)送裝置,所謂異步,就是說發(fā)送和接受不能同時(shí)進(jìn)行,是單工的。對于UART的verilog設(shè)計(jì),簡單的說就是需要“波特率發(fā)生器”與“數(shù)據(jù)傳輸時(shí)序”兩個(gè)模塊,如下:

(1)波特率

在UART通信協(xié)議中很重要的一個(gè)定義,就是“波特率”,即傳輸數(shù)據(jù)時(shí)的速率。波特率一般有以下這些:

(2)數(shù)據(jù)傳輸時(shí)序

對于UART數(shù)據(jù)傳輸?shù)膮f(xié)議,如下所示。其中奇偶校驗(yàn)位與停止位不是必須的。而“起始位、資料位、停止位”則是必須的。一般資料位為8 bits。 
 
 

2、UART硬件設(shè)計(jì)

UART是計(jì)算機(jī)中串行通信端口的關(guān)鍵部分。在計(jì)算機(jī)中,UART相連于產(chǎn)生兼容RS232規(guī)范信號的電路。RS232標(biāo)準(zhǔn)定義邏輯“1”信號相對于地為-3到-15伏,而邏輯“0”相對于地為3到15伏。所以,當(dāng)一個(gè)微控制器中的UART相連于PC時(shí),它需要一個(gè)RS232驅(qū)動(dòng)器來轉(zhuǎn)換電平。

如下圖所示,UART硬件電路灰常的簡單,只需要一塊電平轉(zhuǎn)換芯片即可。電平轉(zhuǎn)換芯片一般用Max3232、Max232,SP3232等,其中Maxim公司的電平轉(zhuǎn)換芯片比較常用。跟PC和處理器相連接的,只要相應(yīng)的TXD、RXD兩根信號線即可。

3、UART Verilog設(shè)計(jì)

基于FPGA的UART設(shè)計(jì),其實(shí)在單片機(jī)中沒有這么一說。單片機(jī)中早已有了UART的IP,我們只要調(diào)用函數(shù)即可,但FPGA中,純硬件設(shè)計(jì)電路上,我們想要使用串口來調(diào)試,那我們就必須了解徹底UART通信協(xié)議,必須自己動(dòng)手寫UART的硬核。利用硬件描述語言,相當(dāng)?shù)姆奖恪?/p>

UART驅(qū)動(dòng)代碼的編寫,算是比較簡單的設(shè)計(jì)了。Bingo當(dāng)年用VHDL編寫串口通信,后來學(xué)了Verilog,重新來過,最后修改串口,改善得到穩(wěn)定的版本,經(jīng)過多次測試,上萬數(shù)據(jù)傳輸未出現(xiàn)過錯(cuò)誤,已應(yīng)用于多個(gè)項(xiàng)目中,在此獻(xiàn)丑,希望對你有用。

以下是相關(guān)的下載信息:

(1)串口調(diào)試助手

http://www.chinaaet.com/lib/detail.aspx?id=86809

(2)uart_io_test工程

http://www.chinaaet.com/lib/detail.aspx?id=86812

(3)uart_fifo_design工程

http://www.chinaaet.com/lib/detail.aspx?id=86813

對于基于FPGA的Verilog設(shè)計(jì)UART通信接口的代碼分析,如下所示:

(1)波特率發(fā)生器

如果您看過前面章節(jié),那您是否還記得“第九章 為所欲為——教你什么才是真正的任意分頻”?此處我們?yōu)榱诉_(dá)到標(biāo)準(zhǔn)的頻率,最大極限的不想出現(xiàn)任何誤差,Bingo利用自己設(shè)計(jì)的“相位控制分頻原理”,來完成此模塊的設(shè)計(jì)。具體的分頻原理請看第九章,此處不再做累贅的闡述,謝謝。

關(guān)于本模塊的主要代碼,如下:

/*************************************************

* Module Name : clk_generator.v

* Engineer : Crazy Bingo

* Target Device : EP2C8Q208C8

* Tool versions : Quartus II 11.0

* Create Date : 2011/01/27

* Revision : v1.0

* Description :

**************************************************/

module clk_generator

(

input clk,

input rst_n,

output clk_bps,

output clk_smp

);

//------------------------------------------

/************clk_smp = 16*clk_bps************

Freq_Word1 <= 32‘d25770; Freq_Word1 <= 32‘d412317; //300 bps

Freq_Word1 <= 32‘d51540; Freq_Word2 <= 32‘d824634; //600 bps

Freq_Word1 <= 32‘d103079; Freq_Word2 <= 32‘d1649267; //1200 bps

Freq_Word1 <= 32‘d206158; Freq_Word2 <= 32‘d3298535; //2400 bps

Freq_Word1 <= 32‘d412317; Freq_Word2 <= 32‘d6597070; //4800 bps

Freq_Word1 <= 32‘d824634; Freq_Word2 <= 32‘d13194140; //9600 bps

Freq_Word1 <= 32‘d1649267; Freq_Word2 <= 32‘d26388279; //19200 bps

Freq_Word1 <= 32‘d3298535; Freq_Word2 <= 32‘d52776558; //38400 bps

Freq_Word1 <= 32‘d3693672; Freq_Word2 <= 32‘d59098750; //43000 bps

Freq_Word1 <= 32‘d4810363; Freq_Word2 <= 32‘d76965814; //56000 bps

Freq_Word1 <= 32‘d4947802; Freq_Word2 <= 32‘d79164837; //57600 bps

Freq_Word1 <= 32‘d9895605; Freq_Word2 <= 32‘d158329674; //115200bps

Freq_Word1 <= 32‘d10995116; Freq_Word2 <= 32‘d175921860; //128000bps

Freq_Word1 <= 32‘d21990233; Freq_Word2 <= 32‘d351843721; //256000bps

*****************************************************/

//only want to generate beautiful clk for bsp and sample

reg [31:0] bps_cnt1;

reg [31:0] bps_cnt2;

always@(posedge clk or negedge rst_n)

begin

if(!rst_n)

begin

bps_cnt1 <= 0;

bps_cnt2 <= 0;

end

else

begin

bps_cnt1 <= bps_cnt1 + 32‘d9895605;

//Bps=115200bps

bps_cnt2 <= bps_cnt2 + 32‘d158329674;

//Bps=115200bps*16

end

end

//------------------------------------------

[!--empirenews.page--]

//clk_bps sync bps generater

reg clk_bps_r0,clk_bps_r1,clk_bps_r2;

always@(posedge clk or negedge rst_n)

begin

if(!rst_n)

begin

clk_bps_r0 <= 0;

clk_bps_r1 <= 0;

clk_bps_r2 <= 0;

end

else

begin

if(bps_cnt1 < 32‘h7FFF_FFFF)

clk_bps_r0 <= 0;

else

clk_bps_r0 <= 1;

clk_bps_r1 <= clk_bps_r0;

clk_bps_r2 <= clk_bps_r1;

end

end

assign clk_bps = ~clk_bps_r2 & clk_bps_r1;

//------------------------------------------

//clk_smp sync receive bps generator

reg clk_smp_r0,clk_smp_r1,clk_smp_r2;

always@(posedge clk or negedge rst_n)

begin

if(!rst_n)

begin

clk_smp_r0 <= 0;

clk_smp_r1 <= 0;

clk_smp_r2 <= 0;

end

else

begin

if(bps_cnt2 < 32‘h7FFF_FFFF)

clk_smp_r0 <= 0;

else

clk_smp_r0 <= 1;

clk_smp_r1 <= clk_smp_r0;

clk_smp_r2 <= clk_smp_r1;

end

end

assign clk_smp = ~clk_smp_r2 & clk_smp_r1;

endmodule

[!--empirenews.page--]

代碼中Bingo設(shè)置了多個(gè)選項(xiàng)的bps,根據(jù)您的需要,可以直接修改代碼,來達(dá)到自己的要求。本模塊的功能主要功能是生成兩個(gè)時(shí)鐘:

a) clk_bps : UART TXD信號線數(shù)據(jù)發(fā)送的波特率

b) clk_smp: UART RXD信號線數(shù)據(jù)接受的采樣速率,以對已波特率的16倍速度采樣,捕獲數(shù)據(jù)的中點(diǎn),在數(shù)據(jù)最穩(wěn)態(tài)讀取數(shù)據(jù),達(dá)到最大限制的穩(wěn)定。

(2)TXD發(fā)送模塊

這部分代碼比較簡單,因?yàn)镕PGA是主控,只要根據(jù)固定的時(shí)序給數(shù)據(jù)即可。Bingo設(shè)計(jì)了一個(gè)狀態(tài)機(jī)來完成時(shí)序,狀態(tài)機(jī)代碼如下:

always@(posedge clk or negedge rst_n)

begin

if(!rst_n)

begin

txd_state <= T_IDLE;

txd_flag_r <= 0;

txd <= 1‘b1;

end

else

begin

case(txd_state)

T_IDLE:

begin

txd <= 1;

txd_flag_r <= 0;

if(txd_en == 1)

txd_state <= T_SEND;

else

txd_state <= T_IDLE;

end

T_SEND:

begin

if(clk_bps == 1)

begin

if(txd_cnt < 4‘d9)

txd_cnt <= txd_cnt + 1‘b1;

else

begin

txd_cnt <= 0;

txd_state <= T_IDLE;

txd_flag_r <= 1;

end

case(txd_cnt)

4‘d0: txd <= 0;

4‘d1: txd <= txd_data[0];

4‘d2: txd <= txd_data[1];

4‘d3: txd <= txd_data[2];

4‘d4: txd <= txd_data[3];

4‘d5: txd <= txd_data[4];

4‘d6: txd <= txd_data[5];

4‘d7: txd <= txd_data[6];

4‘d8: txd <= txd_data[7];

4‘d9: txd <= 1;

endcase

end

end

endcase

end

End

數(shù)據(jù)發(fā)送的狀態(tài)機(jī)設(shè)計(jì)如下:

 

同時(shí),為了軟件調(diào)試,數(shù)據(jù)識別等的方便,Bingo在此模塊設(shè)置了數(shù)據(jù)發(fā)送標(biāo)志位。此部分主要參考了Bingo“第七章 你想干嘛——邊沿檢測技術(shù)”的方法,此處不再做累贅闡述,若有不懂請看上文。此部分代碼如下:

[!--empirenews.page--]

//-------------------------------------

//Capture the falling of data transfer over

reg txd_flag_r0,txd_flag_r1;

always@(posedge clk or negedge rst_n)

begin

if(!rst_n)

begin

txd_flag_r0 <= 0;

txd_flag_r1 <= 0;

end

else

begin

txd_flag_r0 <= txd_flag_r;

txd_flag_r1 <= txd_flag_r0;

end

end

assign txd_flag = txd_flag_r1 & ~txd_flag_r0;

(3)RXD發(fā)送模塊

由于接收數(shù)據(jù)的時(shí)候,主控是PC,從機(jī)是FPGA,因此FPGA需要采樣數(shù)據(jù)。以上波特率發(fā)生器中講到過,采樣時(shí)鐘clk_bps = 16*clk_bps。FPGA硬件描述,通過計(jì)數(shù),當(dāng)采樣到RXD數(shù)據(jù)起始位信號有效時(shí),0-7-15開始計(jì)數(shù),,其中7為數(shù)據(jù)的中點(diǎn),最穩(wěn)定的時(shí)刻。因此在此時(shí)采樣數(shù)據(jù),能夠達(dá)到最穩(wěn)定的效果。Bingo設(shè)計(jì)代碼如下:

always@(posedge clk or negedge rst_n)

begin

if(!rst_n)

begin

smp_cnt <= 0;

rxd_cnt <= 0;

rxd_data <= 0;

rxd_state <= R_IDLE;

end

else if(clk_smp == 1)

begin

case(rxd_state)

R_IDLE:

begin

rxd_cnt <= 0;

if(rxd_sync == 1‘b0)

begin

smp_cnt <= smp_cnt + 1‘b1;

if(smp_cnt == 4‘d7) //8 clk_smp enable

rxd_state <= R_SAMPLE;

end

else

smp_cnt <= 0;

end

R_SAMPLE:

begin

smp_cnt <= smp_cnt +1‘b1;

if(smp_cnt == 4‘d7)

begin

rxd_cnt <= rxd_cnt +1‘b1;

if(rxd_cnt == 4‘d7)

rxd_state <= R_IDLE;

case(rxd_cnt)

3‘d0: rxd_data[0] <= rxd_sync;

3‘d1: rxd_data[1] <= rxd_sync;

3‘d2: rxd_data[2] <= rxd_sync;

3‘d3: rxd_data[3] <= rxd_sync;

3‘d4: rxd_data[4] <= rxd_sync;

3‘d5: rxd_data[5] <= rxd_sync;

3‘d6: rxd_data[6] <= rxd_sync;

3‘d7: rxd_data[7] <= rxd_sync;

endcase

end

end

endcase

end

end

[!--empirenews.page--]


同樣,發(fā)送部分狀態(tài)機(jī)如下如下所示:

4、USB代碼測試圖:

三、USB通信接口設(shè)計(jì)

1、USB通信協(xié)議

USB : Universal Serial BUS(通用串行總線)的縮寫,而其中文簡稱為“通串線,是一個(gè)外部總線標(biāo)準(zhǔn),用于規(guī)范電腦與外部設(shè)備的連接和通訊。是應(yīng)用在PC領(lǐng)域的接口技術(shù)。USB接口支持設(shè)備的即插即用和熱插拔功能。USB是在1994年底由英特爾、康柏、IBM、Microsoft等多家公司聯(lián)合提出的。

USB發(fā)展經(jīng)過了以下幾個(gè)階段:

(1)USB1.0:1.5Mbps(192KB/s) 低速(Low-Speed) 500mA……1996年1月

(2)USB1.1:12Mbps(1.5MB/s) 全速(Full-Speed) 500mA……1998年9月

(3)USB2.0:480Mbps(60MB/s) 高速(High-Speed) 500mA……2000年4月

(4)USB3.0:5Gbps(640MB/s) 超速(Super-Speed) 900mA……200年11月

相對于UART的設(shè)計(jì),USB就要復(fù)雜得多了。USB屬于全雙工器件,速度之快,指令之多,目前直接用Verilog設(shè)計(jì)的硬核在理論上能夠?qū)崿F(xiàn),實(shí)際上還不常見。一般USB通信接口的驅(qū)動(dòng),用Nios II軟核來實(shí)現(xiàn)。

 

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

在數(shù)字化浪潮席卷全球的今天,F(xiàn)PGA技術(shù)正成為驅(qū)動(dòng)創(chuàng)新的核心引擎。2025年8月21日,深圳將迎來一場聚焦FPGA技術(shù)與產(chǎn)業(yè)應(yīng)用的盛會(huì)——2025安路科技FPGA技術(shù)沙龍。本次沙龍以“定制未來 共建生態(tài)”為主題,匯聚行業(yè)...

關(guān)鍵字: FPGA 核心板 開發(fā)板

在現(xiàn)代電子系統(tǒng)中,現(xiàn)場可編程門陣列(FPGA)憑借其開發(fā)時(shí)間短、成本效益高以及靈活的現(xiàn)場重配置與升級等諸多優(yōu)點(diǎn),被廣泛應(yīng)用于各種產(chǎn)品領(lǐng)域。從通信設(shè)備到工業(yè)控制,從汽車電子到航空航天,F(xiàn)PGA 的身影無處不在。為了充分發(fā)揮...

關(guān)鍵字: 可編程門陣列 FPGA 數(shù)字電源

2025年8月4日 – 提供超豐富半導(dǎo)體和電子元器件?的業(yè)界知名新品引入 (NPI) 代理商貿(mào)澤電子 (Mouser Electronics) 即日起開售Altera?的Agilex? 3 FPGA C系列開發(fā)套件。此開...

關(guān)鍵字: FPGA 邊緣計(jì)算 嵌入式應(yīng)用

內(nèi)窺鏡泛指經(jīng)自然腔道或人工孔道進(jìn)入體內(nèi),并對體內(nèi)器官或結(jié)構(gòu)進(jìn)行直接觀察和對疾病進(jìn)行診斷的醫(yī)療設(shè)備,一般由光學(xué)鏡頭、冷光源、光導(dǎo)纖維、圖像傳感器以及機(jī)械裝置等構(gòu)成。文章介紹了一款基于兩片圖像傳感器和FPGA組成的微型3D內(nèi)...

關(guān)鍵字: 微創(chuàng) 3D內(nèi)窺鏡 OV6946 FPGA

運(yùn)用單片機(jī)和FPGA芯片作為主控制器件 , 單片機(jī)接收從PC機(jī)上傳過來的顯示內(nèi)容和顯示控制命令 , 通過命令解釋和數(shù)據(jù)轉(zhuǎn)換 , 生成LED顯示屏所需要的數(shù)據(jù)信號和同步的控制信號— 數(shù)據(jù)、時(shí)鐘、行同步和面同步 。FPGA芯...

關(guān)鍵字: 單片機(jī) FPGA LED顯示屏

在異構(gòu)計(jì)算系統(tǒng)中,ARM與FPGA的協(xié)同工作已成為高性能計(jì)算的關(guān)鍵架構(gòu)。本文基于FSPI(Fast Serial Peripheral Interface)四線模式,在150MHz時(shí)鐘頻率下實(shí)現(xiàn)10.5MB/s的可靠數(shù)據(jù)...

關(guān)鍵字: ARM FPGA FSPI

在全球FPGA市場被Xilinx(AMD)與Intel壟斷的格局下,國產(chǎn)FPGA廠商高云半導(dǎo)體通過構(gòu)建自主IP核生態(tài)與智能時(shí)序約束引擎,走出差異化高端化路徑。本文深入解析高云半導(dǎo)體FPGA工具鏈的兩大核心技術(shù)——全棧IP...

關(guān)鍵字: FPGA 高云半導(dǎo)體

2025年6月12日,由安路科技主辦的2025 FPGA技術(shù)沙龍?jiān)谀暇┱秸匍_,深圳市米爾電子有限公司(簡稱:米爾電子)作為國產(chǎn)FPGA的代表企業(yè)出席此次活動(dòng)。米爾電子發(fā)表演講,并展出米爾基于安路飛龍派的核心板和解決方案...

關(guān)鍵字: FPGA 核心板 開發(fā)板

高 I/O、低功耗及先進(jìn)的安全功能,適用于成本敏感型邊緣應(yīng)用

關(guān)鍵字: FPGA I/O 機(jī)器視覺

本文討論如何為特定應(yīng)用選擇合適的溫度傳感器。我們將介紹不同類型的溫度傳感器及其優(yōu)缺點(diǎn)。最后,我們將探討遠(yuǎn)程和本地檢測技術(shù)的最新進(jìn)展如何推動(dòng)科技進(jìn)步,從而創(chuàng)造出更多更先進(jìn)的溫度傳感器。

關(guān)鍵字: 溫度傳感器 CPU FPGA
關(guān)閉