在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

UART的發(fā)送數(shù)據(jù)模塊及Verilog代碼

FPGA之家 ? 來(lái)源:AriesOpenFPGA ? 作者:AriesOpenFPGA ? 2021-05-27 18:05 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

代碼注釋有些匆忙,如有錯(cuò)誤注釋還請(qǐng)批評(píng),僅作參考

UART

Uart比較簡(jiǎn)單,所以僅對(duì)tx作比較詳細(xì)的注釋,但里面一些內(nèi)容還是值得新手學(xué)習(xí)的

1開(kāi)始位(低電平)+8位數(shù)據(jù)+1停止位(高電平,這里選的是一個(gè)周期高電平,也可兩個(gè))(無(wú)校驗(yàn)位)

1、prescale是完成一個(gè)bit需要主時(shí)鐘計(jì)數(shù)的次數(shù)(其和主時(shí)鐘以及波特率之間的關(guān)系參考網(wǎng)上文章)

2、進(jìn)入uart模塊的異步信號(hào),最好使用提供的同步器同步

3、異步復(fù)位信號(hào)最好使用提供的同步器同步

4、波特率任意選,只要時(shí)鐘夠大,能夠符合誤碼率計(jì)算即可,這里使用的是125Mhz

5、基本的思想就是移位

6、傳輸條件就是握手

7、如果使用Xlinx的片子,建議使用全局時(shí)鐘資源(IBUFG后面連接BUFG的方法是最基本的全局時(shí)鐘資源的使用方法)

8、這個(gè)完整的代碼就是使用IBUFG+BUFG

9、傳輸雖然簡(jiǎn)單,但對(duì)于新手來(lái)講,還是有挺多的知識(shí)點(diǎn)值得學(xué)習(xí)的點(diǎn)

10、公眾號(hào)只是對(duì)代碼進(jìn)行了簡(jiǎn)單注釋

UART的發(fā)送數(shù)據(jù)模塊

// 代碼注釋有些匆忙,如有錯(cuò)誤注釋還請(qǐng)批評(píng),僅作參考// UART// 1開(kāi)始位+8位數(shù)據(jù)+1停止位(無(wú)校驗(yàn))// prescale是完成一個(gè)bit需要主時(shí)鐘計(jì)數(shù)的次數(shù)(其和主時(shí)鐘以及波特率之間的關(guān)系參考網(wǎng)上文章)// 進(jìn)入uart模塊的異步信號(hào),最好使用提供的同步器同步// 異步復(fù)位信號(hào)最好使用提供的同步器同步// 波特率任意選,只要時(shí)鐘夠大,能夠符合誤碼率計(jì)算即可,這里使用的是125M// 基本的思想就是移位// 傳輸條件就是握手// 如果使用Xlinx的片子,建議使用全局時(shí)鐘資源(IBUFG后面連接BUFG的方法是最基本的全局時(shí)鐘資源的使用方法)// 這個(gè)完整的代碼就是使用IBUFG+BUFG// 傳輸雖然簡(jiǎn)單,但對(duì)于新手來(lái)講,還是有挺多的知識(shí)點(diǎn)值得學(xué)習(xí)的// 公眾號(hào)只是對(duì)代碼進(jìn)行了簡(jiǎn)單注釋`timescale 1ns / 1ps/* AXI4-Stream UART */module uart_tx #( parameter DATA_WIDTH = 8)( input wire clk, // 系統(tǒng)時(shí)鐘 input wire rst, // 復(fù)位信號(hào)

/* AXI input */ input wire [DATA_WIDTH-1:0] s_axis_tdata, // 輸入到這個(gè)模塊準(zhǔn)備發(fā)送出去的數(shù)據(jù) input wire s_axis_tvalid, // 有數(shù)據(jù)要輸入到這個(gè)模塊 output wire s_axis_tready, // 該模塊準(zhǔn)備好接收數(shù)據(jù)

output wire txd, // UART interface output wire busy, // Status 線忙 input wire [15:0] prescale // Configuration 預(yù)分度);

reg s_axis_tready_reg = 0;reg txd_reg = 1;reg busy_reg = 0;

reg [DATA_WIDTH:0] data_reg = 0;reg [18:0] prescale_reg = 0;reg [3:0] bit_cnt = 0;

assign s_axis_tready = s_axis_tready_reg;assign txd = txd_reg;assign busy = busy_reg;

