当前位置:首页 > 单片机 > 单片机
[导读]在某控制信号处理系统中,选用ADSP-BF561作为主控机,外接键盘,LCD显示屏,标准RS232接口,实时时钟等,通过DSP编程来实现对各个功能模块的控制,同时产生多路的数字IO信号。

    在某控制信号处理系统中,选用ADSP-BF561作为主控机,外接键盘,LCD显示屏,标准RS232接口,实时时钟等,通过DSP编程来实现对各个功能模块的控制,同时产生多路的数字IO信号。该控制系统还包括电源、时钟、CPLD、FLASH,JTAG调试器、复位电路等基本组成部分,系统框图如图1所示。

                  图1 基于ADSP-BF561的控制信号处理系统框图

    系统电源模块选用TPS54350来实现,外围电路不同的RC值,可以构成不同的输出电压,这里需要产生的是5V、3.3V、1.25V三种电压。时钟电路由48MHz的晶振电路来实现,其输出作为DSP的外围时钟和CPLD的时钟。FLASH用于存储用户的应用程序,JTAG调试口在DSP电路设计中也是必不可少的。后面对各个部分一一介绍,特别是对复位电路,数字IO信号的产生,以及RS232接口进行详细的介绍。

1. 键盘

    键盘选用的是4×4的扫描键盘,如图1所示,由Blackfin的GPIO接口PF5~PF12来实现。其中,KEY_GP3~KEY_GP0为行线输入端,初始化为带上拉电阻的输入口,中断使能(下降沿触发);KEY_GP7~KEY_GP4为列线输出端,初始化为输出低电平。键盘扫描方法同常规的扫描键盘方法相同。

          
                         图 1   扫描键盘结构图

2. LCD显示屏

    LCD显示屏采用320x240的LCD液晶模块。320x240液晶模块配用sed1335驱动接口板,sed1335驱动接口板上配用32K的RAM。LCD除了读写信号线由Blackfin的读写信号来控制以外, 8位数据线由Blackfin的低8位数据线锁存输出,以及其使能信号由Blackfin的AMS3控制,LCD地址分配为0x2C000000。电路连接如图2所示。在对LCD进行控制时,除了要建立在LCD上显示的汉字和英文的字库以外,还要编写对sed1335的底层驱动程序。这可以在LCD自带的驱动程序的基础上,进行代码移植,把它改写成适合BF561的DSP程序。  

              
                           图 2  LCD连接示意图 

3.实时时钟

    控制系统的实时时钟选用了芯片DS1337来实现。DS1337是一个低功耗的串行实时时钟芯片,它有24h/12h制两种模式,它可以输出年、月、日、分、时、秒的形式。它采用I2C协议,Blackfin的PF0和PF1作为I2C的CLK和DATA,而PF3作为实时时钟的中断FLAG,其电路连接示意图如图3所示。

         
                     图3  实时时钟电路连接示意图

4.复位电路

    为了保证DSP在上电或按下复位键时能可靠的复位,一般加一个复位延时电路,选用MAX708S来完成,如图4所示。 

 
                

                               图4 复位电路

    在上电过程中,RESET信号会在VCC达到稳定电压后的一段时间内(约200ms)保持为高,然后再变低。 信号为RESET的“NOT”,即 会相对VCC延时一段时间后再变高,如图5所示。这样,在DSP的各电源电压已稳定的情况下,DSP的复位信号仍为低有效,就可以保证DSP的正常复位。
           
                        图5 上电过程中的 信号

    在上电以后,如果手动按下开关,使得MR上的信号由高→低→高,产生一个低脉冲,这时, 管脚上也会输出一个低脉冲,只是其低电平持续的时间比MR上低电平的持续时间长200ms左右,以保证DSP的复位可靠完成,如图6所示。

          
                       图6 手动复位时的 信号

5.   数字IO信号的产生

    在该控制系统中,要求产生8路数字IO信号。如果把这8路数字IO信号看成一个8bit的数,则需产生一个有限长度的非方波的编码信号,如下图所示。在T0时刻需要产生的数字IO信号为STAT0,比如说10010101;在在T1时刻需要产生STAT1,…,在Tn时刻需要产生STATn,而且T0可能不等于T1或Tn,STAT的状态也各不相同。


                              图7 数字IO信号的状态

    这里选用BF561的看门狗定时器(Watchdog Timer)来实现。在看门狗定时器的操作中,先将计数值写入寄存器WDOG_CNT中,然后看门狗定时器自动将WDOG_CNT的值写入寄存器WDOG_STAT。接着通过寄存器WDOG_CTL使能Watchdog Timer,看门狗定时器开始计数,逐次减小WDOG_STAT的值,直至为0,这时预先编写的程序事件就会发生。要想输出一个8bit的数据,只需往某地址单元写数,对应的数据线就会写出该数据。为了把该数据保持一段时间(Tx的长度),还需使用锁存器将该数据锁住。所以在BF561的DSP程序中先定义了数字IO信号对应的中断事件,且中断优先级较高,这是为了保证定时的精确度,防止别的事件干扰。

            register_handler(ik_ivg9, DIO_WDOGA_ISR);

       然后在中断事件里,把当前要写入的数据写到某地址单元上,然后使能Watchdog Timer,再将定时器的值写入WDOG_CNT中。定时器的计数是以sclk为基准的,程序代码如下:

