摘要:
本文主要介绍VxWorks系统在MPC860系列处理器的开发中怎么实现去掉BOOT Flash,直接从Flash引导VxWorks的BootRom。
关键词:BOOT Flash,Flash,BootRom
引言
美国WindRiver公司的实时嵌入式系统VxWorks和美国Motorola公司MPC860系列处理器已经广泛的应用在通信行业的通信产品中,在用VxWorks系统进行开发时,会生成两个文件,一个是BootRom文件,此文件类似Windows中的BIOS,是引导文件,完成内存初始化,内核初始化,基本硬件的初始化并最终引导VxWorks系统启动,另外一个是VxWorks文件,此文件中包括VxWorks系统内核及上层应用程序,而这两个文件在MPC860的开发中一般都存储在两片不同的Flash上,及BootRom存储在BOOT Flash,而VxWorks存储在Flash上。
产品需要
实际开发中,生成的没有压缩的BootRom大小一般为512K左右,在VxWorks 5.4中是460K左右,而在VxWorks 5.5中是540K左右,一般存储BootRom的Flash只需要512K大小,因为即使540K的 BootRom也可以截成512K。
在硬件开发Flash选型时,BOOT Flash芯片一般采用SST公司的28VF040、29VF040等,Flash芯片一般会采用Intel、AMD公司的,根据需要可能会采用容量为4M、8M、16M、32M大小不等。从节省成本的角度考虑,是不是可以将BootRom直接装载到Flash中并引导呢,这样不是可以省掉一片BOOT Flash吗?
VxWorks系统中,加上上层应用程序的生成的VxWorks文件一般为3M左右,所以不管你采用4M、8M或者更大容量的Flash,同时装载BootRom、VxWorks文件也是绰绰有余的。
实际情况
我和一个做硬件的朋友曾经做过这样的测试,直接从Flash引导BootRom,并引导VxWorks系统,实际上是可行的。
要解决此问题,实际上只要将Flash的地址稍做处理就可以的。
我们将Flash地址映射成两个地址段,一段用做BootRom,一段用做VxWorks使用,用做BootRom的地址段为0xFFF00000~0xFFF80000,另外一段用做VxWorks的地址段为0x04080000~0x04800000(假设此Flash大小为8M大小),在0xFFF00000~0xFFF80000地址段写入BootRom,在0x04080000~0x04800000地址段写入VxWorks,加电后,PC指针会跳到0xFFF00100地址执行第一条指令,引导BootRom起来并最终VxWorks系统引导成功。
实现过程
1、 片选
在romInit.s文件中要做如下的片选操作,片选0为BOOT Flash的地址片选,片选1为Flash的地址片选,其中ROM_BASE_ADRS为0xFFF00000
/* ------------------------------------------------------------------------ */
/* Initialize Chip Select 0 for Bootrom */
/* ------------------------------------------------------------------------ */
lis r5, HIADJ( ROM_BASE_ADRS | BR_PS_8 | BR_WP | BR_V)
addi r5, r5, LO( ROM_BASE_ADRS | BR_PS_8 | BR_WP | BR_V)
stw r5, BR0(0)(r4)
lis r5, HIADJ( 0xFFF80000 | 0x00000100 | 0x00000080)
addi r5, r5, LO( 0xFFF80000 | 0x00000100 | 0x00000080)
stw r5, OR0(0)(r4)
/* ------------------------------------------------------------------------ */
/* Initialize Chip Select 1 for FLASH */
/* ------------------------------------------------------------------------ */
lis r5, HIADJ( 0x04000000 | BR_PS_16 | 0x00000001)
addi r5, r5, LO( 0x04000000 | BR_PS_16 | 0x00000001)
stw r5, BR1(0)(r4)
lis r5, HIADJ(0xff800000 | 0x00000100 | 0x00000080)
addi r5, r5, LO(0xff800000 | 0x00000100 | 0x00000080)
stw r5, OR1(0)(r4)
2、 地址映射
在sysLib.c文件中有一sysPhysMemDesc的地址映射数组的声明,对BOOT Flash和Flash的地址按照如下的地址映射后,VxWorks系统才会让你对此地址进行相应的读写操作。
{
(void *) 0x04000000,
(void *) 0x04000000,
0x00800000, /* 8 m - Flash window 1 */
VM_STATE_MASK_VALID | VM_STATE_MASK_WRITABLE,
VM_STATE_VALID | VM_STATE_WRITABLE
},
{
(void *) ROM_BASE_ADRS,
(void *) ROM_BASE_ADRS,
ROM_SIZE, /* Flash memory */
VM_STATE_MASK_VALID | VM_STATE_MASK_WRITABLE |
VM_STATE_MASK_CACHEABLE ,
VM_STATE_VALID | VM_STATE_WRITABLE |
VM_STATE_CACHEABLE_NOT
}
3、 文件烧录
还存在一个问题,因为BOOT Flash是可以在烧录器上烧录的,而Flash芯片是直接焊接在MPC860的主板上,只能通过相应的Flash驱动才能进行读写的,是不可能通过烧录器烧录,要解决此问题那只能按照如下办法解决。
在主板上要保留有BootRom Flash座,要有一片从BOOT Flash引导的BOOT Flash芯片,此芯片中要有已经烧录好的可以正常运行的BootRom程序,先将此芯片加到BootRom Flash座上,加电将系统引导起来,然后用事先写好的将BootRom及VxWorks写入Flash的函数将BootRom及VxWorks文件写入Flash相应的地址段,注意写入地址要正确,即BootRom的第一条指令必须写在0xFFF00100地址,关电后将BOOT Flash从座中取出来,加电后系统就从Flash中引导起来了。
- Boot(35126)
- VxWo(8949)
相关推荐
VxWorks文件系统、Flash的TFFS设计与实现
2145
6678 EMIF16 Nor Flash多核boot
BOOT MODE是不是烧到了FLASH里面了?
VxWorks for x86系统中实时时钟的应用是什么
VxWorks中的TFFS文件系统怎么实现?
VxWorks常用的Bootrom类型有哪些
VxWorks开发中的Flash BOOT怎么去掉?
VxWorks操作系统映像的启动过程
VxWorks文件系统的结构是什么?
VxWorks映象的分类
boot的问题
vxworks 5.5、6.3-6.9、7.0,vxworks 653 2.3-3.1 vxworks cert、qt、tilcon等
Bootloader的程序(BOOT)放到Flash开始地址设计实现
C6657: 是否能够从Hyperlink成功BOOT?
C6678 EMIF16 NOR FLASH BOOT
C6747 SPI BOOT后继续使用该SPI接口问题怎么解决
CS32F030系列单片机的两引脚BOOT0和BOOT1区别是什么?
Duang Duang Duang开启启动模式,解释BOOT0和BOOT1
EVM6657中I2C nand boot的问题
TM4C129程序跳转:请问如何从boot跳转到App?
U-Boot NAND FLASH移植
YModem协议中boot是否与要搬到RAM中跑?
u-boot详解
《VxWorks应用开发班》专业培训班07月20日上课,火热报名中!
《VxWorks应用开发班》专业培训班07月20日上课,火热报名中!
《VxWorks应用开发班》专业培训班07月20日上课,火热报名中!
《VxWorks应用开发班》专业培训班07月20日上课,火热报名中!
《VxWorks应用开发班》专业培训班07月20日上课,火热报名中!
《VxWorks应用开发班》专业培训班07月20日上课,火热报名中!
为什么AM335X u-boot.img从SPI FLASH启动不成功?原因是什么?
为什么ML507在XMD重置之前不会启动VxWorks内核?
为什么U-Boot 1.1.6 Flash信息读取不出来?
关于6747 SPI0 flash boot的问题
在2片Flash上怎么建立VxWorks下的文件系统?
在VxWorks操作系统的Nor Flash上怎么建立TFFS文件系统?
在u-boot烧写u-boot.ais到nand flash,无法从nand flash启动的原因?
基于VxWorks的测控系统应用
基于powerPC及vxworks的SATA2和1394 BSP
如何在SDARM中调试u-boot?
如何实现利用uCOS系统从flash中动态加载task?
实时操作系统VxWorks下电子盘驱动程序的开发
对于C5000,大于48K的程序如何BOOT?
将U-Boot烧入nand flash,不论是EZSDK预编译好的或者编译的uboot均无法引导板卡从nand flash启动,请问这是什么原因?
教你用JLINK烧NOR/NAND FLASH
求助:Vxworks无法加载boot文件
浅析U-Boot NAND FLASH驱动
烧写u-boot到NAND Flash
详解CPU boot的过程
请问6455 ROM中boot经过load出来改变了是为什么?
请问6713DSP对boot的flash型号有要求吗?
请问EMIF挂载NOR Flash进行BOOT的代码执行速度是否很慢?
请问为什么《Sitara Uniflash Flash Programming with Linux》中的链接打不开?怎么解决?
请问内核参数在nand flash中的地址该怎么确定?
请问怎么把一个数组定义到flash中,怎么从flash中读出来?
采用普通裸机boot跳转到VxWorks_rom镜像启动可行吗
关于Vxworks应用的资料.
0SL811HS VxWorks Host Driverv 1
15通过TFFS加载和升级VxWorks 映像
13WorldWind软件在VxWorks下的移植
18基于VxWorks的FLASH存储器实时存取管理方案
29电器组常见缺陷描述
0基于VxWorks的文件系统的研究与实现
35嵌入式操作系统VxWorks中TFFS文件系统的构建
599
TMS320VC5410的BOOT设计与实现?
855
VxWorks下的异步通用定时器设计
653
VxWorks下的多重定时器设计
2118
什么是手机Flash功能
742MacBook Boot Camp无法安装Windows X
1040什么是Flash Memory
1433VxWorks开发中怎么去掉Flash BOOT
1288基于ARM9的U-Boot自动识别启动实现
91一种基于Flash的VxWorks操作系统快速引导方法设计
6Uboot下关于Nor Flash的驱动问题
7022
AVR单片机的BOOT区简介和相关问题的总结
1STM32的三种Boot模式及验证
88在Linux/U-Boot里为QSPI Flash使用UBIFS
1298Encrypted Boot image泄漏讨论
548RL78 Family C Compiler Package(CC-RL) 如何划分Boot区和Flash区
4RX Family C/C++ Compiler Package(CC-RX) 如何划分Boot区和Flash区Rev.1.00
0RL78 Family C Compiler Package(CC-RL) 如何划分Boot区和Flash区
0RX Family C/C++ Compiler Package(CC-RX) 如何划分Boot区和Flash区Rev.1.00
0stm32中boot0和boot1怎么接
3062
电子发烧友App






评论