关于内核启动流程涉及内容较多而且复杂,过度的分析意义不大,因此,这里不做详细讲解,只做一个大概的介绍。初学者只做了解,有一定基础的可以深入理解。
内核镜像被uboot加载到内存空间之后,获得控制权,内核启动流程开始。在前面章节讲解zImage生成过程的时候说过内核镜像image是被压缩进zImage之中的。所以,内核获得控制权之后,第一件事,是解压缩内核镜像。解压缩工作由arch/arm/boot/compressed/head.S完成,head.S在解压完zImage之后将生成的image镜像重定位到内核入口地址0X80008000,并跳转到此处执行image。
打开arch/arm/kernel/vmlinux.lds可以找到内核入口ENTRY(stext):
而stext存在于arch/arm/kernel/head.S中:
在stext下有一个__mmap_switched函数:
该函数存在于arch/arm/kernel/head-common.S,其中有一句跳转指令:b start_kernel
从start_kernel函数开始,内核进入C语言部分,完成内核的大部分初始化工作。start_kernel函数存在于init/Main.c中:
函数在最后调用rest_init函数:
此函数中调用了kernel_init函数,kernel_init函数完成了设备驱动程序的初始化,并启动了用户进程: