- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于MIPS 的BootLoader 的移植pdf.PDF
基于MIPS 的BootLoader 的移植
曾洋
北京邮电大学计算机科学与技术学院,北京(100876 )
Email :illidan.zen@
摘 要:Bootloader 是嵌入式系统里面在操作系统加载之前对系统进行管理的程序,它包
括对系统进行各种初始化,对 flash 进行读写和管理,加载操作系统等功能。本文对基于
MIPS 4Kec 处理器的AudioCodes 的AC494 芯片进行了分析,对具体的移植工作进行了详细
的介绍。
关键词:嵌入式系统;MIPS;BootLoader;移植;AC494
1.AC494 芯片概述
AudioCodes 的AC494 芯片包括了一个MIPS 4Kec CPU ;UART 模块;中断控制模块;
时钟模块;DSP ;语音编解码模块;包括了PHY 、MAC 和Switch 的以太网模块;以及一些
常用的接口模块[1] 。开发板使用了此芯片,在此芯片外围接上了8 兆的Flash 和64 兆的内存。
在BootLoader 中,使用了CPU,UART 模块,中断控制模块,时钟模块,内存控制模块,
没有使用其它的模块。
AC494 芯片采用了MIPS 公司的4Kec CPU ,属于MIPS32 的家族,此次移植使用的是
windriver 公司的dcc 编译器,编译出属于MIPS32 指令集的代码。MIPS32 处理器的寻址方
式对于BootLoader 的移植非常重要,图1 是MIPS32 处理器在三种模式下的内存地址分配
方式[3]:
在BootLoader 中,我们只关心工作在Kernel mode 下的CPU,图2-2 是工作在Kernel mode
下的CPU 内存映射,其中unmapped 说明此段地址是不经过TLB 映射的,uncached 说明此
段地址不经过cache 而是直接访问内存[2] 。我们可以看到在kernel 模式下内存被分成5 个段,
其中kseg0 是unmapped,kseg1 是unmapped 和uncached 的,这两个段对于Bootloader 来说很
重要,这两个段实际上映射的地址都是物理地址的最低的512 兆,区别是kseg0 是可cache
的,kseg1 是uncached[3] 。
UART 模块,中断控制模块,时钟模块,内存控制模块在后面将会详细的说明,这里就
不多加说明了。
AC494 芯片物理地址空间分配[1] :
1. 0x0~0x0fffffff 内部寄存器及SYS_RAM
2. 00x107fffff FLASH(8MB)
3. 00x17ffffff SDRAM(64MB)
4.00x43ffffff SYS_ROM ;未使用的片选空间;VLYNQ3_ADDR
2 .移植所需要改动的地方
第一,编译器的改变。被移植的Bootloader 的编译器不能生成MIPS 可以执行的二进制
文件,因此,在更换了编译器之后,需要仔细研读编译器手册,学习编译器的用法,编译器
和编译器之间还是有一定的差别[4] 。
第二,所有的汇编程序都需要重写。因为汇编语言是和CPU 架构息息相关的,CPU 换了,
相应的汇编程序也需要重写[4] 。但是因为是移植,所以整个程序的架构还是需要和老程序一
- 1 -
样,做到不破坏程序的结构。
图1 MIPS32 三种模式内存地址 图2 MIPS32 内核态内存地址
第三,因为硬件不同,在对硬件外设,比如 UART ,中断控制器等这些设备操作的部分
也需要重新书写。
第四,注意大端小端的区别,移植之前的BootLoader 是运行在大端CPU 上的,而移植
后的BootLoader 是运行在小端CPU 上的,在很多时候,都是这方面引起的问题。
此外还要注意的是字节对齐的问题,移植之前的Bo
您可能关注的文档
- 在急诊抢救室、急诊监护病房、专科医院急诊、ICU 中需标配心肺复苏 .PDF
- 在疾病预防和控制中的系统解决方案.DOC
- 在驻波振动的其它时刻.PPT
- 地址:北京市昌平区生命园路29号创新大厦A103 邮编:102206 电话 .DOC
- 地形数据库 - 河北省地理信息局.DOC
- 地理(1~14题2分;15~20题1分) - 盐埕国中.DOC
- 地理学习困难学生的学习策略问题研究与实践.PPT
- 地理科融入资讯教学暨学习GPS定位探索营队实师计画.DOC
- 地锦叶片正丁醇提取物的抑菌作用 - 林业科学研究.PDF
- 坩埚下降法钨酸铋钠晶体生长及其生长面研究.PDF
- 基于PC 机的多导联心电图测试系统与检测处理算法 - 仪器信息网.PDF
- 基于PCA多特征融合的肝脏B超临床医学图像识别 - 计算机应用与软件.PDF
- 基于RNA-seq数据的差异基因和异构体检测 - 南京大学学报(自然科学).PDF
- 基于RS-fMRI 针刺加语言康复训练治疗卒中后运动性失语的疗效评价 .PDF
- 基于S3C44B0 的UBOOT 移植.PDF
- 基于SAFT的单晶硅内部缺陷时域检测成像方法 - 中国机械工程.PDF
- 基于Snake 模型的B 超心脏图像的腔体分割及算法研究 - 四川师范大学 .PDF
- 基于VAR 模型的中国农产品期货价格发现的研究 - 管理学报.PDF
- 基于VECM模型的国内外原油价格传导机制的研究 - 中国石油北京石油 .PDF
- 基于VTK的虚拟心脏切面交互式可视化方法 - 哈尔滨工业大学学报.PDF
最近下载
- 必修 中外历史纲要(上)第2课诸侯纷争与变法运动 课件(共24张PPT).pptx VIP
- 分析化学英文课件CH01 Introduction 0830.ppt VIP
- 【新】珠海市纳税百强企业名单(权威).docx VIP
- 某水厂反恐应急预案范本.pdf VIP
- 2025河南省红十字血液中心招聘合同制人员12人笔试备考题库及答案解析.docx VIP
- 道德经全文和译文.doc VIP
- 一种永磁同步电机旋变零位初始角自学习方法及系统.pdf VIP
- 2025年交管学法减分考试题库以及答案(160题完整版) .pdf VIP
- GB50068-2018建筑结构可靠性设计统一标准.doc VIP
- 化工单元过程及操作练习题(附答案).docx VIP
文档评论(0)