在FPGA芯片上使用VHDL语言实现UART模块的设计.docx
《在FPGA芯片上使用VHDL语言实现UART模块的设计.docx》由会员分享,可在线阅读,更多相关《在FPGA芯片上使用VHDL语言实现UART模块的设计.docx(5页珍藏版)》请在第一文库网上搜索。
1、在FPGA芯片上使用VHD1语言实现UART模块的设计1引言在数据采集系统中,常需要进行异步串行数据传输,目前广泛使用的RS232异步串行接口,如8250、NS16450等专用集成芯片,虽然使用简单,却有占用电路体积、引脚连接复杂等缺点。SoC(SystemonChip,片上系统)是AS1C设计中的新技术,是以嵌入式系统为核心,以IP复用技术为基础,集软、硬件于一体的设计方法。使用IP复用技术,将UART集成到FPGA芯片上,可增加系统的可靠性,缩小PCB板体积;其次由于IP核的特点,使用IP核可使整个系统更加灵活,还可以根据需要进行功能的升级、扩充和裁减。本文使用皿3HD1语言编写UART模
2、块,将其集成到FPGA芯片上,与芯片上的其它功能模块构成SoC片上系统。2UART模块设计与实现UART串行数据格式如图1所示,串行数据包括8位数据(8databits)1位起始位(startbit)、1位结束位(StoPbit)、1位校验位(paritybit),共11位。I1111M68I.Hg.wH-ertbMPMJtytd-tcb111UARTftt8UART模块结构如图2所示,左边发送锁存器、发送移位超翟和逻辑控制组成发送模块(txmit),右边接收锁存器、接收移位寄存器和逻辑控制组成接收模块(rxcver)0发送模块和接收模块除了共用复位信号、时钟信号和并行数据线外,分别有各自的输
3、入、输出和控制逻辑单元。UARTWMi*KJ2.1波特率时钟的控制UART核包含一个可辘的波特率发生器,它给发送模块和接收模块提供发送数据和接收数据的基准时钟,波特率发生器产生的时钟mc1kx16是串行数据波特率的16倍。它对系统时钟进n分频,计算公式为:ITIC1kx16=系统时钟/波特率*16,针对不同波特率设定相应的数值就可以得到期望的内部波特率时钟。2.2发送模块设计发送模块分为三种模式:空闲模式、载入数据模式、移位模式。当并行8位数据从总线写入发送模块后,发送模块将并行数据装入锁存器thr中,然后在移位寄存器tsr中将数据移位,产生完整的发送序列(包括起始位,数据位,奇偶校验位和停止
4、位),以相应波特率从tx发送。发送模块的输入时钟mc1kx16是串行数据波特率的16倍,模块内部将其16分频后得到波特率时钟txc1ko在发送时序图中我们看到输入数据为8b00001111校验位为奇校验,产生校验位为1。tx端依次输出起始位0,8位数据00001111,校验位。tsr移位寄存器中数据依次右移,高位在前两次右移中补1,之后8次移位中高位补0。下面是发送模块主要程序段,使用VeriIogHD1语言编写。由于初始和移位程序比较简单,这里没有给出。a1ways(posedgetxc1korposedgereset)if(reset)id1e_reset;初始程序e1sebeginif(
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- FPGA 芯片 使用 VHDL 语言 实现 UART 模块 设计