always @(posedge clk) begin if (rst) begin s_axis_tready_reg 《= 0; // 從機(jī)沒(méi)有準(zhǔn)備好發(fā)送 txd_reg 《= 1; // 發(fā)送線拉高 prescale_reg 《= 0; // bit_cnt 《= 0; // 位計(jì)數(shù)器初始化為0 busy_reg 《= 0; // 復(fù)位后為不忙狀態(tài) end else begin if (prescale_reg 》 0) begin s_axis_tready_reg 《= 0; prescale_reg 《= prescale_reg - 1; end else if (bit_cnt == 0) //比特計(jì)數(shù)器為0 begin s_axis_tready_reg 《= 1; // 從機(jī)把ready信號(hào)拉高 busy_reg 《= 0; // 忙信號(hào)拉低無(wú)效 if (s_axis_tvalid) // 如果從機(jī)準(zhǔn)備好接收數(shù)據(jù) begin s_axis_tready_reg 《= !s_axis_tready_reg; // prescale_reg 《= (prescale 《《 3)-1; // bit_cnt 《= DATA_WIDTH+1; // 一共10次計(jì)數(shù) data_reg 《= {1‘b1, s_axis_tdata}; // txd_reg 《= 0; // 起始位0(起始位tx拉低,停止位拉高) busy_reg 《= 1; // 開(kāi)始傳輸后,傳輸線進(jìn)入忙狀態(tài) end end else begin if (bit_cnt 》 1) // begin bit_cnt 《= bit_cnt - 1; prescale_reg 《= (prescale 《《 3)-1; // 經(jīng)過(guò)(prescale 《《 3)-1次的系統(tǒng)時(shí)鐘計(jì)數(shù),完成一位的移位 {data_reg, txd_reg} 《= {1’b0, data_reg}; // 移位操作 end else if (bit_cnt == 1) begin bit_cnt 《= bit_cnt - 1; prescale_reg 《= (prescale 《《 3); txd_reg 《= 1; // 停止位1 end end end end

endmodule

UART的接收模塊(不詳細(xì)講解)

// Language: Verilog 2001

`timescale 1ns / 1ps

/* * AXI4-Stream UART */module uart_rx #( parameter DATA_WIDTH = 8)( input wire clk, input wire rst,

/* AXI output */ output wire [DATA_WIDTH-1:0] m_axis_tdata, output wire m_axis_tvalid, input wire m_axis_tready, /* UART interface */ input wire rxd, /* Status */ output wire busy, output wire overrun_error, output wire frame_error, /* Configuration */ input wire [15:0] prescale

);

reg [DATA_WIDTH-1:0] m_axis_tdata_reg = 0;reg m_axis_tvalid_reg = 0;

reg rxd_reg = 1;

reg busy_reg = 0;reg overrun_error_reg = 0;reg frame_error_reg = 0;

reg [DATA_WIDTH-1:0] data_reg = 0;reg [18:0] prescale_reg = 0;reg [3:0] bit_cnt = 0;

assign m_axis_tdata = m_axis_tdata_reg;assign m_axis_tvalid = m_axis_tvalid_reg;

assign busy = busy_reg;assign overrun_error = overrun_error_reg;assign frame_error = frame_error_reg;

always @(posedge clk) begin if (rst) // 初始化各種參數(shù) begin m_axis_tdata_reg 《= 0; m_axis_tvalid_reg 《= 0; rxd_reg 《= 1; prescale_reg 《= 0; bit_cnt 《= 0; busy_reg 《= 0; overrun_error_reg 《= 0; frame_error_reg 《= 0; end else begin rxd_reg 《= rxd; overrun_error_reg 《= 0; frame_error_reg 《= 0;

if (m_axis_tvalid && m_axis_tready) // 準(zhǔn)備有數(shù)據(jù)要發(fā)以及準(zhǔn)被好發(fā) begin m_axis_tvalid_reg 《= 0; end

if (prescale_reg 》 0) // begin prescale_reg 《= prescale_reg - 1; end else if (bit_cnt 》 0) begin if (bit_cnt 》 DATA_WIDTH+1) begin if (!rxd_reg) // 實(shí)際的read為0時(shí),開(kāi)始計(jì)數(shù)bit begin bit_cnt 《= bit_cnt - 1; prescale_reg 《= (prescale 《《 3)-1; //prescale是16位移3位減1位,因?yàn)閜rescale_reg end else begin bit_cnt 《= 0; prescale_reg 《= 0; end end else if (bit_cnt 》 1) begin bit_cnt 《= bit_cnt - 1; prescale_reg 《= (prescale 《《 3)-1; data_reg 《= {rxd_reg, data_reg[DATA_WIDTH-1:1]}; end else if (bit_cnt == 1) begin bit_cnt 《= bit_cnt - 1; if (rxd_reg) begin m_axis_tdata_reg 《= data_reg; m_axis_tvalid_reg 《= 1; overrun_error_reg 《= m_axis_tvalid_reg; end else begin frame_error_reg 《= 1; end end end else begin busy_reg 《= 0; if (!rxd_reg) begin prescale_reg 《= (prescale 《《 2)-2; bit_cnt 《= DATA_WIDTH + 2; data_reg 《= 0; busy_reg 《= 1; end end endendendmodule

UART頂層

// Language: Verilog 2001

`timescale 1ns / 1ps

