基于FPGA的Picoblaze核实现Modbus通信协议

发布者:电子设计艺术家最新更新时间:2012-04-10 来源: 电子元器件应用 关键字:FPGA  Picoblaze核  Modbus通信协议 手机看文章 扫描二维码
随时随地手机看文章

0 引言

目前,从各大FPGA厂商公布的销售数据来看,Xilinx的FPGA市场份额占到了近50%。Spartan-3E系列的器件密度范围为10万到160万系统门,其单位逻辑单元的成本是FPGA行业中最低的,能够以标准产品价格实现微处理器、微控制器和数字信号处理器的功能,并可支持18种通用I/O标准,还可通过ISE来操作PicoBlaze软核。Spartan-3E同时结合了强大的平台FPGA功能和超低价位。因而可使更多的设计人员享受可编程能力所带来的益处。

1 Picoblaze核结构

本文采用Xilinx公司的Spartan-3E评估板及其PicoBlaze IP核来进行基于Modbus通信协议的系统设计。该系统的整体结构是以PC做为上位机,并在评估板上嵌入Picoblaze软核作为下位机,从而实现Modbus通信协议。PicoBlaze是Xilinx公司的一款8bit微控制器软核,它非常之小。可以嵌入到Cool RunnerⅡ,Virtex-E,Virtex-II(Pro)和Spartan-3E的CPLD以及FPGA中。对于整个指令集,PicoBlaze执行一条指令需要2个时钟周期。

在对PicoBlaze进行开发时,首先需要将PicoBlaze认识并执行的程序经过Assembler转换成相应的HDL文件并存放在FPGA内部的Block Memory中(因此,PicoBlaze执行一条指令所需的时钟周期是固定的)。然后,微控制器核心KCPSM3再从Block Memory里面读取程序并按顺序执行。PicoBlaze的存储空间为1024x18bit,也就是说,它能够存放1024条位长为18的指令。而PicoBlaze支持的指令集也很精简(只有57条),其中包含程序控制类(跳转,调用,返回)、算数类(加,减,比较)、逻辑类(与,或,异或)、中断类(中断开启/关闭),移位/旋转类(左移/右移,左旋/右旋)和输入/输出类(输入,输出)。PicoBlaze核的结构框架如图1所示。

基于FPGA的Picoblaze核实现Modbus通信协议

图2是微控制器核心KCPSM3的结构框架图。KCPSM3中一共有16个长度为8位的通用寄存器,每个寄存器都可以在汇编代码中分别命名。其中,Scratch Pad Memory的大小为64 Bytes,作用相当于一块临时存储区。KCPSM3只支持1个中断信号,但实际上可以将多个中断信号用逻辑组合的方式变成一个来使用(会降低单中断通道的性能)。

基于FPGA的Picoblaze核实现Modbus通信协议 [page]

2 Modbus协议

2.1 Modbus协议简介

Modbus协议是应用于电子控制器上的一种通用语言。通过此协议,控制器相互之间、控制器经由网络(例如以太网)和其它设备之间可以实现通信。标准的Modbus接口使用RS-232C兼容串行接口,控制器通信使用主从技术,它仅有一个设备(主设备)能初始化传输(查询)。其他设备(从设备)则根据主设备查询提供的数据作出相应反应。

2.2 串行传输模式

在标准Modbus上,控制器可使用ASCII或RTU通讯模式来进行通讯。在本设计采用的是RTU模式。当控制器以RTU模式在Modbus总线上进行通讯时,信息中的每8位字节可分成2个4位16进制的字符,该模式的主要优点是在相同波特率下,其传输的字符密度高于ASCII模式,但每个信息必须连续传输。其RTU模式的数据传输格式如表1所列。

基于FPGA的Picoblaze核实现Modbus通信协议

在RTU模式中,每个字节格式的编码系统可以为8位二进制、十六进制0~9和A~F。其数据位包括1位起始位,8位数据(低位先送)、奇/偶校验时1位/无奇偶校验时0位、带校验时1位停止位/无校验时2位停止位。本系统的错误校验采用循环冗余校验(CRC)。

2.3 Modbus的信息帧

无论是ASCII模式还是RTU模式,Modbus信息都以帧的方式传输,每帧有确定的起始点和结束点。表2所列即为RTU模式时的消息帧格式。
使用时,接收设备在信息的起点开始读地址,并确定要寻址的设备(广播时对全部设备)以及信息传输的结束时间。也可以检测部分信息,有错误也可作为一种结果设定。本文使用的是RTU消息帧。

在RTU模式中,信息开始至少需要3.5个字符的静止时间。依据使用的波特率,很容易计算这个静止的时间(如表2中的T1-T2-T3-T4)。之后,第一个区的数据即为设备地址。各个区允许发送的字符均为16进制的0—9,A—F。

