1,Uboot执行,加载内核load kernel。
2,内核解压。decompress kernel
3,内核启动,加载驱动。 boot kernel
4,Init进程,文件系统挂载,系统配置,加载图形界面。init & mount FS & etc configure & GUI init
Uboot就是bootloader,用来初始化内核区域,内核镜像加载到RAM
下面是第1,2,3步内部汇编过程。
请看arch/arm/boot/compressed/Head.S 中的汇编代码。(我研究的Head.S的内核路径,你的可能不是,大同小异。例如Header_32.S)
初始化一个临时内核栈
用0初始化内核数据,位于_edata 和_end位置之间。
arch/arm/boot/compressed/misc.c 中decompress_kernel来解压内核镜像。解压缩的内核执行,打印出你熟悉的Uncompressing Linux...OK booting the kernel。
第4部没啥说的。