*pDIO_Data_Port  = codes;

         *pWDOGA_CTL  =DISABLE_WDOG; 

            *pWDOGA_CTL  |=WDOG_EXPIRED_BIT;       

            *pWDOGA_CNT  =times;  

            *pWDOGA_CTL  = ENABLE_GPI;   

        codes和times就是当前要产生的数字IO的编码和长度。由于是一系列编码,可以用数组索引的形式,将当前的值写入。而我们事先定义DIO_Data_Port的地址为0x24000000,这对应BF561的AMS1的地址空间,所以用AMS1作为锁存器的使能信号,将数据线上的数据通过锁存器以后再输出,如下图所示 

       
                                       图8   数字IO的锁存器

6.标准RS232接口

    为了让控制系统与计算机之间可以进行数据的相互传递,系统采用MAX3232芯片来实现,如图9所示:

                       图9   BF561与计算机之间的串口通信框图

    BF561的UART遵循异步串行通信协议,包括:5-8个数据位;1、11/2、2个停止位;有/无奇偶检验。而波特率满足

         
    其中,SCLK是DSP系统的时钟频率,Divisor的值介于1~65536,可以由timer寄存器相应的值得到,满足关系式 

           
    在BF561的初始化设置中,将UART设为8bit数据模式,同时将Timer2设置为WDTH_CAP模式,用Timer2去捕获串口的数据变化率,而Timer2位于TMRS8寄存器里,程序初始化代码如下:

*pUART_LCR = WLS(8);

       *pUART_MCR = LOOP_ENA;       

       *pTMRS8_DISABLE = TIMDIS2;

       *pTMRS8_STATUS = TRUN2 | TOVL_ERR2 | TIMIL2;

       *pTIMER2_CONFIG = TIN_SEL | IRQ_ENA | PERIOD_CNT | WDTH_CAP;

       *pTMRS8_ENABLE = TIMEN2;

       *pUART_GCTL = UCEN;

    在程序一开始,就会按照初始化设置进行自动波特率检测。当有字符输入时,timer会测量连续2次下降沿的宽度,并返回到timer所对应的period寄存器里。比如说,如果发送”@”(0x40h)作为自动波特率检测,发送时包括起始位,总共为8bit,如图10所示。


           图10  自动波特率检测字符”@”(0x40h)

    此处period的大小如上图所示,捕获的UART bits为8位,所以得到

     
    再根据波特率的公式,就可以求得波特率的大小。此段程序代码如下:

Period = *pTIMER2_PERIOD;  //返回period的值

Divisor = Period >> 7;         //右移7bit就相当于除以16×8

BaudRate = SYSCLK/16/divisor;  //得到波特率 

 
结论

    整个控制系统是以LCD显示的界面为基础,按提示进行相应的键盘操作。经过测试,该系统各部分工作正常,无相互干扰现象。实时时钟定时精确,可以达到秒级。数字IO输出的波形编码无乱码,定时精度可达毫秒级。RS232接口传输数据时,以高达115200bit/s的波特率传输,误码率小于5%。该控制系统已成功应用于某雷达系统的控制子系统。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

功率器件是一种专门用于控制、调节和放大电能的电子元件,主要用于处理大功率电信号或驱动高功率负载,如电机、变压器、照明设备等。

关键字: 功率器件 控制 放大电能

机器人是一种集成了机械、电子、控制、传感、人工智能等多学科先进技术的自动化装备,能够模仿或替代人类进行各种任务的设备。

关键字: 人工智能 电子 控制

伺服电机是一种高精度、高性能的电机,广泛应用于各种自动化控制系统中。控制伺服电机是实现自动化控制的关键环节,不同的控制方式具有不同的特点和适用场景。本文将介绍几种常见的伺服电机控制方式及其特点,并分析在实际应用中应注意的...

关键字: 伺服电机 控制 自动化

大连2023年9月20日 /美通社/ -- 日前,国际独立第三方检测、检验和认证机构德国莱茵TÜV大中华区(以下简称"TÜV莱茵")受...

关键字: 控制 医疗服务 HEALTH 信息安全

 上海2023年9月7日 /美通社/ -- 近期,“国家卫生健康委国际交流与合作中心·因美纳公共卫生教育奖学金”项目(下称,“公共卫生教育奖学金”)完成首批奖学金颁发。该项目是由国家卫生健康委国际...

关键字: BSP 控制 组网 网络建设

张家港2023年8月25日 /美通社/ -- 对于塔机买家,需求的不仅仅是塔机的功能性,还有塔机的耐用性和残值。在这方面,波坦塔机以其卓越的品质和持久的稳定性,成为了一个值得信赖的选择。 当你在考虑购买二手塔机时,你应...

关键字: BSP 控制 变频调速 应力

上海2023年8月25日 /美通社/ -- 云顶新耀(HKEX 1952.HK)是一家专注于创新药和疫苗开发、制造、商业化的生物制药公司,今日宣布中国澳门特别行政区药物监督管理局已正式受理耐赋康®用于治疗IgA肾...

关键字: NDA 控制 新加坡 COM

上海2023年8月17日 /美通社/ -- 全球领先的专业信息、软件解决方案和服务供应商威科集团今天宣布,梦饷科技选择了CCH® Tagetik企业绩效管理(CPM)解决方案来应对全面预算管理需求。梦饷科技选择了...

关键字: TI GE 控制 软件

在电子测量和控制领域,精确信号放大和处理是至关重要的。而三运放仪表放大器作为一种常用的电子元件,因其高增益、低失真和良好的精确度而备受青睐。本文将介绍三运放仪表放大器的基本原理和结构,并探讨如何正确使用。

关键字: 电子测量 三运放仪表放大器 控制

上海2023年8月14日 /美通社/ -- 在创新驱动发展战略的政策指引下,上海外服作为人力资源行业的领跑者,快速响应政策号召,创新服务,打造以数字化平台为载体,以员工旅程为切入点的数智化人力资源工具——"数职...

关键字: 数字化 电子 手机 控制
关闭
关闭