基于FPGA的Picoblaze核实现Modbus通信协议

网络上的设备可连续监测网络上的信息,包括静止时间等。当接收到第一个地址数据时,每台设备都立即对它解码,以决定是否是自己的地址。发送完最后一个字符号后,也将有一个3.5个字符的静止时间,然后才能发送一个新的信息。

整个信息必须连续发送。如果在发送帧信息期间出现大于1.5个字符的静止时间,则接收设备将刷新不完整的信息,并假设下一个地址数据。

同样,若在一个信息后立即发送一个新信息(若无3.5个字符的静止时间),将会产生一个错误。这是因为合并信息的CRC校验码无效而产生的错误。

RTU方式时,可采用CRC方法计算错误校验码,即用CRC校验传送的全部数据。它会忽略信息中单个字符数据的奇偶校验方法。

2.4 错误检测方法

标准的Modbus串行网络采用奇偶校验和帧检测两种错误检测方法,其中奇偶校验对每个字符都可用,而帧检测(LRC或CRC)则应用于整个消息。由于本文采用RTU模式进行数据传输,故使用CRC校验方法,它可校验传送的全部数据。其具体实现方法如下:

CRC码为2个字节/16位的二进制值。通常由发送设备计算CRC值,并把它附到信息中去;接收设备则在接收信息过程中再次计算CRC值并与CRC的实际值进行比较。若二者不一致,则产生一个错误。校验开始时,先把16位寄存器的各位都置为“1”,然后把信息中的相邻2个8位字节数据放到当前寄存器中处理。一般只有每个字符的8位数据用于CRC处理,而起始位、停止位和校验位不参与CRC计算。

CRC校验时,每个8位数据先与该寄存器的内容进行异或运算,然后向最低有效位(LSB)方向移位,当用零填入最高有效位(MSB)后,再对LSB检查,若LSB=1,则寄存器与预置的固定值进行异或,若LSB=0,则不作异或运算。

之后,重复上述处理过程,直至移位8次。最后一次(第8次)移位后,下一个8位字节数据再与寄存器的当前值进行异或,然后再重复上述过程。全部处理完信息中的数据字节后,最终得到的寄存器值即为CRC值。

CRC值附加到信息时,低位在先,高位在后。CRC生成的多项式是:。

2.5 功能选择

本文选择03读保持寄存器和06预置单个寄存器来进行重点介绍。

(1)03读保持寄存器

查询信息时,寄存器寻址起始地址为0000,寄存器1~16所对应的地址分别为0~15。

响应信息中的寄存器数据为二进制数据,每个寄存器分别对应2个字节,第一个字节为高位值数据,第二个字节为低位数据。表3所列是03读保持寄存器的功能举例。

基于FPGA的Picoblaze核实现Modbus通信协议

[page]

(2) 06预置单个寄存器

该寄存器在查询信息时,寄存器寻址起始地址为0,寄存器1所对应的地址为0。请求的预置值位于查询数据区。寄存器内容被预置后,返回正常响应。表4所列是06预置单个寄存器的功能举例。

基于FPGA的Picoblaze核实现Modbus通信协议

3 程序设计

首先,程序设计时要明确所实现的Modbus协议的功能,并且要确定传输模式和错误校验方法。本文主要是实现Modbus协议中的03读保持寄存器和06预置单个寄存器的功能,并选用RTU模式进行通讯,使用的是CRC错误校验方法。

其次,要熟悉Picoblaze核的结构、编程方法及指令集,同时确定要使用的寄存器编号和I\O接口,文本的编辑器中使用汇编指令编写程序,并以.psm格式保存。

然后,要使用Kcpsm3进行编译综合并将已经编写好的程序(.psm)转换成.vhd格式。具体操作时,首先要将程序(.psm文件)保存到Kcpsm3文件夹下面的Assembler文件夹下,然后设置一个.txt文件,以用来保存编译后的结果(如result.txt)。这样,打开result.txt文件就可以在最下面发现程序是否出错,如果出错,系统应提示相关错误;如果程序无误,则会显示success。这样,就可以在Dos环境下使用Kcpsm3编译器。图3所示是本系统的软件程序流程图。图4给出了其相关命令图。

基于FPGA的Picoblaze核实现Modbus通信协议

基于FPGA的Picoblaze核实现Modbus通信协议

接下来,便可使用ISE下载综合,以将刚生成的.VHD文件添加到工程中。然后再生成工程文件,这样,等运行结束后,就可以下载程序了。

