专注于大学生论文,大学毕业论文
热门搜索: 毕业论文, 论文格式, 教育论, 英语论文, 英语教学论文, 会计论文, 数学论文, 法律论文, 体育论文
论文指导 经济论文 理工论文 管理论文 法律论文 行政论文 英语论文 艺术论文 农学论文 医学论文 文史论文 教育教学论文
当前位置:首页→ 计算机网络论文Motorola微处

Motorola微处理器的bootloader分析与应用

【字体: 】 【收藏此文】 【我要留言】 【打印此文】【浏览次数:: 发表我的文章
Motorola微处理器的bootloader分析与应用 
摘要:以Motorola 32位处理器ColdFire5307为例,分析、介绍Motorola公司用于嵌入式系统开发的dBUG通用bootloader软件的结构、运行原理及应用。  
    关键词:嵌入式系统 ColdFire bootloader dBUG 

引 言 

bootloader是用来完成系统启动和系统软件加载工作的程序。它是底层硬件和上层应用软件之间的一个中间件软件,完成处理器和周边电路正常运行所要的初始化工作;可以屏蔽底层硬件的差异,使上层应用软件的编写和移植更加方便;不仅具有类似PC机上常用的BIOS(Basic Input Output System,基本输入、输出系统监控程序)功能,而且还可具有一定的调试功能。目前,在嵌入式系统开发中有多种bootloader可供选择,其中Motorola公司的名为dBUG的bootloader比较优秀。它可以移植在Motorola MC68000、ColdFire和PowerPC系列所有微处理器上面,有强大的调试功能,支持单步、下载、网络更新等;其良好的软件架构使用户能很方便地修改其代码,扩展新的功能。本文以作者用于网络数据存储的coldfire5307C3开发板为例,简析其上的dBUG bootloader的结构和运行机制,并给出实际修改范例。 

1 bootloader源码结构 

(1)bootloader的文件组织 

  dBUG bootloader源代码可以从Motorola公司网站获得。它是一个范例程序,通过修改相应的配置文件和处理器相关文件,可以很方便地移植到不同的处理器系统上。其源码由两个部分组成,一部分是lib项目,另外一部分是每种Motorola微处理器单独的处理器项目。比如,ColdFire 5307就使用MCF5307C3项目和lib项目一起来生成最终的dBUG代码。其中lib项目中是与处理器无关的一些命令或者函数,而每个单独的处理器项目是和每种不同的处理器息息相关的。在编译的时候,首先需要将lib项目编译生成标准库函数(也就是将一些通用命令和函数先封装起来)。然后,编译MCF5307C3项目,就会将刚才编译的lib项目和MCF5307C3项目结合在一起生成最终代码。 

  整个dBUG bootloader代码的架构比较复杂,其源码按功能可分为3个模块[1]:User Interface Component、CPU-specific Component、Board-specific Component。用户进入dBUG的目录以后,会看到三个子目录,如图1所示[1,2]。 

① 第一个目录是bin目录,在该目录下面主要是一个简单的TFTP Server软件。TFTP是简单的FTP(文件传输协议)。它是基于UDP协议的,主要用来下载程序目标代码。 

② 第二个目录是prog目录,下面主要是lib项目和MCF5307C3项目的项目组织文件和一部分源代码。在prog目录下面的libdbug目录下,有lib项目的项目管理文件libdbug.mcp,使用CodeWarrior可以打开该项目文件和编译等。prog目录下面的M5307C3目录下是ColdFire 5307系统的项目文件,而该目录下的obj目录下是生成的dBUG目标代码。src目录下是5307项目的项目管理文件。用户可以使用CodeWarrior,打开M5307C3目录下的/src/dbug/mwerks/m5307c3.mcp项目管理文件来编译代码。 

③ 第三个目录是src目录,是dBUG的主要源代码。 

  综上所述,用户只要打开m5307c3.mcp和libdbug.mcp两个项目文件,即可以看到dBUG所有的源代码。 

(2)与处理器和外围硬件配置相关的文件 

① 入口文件:vector.s。 

存有处理器复位初始入口地址、跳转指令及中断矢量表。 

