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 Environment valid? */ unsigned long fb_base; /* base address of frame buffer */ #ifdef CONFIG_VFD unsigned char vfd_type; /* display type */ #endif #if 0 unsigned long cpu_clk; /* CPU clock in Hz! */ unsigned long bus_clk; unsigned long ram_size; /* RAM size */ unsigned long reset_status; /* reset status register at boot */ #endif void **jt; /* jump table */ } gd_t; 在同一个文件中有如下定义: #define DECLARE_GLOBAL_DATA_PTR register volatile gd_t *gd asm ("r8") 在需要使用gd 指针的时候,只需要加入DECLARE_GLOBAL_DATA_PTR 这句话就可以了。可以知道,gd 指针始终是放在r8中的。 其中的第一个变量,bd_t 结构体,定义于 include/asm-arm/u-boot.h 中: typedef struct bd_info { int bi_baudrate; /* serial console baudrate */ unsigned long bi_ip_addr; /*...