0:起始位,低电平;1~8:数据位;9:校验位,高电平;10:停止位,高电平。

波特率 “9600bps”表示每秒可以传输9600位。

波特率定时计数器由时钟频率除以波特率。

采集1~8位,忽略0、9、10位。

发送“0、8位数据、1、1”

串口传输数据,从最低位开始,到最高位结束。

串口发送:

module tx_bps_module
(
CLK, RSTn,
Count_Sig,
BPS_CLK
); input CLK;
input RSTn;
input Count_Sig;
output BPS_CLK; /***************************/ reg [:]Count_BPS; always @ ( posedge CLK or negedge RSTn )
if( !RSTn )
Count_BPS <= 'd0;
else if( Count_BPS == 'd5207 )
Count_BPS <= 'd0;
else if( Count_Sig )
Count_BPS <= Count_BPS + 'b1;
else
Count_BPS <= 'd0; /********************************/ assign BPS_CLK = ( Count_BPS == 'd2604 ) ? 1'b1 : 'b0; /*********************************/ endmodule
module tx_control_module
(
CLK, RSTn,
TX_En_Sig, TX_Data, BPS_CLK,
TX_Done_Sig, TX_Pin_Out ); input CLK;
input RSTn; input TX_En_Sig;
input [:]TX_Data;
input BPS_CLK; output TX_Done_Sig;
output TX_Pin_Out; /********************************************************/ reg [:]i;
reg rTX;
reg isDone; always @ ( posedge CLK or negedge RSTn )
if( !RSTn )
begin
i <= 'd0;
rTX <= 'b1;
isDone <= 'b0;
end
else if( TX_En_Sig )
case ( i ) 'd0 :
if( BPS_CLK ) begin i <= i + 'b1; rTX <= 1'b0; end 'd1, 4'd2, 'd3, 4'd4, 'd5, 4'd6, 'd7, 4'd8 :
if( BPS_CLK ) begin i <= i + 'b1; rTX <= TX_Data[ i - 1 ]; end 'd9 :
if( BPS_CLK ) begin i <= i + 'b1; rTX <= 1'b1; end 'd10 :
if( BPS_CLK ) begin i <= i + 'b1; rTX <= 1'b1; end 'd11 :
if( BPS_CLK ) begin i <= i + 'b1; isDone <= 1'b1; end 'd12 :
begin i <= 'd0; isDone <= 1'b0; end endcase /********************************************************/ assign TX_Pin_Out = rTX;
assign TX_Done_Sig = isDone; /*********************************************************/ endmodule
module tx_module
(
CLK, RSTn,
TX_Data, TX_En_Sig,
TX_Done_Sig, TX_Pin_Out
); input CLK;
input RSTn;
input [:]TX_Data;
input TX_En_Sig;
output TX_Done_Sig;
output TX_Pin_Out; /********************************/ wire BPS_CLK; tx_bps_module U1
(
.CLK( CLK ),
.RSTn( RSTn ),
.Count_Sig( TX_En_Sig ), // input - from U2
.BPS_CLK( BPS_CLK ) // output - to U2
); /*********************************/ tx_control_module U2
(
.CLK( CLK ),
.RSTn( RSTn ),
.TX_En_Sig( TX_En_Sig ), // input - from top
.TX_Data( TX_Data ), // input - from top
.BPS_CLK( BPS_CLK ), // input - from U2
.TX_Done_Sig( TX_Done_Sig ), // output - to top
.TX_Pin_Out( TX_Pin_Out ) // output - to top
); /***********************************/ endmodule

串口接受

