当前位置: 首页>编程语言>正文

p15vbios演示 bios p0 p1


p15vbios演示 bios p0 p1,p15vbios演示 bios p0 p1_初始化,第1张




(1)BL0:是指S5PV210的iROM中固化的启动代码



        





(2)BL1:是批在iRAM自动从外扩存储器(nand/sd/usb)中拷贝的uboot.bin二进制文件的头最大16K代码



        





(3)BL2:是指在代码重定向后在内存中执行的uboot的完整代码



        





(4)三者之间的关系:(Interal ROM固化代码)BL0将BL1(bootloader的前16KB--BL1)加载到iRAM;BL1然后在iRAM中运行将BL2(剩下的bootloader)加载到SDRAM;BL2加载内核,把OS在SDRAM中运行起来,最终OS是运行在SDRAM(内存)中的。





下图是三星官方文档的说明:





p15vbios演示 bios p0 p1,p15vbios演示 bios p0 p1_加载_02,第2张






其中BL0是固化的,是不可以改变的,BL1就是u-boot是可以固化到NAND FLASH中的。下图是要烧录的BL2和u-boot的文件大小。BL2是11KB,符合官方的80KB范围。



p15vbios演示 bios p0 p1,p15vbios演示 bios p0 p1_bootloader_03,第3张





S5PV210内部有96Kb的IRAM和64Kb的IROM。





DRAM0的地址:0x2000_0000——0x3FFF_FFFF(512MB)(自带内存)



DRAM1的地址:0x4000_0000——0x7FFF_FFFF(1024MB)(扩展内存)



SROM的地址: 0x8000_0000——0xAFFF_FFFF(128MB*6)(扩展内存)



0xD000_0000——0xD000_FFFF(64Kb)



0xD002_0000——0xD003_7FFF(96Kb)



   0xE000_0000——0xFFFF_FFFF(512Mb)





IROM结构:



BL0:64Kb。





ISRAM结构:



BL1:16Kb,和启动设备的前16Kb地址的BL1对应;前16byte是头部。



BL2:80Kb,和启动设备的前16Kb之后的80Kb地址BL2对应。





完整的启动顺序:





开机启动IROM(BL0)的固话代码;



  



  



  



  



  



  



  



  



  





在ISRAM的BL1运行代码(裸机程序或者bootloader程序,从0xD0020010开始)。



  



  



  





在ISRAM的BL2运行代码(裸机程序或bootloader程序,从0xD0020010开始)。



  



  



  





在DRAM运行操作系统。





启动设备由OM5-OM0六个管脚的值来决定:





从1st和2st启动(OM5=0):从nand、sd等设备启动。



NAND 2kb 5cycle:000010



SD:001100



eMMC:00111X



OneNAND:00101X



eSSD:00000X





从uart和usb启动(OM5=1):先从uart启动,如果要从usb启动,手动断开uart。



eSSD:10000X



NAND 2k 5cycle:10001X



OneNAND:10100X



SD:10110X



eMMC:10111X





启动设备的顺序:











1st和2st是:NAND、NOR、OneNAND、SD(MMC)、eMMC、eSSD(SSD)。





S5PV210启动时,会先运行内部IROM中的固化代码进行一些必要的初始化,执行完后硬件上会自动读取NAND Flash或sd卡等启动设备的前16K的数据到IRAM中,这16K数据中的前16byte中保存了一个叫校验和的值,拷贝数据时S5PV210会统计出待运行的bin文件中含‘1’的个数,然后和校验和做比较,如果相等则继续运行程序,否则停止运行。所以所有在S5PV210的ISRAM上运行的bin文件都必须具有一个16byte的头部,该头部中需包含校验和信息。因为程序有16字节的头部,所以BL1中代码的实际地址是在ISRAM的0xD0020010。





**************************************



XXX.bin加上16byte的头部之后叫做210.bin



用来给启动设备添加16byte头的程序:



源程序参考mkv210_image.c



注意在DRAM运行的,就不需要再给程序加一个16byte的头了。



**************************************





启动代码的分析:



硬件:



1.时钟初始化



2.DRAM初始化



3.其它初始化(根据需要)



软件:



1.关闭看门狗



2.初始化I cache



3.栈的初始化



4.清空bss段


https://www.xamrdz.com/lan/5au1925746.html

相关文章: