欢迎来到天天文库
浏览记录
ID:14409912
大小:224.84 KB
页数:7页
时间:2018-07-28
《fpga与arm的遥测数据网络化采集》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、FPGA与ARM的遥测数据网络化采集对于20Mb/s以下的码速率,100Mb/s的网卡可以进行不丢包转发,采用TCP包格式还可使设备小型化,便于数据的转发,因此有必要扩展设备功能。一、整体模块设计系统设计系统设计框图如图所示。其中,采编器或接收机解调输出的PCM信号及时钟输入到FPGA中进行帧同步,IRIG—B码信息也送到FPGA中进行解调,得到时间信息。数据与时间一起存入SRAM乒乓缓冲区中,达到一定大小后,FPGA向ARM处理器发器中断,ARM中运行的Linux系统,将数据取走,进行TCP/IP打包,发送给接收计算机。系统框图在设备开始工作前,需
2、要在计算机端进行参数设置,计算机TCP/IP包将参数发送给ARM处理器,由ARM处理器转发给FPGA。帧同步器的设计中,码速率为100b/s~10Mb/s,帧长为4~4096Word,帧同步码组为4~32,ARM网卡为100Mb/s。硬件实现PCB采用6层结构,相邻布线层,水平垂直交叉,电路层与电源层单独分开,提供良好的电磁兼容特性。FPGA——FPGA选择EP1C12,为实现乒乓缓冲结构,采用SRAM为IS61LV25616。输入信号使用SMA线缆连接,在传输过程中会引入衰减,信号输入输出易出现阻抗不匹配的情况,选用AD8556构成射随器,对输入信
3、号进行匹配,同时也增大模拟源的输出能力。ARM——采用S3C2440,内核为ARM920T,最高频率为400MHz,带MMU支持操作系统。内存采用2×32MB的SDRAM,存储采用128MBNANDFLASH,网卡采用DM9000A。ARM与FPGA的接口连接——这里采用总线接口,将FPGA作为一个存储设备挂在ARM的存储器总线上,如下图所示。FPGA在ARM中起始地址为0x18000000,以4B对齐,占用0x80个地址,地址范围为0x18000000~Ox1800007C,中断为EINT0。在FPGA内部采用读/写指针来模拟FIFO,用一个地址来
4、读取FPGA数据,其余地址用于配置帧同步器与模拟源的参数。二、帧同步与B码解调FPGA完成PCM数据的帧同步和解调B码,写入到乒乓SRAM缓冲区中,实现如图所示。1帧同步模块帧同步器根据帧同步码组的相关性和周期性,经过相关运算将同步码从PCM串行流中识别出来,原理框图如图4所示。帧同步原理PCM数据按时钟进行串/并转换,与本地帧同步码进行同或运算后再与上屏蔽位,由全加网络将相关运算结果按位相加统计结果中1的个数,大于门限值则表示可能接收到了帧同步码。为避免虚警和漏检,使帧同步器稳定可靠工作,采用搜索、校核、锁定三态逻辑。系统开始时处于搜索态,符合相关
5、器输出,由搜索态转入校核态。在预期检测窗口内没有帧码,从校核返回到搜索态。连续通过校核数α,进入锁定态。为避免帧同步码的漏检,连续漏检超过保护帧数β,帧同步才返回搜索态,否则保持在锁定态,帧脉冲由本地产生。2IRIG—B码解调IRIG时间序列码是一种串行码,共有3种码元,如图所示。P码元是位置码元,连续2个P码为一帧的开始,第1个P码元定义为P0,第2个P码元为秒脉冲pps,上升沿为该秒的准时刻,时间信息以BCD码依次分布在其后的码元中。解调时先进行pps的提取,再进行秒、分、时、天的信息提取,其流程如下图所示。时钟频率为1MHz,用计数器对输入信号
6、的脉宽进行计数。8ms,5ms,2ms脉宽计数为8000,5000,2000。输入B码的脉宽会混有干扰,晶振时钟也存在一定的误差,计数器的计时判别应浮动一个范围,设置门限为脉宽的85%~115%,当满足一定范围的数值时,分别输出P码,0码,1码信号。FPGA中的时码产生“天:时:分:秒:毫秒:微秒”信息。解调出B码时,FPGA更新内部时间,B码中不含毫秒与微秒信息,由FPGA根据秒脉冲信息的准时刻来生成。三、FPGA驱动程序开发在Linux中,所有的硬件设备都像常规文件一样进行打开、关闭和读/写。把FPGA当作字符设备进行设计,驱动由设备加载与卸载,
7、以及文件操作file_operation结构体中成员函数组成。1加载与卸栽设备驱动FPGA设备驱动程序初始化流程为动态获得主设备号、字符设备注册和申请中断;卸载流程为注销设备,释放设备编号。定义一个设备结构体来表示FPGA,如下:当用户程序读FPGA设备时,数据还未准备好,此时驱动程序应该阻塞该进程,将其置入睡眠状态直到条件满足。此时需要初始化一个等待队列头,对读进程的休眠和唤醒时使用:在卸载函数中,删除一个cdev,完成字符设备的注销,然后释放设备编号:2文件接口操作Linux为所有的设备文件都提供了统一的操作函数,FPGA设备驱动。file_op
8、erations包含打开函fpga_open、读函数fpga_read、设置参数函数fpga_ioctl和关
此文档下载收益归作者所有