串口RS232通信程序.docx

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

串口RS232通信程序(Verilog)

串口有9个管脚,其中只有三个是最重要的,分别是

pin2:RxD(receivedata).接收数据pin3:TxD(transmitdata).发送数据pin5:GND(ground).地

串行通信时序

我们先来看看字节0x55的发送

0x55的二进制代码是但发送时由低字节开始的,因此发送次序依次为1-0-1-

0-1-0-1-0.

串行通信电平

1issentusing-10V(orbetween-5Vand-15V).

0issentusing+10V(orbetween5Vand15V).

由于计算机RS232的电平与电路板(通常+5V)之间电平的不同所以要用到转换芯片如果PCB板电源+-5V的话用MAX232

如果PCB板(FPGA)电源是+-3.3V的话用MAX3232

这个图的串口如果采用母头的话,要用交叉公母线,保证是PCB板上这边的RxD连计算机的TxD(3Pin),PCB板这边的TxD连计算机的RxD(2Pin).

串行通信波特率

这里要弄清楚波特率与比特率的差别:

比特率是数字信号的传输速率,它用单位时间内传输的二进制代码的有效位(bit)数来表示,其单位为每秒比特数bit/s(bps)、每秒千比特数(Kbps)或每秒兆比特数(Mbps)来表示(此处K和M分别为1000和1000000,而不是涉及计算机存储器容量时的1024和1048576)。

波特率指数据信号对载波的调制速率,它用单位时间内载波调制状态改变次数来表示,其单位为波特(Baud)。

波特率与比特率的关系为:比特率=波特率X单个调制状态对应的二进制位数两相调制(单个调制状态对应1个二进制位)的比特率等于波特率;

四相调制(单个调制状态对应2个二进制位)的比特率为波特率的两倍;

八相调制(单个调制状态对应3个二进制位)的比特率为波特率的三倍;依次类推。

对于串行通信来说,或者说是对于普通的数字电路来说,都是两相调制(单个调制状态对应1个二进制位),因此波特率=比特率(通常叫波特率)。

PS:可以看看下面图就知道什么是四相调制。

reg[3:0]BaudDivCnt;always@(posedgeclk)BaudDivCnt=BaudDivCnt+1;wireBaudTick=

reg[3:0]BaudDivCnt;

always@(posedgeclk)BaudDivCnt=BaudDivCnt+1;

wireBaudTick=(BaudDivCnt==15);

但通常系统的时钟不是刚刚好是波特率的整数倍,如果不采用DCM对系统进行倍频的话,可以采用下面程序进行处理,设系统时钟为2MHz=2000000Hz

2000000/115200=17.36111

1024/59=17.356

2000000/115200≈1024/59

两个频率很接近,可以采用下面程序产生我们要的波特率。

//10bitsfortheaccumulator([9:0]),andoneextrabitfortheaccumulatorcarry-out([10])

//10bitsfortheaccumulator([9:0]),andoneextrabitfortheaccumulatorcarry-out([10])

reg[10:0]acc; //11bitstotal!

always@(posedgeclk)

acc=acc[9:0]+59;

//useonly10bitsfromthepreviousresult,butsavethefull11bits

wireBaudTick=acc[10];//sothatthe11thbitisthecarry-out

当系统时钟为2MHz的时候,计算得到的波特率的值为115234,与115200只有0.03%的误差。

我们怎么得到“59呢”,可以看下面的推导

(

(程序中的和此有不同容易造成误解)

其中BaudBaudGeneratorAccWidth,Baud左移BaudGeneratorAccWidth位,相当于Baud乘以2的BaudGeneratorAccWidth次方。

参照上面的程序与公式推导可以把程序修改如下:

parameter

parameterClkFrequency=25000000

文档评论(0)

tianya189 + 关注
官方认证
内容提供者

该用户很懒,什么也没介绍

认证主体阳新县融易互联网技术工作室
IP属地上海
统一社会信用代码/组织机构代码
92420222MA4ELHM75D

1亿VIP精品文档

相关文档