打印

基于BF533 的 图像采集与显示

[复制链接]
676|0
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
qwe890asd|  楼主 | 2017-11-11 10:48 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
基于BF533 的 图像采集与显示


嵌入式图像处理系统中,经常需要对图像进行采集,并将采集图像的处理结果显示在嵌入式系统的彩色LCD之上,以使人能够对处理后的图像结果进行直观的观察,进一步对图像识别的正确与否进行人工判断。本设计主要是将嵌入式系统应用到智能饮水控制系统之中,从而实现对水位状况的检测。本系统可对所采集的图像进行边缘提取,并将结果显示在TFTLCD上。该设计将BF533提供的PPI接口同时连接到CMOS图像传感器MT9Vlll和TFTLCD显示器TS35NDl50l上,并采用分时工作方式来实现对图像的采集和显示。
   
        Blackfin处理器的PPI
        (并行外设接口)是一种多功能的并行接口,它可以配置为8 bit和16 bit两种带宽,并可支持双向数据流,同时包含了3条同步线以及一个与外部时钟相连的时钟引脚。PPI可以对ITU—R BT.656数据进行无缝解码,可实现对输入视频流进行解码,并能自动忽略有效视频之外的任何信号。

       1 系统结构
        Blackfin系列处理器是ADI公司研制的一款嵌入式处理器,它集微控制器、DSP和媒体处理器的优势于身,可广泛应用于消费类多媒体、网络通信等多个领域。
        MT9V111是Micron Technology公司推出的一款l/4英寸图像传感器,它能够输出分辨率为640x480的数码图像信号。通过以I2C总线对其IFP(Image Flow Processor)寄存器进行配置,即可输出ITU_R BT.656 (YCbCr)、YUV、565RGB、555RGB和444RGB等数据格式的视频信号。
        TS35NDl50l是台湾台盛公司生产的一款以薄膜场效应晶体管为开关器件,能显示彩色图像的矩阵型液晶显示器。使用时可通过SPI总线对其内部的寄存器进行配置,如果没有对这些寄存器进行配置,该LCD将会自动运行在默认模式。
        在应用中,可将图像传感器MT9V111与TFTLCD TS35ND1501同时连接在BF533的PPI总线上,并采用分时方式完成图像的采集与显示,其系统硬件框图如图1所示。图中,ADG704为4选1的四通多路复用器,用以选择图像传感器和TFTLCD时对PPI总线提供的时钟进行切换。在图像采集方面,可将BF533的可编程I/O接口PF4与图像传感器的SCLK端口相连,并将PF2与SDATA相连,同时采用I2C总线方式实现对图像传感器MT9Vlll的配置。将PF0置l,PFI清0,可使FTFLCD处于复位状态,图像传感器处于工作状态。

        这时,ADG704的接口S2与接口D处于连通状态。而将图像传感器MT9V111提供的PIXCLK时钟信号提供给BF533的PPI_CLK接口,则可实现BF533对图像传感器传来数据的正确接收。图像显示可采用BF533内部提供的TIMERl作为帧同步信号,TIMER2作为行同步信号来控制图像的显示,不对TS35NDl501进行配置,系统将采用默认工作方式。进行图像显示时,可将可编程I/O接口PF0清0,以使图像传感器处于复位状态,将PFl置1使TFTLCD处于工作状态,这时,ADG704的接口S3与接口D处于连通状态,从而为BF533的PPI_CLK接口提供数据输出的20MHz时钟信号。需要指出,当有更多的外设需要和BF533通信时,采用CPLD进行逻辑扩展,可以解决GPIO接口不足的问题。

        2 图像的采集
        在首次进行图形采集和图像显示之前,首先应对BF533的PLL、EBIU和系统的SDRAM进行设置,以使BF533能够正常稳定的工作。
        图2所示是图像采集的软件流程。通过设置BF533的FIO_DIR,FIO_FLAG_C,FIO_LAG_S寄存器,可使可编程I/O接口PFO为高电平,PF1为低电平,从而使图像传感器处于工作状态,TFTLCD处于复位状态。然后,就可以采用如下代码来实现对BF533的PPI接口初始化。
  •   *pPPI_CONTROL=Ox001c;
  •     *pPPI_FRAME=240;//240行
  •     *pPPI_COUNT=639;//每行传输640个采样点
  •     *pPPI_DELAY=0;

复制代码
       之后,再以如下代码对DMA控制器进行配置,便可使DMAO控制器映射为PPI接口,以便使DAMO通过PPI读取的数据的存储地址指向二维数组ImagelnBuffer[240][640],并将DMA设置为二维传输模式。其代码为:
  •     *pDMAO_CONFIG=0x00b2;
  •     *pDMAO_PERIPHERAL_MAP=0x0;//配置为PPI
  •     *pDMAO_START_ADDR=&ImageInBuffer[0][0];//指向要存放的首地址
  •     *pDMAO_X_COUNT=640;//二维传送,内层计数
  •     *pDMAO_X_MODIFY=0x1;//每次传送一个字节
  •     *pDMAO_Y_COUNT=240;//外层计数
  •     *pDMAO_Y_MODIFY=0x1;