最后,可以通过一个安装好的Modbus上位机程序Modbus Poll来检测数据传输的正确性,再选择要实现的功能、地址和寄存器,并写入数据,之后便可选择发送,其发送后的结果如图5所示。一切就绪后,便可将数据写到相应的地址。

基于FPGA的Picoblaze核实现Modbus通信协议

4 结束语

本文研究了工业上常用的Modbus通讯协议的基本通信方式,并基于Xilinx Spartan-3E FPGA的Picoblaze软核实现了RTU模式的Modbus通信协议。实验证明,该方式的收、发双方通信良好,可以达到预计效果。从而证明,该设计方法具有一定的实用性。

关键字:FPGA  Picoblaze核  Modbus通信协议 引用地址:基于FPGA的Picoblaze核实现Modbus通信协议

上一篇:单片机系统的常用输入/输出电路设计
下一篇:一种基于单片机的RGB LED背光源的设计方案

推荐阅读最新更新时间:2024-03-16 12:57

中芯国际FPGA产品线又迎新客户,与Efinix首推产品2018年投产
   中芯国际 与Efinix,可编程产品平台及技术的创新企业,今日共同宣布, 中芯国际 40纳米工艺平台成功交付Efinix首批QuantumTM可编程加速器产品样本。从使用 中芯国际 物理设计工具(PDK)进行产品开发,到系统生效交付产品样本,双方仅用了不到六个月时间,以破纪录的效率创造了这一重要里程碑。预计QuantumTM 加速器产品将在 2018 年投入生产,面向大规模的可编程加速器市场。下面就随嵌入式小编一起来了解一下相关内容吧。   “这是Efinix第一次与中芯国际合作,他们的鼎力支持给我们留下了深刻印象。中芯国际与我们的商业和技术合作,有力地帮助我们创建了成功开发产品的重要基石。”Efinix联合创始人、首席执
[嵌入式]
基于FPGA的工控领域监控系统设计
摘要:给出了两路输入信号AD转换器AD7705与FPGA的接口应用方案,利用该方案可对工控领域后台的温度和电压两路信号进行实时监控。其中温度信号是利用PT电阻值随温度变化的线性关系将温度信号转换为电压信号,来实施采集。 关键字:PT电阻;SPI接口;AD7705 O 引言     整机在工作时,大概有4%的能量被各种电力电子器件所消耗,这些被消耗的能量以热量的形式分别在单个模块中通过散热器散发出去。 针对以上的现象,可用PTl00铂电阻温度传感器在散热器表面感应温度,以保护电力电子器件不因为在高温下运行而损坏。金属铂(Pt)的电阻值随温度变化而变化,并且具有很好的重现性和稳定性,利用铂的此种物理特性制成的传感器称为铂电阻温度传
[电源管理]
基于<font color='red'>FPGA</font>的工控领域监控系统设计
赛灵思发布世界最大容量 FPGA,晶体管数纪录翻一番
赛灵思公司 (Xilinx, Inc. (NASDAQ:XLNX) )今天宣布推出首批 Virtex?-7 2000T FPGA,这是利用68 亿个晶体管打造的世界容量最大的可编程逻辑器件,为客户提供了无与伦比的200 万个逻辑单元,相当于 2,000 万个 ASIC 门,专门针对系统集成、ASIC 替代以及 ASIC 原型和模拟仿真的市场需求。堆叠硅片互联 (SSI) 技术的应用成就了赛灵思大容量FPGA,而2.5D IC堆叠技术的率先应用, 使得赛灵思能够为客户提供两倍于同类竞争产品的容量并超越摩尔定律的发展速度。 而这是单硅片FPGA在 28nm工艺节点所根本无法实现的。客户利用赛灵思 Virtex-7 2000T FPGA可
[嵌入式]
三重播放业务将成为未来10年驱动半导体行业发展创新的主要动力
语音、数据和多媒体技术的数字融合趋势推动了 IC 设计行业的快速发展。对 三重播放业务 的部署将成为未来5-10年驱动 半导体 行业发展创新的主要动力。这一市场需求对于功耗、性能和成本提出了巨大的挑战,使得可编程解决方案成为替代ASIC和ASSP的颇具吸引力的解决方案。 PLD 行业将会继续遵循摩尔定律向前发展,并为我们的客户带来巨大的优势。在性能提升方面,传统的处理器架构已经显现出发展疲势,而FPGA的发展前景仍然欣欣向荣。 随着全球无线基础设施持续从原有标准迁移到TD-SCDMA和长期演化(LTE)技术,半导体行业总体上呈现增长趋势。这一应用需要极高性能的数据处理和DSP能力,这是高性能FPGA的理想应用之一。对于
[应用]
FPGA与PCB板焊接连接的实时失效检测
  81%的电子系统中在使用FPGA,包括很多商用产品和国防产品,并且多数FPGA使用的是BGA封装形式。BGA封装形式的特点是焊接球小和焊接球的直径小。当FGPA被焊在PCB板上时,容易造成焊接连接失效。焊接连接失效可以“致命“一词来形容。当焊接球将封装有FPGA的器件连接到PCB上时,如果没有早期检测,由焊接失效引起的电性异常可能会导致关键设备的灾难性故障。为了防止关键设备由于焊接问题引起的灾难性故障,美国锐拓集团公司(Ridgetop-Group)开发了SJ-BIST解决方案。作为一系列的故障预测产品中的一员,SJ-BIST对工作中的FPGA的焊接失效提供了实时检测手段。   焊接点故障失效经常发生在FGPA,在所有类型
