|  | 
 
| 
 很多同学对3399Pro的启动方式和分区表开始感兴趣了,想着如何自己修改烧写固件,如何修改分区表,
 今天就教大家识别下分区表文件parameter.txt以及固件的启动方式
 
 1. 分区表
 
 
 首先大家拿到的开发版默认是双系统启动的,里头包含了Android和Linux固件,我们先打开他的分区表来识别下。
 请直接看CMDLINE这行信息:
 
 CMDLINE:mtdparts=rk29xxnand:
 0x00002000@0x00002000(uboot),
 0x00002000@0x00004000(trust),
 0x00002000@0x00006000(misc),
 0x00010000@0x00008000(boot),
 0x00020000@0x00018000(recovery),
 0x00038000@0x00038000(backup),
 0x00002000@0x00070000(security),
 0x00100000@0x00072000(cache),
 0x00500000@0x00172000(system),
 0x00008000@0x00672000(metadata),
 0x00100000@0x0067a000(vendor),
 0x00100000@0x0077a000(oem),
 0x00000400@0x0087a000(frp),
 0x00375c00@0x0087a400(userdata),
 0x00010000@0x00bf0000(boot_linux:bootable),
 -@0x00c00000(rootfs:grow)
 
 他所描述的就是整个emmc中分区的排布方式,烧写工具和启动程序会按照该表进行烧录和引导。他的格式是:
 
 分区大小 @ 所在地址 (分区名)
 
 其中大小和地址都是以块为单位(1块=512byte),换算成MByte可以用以下公式:
 
 MByte = N * 512 / 1024 / 1024
 
 例如我们看uboot这行,
 他的分区大小是0x2000, 也就是 8192块 * 512字节每块 / 1024 / 1024 = 4MByte ,所以uboot分区大小就是4M,而他所在的位置也是在emmc 4M的位置。
 
 接下去trust分区紧跟uboot分区,所以他所在的地址就是 uboot的地址+uboot大小 = 0x2000+0x2000 = 0x4000
 而最后一个分区可以看到他的分区大小是个减号"-",意思就是emmc剩下的所有大小全部给他。非常方便吧。一般我们会把user分区放在最后一个分区给用户自由使用。
 
 注:EMMC前4M的空间是保留空间,他是用来存放BootLoader和Parameter的,所以请勿挂念。
 
 
 2. 启动顺序
 
 开机时候,3399Pro总是会从emmc的0地址读取BootLoader,也就是发布固件里的(MiniLoaderAll.bin),
 然后:
 Loader 引导 trust和uboot,
 uboot 引导 boot             (安卓的kernel resource 和boot打包在一个固件里了)
 或 boot_linux     (linux的kernel resource)
 
 boot 挂载 system(Android系统)、metadata、vendor、oem(都是安卓8.1后新加的安卓分区)
 boot_linux 挂载 rootfs (Linux系统)
 
 从而进入了各自的系统里。
 
 这里还有个Misc分区没说到,Misc只是一个附加启动命令,如果被烧写,loader(或者uboot)就会读取他的内容并执行(主要是用来进入安卓的recovery模式,还有RK的厂测模式),成功执行完会清空misc分区,这样下次运行时候就不会再次进入。
 
 
 那么这么解释完同学们是否已经对RK3399PRO的分区表和启动顺序有了大致的了解了呢。
 
 | 
 
x本帖子中包含更多资源您需要 登录 才可以下载或查看,没有帐号?立即注册  |