/* * AXI4-Stream UART */module uart #( parameter DATA_WIDTH = 8)( input wire clk, input wire rst,

/* * AXI input */ input wire [DATA_WIDTH-1:0] s_axis_tdata, input wire s_axis_tvalid, output wire s_axis_tready,

/* * AXI output */ output wire [DATA_WIDTH-1:0] m_axis_tdata, output wire m_axis_tvalid, input wire m_axis_tready,

/* * UART interface */ input wire rxd, output wire txd,

/* * Status */ output wire tx_busy, output wire rx_busy, output wire rx_overrun_error, output wire rx_frame_error,

/* * Configuration */ input wire [15:0] prescale

);

uart_tx #( .DATA_WIDTH(DATA_WIDTH))uart_tx_inst ( .clk(clk), .rst(rst), // axi input .s_axis_tdata(s_axis_tdata), .s_axis_tvalid(s_axis_tvalid), .s_axis_tready(s_axis_tready), // output .txd(txd), // status .busy(tx_busy), // configuration .prescale(prescale));

uart_rx #( .DATA_WIDTH(DATA_WIDTH))uart_rx_inst ( .clk(clk), .rst(rst), // axi output .m_axis_tdata(m_axis_tdata), .m_axis_tvalid(m_axis_tvalid), .m_axis_tready(m_axis_tready), // input .rxd(rxd), // status .busy(rx_busy), .overrun_error(rx_overrun_error), .frame_error(rx_frame_error), // configuration .prescale(prescale));

endmodule

同步(異步復(fù)位)模塊

// Language: Verilog-2001// 很常用的模塊`timescale 1 ns / 1 ps

/* * Synchronizes an active-high asynchronous reset signal to a given clock by * using a pipeline of N registers. */module sync_reset #( parameter N=2 // depth of synchronizer)( input wire clk, input wire rst, output wire sync_reset_out);

reg [N-1:0] sync_reg = {N{1‘b1}};

assign sync_reset_out = sync_reg[N-1];

always @(posedge clk or posedge rst) begin if (rst) sync_reg 《= {N{1’b1}}; else sync_reg 《= {sync_reg[N-2:0], 1‘b0};end

endmodule

同步(異步信號(hào))模塊

// Language: Verilog-2001// 很常用的模塊`timescale 1 ns / 1 ps

/* * Synchronizes an asyncronous signal to a given clock by using a pipeline of * two registers. */module sync_signal #( parameter WIDTH=1, // width of the input and output signals parameter N=2 // depth of synchronizer)( input wire clk, input wire [WIDTH-1:0] in, output wire [WIDTH-1:0] out);

reg [WIDTH-1:0] sync_reg[N-1:0];

/* * The synchronized output is the last register in the pipeline. */assign out = sync_reg[N-1];

integer k;

always @(posedge clk) begin sync_reg[0] 《= in; for (k = 1; k 《 N; k = k + 1) begin sync_reg[k] 《= sync_reg[k-1]; endend

endmodule

原文標(biāo)題:Uart協(xié)議及Verilog代碼

文章出處:【微信公眾號(hào):FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Verilog
    +關(guān)注

    關(guān)注

    29

    文章

    1366

    瀏覽量

    112012
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4891

    瀏覽量

    70407

原文標(biāo)題:Uart協(xié)議及Verilog代碼