[测试测量]
LATTICE推出低成本PCI-E开发工具套件
Lattice新推出一款用于其低成本Lattice ECP2M系列90nm FPGA的低成本PCI Express开发工具套件,该开发工具套件的推出将加速采用Lattice ECP2M系列FPGA的PCI Express设计。通过采用新的PCI Express x1/x4评估板,该开发套件可加速对Lattice PCI Express技术的评估和对一系列匹配典型应用要求的解决方案进行验证,从而加速开发进度 。 此次新推出的工具套件具有四个针对快速评估和高速、低成本PCI Express系统设计的核心功能。首先,该工具套件可使用户在三十分钟或更短时间内构架好PCI Express硬件。其次,可满足不同情况下对控制面板和
[嵌入式]
基于单片机和FPGA的频率特性测试仪的设计
   1 引言   频率特性是网络的性能最直观反映。频率特性测试仪是测量网络的幅频特性和相频特性,并显示相应曲线的一种快速、方便、动态、直观的测量仪器,可广泛应用于电子工程领域。   该测试仪以扫频外差为基本原理,并以单片机和FPGA构成的最小系统为控制核心,很好地完成对有源双T网络进行频率在100 Hz~100 kHz范围内的幅频响应和相频响应特性的测试,并实现在通用数字示波器上同时显示幅频和相频响应特性曲线。    2 系统设计方案   2.1 总体方案   该设计采用单片机和FPGA结合的方式。将输出频率可步进的正弦信号的扫描信号源作为被测网络的输入信号Vi,则被测网络的输出信号Vo为频率可步进的信号。通过测量各
[单片机]
AMD推出16nm的第六代Spartan UltraScale+:功耗骤降60%
从1998年到现在,AMD Spartan系列FPGA已经帮助我们解决了很多医疗问题,探索其他星球,甚至是了解宇宙。作为一个服役25年的知名产品,它也需要跟上时代的脚步,进一步升级。 日前,AMD推出全新的Spartan UltraScale+系列,作为第六代Spartan FPGA产品,它依然延续Spartan的低成本、低功耗优势。 提升生命周期 的秘诀 事实上,观察AMD此前产品线可以看出,Virtex、Kintex、Artix、Zynq均已推出Ultra Scale+产品系列,并迈入16nm阶段。 为了增加使用生命周期,首先考量的就是选择对相关的制程工艺,同时要有适配的供应商一起在长时间周期里去交付产
[嵌入式]
AMD推出16nm的第六代Spartan UltraScale+:功耗骤降60%
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
  • ARM裸机篇--按键中断
    先看看GPOI的输入实验:按键电路图:GPF1管教的功能:EINT1要使用GPF1作为EINT1的功能时,只要将GPFCON的3:2位配置成10就可以了!GPF1先配 ...
  • 网上下的--ARM入门笔记
    简单的介绍打今天起菜鸟的ARM笔记算是开张了,也算给我的这些笔记找个存的地方。为什么要发布出来?也许是大家感兴趣的,其实这些笔记之所 ...
  • 学习ARM开发(23)
    三个任务准备与运行结果下来看看创建任务和任运的栈空间怎么样的,以及运行输出。Made in china by UCSDN(caijunsheng)Lichee 1 0 0 ...
  • 学习ARM开发(22)
    关闭中断与打开中断中断是一种高效的对话机制,但有时并不想程序运行的过程中中断运行,比如正在打印东西,但程序突然中断了,又让另外一个 ...
  • 学习ARM开发(21)
    先要声明任务指针,因为后面需要使用。 任务指针 volatile TASK_TCB* volatile g_pCurrentTask = NULL;volatile TASK_TCB* vol ...
  • 学习ARM开发(20)
  • 学习ARM开发(19)
  • 学习ARM开发(14)
  • 学习ARM开发(15)
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved