Blackfin及嵌入式ktClinux在数据采集系统中的应用-设计应用_第1页
Blackfin及嵌入式ktClinux在数据采集系统中的应用-设计应用_第2页
Blackfin及嵌入式ktClinux在数据采集系统中的应用-设计应用_第3页
Blackfin及嵌入式ktClinux在数据采集系统中的应用-设计应用_第4页
Blackfin及嵌入式ktClinux在数据采集系统中的应用-设计应用_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

精品文档-下载后可编辑Blackfin及嵌入式ktClinux在数据采集系统中的应用-设计应用前言

在数据采集系统中,数字处理是系统内容之一;然而随着科技发展,越来越多的功能需求使得采集系统的外设也越来越复杂,外设通讯和驱动编写成为一项复杂和繁琐的工作。以应用为中心的嵌入式系统为此类需求提供了一个良好的解决方案,能够适应实际应用中对功能、可靠性、成本、体积、功耗的严格要求。ADI公司的Blackfin系列处理器将嵌入式微控制器和DSP融为一体,取二者之长,提高了系统工作效能,大大降低了成本。同时,多线程的实时嵌入式操作系统也可增强采集系统的实时性、稳定性。对开发者来说,Blackfin处理器和μClinux的结合很有吸引力。

系统结构及硬件平台

本数据采集系统主要由2个数据采集通道、1个触发通道、ADc转换及存储电路、DSP及FPGA控制部分组成,并包含有以太网、RS232接口、USB、TFT液晶显示部分。系统硬件平台原理框图如图1所示。

信号从采集通道进入,经过信号调理电路进入ADC,被转换后的数字信号即进入FPGA、DSP进行数字控制处理。经过DSP处理过的信号,可送至其它外设以显示、存储,或通讯。

BF531为系统的部分之一,供电电压3.3V,内核电压1.2V,为了使系统能够开机自动从FLASH中启动,设置。BMODE为00,即从外部存储器启动。FPGA、片外SDRAM、FLASH,以及USB和液晶直接和BF531通过地址线、数据线相连。

系统中应用了TFTLCD液晶显示模块FG050605DNC:,该LCD控制简单,只有RGB每色5个共15个信号,以及数据使能、数据时钟和行频、场频控制信号。LCD晶直接由DSP控制,DSP的Timerl、Timer2提供行、场频信号,PPI口传输数据,由FPGA提供时钟,配置μClinux开辟一块framebuffer作为显示数据存储区,配合Linux下的液晶驱动,即可工作。

软件设计

由于DSP中运行的是基本上已经成熟的算法和控制流程,所以软件设计的主要工作为在DSP中嵌入操作系统。

U-Boot的移植

U-Boot的移植主要分为两个层面,一个是对CPU的移植,一个是针对Board的移植。U-Boot中已经有大量可直接到某些开发板上的程序,为了减小工作量,可选一个接近自己设计的开发板来进行修改。本设计中采用了stamp目标板。

具体如下:

(1)拷贝board下面的文件夹stamp,重命名为mybf531,作为即将要修改配置的目标板。拷贝cpu下面的文件夹bf533,重命名为bf531,作为将要修改的cpubf531。再将board和bf531文件夹中所有关于stamp板的文件名及包含头文件等改为mybf531;将所有关于bf533的文件名及包含头文件等改为bf531。注意文件间的依赖关系,确定是该添加文件还是修改文件,并记录文件改动。

(2)Makefile文件

在u-boot根目录下的makefile文件中添加bf531和mybf531的编译规则,如下:

ifeq($(CPU),bf531)

OBJS+=cpu/$(CPU)/start1.0

OBJS+=cpu/$(CPU)/interrupt.0

0BJS+=cpu/$(CPU)/cache.0

OBJS+=cpu/$(CPU)/cplbhdlr.0OBJS+=cpu/$(CPU)/cplbmgr.O

OBJS+=cpu/$(CPU)/flush.O

OBJS+=cPu/$(CPU)/

initsdram.O

endif

mybf531_config:unconfig

@./mkconfig$(@:_config=)

blackfinbf531mybf531

(3)include/configs/mybf531.h

板子的功能配置信息大都在include/configs/mybf531.h中,故拷贝stamp.h并修改其中的启动信息和配置信息。重点修改部分如下:

时钟信息:

#defineCONFIGCLKINHZ

11059200

#deftneCONFIGVCOMULT

36

#deftneCONFIGSCLKDIV

5

FLASH信息:

#deftlieCFGMAX

FLASHSECT67

#defineCFGENVADDR

0x20004000

#defilieCFGENVSIZE

0x2000

#deftneCFGENVSECTSIZE

0x2000

#defi!qeCFGFLASHERASE

TOUT30000

#defineCFGFLASHERASE

TOUT30000

SDRAM信息:

