u-boot 向linux 内核传递启动参数(详细) U-BOOT 在启动内核时,会向内核传递一些参数
BootLoader 可以通过两种方法传递参数给内核,一种是旧的参数结构方式(parameter_struct) ,主要是 2
6 之前的内核使用的方式
另外一种就是现在的 2
6 内核在用的参数链表 (tagged list) 方式
这些参数主要包括,系统的根设备标志,页面大小,内存的起始地址和大小,RAMDISK 的起始地址和大小,压缩的RAMDISK 根文件系统的起始地址和大小,当前内核命令参数等而这些参数是通过 struct tag 来传递的
U-boot 把要传递给 kernel 的东西保存在 struct tag 数据结构中,启动 kernel 时,把这个结构体的物理地址传给 kernel ;Linux kernel 通过这个地址分析出 u-boot 传递的参数
大家都知道 U-Boot启动的时候会将启动参数的地址放入 R2 中,然后再启动内核
首先看两个重要的数据结构: 第一个是global_data,定义在include/asm-arm/global_data
h 文件中: typedef struct global_data { bd_t *bd; unsigned long flags; unsigned long baudrate; unsigned long have_console; /* serial_init() was called */ unsigned long reloc_off; /* Relocation Offset */ unsigned long env_addr; /* Address of Environment struct */ unsigned long env_valid; /* Checksum of Env