耗时2个星期,uboot的代码终于看完了,,他的结构比较复杂,最重要的是要搞清楚层次,有条线移植贯穿下去才不会被搞得晕头转向哦 ,给你们看一下我的uboot学习线路,
start.s-----start_armboot()------main_loop()--------do_bootm()------do_bootm_linux()
1,start.s主要完成的是CPU的基本设置,比如设置位SVC模式,关闭watchog,关闭中断,关闭MMU(哥当时就笑了,
当然,这也提醒和我一样广大的同学们要在学习中注重基础,为什么要关MMu? 因为uboot中所有对地址的操是使用物理地址,在的实地址,不存在虚拟地址,因此MMU必须关闭。晓得了不),还有设置堆栈,最后将剩下的uboot 搬到SDRAM(有人说是将全部的uboot代码搬过去,有 的又说是只讲 stage2的代码搬过去,到底是哪个不清楚,不过这个问题没必要纠结,没什么影响)。
2,start_armboot()主要完成的是对板子的外设的初始化,串口啊,LCD啊,NAND啊,设置一下环境变量啊,这个函数中重点有3个结构体,gd,bd,sequence,搞清楚就ok了
3,mainloop简单的说就是在板子上电延时的那会,如果有按键按下,则进入交互模式,就是一直解析你输入的命令,如果没有按下,则继续往下走,启动kernel去
4,dobootm主要是解析kernel的头,制作uboot可以启动的kernel时,需要在前面加头,头的内容包括有什么类型的映像,什么类型的操作系统,还有怎么压缩的等,最后还完成一个重要的工作就是将kernel搬到SDRAM中,接着调用do_bootm_linux()
5,do_bootm_linux()做的就比较简单了,设置一下启动参数,然后直接启动内核,over
当然,这只是大体的框架,更细致的工作要留待各位去完成,看了网上很多高手的文章,今天我也贡献一下自己的力量,希望对你们有所帮组