移植
不同架构的处理器指令集不兼容,即便是相同的处理器架构,板卡不同驱动代码也不兼容
Linux是一个通用的内核并不是为某一个特定的处理器架构或板卡设计的,所以从官方获取Linux源码后我们要先经过相应的配置使其与我们当前的硬件平台相匹配后才能进行编译和安装
安装过程
开发板启动过程
1.开发板上电后首先运行SOC内部iROM中固化的代码(BL0),这段代码先对基本的软硬件环境(时钟等...)进行初始化,然后再检测拨码开关位置获取启动方式,然后再将对应存储器中的uboot搬移到内存,然后跳转到uboot运行
2. uboot开始运行后首先对开发板上的软硬件环境做进一步初始化,然后将linux内核、设备树(dtb)、根文件系统(rootfs)从外部存储器(或网络)搬移到内存,然后跳转到linux运行
3. linux开始运行后先对系统环境做初始化,当系统启动完成后,Linux再从内存中(或网络)挂载根文件系统
CPU能够读写的范围大小即为 地址空间-->由地址总线宽度决定(32位)
2^32 = 4G 为4412可读写空间, 4G内存进行划分得地址映射表(各个地址的用途)
刚上电时PC指向0地址 iROM(inter read only memory)中的BL0;
ROM: read only memory 只读程序 。 4412扩了1G内存 0x4000 000 - 0x8000 0000
RAM: random access memory 随机存取存储器
EMMC -> 硬盘,断电数据不丢失
想要执行,先要放到内存RAM中,供CPU去读取执行
上电后:
1.首先执行iROM中的BL0,
BL0做了三件事:
a.初始化时钟,内存等;b.读取拨码开关状态(
SD卡启动);c.
SD卡内容uboot放到内存RAM中;
非EMMC中的uboot,因为非EMMC启动
2.uboot将linux从EMMC中搬到RAM内存中;
3.uboot将dtb(device tree)从EMMC中搬到RAM内存中;
4.uboot将rootfs从EMMC中搬到RAM内存中;
5.uboot完成任务停止,linux 启动,做一些初始化
linux + dtb --> linux