当前位置:首页 > EDA > 电子设计自动化
[导读]本文设计了一种基于FPGA的UART核,该核符合串行通信协议,具有模块化、兼容性和可配置性,适合于SoC应用。

摘要:本文设计了一种基于FPGAUART核,该核符合串行通信协议,具有模块化、兼容性和可配置性,适合于SoC应用。设计中使用Verilog HDL硬件描述语言在Xilinx ISE环境下进行设计、仿真,最后在FPGA上嵌入UART IP核实现了电路的异步串行通信功能。 
关键词:IP核;UART;Verilog HDL;FPGA 

Abstract:This article introduces the design of a UART core based on FPGA. According to the protocol of serial communication, this core has the characteristic of modularity and configurability, and is ideal for SoC(system on a chip). Verilog hardware description language (HDL) in the Xilinx ISE environment has been used for its design, compilation and simulation. The UART IP core has been implemented using FPGA technology.

Keywords:IP core;UART;Verilog HDL;FPGA

1 引言

在数据采集系统中, 常需要进行异步串行数据传输,目前广泛使用的RS232异步串行接口,如8250、NS16450等专用集成芯片,虽然使用简单,却有占用电路体积、引脚连接复杂等缺点。SoC(System on Chip,片上系统)是ASIC设计中的新技术,是以嵌入式系统为核心,以IP 复用技术为基础,集软、硬件于一体的设计方法。使用IP复用技术,将UART集成到FPGA芯片上,可增加系统的可靠性,缩小PCB板体积;其次由于IP核的特点,使用IP核可使整个系统更加灵活,还可以根据需要进行功能的升级、扩充和裁减。

本文使用Verilog HDL语言编写UART模块,将其集成到FPGA芯片上,与芯片上的其它功能模块构成SoC片上系统。

2         UART模块设计与实现

UART串行数据格式如图1所示,串行数据包括8位数据(8 data bits)、1位起始位(start bit)、1位结束位(stop bit)、1位校验位(parity bit),共11位。

图1. UART数据格式

UART模块结构如图2所示,左边发送锁存器、发送移位寄存器和逻辑控制组成发送模块(txmit),右边接收锁存器、接收移位寄存器和逻辑控制组成接收模块(rxcver)。发送模块和接收模块除了共用复位信号、时钟信号和并行数据线外,分别有各自的输入、输出和控制逻辑单元。

 

图2. UART模块结构

2.1 波特率时钟的控制

UART核包含一个可编程的波特率发生器,它给发送模块和接收模块提供发送数据和接收数据的基准时钟,波特率发生器产生的时钟mclkx16是串行数据波特率的16倍。它对系统时钟进n分频,计算公式为:mclkx16=系统时钟/波特率*16,针对不同波特率设定相应的数值就可以得到期望的内部波特率时钟。

2.2 发送模块设计

       发送模块分为三种模式:空闲模式、载入数据模式、移位模式。当并行8位数据从总线写入发送模块后,发送模块将并行数据装入锁存器thr中,然后在移位寄存器tsr中将数据移位,产生完整的发送序列(包括起始位,数据位,奇偶校验位和停止位),以相应波特率从tx发送。发送模块的输入时钟mclkx16是串行数据波特率的16倍,模块内部将其16分频后得到波特率时钟txclk。

在发送时序图中我们看到输入数据为8’b00001111,校验位为奇校验,产生校验位为’1’。tx端依次输出起始位’0’,8位数据’00001111’,校验位’1’。tsr移位寄存器中数据依次右移,高位在前两次右移中补’1’,之后8次移位中高位补’0’。

下面是发送模块主要程序段,使用Verilog HDL语言编写。由于初始和移位程序比较简单,这里没有给出。

always @(posedge txclk or posedge reset)

if (reset)

       idle_reset;                                          //初始程序

else

       begin

              if (txdone && txdatardy)

                     load_data;                            //将数据装入tsr,并发送起始位

              else

            begin  

                     shift_data;                           // tsr8位数据移位,并产生校验位          

                 if (txdone )              

                   tx <= 1'b1;                      // 输出停止位

                  else if (paritycycle)

                   tx <= txparity;               // 输出校验位

                 else                      

                            tx <= tsr[0];       //输出数据位

                  end

       end

图3. 发送时序

2.3    接收模块设计

接收模块也分为三种模式:空闲模式、检测起始位模式、移位模式。首先捕捉起始位,

在mclkx16时钟下不断检测从rx端输入数据的起始位,当检测到起始位后,接收模块由空闲模式转换为移位模式,并且16分频mclkx16产生rxclk波特率时钟。此时rxclk时钟的上升沿位于串行数据每一位的中间,这样接下来的数据在每一位的中点采样,能有效滤除噪声影响。然后由rxclk控制在上升沿将数据位写入移位寄存器rsr的rsr[7]位,并且rsr右移1位,照此过程8位数据全部写入rsr,并且停止产生rxclk波特率时钟。判断奇偶校验、帧结构和溢出标志正确后,rsr寄存器中的数据写入rhr数据锁存寄存器中,最后由8位数据总线输出转换完成的数据。

    rxclk时钟的产生依靠判断起始位,在起始位’0’的中点产生,并且在检测到结束位后停止,如图4所示。

                          图4. 接收模块波特率时钟产生时序

接收移位程序段如下:

task shift_data;

       begin                                                                                             

       rsr         <= rsr >> 1;            // 寄存器右移一位 

      rsr[7]      <= rxparity;             // 数据装入rsr[7]

      rxparity    <= rxstop;             

      rxstop      <= rx;                

      paritygen   <= paritygen ^ rxstop;     // 产生奇偶比较标志

       end

endtask

