版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
基于IntelSoCFPGA的光伏电力通信管理机系统设计0引言光伏发电站利用大量的光伏电池板完成从光能到直流电能的转换,再将直流电能使用逆变器转换为50Hz的交流电,输送到电网中。整个光伏电站中电能控制及转换设备需求量巨大。通信管理机作为电站中连接各个设备和电站中控台的设备,通过控制平台控制下行的Rtu设备,实现遥信、遥测、遥控等信息的采集,将消息反馈回调度中心,然后控制中心管理员通过对消息的处理分析,选择将执行的命令,达到远动输出调度命令的目标。目前广泛采用的通信管理机实现方案主要有3种:PowerPC处理器+串口扩展芯片架构、ARM处理器架构、ARM处理器+FPGA架构。其中:(1)PowerPC处理器+串口扩展芯片架构使用带通信协处理器的PowerPC处理器作为系统的核心,使用串口通信扩展芯片为PowerPC扩展出最多16个串口。所有数据处理和运算全部由PowerPC处理器完成,在所有串口全部使用的情况下,整个系统运行较为缓慢,数据的实时性难以保证。(2)使用单独ARM处理器作为核心实现的通信管理机结构简单,但是能够支持的串口数量受到ARM处理器本身集成的串口数量限制,一般都不超过6个,无法满足光伏电站中海量设备的需求。(3)ARM处理器+FPGA架构利用FPGA完成串口扩展,基于ARM处理器完成数据的处理和网络协议的实现,它本质上和基于PowerPC+串口扩展芯片的方案一致。该种方案增加了系统的复杂度,但单性能上提升并不明显。以上3种方案都存在的问题是系统有且仅有一个核心单元,一旦系统宕机,就不得不重启系统,在系统未恢复的情况下,整个系统与电站中心控制台处于完全断开的状态,无法接收中心控制台的控制指令。本文基于Intel全新的SoCFPGA芯片,将原本采用分立的FPGA和ARM处理器实现的系统使用单一的SoCFPGA芯片实现,并在FPGA上搭建了冗余监控系统。在提高系统性能的同时,保证了系统的在线可恢复性。1系统建模IntelCycloneVSoCFPGA芯片5CSEMA4U23C6芯片是一款在单一芯片上集成了高性能的双核ARMCortex-A9CPU和FPGA的SoC芯片,它是本系统的核心单元。在本系统中,SoCFPGA芯片上的FPGA部分主要负责UART接口的扩展以及MODBUS协议的加速。在电力系统中,几乎所有设备都支持标准的RS485接口,并使用MODBUS协议与其他设备进行通信。光伏电站中,因为设备多、数据量大,通信管理机的一个RS485端口在同一时刻只能和一台设备通信,因此导致数据传输速度出现瓶颈。为了解决这个问题,往往采用多个MODBUS网络端口来实现众多设备的管理[2]。众多电力设备的数据在被通信管理机采集之后最终需要通过以太网接口与电站的中控后台进行数据交互,该数据交互主要通过IEC104协议实现,而IEC104协议的实现是通过SoCFPGA中的硬件处理系统(HardProcessSystem,HPS)运行成熟的Linux操作系统来完成的。2硬件电路方案设计2.1SoCFPGA配置电路设计为了使系统支持远程在线升级,本系统设置SoCFPGA的FPGA部分接收HPS部分的配置数据。HPS部分可以接收串口或者网口传输的FPGA配置文件。运行时SoCFPGA的HPS部分先启动并运行Linux操作系统,Linux操作系统启动完毕之后进行FPGA部分的配置。如果需要远程更新FPGA的配置数据,只需要通过网口将新的FPGA配置内容传输到操作系统所管理的磁盘上替换原来的配置文件,则系统下一次启动时就可以使用新的配置文件来配置FPGA。2.2SoCFPGA启动电路设计SoCFPGA中的HPS部分运行Linux操作系统,HPS支持从SD卡、QSPIFlash、NANDFlash存储器中启动。NANDFlash和QSPIFlash存储器一般都采用焊接的方式安装在电路板上,而SD卡则是可拆卸并单独在PC上读写的。在工业现场,如果设备系统一旦损坏,需要重新烧录系统时,QSPIFlash和NANDFlash由于焊接在PCB板上,只能使用PC在线烧写,而SD卡则可以采用预先烧录好系统的SD卡进行更换,因此节省了现场维修的工作量。2.3RS485接口电路设计通信管理机作为一个工业设备,其通信接口可能承受各种冲击,包括强共模电压、高压静电、雷击等,因此通信接口的防护措施至关重要。在本系统中,使用RSM3485模块完成TTL电平到RS485电平的双向转换。RSM3485模块实现标准RS485接口,具有ESD保护、短路或断路失效保护功能,内置120kΩ上下拉电阻,双绞线输出,提供接触情况下±4kV和空气放电情况下±8kV的ESD放电功能,同时设计防雷电路,预防在雷击的情况下损坏通信接口,该接口电路图如图1所示。2.4以太网接口方案设计电力系统通信管理机都要求提供主备双网口,以保证在其中一个网口出现故障时,另一个网口能够继续传输必要数据。5CSEMA4U23C6芯片默认提供了两个千兆以太网MAC,但是这两个MAC都是由HPS部分管理的,为了保证网口的可靠性,即使在ARM部分系统宕机的情况下,备用网口也能正常工作,设计时仅使用一个MAC层,并由HPS驱动,另一个网口使用NIOSII软核控制集成的以太网通信芯片W5500实现。W5500芯片是一个全硬件实现的单芯片TCP/IP协议芯片,支持8个Socket端口,使用非常方便可靠。使用NIOSII控制W5500完成以太网传输,即使HPS工作异常,FPGA中的NIOSIICPU还可以继续通过W5500进行数据的收发,保证备用网口的稳定运行。3SoCFPGA应用架构设计由于SoCFPGA作为一种创新的架构,集成了FPGA和高性能HPS,因此在设计时,可以充分利用HPS强大的数据处理能力、FPGA侧灵活的定制特性以及HPS和FPGA之间高速通信桥,将各种工作根据其特性合理分配给FPGA或者HPS,通过两者协作,以实现最高的性能。FPGA侧主要实现UART通信接口的扩展和基于NIOSII处理器的备用系统。HPS端主要实现大量数据处理和通信规约之间的转换。图2为SoCFPGA上的功能划分框图。3.1FPGA逻辑设计FPGA侧逻辑部分实现16个支持MODBUS帧自动识别的UART通信控制单元,如图3所示。每个单元由CRC校验逻辑、串口数据收发缓存、核心控制状态机和MODBUS帧识别逻辑组成。各单元在核心控制状态机的控制下自动完成MODBUS数据帧的收发和数据校验码的生成,并经由AvalonMMSlave接口与HPS传输MODBUS接收和需要发送的数据。图4为支持MODBUS帧自动识别的增强型UART通信控制单元接收数据时的工作状态转移图。整个状态机由空闲状态(IDLE)、接收数据状态(GET_DATA)、接收超时状态(TIMEOUT)、接收字节数据完成状态(GET_BYTE)、帧传输完成状态(FRAME_DONE)组成。当主机发出MODBUS请求帧后,本模块进入接收数据状态(GET_DATA),每接收到一个字节,就跳转进入接收字节完成状态(GET_BYTE),当帧结束判定信号有效时,表明一帧数据接收完成,此时进入帧接收完成状态。通过比对接收到的数据帧中CRC数据字段和FPGA中CRC校验单元对该帧产生的校验数据,确定当前帧是否正确。然后通过FPGA与HPS互联桥向HPS发出中断请求,并报告当前帧的校验结果,HPS侧的Linux驱动程序则会根据校验结果完成相应的处理,如果校验正确,则读取该帧数据并递交给上层MODBUS协议层进行进一步解析处理,如果该帧错误,则丢弃该帧,并进入错误处理程序。3.2Linux软件设计SoCFPGA芯片中的HPS运行Linux操作系统,在Linux系统上运行通信管理机的应用程序。该应用程序主要包括三大部分,分别为MODBUS协议主站、IEC104协议从站、MODBUS和IEC104协议间规约转换程序。其中,MODBUS协议主站运行开源的Libmodbus协议栈,完成MODBUS指令和数据的收发。Libmodbus协议栈是一个免费开源的MODBUS协议栈,支持MODBUS协议主站和从站功能。由于本系统在FPGA侧使用硬件逻辑电路已经实现了MODBUS协议的部分功能,如帧结束判定、CRC校验等。因此,对Libmodbus协议栈进行了一定的删减优化,去掉了底层数据帧接收和校验的部分,仅使用其指令和数据解析部分,这也是本系统的优势,通过FPGA侧硬件实现MODBUS协议底层内容,降低了处理器的工作量,使得处理器能够轻松完成对多达16个基于MODBUS协议的端口的支持。为了方便实现对FPGA侧的16端口个MODBUS加速器的控制,在Linux侧单独开设一个进程用于16端口MODBUS加速器的控制,当该任务被调度并得到执行机会后,开始依次查询当前端口的状态,然后根据得到的端口状态执行相应的处理代码。该程序流程如图5所示。空闲态:当查询到一个端口的状态为空闲时,表明此端口已经正确地完成了一轮数据收发,在新的通信命令到来之前,该端口将处于空闲状态,即不需要发送数据,也不需要接收数据,MODBUS端口是处于空闲状态的。接收成功:当查询到某个端口成功接收到返回的数据后,则开始进行接收数据的处理工作,完成之后,进入下一个端口的状态查询工作。接收超时:当查询到某个端口在设定的响应时间内无响应时,则返回接收超时状态。若检测到超时状态,系统开始进行超时处理工作。接收超时处理完成后,进入下一个端口的状态查询工作。接收错误:当查询到某个端口接收数据出错时,则进行接收错误处理工作。当接收错误处理完成后,进入下一个端口的状态查询工作。该部分任务代码框架如下所示:for(i=0;i《=15;i++){port_state=mdp_state_read(port_num);//读取指定端口状态switch(port_state){caseNO_STATE:break;//无就绪端口caseRX_DONE://接收数据成功…//接收到数据处理代码模块break;caseRX_TIMEOUT://接收超时…//接收超时端口处理代码模块break;caseRX_ERROR://接收错误…//接收错误端口处理代码模块break;default:printf(“default%d\n\n”,port_num);//默认为读错误处理,将状态寄存器设置为错误标志FPGA_WR16((port_num《《8|128),1);}//读到第16个端口后,回到0号口读取if(port_num==15)port_num=0;elseport_num++;//端口号自加1}usleep(30000);//释放CPU权限3.3NIOSII备用系统软件设计通常状态下NIOSIICPU处于待机状态,若NIOSIICPU在设定的时间内没有接收到状态消息,则表明HPS系统侧软件系统崩溃,NIOSIICPU再通过和HPS互联的状态指示信号确认当前是操作系统宕机或应用程序异常。如果是应用程序异常,则触发Linux侧安全监视软件重启应用程序;如果是操作系统异常,则启动备用网口上报当前系统故障信息到电站中心控制台,并通过硬件复位来重启HPS。图6为NIOSII备用系统的程序流程图。4系统性能分析表1为以16个RS485端口,每个端口每500ms完成一次对总线上设备的数据读取,每次通信数据帧长度平均为64B为例,分析1s内本系统方案(简称SoCFPGA方案)和PowerPC+串口扩展芯片ST16C2550方案(简称PowerPC方案)在串口芯片数量、CPU的CRC运算事务、CP
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年中国无骨型雨刮器市场调查研究报告
- 2024年江西省德胜企业集团公司职工医院高层次卫技人才招聘笔试历年参考题库频考点附带答案
- 2024年中国揩布拖把布市场调查研究报告
- 2024年中国指天椒市场调查研究报告
- 《新型交联透明质酸颗粒的制备及其性能研究》
- 《我国行政规范性文件法律监督制度研究》
- 2025年学校学生资助与奖学金发放合同3篇
- 2024年中国平面度测量仪市场调查研究报告
- 2024年中国帽子二件套市场调查研究报告
- 2024至2030年硝铵项目投资价值分析报告
- 诉讼费退费确认表
- 全球变暖视野下中国与墨西哥的能源现状分析
- 建筑结构荷载统计计算表格(自动版)
- 学前教育学课程思政建设
- 事故隐患报告和举报奖励制度
- 腹部外伤门诊病历
- 品质异常处理及要求培训
- 模具部年终总结--ppt课件
- 立式热虹吸再沸器机械设计说明书
- 国家开放大学电大《生产与运作管理》2025-2026期末试题及答案
- 质量保证大纲(共14页)
评论
0/150
提交评论