1 硬件设计
系统主要包括指令处理部分和接口部分,如图1所示。指令处理部分完成协议转换以及通信处理;接口部分完成模拟到数字的转换、PROFIBUS-DP接口等。下面简单介绍主要模块的功能。
调试(JTAG):M16C/62P通用通信模块的设计提供一个JATG仿真器,它可以用来进行配置或者是编程。
SRAM模块:当编写比较大的程序(如操作系统)时,M16C的内部RAM可能不够用,此时就可以用外接的SRAM(128K×16位)。
拨码开关:拨码开关用于通信地址方案的实施。PROFIBUS-DP支持的站地址为0~126(共127个),同时为了防止寻址过程发生地址的冲突,所以采用一个8位的拨码开关,用后7位进行128位的寻址。阀门控制器作为PROFIBUS-DP通信的从站,必须有不与其他站冲突的地址。PR-OFIBUS-DP从站通信地址的设计方案有两种:一种是由远程的PROFIBUS-DP主站通过特定的数据通信设定或修改从站地址;另一种是禁止PROF-IBUS-DP主站设定和修改从站地址,从站的地址由从站本地设定。本设计采用的是后一种设计方案,通过一个8位的拨码开关手动设定阀门控制器的地址,然后由中央处理器读入并写入VPC3特定的存储位置。
A/D、D/A等模块:PROFIUBS-DP智能从站通信卡采用4~20 mA/1~5 V模拟信号传输方式,对4~20mA的输入信号(阀位反馈信号)进行校准和量程变换后,将其转换为DP总线输入数据,DP总线输出数据经过校准和量程变换后转换为1~5 V的输出信号(控制输出信号)。由于PROFIUBS-DP通信卡在工作过程中共有两个数据需要在DP总线上传输,因此需要两个数据通道,一个用于16位模拟量输入(A/D),另一个用于16位模拟量输出(D/A)。其中模拟与数字电路之间采用PC417进行光耦隔离。
本设计一共有两个时钟:一个是M16的时钟,M16本身有两个时钟(分别为主时钟和副时钟),但是由于VPC3的特殊性使得M16的时钟必须由VPC3提供;另一个是VPC3的时钟,直接由48 MHz的有源晶振提供。其中,M16的时钟是由VPC3对48 MHz的时钟进行1/4分频得到的12 MHz。
总线接口引脚如表1所列,VPC3的数据传输是在RS485模式下进行的。VPC3通过表1中的信号与光耦隔离驱动相连接。
按键复位:其作用是对M16和VPC3进行复位。该电路用于监视M16的核电压,当核电压低于3.3 V时,该电路产生一个低脉冲信号传送到M16的RESE(10)引脚。除了监视的功能以外,还可以通过按键的闭合来产生一个低脉冲的复位信号。
2 软件设计
对VPC3的软件操作主要包括两个部分:VPC3的初始化、主程序和VPC3的中断处理。主程序和中断处理流程分别如图2和图3所示。
VPC3的初始化程序应放在主程序的前面,而中断处理程序完成CPU对VPC3中断输出的响应。VPC3上电复位之后,在正常工作之前必须进行初始化,以配置各个寄存器。中断处理程序用于处理VPC3发生的各种事件,这些事件包括新的参数报文事件、全局控制命令报文事件、进入或退出数据交换状态事件、新的配置报文事件、新的地址设置报文事件、监测到波特率事件和看门狗溢出事件。
数据输入和输出处理(输入、输出相对于主站而言)及用户诊断数据输入可以放在应用程序主循环中。在一个应用循环申,由应用来刷新输入BUF中的数据,保障所有输入数据是最新的更新数据。而VPC3在接收到由PROFI-BUS-DP主站传送的不同输出数据时,会产生输出标志位(同样位于中断请求字单元中),CPU通过在应用循环中轮询该标志位来进行接收主站数据。对于特定应用的诊断信息,需要实时地传递到主站。主应用程序在应用循环中判断是否有可用的诊断BUF存在,当有空闲BUF时应用程序输入诊断信息,并请求更新。对于实时性要求严格的系统,应采用中断方式进行输出数据和诊断数据处理。
结语
VPC3芯片的使用方法简单(与SPC3相似),功能比较完善,可以满足本通信接口设计的要求。使用VPC3进行PROFIBUS-DP从站接口的开发,能够降低开发难度和开发成本;使用现场设备/仪表上配置PROFIBUS-DP接口,可以满足相关行业的需要。