复制代码
       然后再初始化定时器,使其能从图像显示模式恢复为默认模式。再通过可编程逻辑接口PF2,并通过PF3采用I2C总线工作方式对图像传感器MTOVlll进行配置,以将图像传感器MT9V111设置为ITU_R BT.656(YCbCr)的数据输出方式。最后,再将BF533的寄存器DMA0_CONFIG中的标志位DMA_EN和PPI_CONTROL中的标志位PORT_EN置1,同时开启DMA0和PPI接口,并将寄存器TIMER_ENABLE中相应的标志位置1以开启相应的定时器。最后等待DAM0接收完一帧图像数据后的中断。
        3 图像的显示
        图像显示中的TS35NDl501 TFTLCD是一款RGB数据接口的彩色图形点阵显示器,它的数据传输时序如图3所示。信号VSYNC与HSYNC分别为LCD的帧同步信号和行同步信号,DCLK为点阵数据传输时钟信号。其中TVP为帧同步信号的脉冲宽度,典型值为3倍行同步信号宽度(TH)。TVB为帧同步信号后沿时间,典型值为15个行脉冲宽度。TVF为帧同步信号的后沿时间,典型值为4个行脉冲宽度。在以上这三个信号时间内TFTLCD是不会接收要显示的数据的,故不显示的行数为3+4+15=22,也就是说,传输的图像数据中有22行的数据不会被显示到LCD上。所以定义一个无符号字符型二维数组DisplayBuffer[262][960]作为要显示数据的缓冲区,其中所定义数组的前22行是无用数据,后240行数据为要显示在TFTLCD上的图像数据。将从图像传感器获取的、存放在ImagelnBuffer中的UYVY (4:2:2)图像数据转换成LCD要显示的灰度图像数据格式(RGB24),并存储在二维数DisplayBuffer[262][960]中。
        通过设置BF533的
  • FIO_DIR,
  • FIO_FIAG_C,
  • FIO_FLAG_S

复制代码
       寄存器可使可编程I/O接口PF0为低电平,PF1为高电平,从而使LCD处于工作状态,图像传感器处于复位状态。之后,可以用如下代码对PPI接口进行配置。
   
  • *pPPI_CONTROL=0x009e;//POLSIPACK_EN |Ox0010 | XFR_TYPE | PORT_DIR;
  •     *pPPI_DELAY=0xcb;//在进行写操作前延时106个时钟周期
  •     *pPPI_COUNT=959;//每行传输960个数据点然后,可采用如下代码对DMA0控制器进行配置,以将DAM0控制器配置为RESTART和FLOW_AUTO模式,从而使它能够循环实现对缓冲区DisplavBuffer中的数据的输出。
  •     *pDMA0_PERIPHERAL_MAP=Ox0;//映射为PPI接口
  •     *pDMA0_CONFIG=0x1030;//FLOW_AUTO |RESTART | DMA2D | WDSIZE_8;
  •     *pDMA0_START_ADDR=&DisplayBuffer[0][0];//要显示数据的首地址
  •     *pDMA0_X_COUNT=960;
  •     *pDMA0_X_MODIFY=1;
  •     *pDMA0_Y_COUNT=262;
  •     *pDMA0_Y_MODIFY=1;

复制代码
       对定时器TIMER1,TIMER2进行配置,可以使其对TFTLCD提供行同步和帧同步信号,以将其设置为PWM_OUT输出模式,并将定时时钟设置为采用PPI_CLK接口输入的20 MHz时钟信号,其代码如下:
  
  • *pTIMER1_PERIOD=1224;//TH
  •     *pTIMER1_WIDTH=5;//THP,最小值
  •     *pTIMER1_CONFIG=0x02a9;//EMU_RUN |CLK_SEL|TIN_SELIPERIOD_CNTlPWM_OUT
  •     *pTIMER2 PERl0D=320688;//TV=262*TH=262*1224=320668
  •     *pTIMER2_WIDTH=3672;//TVP=3*TH=3*1224=3672
  •     *pTIMER2_CONFIG=0x02a9;

复制代码
       最后,再启动PPI接口、DAM0控制器和相应的定时器,开始图像的显示,并延时5秒,以使图像在LCD上稳定的显示5秒钟。其显示软件流程图如图4所示。
        4 结束语
        经过调试和修改,该系统能够实现对图像的采集并正确显示图像的处理结果,本设计可以满足预期的数据显示需求。本文经过对BF533的PPI接口进行合理应用,实现了对图像采集和显示的分时工作,能够满足一些情况下的应用。因为BF533只有一路PPI接口,所以无法实现对采集图像的实时显示。而要实现的对所采集数据的实时显示,则可采用BF561DSP,该DSP可提供两路PPI接口,因而能够满足图像的采集与实时显示


相关帖子

发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

455

主题

583

帖子

5

粉丝