如何实现基于ARM44B0x的信号发射机控制器设计

发布时间:2015-06-20 阅读量:846 来源: 我爱方案网 作者:

【导读】我爱方案网小编为大家介绍如何实现基于ARM44B0x的信号发射机控制器设计,采用嵌入式的32位微处理ARMS3C44B0x作为控制器的内核,设计的控制器将比用单片机作内核的处理器具有更全面的功能和更好的使用性能。

1.前言

船舶上使用的信号发射机是连续工作的,所以需要一个控制器对发射机的工作状态进行监控,常见的是用单片机作控制器的内核,但由于32位微处理器具有更好的精度和可靠性且低成本低功耗,所以在工业控制领域的应用日益广泛。

发射机控制器的主要功能是对多路模拟量和开关量的数据采集和处理监控发射机的工作状态;控制器控制发射机同时控制器又受上位机的控制,它要能在任意时刻准备好接收从上位机串口、网口发来的数据,它们之间的相对关系如图:

如何实现基于ARM44B0x的信号发射机控制器设计

图1 控制器系统结构图

上位机向控制器发送数据从而实现对控制器的控制,首先上位机送出机号,再送命令字;控制器也要向上位机上传数据完成通讯应答,它首先解析机号是否与自己的机号一致,若一致则再解析命令字,根据命令字来送出上传的数据完成应答;若不一致则不再作进一步的数据解析。它们的通讯方式有串口通讯和以太网通讯两种;控制器和发射机的数据传输主要有模拟量的采集和开关量的输入输出;另外,人机接口模块实现发射机工作过程中的参数的实时显示和参数修改和查询。实时采集的数据是由AD采样得到的,需要注意的是S3c44B0没有采样保持电路所以通道的切换频率不能超过100Hz,在ADC开启路时都需要一个延时,利用这段时间来对上一路进行滤波而提高程序的效率。整个采样的过程可以描述为开启当前通道,然后滤波上次采样的通道(中位值平均滤波法)。

2.开关机描述及软件设计

如何实现基于ARM44B0x的信号发射机控制器设计

图2 传口通讯流程图

项目的开发首先要完成开关机功能、人机接口功能模块、通讯模块的程序设计和调试,先讨论开关机的程序设计;用户要求控制器上键的功能是能编辑的即每一个键的功能不固定,可以通过PC机修改;开机时要按优先级顺序由高到低输出一系列的动作,每个动作都有可编辑的优先级(通过PC机编辑),一个动作输出后可能会引起其它同一优先级水平动作的发生,这就是动作的关联。在开当前优先级动作时必须要检测更高优先级动作的状态,遇到故障需要进行故障处理。针对上述的较复杂的需求设计如下数据结构:

如何实现基于ARM44B0x的信号发射机控制器设计

图3 开机流程

 typedef struct{

char *pName;//动作名称

char FunctionID; //动作(功能)编号

char Priority; //动作优先级

short KeepTime1; //等待前一个输出动 作稳定需要的时间

short DelayTime1;//下一动作执行前的延时

short DelayTime2;//当检测模拟量或开关量不正常时需要重复检测的延时

short RepeatNum;//有故障重新检测的次数

}OutputAction;

把所有的功能依次编号,把这个编号赋给某个键则该键就具备了该功能,功能的编辑通过修改OutputAction.FunctionID的值实现;每个键最多有16个功能,最少没有功能;在每一个键的所有功能都是轮循有效的,用一个循环链表来存放功能编号,始终是处于表头位置编号对应的功能有效,每个功能(动作)只能归属于一个键,在每次开机时首先由串口把已定义好的键功能送到控制器并烧写到固定位置的ROM中;动作优先级的编辑是通过修改结构体中OutputAction.Priority的值实现;开机时再从ROM中把这些数据读出来,若上位机没有进行键功能编辑就按默认形式进行,需要指出的是关机时,按和开机向反的顺序依次关闭所有的输出动作.

开机时根据固定位置ROM中的内容或按默认的定义获取动作的属性,①首先搜索优先级最高的动作编号,然后根据不同的延时把这些动作依次送出;②把优先级降一级,检测比当前优先级更高的所有的输入、输出的状态是否正常如果正常则送出当前优先级的动作,再重复②的过程,否则进入故障处理程序,如果处理故障成功则继续重复②的过程,否则关机并返回开机失败信息。开机流程图如图3所示。

在软件设计中的一个特色就是利用I/O端口来模拟IIC总线来读取键值,其总体思路是用两个端口一个模拟IIC的时钟信号,另一个模拟IIC的数据线。需要注意的是在配制I/O端口时,时钟线始对应的端口终是输出口而数据线端口是不确定的。通过给端口置位和清零结合延时来模拟IIC的数据传输协议。在调试的过程中发现,这种方法能很好的完成键值的获取和对CPLD器件的访问。

 

3.人机接口模块设计

要监控发射机工作状态就必须具备良好的人机接口,需要给控制器选配合适的显示设备,在本项目中选用7.8寸640×480象素STN型彩色液晶显示屏(LCD),采用8位数据单扫描方式,在实际应用中显示效果很好不仅成本低且美观大方,STN型LCD屏与44B0x的接口比较简单但需要注意的是第18引脚(Vcom)通过一个变阻器与电源相连,调整该引脚上的电压就可以调整LCD屏的对比度。软件设计中的关键是菜单的设计和按键响应及处理,由于本项目中的界面较多且存在翻屏所以宜设计一个统一处理的算法,为此,把每个界面统一编号WndID,把按键作为一个消息处理MessageFun();每次按一个键就调用MessageFun(),找到需要显示的界面并在LCD上显示。LCD翻屏的方法是每次记录显示的内容在整个菜单数组中的偏移,若当前行超过偏移就需要翻屏否则不翻屏。对于菜单的设计作如下处理:用一个结构体把一个菜单的属性完整地封装好,其属性包括菜单名称、坐标、参数标志、参数。

typedefstruct{

UINT8T Menu_ID;//菜单编号

UINT8T *Text; //菜单名称

UINT16T xPos; //菜单x坐标

UINT16T yPos; //菜单y坐标

UINT8T ParaFlag; //参数标志

UINT8T pData[7]; //参数

}Menu;

如何实现基于ARM44B0x的信号发射机控制器设计

图4 菜单显示

利用结构体将每一个菜单的属性都封装好再放到一个数组里面,这样对菜单的个数没有限制且容易管理,每一个菜单的信息都很清晰,编程不易出错。

人机界面操作的核心工作就是界面的切换、主菜单和子菜单操作。根据按键来确定对应的界面ID号,切换界面的方法通常有两种改变显存的内容和改变显存的基址,改变显存的基址就需要定义很大的显存,这样做的优点是利用硬件资源使LCD屏显示的刷新速度很高、界面切换快,缺点是很大地浪费了系统资源;若改变显存中的内容就需要用软件的方法来更新显存中的内容,这种方法的好处就是节约了系统资源,但是增加的软件设计的复杂度;本项目采用的就是更新显存内容的方法在实际的调试中发现能够很好地满足要求。关于主菜单和子菜单的操作设计了一种统一调度的算法,其思想是根据获取的按键信息来确定主菜单的ID号和子菜单的ID号,使用焦点标记当前菜单的ID号,由这两个ID号就可以确定相应的主、子菜单同时进入对应的功能处理程序。

4.以太网通信模块设计


在硬件设计时选择RTL8019AS网络控制芯片,它可以工作在8/16 位总线宽度下传输速度为10Mbps,遵循IEEE 802.3 协议。内部具有16KB SRAM集成了MAC收发缓冲区和物理层的功能,它用来接收和发送以太网的物理传输数据,当RTL8019AS收到网络数据包后,RTL8019AS内部的某些控制寄存器的状态就被改变,通过设置中断或者查询的方法来读取这些寄存器的状态判断数据是否收到;发送数据时,将数据放入到RTL8019AS内部数据缓冲区后,通过控制内部的寄存器,将缓冲区的网络数据发送到网络上去。该芯片有三种工作模式:跳线模式,即插即用模式,免跳线模式。在项目中网卡芯片RTL8019AS是在跳线模式下工作。对该芯片的驱动主要包括以下几个步骤:复位、初始化、收发数据。RTL8019的复位引脚RSTDRV是高电平有效,有效的保持时间宜大于800ns,且在由高到低切换后的100ms后才对芯片操作。在对芯片初始化之前需要预先分配好片内RAM中的空间即接收和发送缓存的大小,在把所有的设置参数在初始化的时候一起写入RTL8019的寄存器完成初始化。

项目开发调试的过程中有许多软件和硬件方面的困难,但是问题最后都是在不断地解决,如系统的了串口,LCD,AD采样,Flash操作的调试等工作以及控制器所要具备的人机交互功能的程序设计且需调试通过。把以太网模块加到工程中后,其物理层芯片的驱动程序需进一步调试,把TCP/IP协议加入模块,参照成功的案例,完成系统的调试任务。同时,本文具有以下创新点:

(1)开发应用32位微处理ARMS3C44B0x作为控制器的内核,使控制器比用单片机作内核的处理器具有更全面的功能和更好的使用性能。

(2)在菜单的设计中,用一个结构体把一个菜单的属性完整地封装好,其属性包括菜单名称、坐标、参数标志、参数。

(3)解决了该网卡芯片使RTL8019AS正常工作的问题,在对芯片初始化之前需要预先分配好片内RAM中的空间即接收和发送缓存的大小,在把所有的设置参数在初始化的时候一起写入RTL8019的寄存器完成初始化。

相关文章

DIY小功率FM调频发射机,制作自己的私人电台

克服多标准无线电基站发射机测试的挑战

支持"任意一代至4G"无线标准转换数字发射机方案
相关资讯
半导体产业升级战:三星电子新一代1c DRAM量产布局解析

在全球半导体产业加速迭代的背景下,三星电子日前披露了其第六代10纳米级DRAM(1c DRAM)的产能规划方案。根据产业研究机构TechInsights于2023年8月22日发布的行业简报,这家韩国科技巨头正在同步推进华城厂区和平泽P4基地的设备升级工作,预计将于2023年第四季度形成规模化量产能力。这项技术的突破不仅标志着存储芯片制程进入新纪元,更将直接影响下一代高带宽存储器(HBM4)的市场格局。

蓝牙信道探测技术落地:MOKO联手Nordic破解室内定位三大痛点

全球领先的物联网设备制造商MOKO SMART近期推出基于Nordic Semiconductor新一代nRF54L15 SoC的L03蓝牙6.0信标,标志着低功耗蓝牙(BLE)定位技术进入高精度、长续航的新阶段。该方案集成蓝牙信道探测(Channel Sounding)、多协议兼容性与超低功耗设计,覆盖室内外复杂场景,定位误差率较传统方案降低60%以上,同时续航能力突破10年,为智慧城市、工业4.0等场景提供基础设施支持。

财报季再现黑天鹅!ADI营收超预期为何股价暴跌5%?

半导体行业风向标企业亚德诺(ADI)最新财报引发市场深度博弈。尽管公司第三财季营收预期上修至27.5亿美元,显著超出市场共识,但受关税政策驱动的汽车电子产品需求透支风险显露,致使股价单日重挫5%。这一背离现象揭示了当前半导体产业面临的复杂生态:在供应链重构与政策扰动交织下,短期业绩爆发与长期可持续增长之间的矛盾日益凸显。

全球可穿戴腕带市场首季激增13%,生态服务成决胜关键

根据国际权威市场研究机构Canalys于5月23日发布的调研报告,2025年第一季度全球可穿戴腕带设备市场呈现显著增长态势,总出货量达到4660万台,较去年同期增长13%。这一数据表明,消费者对健康监测、运动管理及智能互联设备的需求持续升温,行业竞争格局亦同步加速重构。

RP2350 vs STM32H7:性能翻倍,成本减半的MCU革新之战

2025年5月23日,全球领先的半导体与电子元器件代理商贸泽电子(Mouser Electronics)宣布,正式开售Raspberry Pi新一代RP2350微控制器。作为RP2040的迭代升级产品,RP2350凭借双核异构架构(Arm Cortex-M33 + RISC-V)、硬件级安全防护及工业级性价比,重新定义了中高端嵌入式开发场景的技术边界。该芯片通过多架构动态切换、可编程I/O扩展及4MB片上存储等创新设计,解决了传统微控制器在实时响应能力、跨生态兼容性与安全成本矛盾上的核心痛点,为工业自动化、消费电子及边缘AI设备提供了更具竞争力的底层硬件方案。