0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

在FPGA中利用IP核实现SOC系统中的串口收发接口的设计

电子设计 来源:郭婷 作者:电子设计 2019-08-02 08:08 次阅读

1、概述

在基于FPGA的SOC设计中,常使用串口作为通信接口,但直接用FPGA进行串口通信数据的处理是比较繁杂的,特别是直接使用FPGA进行串口通信的协议的解释和数据打包等处理,将会消耗大量的FPGA硬件资源。为简化设计,降低硬件资源开销,可以在FPGA中利用IP核实现的嵌入式微处理器来对串口数据进行处理。

本文中的设计采用了XILINX的FPGA,可选用的嵌入式微处理器IP核种类繁多,但基于对硬件资源开销最少的考虑,最终选用了Picoblaze。

嵌入式微处理器PicoBlaze适用于Spartan-II/E、CoolRunner-II和Virtex系列FPGA,运行速度可达到40MIPS以上,提供49个不同的指令,16个寄存器,256个地址端口,1个可屏蔽的中断。其性能超过了传统的8bit微处理器。

Picoblaze使用灵活,但其缺点是可寻址的存储空间非常有限,因此为满足实际需要本文同时也提出了使用片外SDRAM器件对其存储能力进行扩展的设计方法。

2、串口收发接口设计

2.1串口收发接口硬件设计

嵌入式微处理器PicoBlaze本身并不具备串行接口,因此必须在FPGA中设计串口接收和发送模块并通过总线结构与Picoblaze连接。

串口接收和发送模块的设计可采用成熟的IP核。实际设计中采用了XLINX的串口收发IP核,其特点是串口波特率,符号规则都可以灵活地定制,同时具有16字节的接收FIFO和16字节的发送FIFO。

使用Picoblaze和串口收发IP核构成的串口收发系统结构见图1。

在设计中,发送模块、接收模块和标志寄存器分别有不同的地址,Picoblaze通过地址端口对串口收发模块进行访问。设计中的标志寄存器,可用于指示发送模块和接收模块中FIFO的状态,Picoblaze通过查询标志寄存器来完成对串口数据的收发控制。

2.2串口收发接口软件设计

串口发送、接收子程序

Picoblaze通过对标志寄存器的查询,根据FIFO的状态进行操作。串口发送和接收子程序流程见图2。

在FPGA中利用IP核实现SOC系统中的串口收发接口的设计

Picoblaze的编程,类似于汇编语言。

串口发送子程序代码如下:

(1)串口接收子程序

receive:

INPUT s0,uartrxflag;查询接收FIFO是否非空

AND s0,01

AND s0,s0

JUMP Z,receive;若FIFO为空时继续查询

INPUT rxdata,uartrx;若FIFO非空时读取数据

RETURN

(2)串口接收子程序

translate:

INPUT s0,uarttxflag;查询发送FIFO是否为空

AND s0,01

AND s0,s0

JUMP NZ,translate;若发送FIFO非空时继续查询

OUTPUTtxdata,uarttx;若发送FIFO为空时写入数据

RETURN

协议处理子程序

本文应用中的串口通信,采用应答机制,数据具有一定的帧结构,Picoblaze需要对命令帧进行拆包处理,并根据帧的内容进行相应的操作,然后发送响应帧。

在FPGA中利用IP核实现SOC系统中的串口收发接口的设计

根据帧格式,Picoblaze对串口数据的处理流程见图3。

在FPGA中利用IP核实现SOC系统中的串口收发接口的设计

以上的Picoblaze程序流程所处理的数据帧结构是较为简单的,当需要处理复杂的通信协议时可以考虑采用多个Picoblaze并行处理。

3存储器接口设计

Picoblaze的优点是资源占用少,使用灵活,但可寻址的地址空间最多为256字节,无法满足对大量通信数据进行存储的需要。因此本文中采用了SDRAM器件来对Picoblaze的存储能力进行扩展。

SDRAM器件的管脚分为控制信号、地址和数据三类。通常一个SDRAM中包含几个BANK,每个BANK的存储单元是按行和列寻址的。SDRAM的具体特性见参考文献[3]。

SDRAM在使用时需要专用的控制器来产生满足SDRAM所需的信号。FPGA中SDRAM控制器也有多种IP核可以选用。出于对设计通用性的考虑,本文中采用了一款Altera提供的SDRAM控制器IP核,并增加了必要的设计以满足与Picoblaze的接口要求。SDRAM控制器IP核的功能、原理见参考文献[4]。

对Picoblaze与SDRAM控制器的接口设计有以下几个出发点:

总线匹配

Picoblaze为8位处理器,数据线仅8bit,而SDRAM控制器总线宽度与SDRAM相同,可以为8、16或32bit。因此对于SDRAM控制器的数据Picoblaze必须以字节为单位进行处理。

地址控制

Picoblaze地址线仅8位,无法直接对SDRAM进行寻址。因此Picoblaze对SDRAM的寻址可借鉴先入先出存储器FIFO的设计,即设计专门的地址计数器,通过地址计数器实现对SDRAM的寻址。

时序匹配

Picoblaze的运行速度不超过40MHz,而SDRAM的工作速度通常大于100MHz。因此为了满足SDRAM的时序要求,要增加必要的缓冲机制。

3.1存储器接口硬件设计

Picoblaze与SDRAM存储器接口的硬件原理框图见图4。

在FPGA中利用IP核实现SOC系统中的串口收发接口的设计

控制状态机控制的地址计数器为SDRAM控制器提供地址,同时控制状态机还控制输入数据缓冲区和输出数据缓冲区,并且根据Picoblaze的地址端口数据和读/写使能信号产生SDRAM控制器的命令字。

(1)SDRAM初始化

每次加电或复位后控制状

态机执行对SDRAM控制器的初始化操作,设置SDRAM的时间参数和刷新周期等。

(2)数据写入SDRAM

输出数据缓冲区由16×8bit的FIFO构成,当Picoblaze向输出数据缓冲区写入超过8个字节后,通过“半满”信号使控制状态机进入SDRAM的长度为8的突发写模式,在写入完成后控制状态机将地址计数器增加8,以准备好下一次的写入。

(3)数据读取

数据读取时Picoblaze首先向控制状态机发送读取请求,控制状态机进入SDRAM的长度为1的突发读模式,并将读取的数据写入输入数据缓冲区,此后Picoblaze再由输入数据缓冲区中读取数据。在读取后,地址计数器做相应的增加,以实现先入先出功能。

以上的设计方法适用于需要数据连续写入后再连续读取的场合。

控制状态机状态图见图5。

在FPGA中利用IP核实现SOC系统中的串口收发接口的设计

3.2存储器接口软件设计

由于在SDRAM控制器与Picoblaze之间增加了控制状态机,简化了Picoblaze的程序设计。

(1)数据写入

数据写入时Picoblaze向输出数据缓冲区直接写入数据即可。

(2)数据读取

数据读取时Picoblaze首先向控制状态机发出请求,然后等待输入数据缓冲区的数据准备就续后再读取。

4结论

本文在XILINX FPGA中采用嵌入式处理器Picoblaze进行SOC设计,以较少的硬件资源实现了对串口通信数据的处理,同时采用SDRAM器件对Picoblaze的存储能力进行扩展。所采用的设计已应用于多个产品中。经过了长期的使用和测试证明文中的设计方法稳定、可靠,并且具有资源占用少,设计灵活的优点。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1629

    文章

    21735

    浏览量

    603180
  • 嵌入式
    +关注

    关注

    5082

    文章

    19117

    浏览量

    304988
  • 微处理器
    +关注

    关注

    11

    文章

    2261

    浏览量

    82431
