移植u-boot和linux3.4.2内核到s3c2440
开发环境:Gcc3.4.2,Linux3.4.2 内核,Ubuntu16.04,S3C2440 开发板 技术框架:裸板启动流程、重定位、内存分布、u-boot 裁剪、内核裁剪、移植驱动到3.4.2内核 职责描述:修改底层汇编代码实现u-boot支持S3C2440、修改代码支持Nand、NorFlash、DM9000 网卡、裁剪u-boot制作根文件系统、裁剪内核、移植驱动(Nand、NorFlash、DM9000 网卡)
1.介绍:
uboot > 启动内核 > 挂载根文件系统 > 执行应用程序
1.1 uboot打补丁 、编译、烧写、试验;
1.2 uboot功能、结构,结合Makefile分析;
1.3 uboot源码分析:
汇编实现:Start.S (硬件相关的知识 (裸机开发/单片机方向):)
第一个阶段:
设置管理模式 ? 关闭看门狗 ? 关中断 ? 初始化CPU (blne cpu_init_crit) (清理cache、关闭MMU、初始化SDRAM) ? 设置栈 ? 初始化时钟(bl clock_init) ? Flash > SDRAM ? 清理bss端 ? 调用start_armboot
第二个阶段: (1.从Flash读出内核…2.启动内核)
1.跳到C函数里,实现一些初始化(nand_init、flash_init…),然后会看见 main_loop
2.main_loop: 在这个循环函数下面有两个函数,s =getenv(“bootcmd”) 、 run_command(s,0)…
3.环境变量 bootcmd: (我们设置的环境变量…)
两个变量 : 1.nand read.jffs 0x30007Fc0 kernel(从kernel读 到 0x30007Fc0…) 2.bootm 0x30007Fc0(bootm跳到0x30007Fc0这个地址)
4.到底是怎样实现将 “环境变量” >>> 转换为具体实现的函数 ???
4.1 解析字符串会跳到这个段(_u_boot_cmd_start / _u_boot_cmd_start)里面去找 结构体…
4.2 链接脚本里设置的段
4.3 U_BOOT_CMD设置结构体 >>> 强制设置段 .boot_cmd 属性… 4.4 所以bootm设置了一个函数 do_bootm 放在结构体里(放在了.boot_cmd段) 4.5 源码上新加一个 “hello”的命令…
1.4 uboot启动内核分析:
1.nand read.jffs2 0x30007fc0 kenal;
kenal 分区——内核在Nand Flash 上的存放位置
分区地址,在配置文件里面写死的…
bootm 0x30007FC0;
为什么是拷贝到0x30007fc0 ???;
因为内核的 in_load 加载地址 是 0x30008000 0x30008000 - 64(头文件的大小) = 0x30007fc0…加快启动速度…
do_bottm_linux
1.设置一些内核启动参数(tag):
在某个地址0x30001000,按照某个格式tag,存放数据…其中tag就是结构体
2.跳到入口地址:
自己编写uboot:
1.硬件的初始化
2.在main.c函数里面实现nand read 和 bottm:
|