微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > 嵌入式系统设计讨论 > 系统移植之bootloader移植

系统移植之bootloader移植

时间:10-02 整理:3721RD 点击:

钟,初始化内存等。这一阶段代码通常由汇编代码编写,为了运行下一阶段的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较小就需要针对不需要的功能进行裁剪)



Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top