module detect_module
(
CLK, RSTn,
RX_Pin_In,
H2L_Sig
);
input CLK;
input RSTn;
input RX_Pin_In;
output H2L_Sig; /******************************/ reg H2L_F1;
reg H2L_F2; always @ ( posedge CLK or negedge RSTn )
if( !RSTn )
begin
H2L_F1 <= 'b1;
H2L_F2 <= 'b1;
end
else
begin
H2L_F1 <= RX_Pin_In;
H2L_F2 <= H2L_F1;
end /***************************************/ assign H2L_Sig = H2L_F2 & !H2L_F1; /***************************************/ endmodule
module rx_control_module
(
CLK, RSTn,
H2L_Sig, RX_Pin_In, BPS_CLK, RX_En_Sig,
Count_Sig, RX_Data, RX_Done_Sig ); input CLK;
input RSTn; input H2L_Sig;
input RX_En_Sig;
input RX_Pin_In;
input BPS_CLK; output Count_Sig;
output [:]RX_Data;
output RX_Done_Sig; /********************************************************/ reg [:]i;
reg [:]rData;
reg isCount;
reg isDone; always @ ( posedge CLK or negedge RSTn )
if( !RSTn )
begin
i <= 'd0;
rData <= 'd0;
isCount <= 'b0;
isDone <= 'b0;
end
else if( RX_En_Sig )
case ( i ) 'd0 :
if( H2L_Sig ) begin i <= i + 'b1; isCount <= 1'b1; end /*进入第0位,同时驱动bps_module开始计数。又以bps_module驱动状态1~11*/ 'd1 :
if( BPS_CLK ) begin i <= i + 'b1; end /*第0位中部,BPS_CLK发出第一个脉冲,忽略第0位*/ 'd2, 4'd3, 'd4, 4'd5, 'd6, 4'd7, 'd8, 4'd9 :
if( BPS_CLK ) begin i <= i + 'b1; rData[ i - 2 ] <= RX_Pin_In; end 'd10 :
if( BPS_CLK ) begin i <= i + 'b1; end 'd11 :
if( BPS_CLK ) begin i <= i + 'b1; end 'd12 :
begin i <= i + 'b1; isDone <= 1'b1; isCount <= 'b0; end 'd13 :
begin i <= 'd0; isDone <= 1'b0; end endcase /********************************************************/ assign Count_Sig = isCount;
assign RX_Data = rData;
assign RX_Done_Sig = isDone; /*********************************************************/ endmodule
module rx_bps_module
(
CLK, RSTn,
Count_Sig,
BPS_CLK
); input CLK;
input RSTn;
input Count_Sig;
output BPS_CLK; /***************************/ reg [:]Count_BPS; always @ ( posedge CLK or negedge RSTn )
if( !RSTn )
Count_BPS <= 'd0;
else if( Count_BPS == 'd5207 )
Count_BPS <= 'd0;
else if( Count_Sig )
Count_BPS <= Count_BPS + 'b1;
else
Count_BPS <= 'd0; /********************************/ assign BPS_CLK = ( Count_BPS == 'd2604 ) ? 1'b1 : 'b0; /*周期中间开始采集数据*/ /*********************************/ endmodule
module rx_module
(
CLK, RSTn,
RX_Pin_In, RX_En_Sig,
RX_Done_Sig, RX_Data
); input CLK;
input RSTn; input RX_Pin_In;
input RX_En_Sig; output [:]RX_Data;
output RX_Done_Sig; /**********************************/ wire H2L_Sig; detect_module U1
(
.CLK( CLK ),
.RSTn( RSTn ),
.RX_Pin_In( RX_Pin_In ), // input - from top
.H2L_Sig( H2L_Sig ) // output - to U3
); /**********************************/ wire BPS_CLK; rx_bps_module U2
(
.CLK( CLK ),
.RSTn( RSTn ),
.Count_Sig( Count_Sig ), // input - from U3
.BPS_CLK( BPS_CLK ) // output - to U3
); /**********************************/ wire Count_Sig; rx_control_module U3
(
.CLK( CLK ),
.RSTn( RSTn ), .H2L_Sig( H2L_Sig ), // input - from U1
.RX_En_Sig( RX_En_Sig ), // input - from top
.RX_Pin_In( RX_Pin_In ), // input - from top
.BPS_CLK( BPS_CLK ), // input - from U2 .Count_Sig( Count_Sig ), // output - to U2
.RX_Data( RX_Data ), // output - to top
.RX_Done_Sig( RX_Done_Sig ) // output - to top ); /************************************/ endmodule

Verilog之串口(UART)通信的更多相关文章

  1. mini2440裸机试炼之——DMA直接存取 实现Uart(串口)通信

    这个仅仅能作为自己初步了解MDA的开门篇 实现功能: 将字符串数据通过DMA0通道传递给UTXH0,然后在终端 显示.传输数据完后.DMA0产生中断,beep声, LED亮. DMA基本知识 计算机系 ...

  2. [转]UART通信简介

    1.前言 UART通信,即通用异步收发传输器(Universal Asynchronous Receiver/Transmitter). 串行通信是指利用一条传输线将资料一位位地顺序传送.特点是通信线 ...

  3. Arduino与Air800开发板使用UART通信:传输DHT22传感器数据

    硬件介绍 Arduino Leonardo在数字引脚0(RX)和1(TX)进行串口通信时是使用“Serial1”,USB的串口通信使用的是“Serial”.在数字引脚0(RX)和1(TX)与USB是相 ...

  4. 串口UART学习笔记(一)

    买了一个开发板学习FPGA,找到的各种东西就记录在这个博客里了,同时也方便把自己不会的问题找到的结果记录一下,都是自己手打,所以可能说的话不那么严谨,不那么精准,看到的人要带着自己的思考去看,记住尽信 ...

  5. ZigBee学习四 无线+UART通信

    ZigBee学习四 无线+UART通信 1) 协调器编程 修改coordinator.c文件 byte GenericApp_TransID; // This is the unique messag ...

  6. ZigBee学习三 UART通信

    ZigBee学习三 UART通信 在使用串口时,只需掌握ZigBee协议栈提供的串口操作相关的三个函数即可. uint8 HalUARTOpen(uint8 port,halUARTCfg_t *co ...

  7. 痞子衡嵌入式:嵌入式里串口(UART)自动波特率识别程序设计与实现

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是嵌入式里串口(UART)自动波特率识别程序设计与实现. 串口(UART)是嵌入式里最基础最常用也最简单的一种通讯(数据传输)方式,可以说 ...

  8. 如何在User版本开启串口(Uart),抓取上层Log,开启输入控制台

    [原][FAQ03891] 如何在User版本开启串口(Uart),抓取上层Log,开启输入控制台 2014-11-26阅读1369 评论0 FAQ Content [Description]如何在U ...

  9. 第011课_串口(UART)的使用

    from: 第011课_串口(UART)的使用 第001节_辅线1_硬件知识_UART硬件介绍 1. 串口的硬件介绍 UART的全称是 Universal Asynchronous Receiver ...

随机推荐

  1. Python中,添加写入数据到已经存在的Excel的xls文件,即打开excel文件,写入新数据

    背景 Python中,想要打开已经存在的excel的xls文件,然后在最后新的一行的数据. 折腾过程 1.找到了参考资料: writing to existing workbook using xlw ...

  2. ThinkPad E440 Ubuntu 13.1无线网卡 RTL8723BE 驱动解决办法总结

    方法一.在使用网线链接到情况下 第一步.执行下边到命令,即从github上下载驱动程序并安装 sudo apt-get install linux-headers-generic build-esse ...

  3. 关于iscroll阻止浏览器默认动作

    使用iscroll时,移动端遇到需要长按复制功能,但是iscroll屏蔽了浏览器默认事件,所以实现不了. 解决方案: myScroll = new IScroll('#wrapper',{ preve ...

  4. 为什么在注册和注销的时候intent要改成隐式调用

    显式意图:调用Intent.setComponent()或Intent.setClass()方法明确指定了组件名的Intent为显式意图,显式意图明确指定了Intent应该传递给哪个组件. 隐式意图: ...

  5. 在.NET中使用EPPlus生成Excel报表 .

    --摘抄自:http://blog.csdn.net/zhoufoxcn/article/details/14112473 在开发.NET应用中可能会遇到需要生成带图表(Chart)的Excel报表的 ...

  6. XE6移动开发环境搭建之IOS篇(2):安装VM9虚拟机(有图有真相)

    网上能找到的关于Delphi XE系列的移动开发环境的相关文章甚少,本文尽量以详细的图文内容.傻瓜式的表达来告诉你想要的答案. 原创作品,请尊重作者劳动成果,转载请注明出处!!! 1.安装VM9英文原 ...

  7. mybatis-generator-core生成代码

    mybatis-generator-core-1.3.3下载地址:http://blog.mybatis.org/p/products.html 下载后名解压,进入lib目录 修改一个Generato ...

  8. iMac 重装系统

    iMac重装系统相当简单.开机的时候按下option键选择恢复系统或者在开机前按下 command+R然后按开机键松开同样会进入系统选择界面: 当中有 4 个选项:Restore From Time ...

  9. PHP指定字段的多维数组排序方法

    PHP数组排序可以用array_multisort方法实现,但是如果是多维数组,并且我们要指定数组中的某个字段进行排序,那么这就需要我们自己写方法实现了. function sortArrByFiel ...

  10. 误将文件push到Git,如何删除

    首先在本地删除多余文件夹(文件) 使用git add -u  git add -u,使用-u参数调用了git add命令,会将本地有改动(包括删除和修改)的已经追踪的文件标记到暂存区中.    再co ...