收藏 人收藏

    评论

    相关推荐

    USB_OTG_IPAMBA接口的设计与FPGA实现

    USB_OTG_IPAMBA接口的设计与FPGA实现
    发表于 08-06 11:40

    利用FPGA自带的IP核实现双口RAM用于2片MCU进行数据交换时多次读数据后RAM数据变为了0

    利用FPGA自带的IP核实现双口RAM用于2片MCU进行数据交换时多次读数据后RAM数据变为了0,是什么意思,打什么帮帮忙!!!!!!!!
    发表于 01-15 16:22

    开放核协议:IPSoC设计接口技术

    本文介绍了IP核的概念及其SoC设计的应用,讨论了为提高IP核的复用能力而采用的IP核与
    发表于 12-11 11:07

    采用IP核实现PCI总线接口设计

    消息。ICMP回复消息经常被用来调用ping程序测试对方主机是否在线。嵌入式TCP/IP协议栈,ICMP回送消息用一种十分简单的方式实现,即将ICMP类型的字段由echo类型改变为
    发表于 04-23 07:00

    采用IP核实现PCI总线接口设计

    嵌入式操作系统 和欣操作系统基于微内核,服务动态加载。内核包括硬件驱动(串口、USB、以太网卡、无线通信模块)、内存管理等系统基本服务,如图1所示。TCP/
    发表于 04-28 09:57

    求一种基于FPGASOC系统串口设计

    本文XILINX FPGA采用嵌入式处理器Picoblaze进行SOC设计,以较少的硬件资源实现了对
    发表于 04-29 06:22

    搭建一个SoC下载到FPGA开发板设计实现

    SoC下载到安路FPGA开发板,并编写简单的汇编代码,利用KeilSoC平台上进行调试运行。
    发表于 08-09 17:09

    测控系统中用IP 核实现D/A 转换

    采用数字化技术, 测控系统中用IP 核实现D/A 转换,并且1 片可编程逻辑器件
    发表于 04-16 08:51 11次下载

    测控系统中用IP核实现D/A转换

    采用数字化技术, 测控系统中用IP 核实现D/A 转换,并且1 片可编程逻辑器件
    发表于 05-15 15:09 12次下载

    基于FPGASOC系统串口设计

    基于FPGASOC 系统串口设计 作者:葛锐 欧钢摘要:本文XILINX
    发表于 02-08 09:48 21次下载

    开放核协议—IPSoC设计接口技术

    摘    要:本文介绍了IP核的概念及其SoC设计的应用,讨论了为提高IP核的复用能力而采用的
    发表于 06-07 11:11 671次阅读

    测控系统中用IP核实现D/A转换

    摘要:采用数字化技术、测控系统中用IP核实现D/A转换,并且1片可编程逻辑器件
    发表于 06-20 15:04 1021次阅读
    <b class='flag-5'>在</b>测控<b class='flag-5'>系统</b>中用<b class='flag-5'>IP</b><b class='flag-5'>核实现</b>D/A转换

    W5100FPGA系统实现TCP_IP网络通信

    介绍了W5100现场可编程门阵列(FPGA)系统实现TCP/IP网络通信的方法。描述了W51
    发表于 04-24 15:13 297次下载
    W5100<b class='flag-5'>在</b><b class='flag-5'>FPGA</b><b class='flag-5'>系统</b><b class='flag-5'>中</b><b class='flag-5'>实现</b>TCP_<b class='flag-5'>IP</b>网络通信

    IPSoC设计接口技术解析

    接口标准,因此,开发统一的IP接口标准对提高IP核的复用意义重大。本文简单介绍IP核概念,然后从接口
    发表于 11-06 11:30 0次下载
    <b class='flag-5'>IP</b>核<b class='flag-5'>在</b><b class='flag-5'>SoC</b>设计<b class='flag-5'>中</b>的<b class='flag-5'>接口</b>技术解析

    如何使用FPGA进行仿真系统数据采集控制器IP核设计的资料概述

    介绍了大型工业模拟仿真系统利用FPGA和软IP核实现
    发表于 11-07 11:14 20次下载
    如何使用<b class='flag-5'>FPGA</b>进行仿真<b class='flag-5'>系统</b>数据采集控制器<b class='flag-5'>IP</b>核设计的资料概述