② 初始化汇编语言文件:mcfxxxx_lo.s。 

功能为预初始化处理器、调用初始化函数及跳转到main主函数。其中xxxx表示某特定的处理器型号,如5307。 

③ 初始化C语言文件:Sysinit.c。 

内含多个初始化函数,功能为初始化处理器及各底层硬件。 

④ 系统配置文件:Config.h和Board.h 。 

Config.h 

设定板上处理器类型和其它模块功能。 

Board.h 

设定板上各参数信息,如片外Flash和SDRAM大小、类型、数据宽度和地址范围、划分板上内存空间范围、系统时钟大小、系统总线速率以及一些其它要用到的系统常量。 

⑤ 连接配置文件:Flash.lcf。 

设定连接时各函数空间地址及内存分配。 

⑥ 预包含头文件:mxxxx_mwerks.h和mwerks.h。 

两函数被所有的C语言和汇编语言函数包含,它们设定CodeWarrior 预处理器所用到的常量和编译器编译选项。 

2 bootloader运行流程简介 

  bootloader启动流程如图2所示。 

  系统上电复位后,跳到Boot ROM的最低地址处。Boot ROM的开始空间FFE00000~FFE00400为vector.s中的中断矢量表。将表中第一个32位字传给5307的SP,将第二个32位字传给PC,即完成复位中断跳转。 

  该复位中断跳转到vector.s中的start处。此处仅初始化sr,然后跳转到mcf5307_lo.s中的asm_startmeup。该段代码首先进行部分初始化和真正初始化前的准备工作:禁止Cache、禁止中断和地址转换、初始化用户指定的内部模块(MBAR)和内部SRAM(RAMBAR)起始地址。然后,将SP指向内部SRAM空间,即当调用真正的初始化程序时用内部SRAM的一段地址空间作为临时堆栈。接下来,调用sysinit.c文件中的外围电路和系统配置的初始化程序mcf5307_init()。 

  mcf5307_init()函数顺序调用各个功能的初始化子函数,初始化系统集成模块、并行通用输出输入口、串口、I2C控制器、DMA控制器、片选寄存器、SDRAM控制器。当运行完mcf5307_init()后,流程回到asm_startmeup中。此时,外围电路和内部模块已按用户要求进行了正确的配置,系统的初始化已基本完成。于是,将堆栈指针SP指向用户要求的堆栈空间,该堆栈为该板上的外部SDRAM空间。最后,跳转至main函数。 

  在main中,首先将系统的矢量表从Flash空间拷贝到用户指定的外部SDRAM中。然后,将Flash中的data段初值拷贝到外部SDRAM指定的data空间中,根据配置将外部SDRAM中的bss段清0,之后进行一些系统全局数据结构、参数表等的初始化。最后,调用mainloop开始人机交互循环:不断接收用户的命令、根据命令查表调用相应的任务函数、在界面上打印出相应的执行信息。 

[1] [2] 下一页

前五篇文章
[74288]SoC系统的低功耗设计
[74287]智能传感器的蓝牙协议栈与SoC结构设计
[74286]在Linux下用Qt开发新一代DTS图形数据系统的分析
[74285]浅论网站的制作
[74284]Asp.net组件设计浅论
后五篇文章
[74289]Motorola微处理器的bootloader分析与应用
[74290]矢量字库在嵌入式机顶盒中的应用


友情提示:按住Ctrl+D可以直接将本文加入收藏夹,方便下次访问。
本类TOP10
高校校园网解决方案(562)
“校校通”网络方案(447)
企业园区网的构建和开发建设(408)
校园网设计与建设(384)
论网络对社会的正负效应(375)
网吧组建与管理(350)
校园网站设计(325)
浅论ADSL宽带网接入技术(322)
中小型企业内部网(Intranet)的实现(286)
宽带接入技术的发展(267)
关于大学论文网 | 联系我们 | 广告服务 | 免责声明 | 站点地图 | 友情链接
大学论文网(l-w.org.cn)版权所有 ICP备案 鄂ICP备05025604号
Copyright © 2007 l-w.org.cn