linux-kernel - 为什么内核的加载地址,ramdisk 在启动时很重要?

标签 linux-kernel boot

我正在处理 android boot.img,它是压缩内核、ramdisk 和 dtb 的组合。我从 uboot 的串行控制台日志中看到有关启动过程的信息,这是触发我好奇心的部分

CPU:   Freescale i.MX6Q rev1.2 at 792 MHz
CPU:   Temperature 27 C
Reset cause: POR
Board: MX6-SabreSD
I2C:   ready
DRAM:  1 GiB
PMIC:  PFUZE100 ID=0x10
MMC:   FSL_SDHC: 0, FSL_SDHC: 1, FSL_SDHC: 2
No panel detected: default to Hannstar-XGA
Display: Hannstar-XGA (1024x768)
In:    serial
Out:   serial
Err:   serial
check_and_clean: reg 0, flag_set 0
Fastboot: Normal
flash target is MMC:1
Net:   FEC [PRIME]
Normal Boot
Hit any key to stop autoboot:  3  2  1  0 
boota mmc1 
kernel   @ 14008000 (7272352)
ramdisk  @ 15000000 (869937)
fdt      @ 14f00000 (44072)
## Booting Android Image at 0x12000000 ...
Kernel load addr 0x14008000 size 7102 KiB
Kernel command line: console=ttymxc0,115200 init=/init video=mxcfb0:dev=hdmi,1920x1080M@60,bpp=32 video=mxcfb1:off video=mxcfb:off video=mxcfb3:off vmalloc=256M androidboot.console=ttymxc0 consolebalank=0 androidboot.hardware=freescale cma=384M
## Flattened Device Tree blob at 14f00000
   Booting using the fdt blob at 0x14f00000
   Loading Kernel Image ... OK
   Using Device Tree in place at 14f00000, end 14f0dc27
switch to ldo_bypass mode!

Starting kernel ...

内核地址为14008000,ramdisk 15000000,fdt 14f00000。
我发现这些值保存在 boot.img header 中,当我手动修改这些值时,即使未修改实际内容,图像也不会启动。

为什么这个地址如此重要?为什么必须是这些值?为什么不是其他值?

我自己的猜测之一是:
这些加载地址值是在内核中硬编码的,因此如果我在 boot.img 头文件中更改它,将会导致副作用。详细阐述我自己的理论,将内核加载到“修改后的”加载地址不会有问题。但是当实际执行这些行时,它会导致严重的问题,因为这些代码被固定为与正确的“加载地址”一起工作。

我的理论错了吗?如果是这样,如果你能纠正我,我将不胜感激。

最佳答案

U-boot 完成后,它需要将进一步的执行移交给内核,以便内核负责所有后续进程。另外内核有一些对初始化板必不可少的例程。
这组例程有一个入口点 start_kernel() .在此之前还调用了一些其他例程来执行 start_kernel .可以通过这个识别linker script而这个 init.S .

为了维持在这个过程中的执行,内核需要从一个特定的地址开始,而且它的数据段和其他内存也与之相连,以便以适当的方式加载和运行所有这些,需要提供准确的内存位置。

使用这个内核需要设备树 blob 来探测连接到它的设备和 rootfs 来启动用户空间,在这里加载设备树和 rootfs 需要精确的偏移量,以便任何数据都不会丢失或损坏。每个字节对于所有这些执行都很重要。

因此,为了安全启动,所有这些值都存储在引导加载程序的配置中。

关于linux-kernel - 为什么内核的加载地址,ramdisk 在启动时很重要?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36427023/

相关文章:

c - 执行USB/Pendrive中编译的C

windows - 列出机器上安装的操作系统

linux boot splash plymouth 日志记录

Linux:/var/log/syslog 段错误消息格式?每个参数是什么意思?

linux - initrd 和 initramfs 的区别?

linux - Yocto Bitbake - Git Fetch 总是卡住

linux - 为什么我们需要 linux 中的 swapper 任务?

linux - TBOOT : DMAR not found

linux - Linux下的签名可执行文件

c - 在 4.3.0-sabayon linux 中编译 'hello world' 内核模块时遇到问题