#defineCONFIGMEMSIZE

128

#defineCONFIGMEMADD

WDTH11

#deftlieCONFIGMEM

MT48LC64M4A2FB7E1

其它配置信息#defilieAMBCTLOVAL

0xBBC3BBC3

#defineAMBCTL1VAL

0x99839983

#defineVDSP--ENTRY--ADDR

0xFFA00000

并将板子上不需要的功能的宏定义作相应设置。

(4)Board的移植

检查board/mybf531/中所有文件,首先将board和CPU的相关stamp.h、stamp.C改为bf531.h和mybf531.C,并检查其文件的设置、包含的头文件和宏定义是否正确。在board/mybf531/config.mk中,找到

TEXT_BASE=0x03FC0000

PLATFORM_CPPFLAGS+=-

I$(TOPDIR)

修改其中的TEXT_BASE值为SDRAM的地址与CFG_MONITOR_LEN之差。

(5)CPU的移植

检查cpu/bf531/中所有文件,首先将board和cpu的相关stamp.h、stamp.C改为bf531.h和mybf531.C,并检查其文件的设置、包含的头文件和宏定义是否正确。

cpu/bf531/cpu.C文件的修改主要在于配置SDRAM页的大小属性,设置ICPLB、DCPLB、cache的状态设置,icplb_table和dcplb_table和其相应属性的修改。

(6)其它

在以下文件夹中找到下面函数,检查并根据具体要求修改

initIRQ()cpu/bf531/ints.C

flash_init()drivers/

cfi_flash.C

env_init()common/

envflash.Cinit_baudrate()lib_blackfin/

board.C

serial_init()cpu/bf531/

serial.C

console_init_f();common/

console.C

display_banner();lib_blackfin/

board.C

checkboard();board/stamp/

stamp.C

timer_init();cpu/bf531/

interrupts.C

至此,U-Boot的修改配置基本完成,重新编译U-Boot代码,将得到的u-boot.bin通过JTAG口到目标板,如果能够通过串口输出启动信息,表明移植基本成功。其间仍需多次修改。移植成功后可相应对功能进行增删。

μClinux的移植

本文选择了httP://blackfin.UC中提供的μClinux-dist-RO6R2-RC2.tar.bz2作为系统使用μClinux的源代码。解压缩之后就可以进行内核配置和内核编译了,内核配置即为内核制定适当的功能。在解压缩之后的源码根目录下,执行makemenuconfig或makexconfig进行配置。

其中重要的部分如下:

(1)系统cpu的选择、系统板卡的选择及设置

KernelexecutesfromRAM

CyrstalFrequency1000Hz

SDRAMMemorySizeinMbytes

32SDRAMMemory

AddressWidth9

BaudRate57600

EnableDMASupport

(BFIN_DMA_5xx)

EBIU_AMBCTLGlobalControl

EBIU_AMBCTLControl

(2)系统外设选择及驱动设置

本系统外挂以太网、USB、LCD及SPIFALSH,使用RS232、PPI接口等,μClinux内核源文件已经包含支持Blackfin系列处理器的驱动,故只需对各接口进行驱动选择,对部分外设进行驱动编写即可。主要的设置如下:

Networkingsupport(NET)

DeviceDrivers

Detectnon-CFIAMD/JEDEC-C0mPatib1eflashChiPS(MTDjEDECPROBE)

STMW320Dcompatibleflashchipsupport(MTD_MW320D)

SupportforRAMchipsinbusmapping(MTD_RAM)

Parallelportsupport(PARPORT)

SCSIdevicesupport

NetW0rkdeViceSUPPort(NETDEVICES)

BlackfinBF53xProgrammableFlagsDriver(BF533_PFLAGS)

B1ackfinBF5xxPPIDriver(BF5xx_PPI)

Supportforflamebufferdevices(FB)

FG0506TFTLCDonuClinux(MYBF531STAMP)(FB_BF531_FG0506)

SupportforHost-sideUSB(USB)

其中FG0506TFTLCDonUClinux(MYBF531STAMP)(FB_BF531_FG0506)为在/uClinux-dist/linux2.6.x/driver/video/下编写bf531_fg0506.C的液晶显示驱动,并改写该文件夹下的Makefile和Kconfig文件,将该选项编入?clinux源程序的配置选项中。

(3)操作系统内核的剪裁

AnalogDeVicesBlackfinEmbeddedLinuxApplicationconfiguration菜单下为关于Linux系统应用程序的配置信息,可以添加或删除适合本系统的软件设置,应用程序等。例如,如果要在系统上使用图形界面,就需要在此部分中选择Microwindows下的microwin和nano-x的相应选项,或是将Qt/Embedded编人μClinux源文件,再编入系统内核中。除了适合系统的特殊需要,一般此项中的内容不需修改。

全部选择完成之后,使用make进行内

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论