- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Linux内核开发框架学习常见linux内核文件的区别vmlinux 编译出来的最原始的内核文件,未压缩。zImagevmlinux经过gzip压缩后的文件。bzImage bz表示“big zImage”,不是用bzip2压缩的。两者的不同之处在于,zImage解压缩内核到低端内存(第一个640K),bzImage解压缩内核到高端内存(1M以上)。如果内核比较小,那么采用zImage或bzImage都行,如果比较大应该用bzImage。uImageU-boot专用的映像文件,它是在zImage之前加上一个长度为0x40的tag。vmlinuzbzImage/zImage文件的拷贝或指向bzImage/zImage的链接。initrd“initial ramdisk”的简写。一般被用来临时的引导硬件到实际内核vmlinuz能够接管并继续引导的状态。linux内核源码目录结构arch目录包括了所有和体系结构相关的核心代码。它下面的每一个子目录都代表一种Linux支持的体系结构,例如i386就是Intel CPU及与之相兼容体系结构的子目录。PC机一般都基于此目录。include目录包括编译核心所需要的大部分头文件,例如与平台无关的头文件在include/linux子目录下。init目录包含核心的初始化代码(不是系统的引导代码),有main.c和Version.c两个文件。这是研究核心如何工作的好起点。mm目录包含了所有的内存管理代码。与具体硬件体系结构相关的内存管理代码位于arch/*/mm目录下。drivers目录是系统中所有的设备驱动程序。它又进一步划分成几类设备驱动,每一种有对应的子目录,如声卡的驱动对应于drivers/sound。ipc目录包含了核心进程间的通信代码。modules目录存放了已建好的、可动态加载的模块。fs目录存放Linux支持的文件系统代码。不同的文件系统有不同的子目录对应,如ext3文件系统对应的就是ext3子目录。Kernel内核管理的核心代码放在这里。同时与处理器结构相关代码都放在arch/*/kernel目录下。net目录里面是核心的网络部分代码,其每个子目录对应于网络的一个方面。lib目录包含了核心的库代码,不过与处理器结构相关的库代码被放在arch/*/lib/目录下。scripts目录包含用于配置核心的脚本文件。documentation目录该目录是对其它每个目录作用的具体说明。Uboot加载内核的流程uboot通过执行bootm 0令来启动 do_bootm (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){bootm_start(cmdtp, flag, argc, argv);ret = bootm_load_os(images.os, load_end, 1);boot_fn = boot_os[images.os.os];// 选择启动函数,即do_bootm_linuxboot_fn(0, argc, argv, images);// 执行do_bootm_linux}int do_bootm_linux(int flag, int argc, char *argv[], bootm_headers_t *images){intmachid = bd-bi_arch_number;void(*theKernel)(int zero, int arch, uint params);// theKernel指向内核入口地址theKernel = (void (*)(int, int, uint))images-ep;// 在启动内核之前做一些清理工作cleanup_before_linux ();// 启动内核theKernel (0, machid, bd-bi_boot_params);}在启动内核之前,uboot必须为uImage准备以下准备:?1. CPU 寄存器的设置:R0=0;R1=Machine ID(即Machine Type Number,定义在linux/arch/arm/tools/mach-types);R2=内核启动参数在 RAM 中起始基地址;?2. CPU 模式:必须禁止中断(IRQs和FIQs);CPU 必须 SVC 模式;?3. Cache 和 MMU 的设置:MMU 必须关闭;指令 Cache 可以打开也可以关闭;数据 Cache 必须关闭;uImage中64字节的头信息结构体如下:#define IH_NMLEN32/* Image Name Length*/typedef struct image_header {uint32_tih_magic;/* Image
文档评论(0)