首先看一下boot的启动流程:Bootloader执行最基本的硬件初始化操作。如关闭中断,关闭看门狗以避免处理器被复位,以及关闭MMU功能,关闭处理器缓存(数据缓存一定要关闭,指令缓存可以打开),设置系统时钟,初始化内存等。这一阶段代码通常由汇编代码编写,为了运行下一阶段的C程序还必须设置好堆栈。如果是从NAND Flash启动,则必须通过NAND Flash控制器将bootloader代码复制到内存。这一阶段一般用C语言编写,大致分为一下几步:1)初始化各种硬件设备,如设置处理器正常工作的时钟频率,初始化串口等。2)检测系统内存,主要是确定系统内存容量以及其地址空间信息。3)将内核映像文件加载到内存。4)准备内核引导参数。5)跳转到内核的第一条指令处,开始执行内核初始化代码,控制权转移到内核代码,bootload的使命结束。
基本上每个架构平台的单板移植都需要以下移植步骤:1、确定架构(比如ARM,MIPS,POWERPC)、平台(比如三星、海思)、单板(fs4412、exynos_origen)2、确认交叉开发环境(更改Makefile的CROSS_COMPILE为arm-linux-)3、配置、编译及烧写(make fs4412_config;make)烧写时要注意环境变量的配置4、查看串口是否有输出如果没有输出首先查找串口驱动上面的问题,再按照整个boot的启动流程判断哪里存在问题。5、查看外围设备是否正常工作(如网卡)6、裁剪(如果使用flash较小就需要针对不需要的功能进行裁剪)