- 3
- 0
- 约1.8万字
- 约 39页
- 2021-12-06 发布于福建
- 举报
U-Boot第二阶段代码分析 初始化本阶段要使用到的硬件设备 系统时钟、初始化串口、UART控制器、机器类型ID等 gd-bd-bi_arch_number = MACH_TYPE_SMDK2440 检测系统内存映射( memory map ) int dram_init (void) { gd-bd-bi_dram[0].start = PHYS_SDRAM_1; gd-bd-bi_dram[0].size = PHYS_SDRAM_1_SIZE; return 0; } U-Boot第二阶段代码分析 U-Boot命令的格式 U-Boot中每 个命令都通过U_BOOT_CMD宏来定义,格式如下: 各项参数的意义如下: name:命令的名字,注意,它不是一个字符串(不要用双引号括起来)。 maxargs:最大的参数个数。 repeatable:命令是否可重复,可重复是指运行一个命令后,下次敲回车即可再次运行。 command:对应的函数指针,类型为(*cmd)(struct cmd_tbl_s*,int,int,char*[] usage:简短的使用说明,这是个字符串。 help:较详细的使用说明,这是个字符串。 U_BOOT_CMD(name,maxargs,repeatable,command,”usage”,”help”) U-Boot第二阶段代码分析 为内核设置启动参数 U-Boot也是通过标记列表向内核传递参数。 在配置文件include/configs/smdk2440.h中增加如下两个配置项: 对于ARM架构的CPU,都是通过lib_arm/armlinux.c中的do_bootm_linux函数来启动内核 #define CONFIG_SETUP_MEMORY_TAGS 1 #define CONFIG_CMDLINE_TAG 1 theKernel (0, bd-bi_arch_number, bd-bi_boot_params) 机器类型ID 标记列表的开始地址 1-4 U-Boot的常用命令 帮助命令help 下载命令 tftpboot命令使用TFTP协议从服务器下载文件 nfs命令使用NFS协议下载文件 help 命令名, 比如: help bootm tftpboot [loadAddress] [bootfilename] nfs [1oadAddress][host ip addr:bootfilename] U-Boot的常用命令 Nand Flash操作命令 环境变量命令 “nand info” 查看NAND Flash信息 “nand erase [clean] [off size]”擦除NAND Flash “nand read[.jffs2] addr off size” “nand write.yaffs addr off size” “nand read.yaffs addr off size” “nand write.yaffs addr off size” “printenv”命令打印全部环境变量 “setenv name value”设置名字为 name的环境变量的值为value。 “setenv name”删除名字为name的环境变量 “saveenv”将更改后的所有环境变量写入Nand Flash中 U-Boot的常用命令 启动命令 “bootm [addr[arg…]]” 命令启动存放在地址adds处的U-Boot格式的映象文件 “go addr[arg…]” 启动存放在地址addr处的二进制文件 “nboot[[[loadAddr] dev] offset]” 命令将NAND Flash设备dev上偏移地址off处的映象文件复制到内存loadAddr处,然后,如果环境变量autostart的值为“yes”,就启动这个映象 U-Boot命令使用实例 制作内核镜像文件 烧写内核镜像文件uImage arm-linux-objcopy –o binary –R .note –R ment –S vmlinux linux.bin gzip -9 linux.bin mkimage –A arm –O linux –T kernel –C gzip –a 0–e 0–n “Linux Kernel Image” –d linux.bin.gz uImage tftp 0uImage 或 nfs 001:
原创力文档

文档评论(0)