一.uboot
1.flash分区:
-------------------
自由发挥空间(剩余空间一般在rootfs根文件系统启动后,将此分区挂载到rootfs下,用于用户使用)
-------------------
rootfs根文件系统(根据用户软件大小来设置)
-------------------
kernal镜像(大小一般3MB或5MB)
-------------------
环境变量(大小一般32KB)
-------------------
uboot镜像(大小一般不大于512KB,启动位置不可变,由SOC启动特性决定的,其他分区位置可变由软件设计)
-------------------
2.最关键的环境变量
bootcmd和bootargs(启动内核时给内核传递参数,参数格式和参数一定是uboot和内核约定的)
3.kernal下载
tftp下载kernal.img到内存地址0x3000800(该地址在uboot中定义的镜像内存地址,在uboot下敲入print查看环境变量定义文件,会有read kernal 3000800,bootm 0x3000800)
bootm 0x3000800 启动kernal.img
3.uboot对flash分区管理
uboot中启动后是没有操作系统的(不像PC机,有操作系统介入,不用关系磁盘/flash分区),所以要对flash分区管理,即存在分区表。
移植时uboot和kernal中都存在分区表,在移植时设计好该分区表(uboot和kernal使用同一个分区表,因为操作的是同一块flash).uboot镜像必须在flash扇区的起始地址开始存放(可能是扇区0/扇区1/其他扇区的起始地址,这个由SOC设计启动时特性决定的,非软件决定)
4.uboot对DDR分区管理
在kernal启动之前,uboot镜像和环境变量都要先加载到内存中,由于裸机/uboot内部没有内存管理模块,所以需要避免各个功能访问内存DDR地址混乱。譬如tftp 0x23E00000 zImage,吧zImage下载到内存地址处,而该地址大概率是uboot加载在内存中的位置导致覆盖了正在运行的uboot,产生错误。
当kernal启动之后,由kernal的内存管理模块接手对DDR的管理.