由时序图可以看到一个完整的数据帧的接收过程,hunt和idle标志捕捉到起始位后,产生rxclk波特率时钟,串行数据在rsr中移位,rsr中数据右移高位补零。当起始位’0’移位到rsr[0]后,接收模块在下一个clk上升沿返回空闲状态,返回空闲状态后产生数据移位完成中断rxrdy,数据可从8位数据总线读出。

图5. 接收时序

3  UART综合

程序经仿真验证后,须综合生成IP核并嵌入FPGA中。使用Xilinx公司的Xilinx ISE工具综合UART模块,FPGA选用Xilinx公司的Spartan-IIE xc2s50E,系统时钟40Mhz。经Xilinx ISE综合后,资源使用结果如下所示,表明使用少量FPGA的Slice和LUT单元就可生成UART核。

表1. 资源使用情况

Number of Slices     

108  out of    768

14%

Number of Slice Flip Flops 

90   out of   1536

5% 

Number of 4 input LUTs 

195  out of   1536

12% 

Number of bonded IOBs     

25   out of    102

24% 

Number of GCLKs 

1    out of      4

25% 

UART核可灵活分成接收和发送两部分,可根据需要选择使用,节省系统资源;一些控制标志字也可根据需要自行删减和扩充。最后将集成有UART核的FPGA数据采集系统与测试台进行异步串行通信实验,通信数据经检测表明使用UART核传输数据稳定可靠。

4  结束语

    在数据采集系统中经常采用UART异步串行通信接口作为数据采集系统的短距离串行通信。相对于传统的UART芯片来说,集成在FPGA中的具有UART功能的IP核更有利于提高数据采集系统的可靠性和稳定性,缩小电路体积。本文设计的UART IP核通过仿真验证,经综合、编译、嵌入FPGA,成功应用于数据采集系统的端口通信中。

参考文献

[1] 侯伯亨, 顾新. VHDL硬件描述语言与数字逻辑电路设计[M]. 西安: 西安电子科技大学出版社, 19991

[2] 张莉, 杨永明. 基于CPLD的UART设计[J]. 微计算机信息. 2002. 2(18): 60-61

[3] Xilinx, Inc. Spartan-IIE 1.8V FPGA Functional Description , 2003, 9

[4] 刘 达, 龚建荣. 系统级可编程芯片(SOPC)设计思想与开发策略[J]. 现代电子技术, 2002, (11): 124

[5] 周恒, 罗斯青. 基于FPGA的SOC设计策略[J]. 山西电子技术, 2002, (11): 629

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

成都2022年10月19日 /美通社/ -- 近期,平安养老险积极筹备个人养老金的产品设计和系统开发工作,发展多样化的养老金融产品,推动商业养老保险、个人养老金、专属商业养老保险等产品供给。 搭养老政策东风 ...

关键字: 温度 BSP 东风 大众

广东佛山2022年10月19日 /美通社/ -- 空间是人居生活的基础单元,承载着生存与活动的最基本功能。而对于理想空间的解构意义却在物理性容器之外,体现出人们对于空间和生活深层关系的思考,同时也塑造着人与空间的新型连接...

关键字: 温度 BSP 智能化 进程

上海2022年10月19日 /美通社/ -- 10月17日晚间,安集科技披露业绩预告。今年前三季度,公司预计实现营业收入7.54亿元至8.33亿元,同比增长60.24%至77.03%;归母净利润预计为1.73亿...

关键字: 电子 安集科技 BSP EPS

北京2022年10月19日 /美通社/ -- 10月18日,北京市经济和信息化局发布2022年度第一批北京市市级企业技术中心创建名单的通知,诺诚健华正式获得"北京市企业技术中心"认定。 北京市企业技...

关键字: BSP ARMA COM 代码

北京2022年10月18日 /美通社/ -- 10月14日,国际数据公司(IDC)发布《2022Q2中国软件定义存储及超融合市场研究报告》,报告显示:2022年上半年浪潮超融合销售额同比增长59.4%,近5倍于...

关键字: IDC BSP 数字化 数据中心

上海2022年10月18日 /美通社/ -- 2022年9月5日,是首都银行集团成立60周年的纪念日。趁着首都银行集团成立60周年与首都银行(中国)在华深耕经营12年的“大日子”,围绕作为外资金融机构对在华战略的构想和业...

关键字: 数字化 BSP 供应链 控制

东京2022年10月18日  /美通社/ -- NIPPON EXPRESS HOLDINGS株式会社(NIPPON EXPRESS HOLDINGS, INC.)旗下集团公司上海通运国际物流有限公司(Nipp...

关键字: 温控 精密仪器 半导体制造 BSP

广州2022年10月18日 /美通社/ -- 10月15日,第 132 届中国进出口商品交易会("广交会")于"云端"开幕。本届广交会上高新技术企业云集,展出的智能产品超过140,...

关键字: 中国智造 BSP 手机 CAN

要问机器人公司哪家强,波士顿动力绝对是其中的佼佼者。近来年该公司在机器人研发方面获得的一些成果令人印象深刻,比如其开发的机器人会后空翻,自主爬楼梯等。这不,波士顿动力又发布了其机器人组团跳男团舞的新视频,表演的机器人包括...

关键字: 机器人 BSP 工业机器人 现代汽车

南京2022年10月17日 /美通社/ -- 日前《2022第三届中国高端家电品牌G50峰会》于浙江宁波落幕,来自两百余名行业大咖、专家学者共同探讨了在形势依然严峻的当下,如何以科技创新、高端化转型等手段,帮助...

关键字: LINK AI BSP 智能家电

电子设计自动化

21191 篇文章

关注

发布文章

编辑精选

技术子站

关闭