串口RS232通信程序(Verilog).pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
串 RS232通信程序(Verilog) 串口有9 个管脚,其中只有三个是最重要的,分别是 pin 2: RxD (receive data). 接收数据 pin 3: TxD (transmit data). 发送数据 pin 5: GND (ground). 地 串行通信时序 我们先来看看字节0x55 的发送 0x55 的二进制代码但发送时由低字节开始的,因此发送次序依次为1-0-1- 0-1-0-1-0. 串行通信电平 · 1 is sent using -10V (or between -5V and -15V). · 0 is sent using +10V (or between 5V and 15V). 由于计算机RS232 的电平与电路板(通常+5V)之间电平的不同所以要用到转换芯片 如果PCB 板电源+-5V 的话用MAX232 如果PCB 板(FPGA)电源是+-3.3V 的话用MAX3232 这个图的串口如果采用母头的话,要用交叉公母线,保证是PCB 板上这边的RxD 连计 算机的TxD (3 Pin),PCB 板这边的TxD 连计算机的RxD(2 Pin). 串行通信波特率 这里要弄清楚波特率与比特率的差别: 比特率是数字信号的传输速率,它用单位时间内传输的二进制代码的有效位(bit)数来表 示,其单位为每秒比特数bit/s(bps)、每秒千比特数(Kbps)或每秒兆比特数(Mbps)来表示(此 处K和M分别为1000和1000000,而不是涉及计算机存储器容量时的1024和1048576)。 波特率指数据信号对载波的调制速率,它用单位时间内载波调制状态改变次数来表示, 其单位为波特(Baud)。 波特率与比特率的关系为:比特率=波特率X单个调制状态对应的二进制位数 两相调 (单个调制状态对应1个二进制位)的比特率等于波特率; 四相调 (单个调制状态对应2个二进制位)的比特率为波特率的两倍; 八相调 (单个调制状态对应3个二进制位)的比特率为波特率的三倍; 依次类推。 对于串行通信来说,或者说是对于普通的数字电路来说,都是两相调 (单个调制状态 对应1个二进制位),因此波特率=比特率(通常叫波特率)。 PS:可以看看下面图就知道什么是四相调制。 如果系统时钟是1.8432MHz ,那16 分频就得到115200Hz reg [3:0] BaudDivCnt; always @(posedge clk) BaudDivCnt = BaudDivCnt + 1; wire BaudTick = (BaudDivCnt==15); 但通常系统的时钟不是刚刚好是波特率的整数倍,如果不采用DC 对系统进行倍频的 话,可以采用下面程序进行处理,设系统时钟为2MHz=2000000Hz 2000000/115200=17.36111 1024/59= 17.356 2000000/115200≈1024/59 两个频率很接近,可以采用下面程序产生我们要的波特率。 // 10 bits for the accumulator ([9:0]), and one extra bit for the accumulator carry-out ([10]) reg [10:0] acc; // 11 bits total! always @(posedge clk) acc = acc[9:0] + 59; // use only 10 bits from the previous result, but save the full 11 bits wire BaudTick = acc[10]; // so that the 11th bit is the carry-out 当系统时钟为2MHz 的时候,计算得到的波特率的值为115234,与115200 只有0.03%的 误差。 我们怎么得到 “59”呢,可以看下面的推导 (程序中的和此有不同 容易造成误解) 其中BaudBaudGeneratorAccWidth,Baud左移BaudGeneratorAccWidth位,相 当于Baud乘

文档评论(0)

134****3224 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档