文章出處:【微信號(hào):zhuyandz,微信公眾號(hào):FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    verilog模塊的調(diào)用、任務(wù)和函數(shù)

    在做模塊劃分時(shí),通常會(huì)出現(xiàn)這種情形,某個(gè)大的模塊中包含了一個(gè)或多個(gè)功能子模塊verilog是通過(guò)模塊調(diào)用或稱為
    的頭像 發(fā)表于 05-03 10:29 ?584次閱讀
    <b class='flag-5'>verilog</b><b class='flag-5'>模塊</b>的調(diào)用、任務(wù)和函數(shù)

    為什么無(wú)法使用Lpuart_Uart_Ip_ 發(fā)送任何數(shù)據(jù)回調(diào)中的AsyncSend?

    我已經(jīng)實(shí)現(xiàn)了基于 LPUART 的 DMA ,我可以發(fā)送使用 Lpuart_Uart_Ip_ 接收的數(shù)據(jù)同步發(fā)送 in lpuart_6_callback , 但是,我無(wú)法
    發(fā)表于 04-11 07:51

    UART、MCXA142實(shí)現(xiàn)ISP通信的主機(jī)端,發(fā)送Ping數(shù)據(jù)包并收到預(yù)期的響應(yīng),發(fā)送和接收數(shù)據(jù)包的典型順序是什么?

    我想為 UART、MCXA142 實(shí)現(xiàn) ISP 通信的主機(jī)端。我發(fā)送 Ping 數(shù)據(jù)包并收到預(yù)期的響應(yīng)。發(fā)送和接收數(shù)據(jù)包的典型順序是什么?
    發(fā)表于 04-03 08:05

    開(kāi)源直接用!UDP-UART數(shù)據(jù)透?jìng)鱽?lái)了

    UDP連接將數(shù)據(jù)發(fā)送到遠(yuǎn)程設(shè)備,然后將這些數(shù)據(jù)通過(guò)UART接口發(fā)送到本地設(shè)備。 這種通信方式在需要將遠(yuǎn)程設(shè)備的
    的頭像 發(fā)表于 02-05 17:14 ?314次閱讀
    開(kāi)源直接用!UDP-<b class='flag-5'>UART</b><b class='flag-5'>數(shù)據(jù)</b>透?jìng)鱽?lái)了

    Verilog 與 ASIC 設(shè)計(jì)的關(guān)系 Verilog 代碼優(yōu)化技巧

    Verilog與ASIC設(shè)計(jì)的關(guān)系 Verilog作為一種硬件描述語(yǔ)言(HDL),在ASIC設(shè)計(jì)中扮演著至關(guān)重要的角色。ASIC(Application Specific Integrated
    的頭像 發(fā)表于 12-17 09:52 ?970次閱讀

    Verilog 測(cè)試平臺(tái)設(shè)計(jì)方法 Verilog FPGA開(kāi)發(fā)指南

    Verilog設(shè)計(jì)的仿真需求。 編寫(xiě)測(cè)試文件 : 編寫(xiě)Verilog測(cè)試文件,對(duì)設(shè)計(jì)的各個(gè)模塊進(jìn)行測(cè)試。測(cè)試文件應(yīng)覆蓋各種情況,包括正
    的頭像 發(fā)表于 12-17 09:50 ?1074次閱讀

    Verilog與VHDL的比較 Verilog HDL編程技巧

    Verilog 與 VHDL 比較 1. 語(yǔ)法和風(fēng)格 VerilogVerilog 的語(yǔ)法更接近于 C 語(yǔ)言,對(duì)于有 C 語(yǔ)言背景的工程師來(lái)說(shuō),學(xué)習(xí)曲線較平緩。它支持結(jié)構(gòu)化編程,代碼
    的頭像 發(fā)表于 12-17 09:44 ?1573次閱讀

    如何自動(dòng)生成verilog代碼

    介紹幾種自動(dòng)生成verilog代碼的方法。
    的頭像 發(fā)表于 11-05 11:45 ?972次閱讀
    如何自動(dòng)生成<b class='flag-5'>verilog</b><b class='flag-5'>代碼</b>

    Verilog硬件描述語(yǔ)言參考手冊(cè)

    一. 關(guān)于 IEEE 1364 標(biāo)準(zhǔn)二. Verilog簡(jiǎn)介三. 語(yǔ)法總結(jié)四. 編寫(xiě)Verilog HDL源代碼的標(biāo)準(zhǔn)五. 設(shè)計(jì)流程
    發(fā)表于 11-04 10:12 ?4次下載

    uart波特率和傳輸頻率的關(guān)系 UART串口的常用波特率為多少

    ) :是衡量UART通信速度的單位,表示每秒傳輸?shù)谋忍財(cái)?shù)(bits per second,bps)。它反映了UART設(shè)備在發(fā)送和接收數(shù)據(jù)時(shí)使用的傳輸
    的頭像 發(fā)表于 10-06 16:12 ?6621次閱讀
    <b class='flag-5'>uart</b>波特率和傳輸頻率的關(guān)系 <b class='flag-5'>UART</b>串口的常用波特率為多少

    怎么樣提高verilog代碼編寫(xiě)水平?

    優(yōu)秀代碼:在網(wǎng)上查找開(kāi)源的、經(jīng)過(guò)驗(yàn)證的高質(zhì)量 Verilog 代碼,學(xué)習(xí)他人的編程風(fēng)格、代碼結(jié)構(gòu)和設(shè)計(jì)思路。 實(shí)踐項(xiàng)目:嘗試自己設(shè)計(jì)和實(shí)現(xiàn)一些較為復(fù)雜的項(xiàng)目,如復(fù)雜的控制器、
    發(fā)表于 09-25 20:05

    FPGA Verilog HDL代碼如何debug?

    monitor 語(yǔ)句,在關(guān)鍵位置輸出一些關(guān)鍵變量或中間結(jié)果的值,以便了解代碼執(zhí)行過(guò)程中的數(shù)據(jù)變化。 分模塊調(diào)試:將復(fù)雜的設(shè)計(jì)分解為較小的模塊,分別對(duì)每個(gè)
    發(fā)表于 09-24 19:16

    藍(lán)牙模塊如何實(shí)現(xiàn)單片機(jī)和手機(jī)端數(shù)據(jù)互傳

    ZX-D30、ZX-D37、ZX-D32等。 藍(lán)牙模塊設(shè)置 : 將藍(lán)牙模塊與單片機(jī)連接。通常,藍(lán)牙模塊通過(guò)串口(UART)與單片機(jī)通信。 設(shè)置藍(lán)牙
    的頭像 發(fā)表于 07-24 17:59 ?5424次閱讀
    藍(lán)牙<b class='flag-5'>模塊</b>如何實(shí)現(xiàn)單片機(jī)和手機(jī)端<b class='flag-5'>數(shù)據(jù)</b>互傳

    為什么無(wú)法在PSoC4的UART發(fā)送16個(gè)以上字節(jié)?

    我正在使用 CY8CKIT-149 套件,我想發(fā)送 24 個(gè)字節(jié),但一次無(wú)法發(fā)送超過(guò) 16 個(gè)字節(jié)。 如何用一條指令發(fā)送整條信息? 我在下面附上了我的代碼,下面是我使用的 API。 我
    發(fā)表于 07-23 07:19

    TCP服務(wù)器發(fā)送數(shù)據(jù)丟失的原因?

    當(dāng)UART數(shù)據(jù)后,Tcp服務(wù)器會(huì)獲取發(fā)送到TCP客戶端的數(shù)據(jù)。我們無(wú)法知道 UART 數(shù)據(jù)的數(shù)
    發(fā)表于 07-19 16:51
    主站蜘蛛池模板: 又污又黄的网站 | 婷五月综合 | 天天插天天舔 | 99久久精品免费看国产免费 | 最猛91大神ben与女教师 | 午夜逼逼| 天天摸天天看天天爽 | 四虎成人影院网址 | 色综合久久丁香婷婷 | 欧美成人一区二区三区在线视频 | 免费高清一级欧美片在线观看 | 午夜久久久久久久 | 有没有免费的视频在线观看 | 九九精品国产兔费观看久久 | 色多多最新地址福利地址 | 国产亚洲综合精品一区二区三区 | 看毛片网 | www.亚洲视频.com | 婷婷四房播客五月天 | 国产高清在线精品一区 | 色在线国产 | 欧美男人天堂网 | 亚洲精品国产美女在线观看 | 拍拍拍美女黄色1000视频 | a天堂影院 | 免费网站毛片 | 在线视频综合网 | 午夜国产福利在线观看 | 国产成人毛片毛片久久网 | 久久免费99精品久久久久久 | 国产成人一级片 | 久久综合九色综合97_ 久久久 | 欧美性猛交xxxx黑人猛交 | 热re99久久国产精品 | 韩国三级久久精品 | 国产大乳喷奶水在线看 | 一区二区中文字幕亚洲精品 | 国产精品久久久久久久久久影院 | 亚洲射图 | 日韩免费三级电影 | 岛国三级在线看 |