【系统启动过程简介】
2016-04-23 21:05
141 查看
【系统启动过程简介】 初始化代码读取uboot到内存里面,然后跳转到uboot那里去执行uboot,uboot初始化必要的硬件,加载一些驱动,其中包括nand flash的驱动,然后根据uboot里面设置的一个启动命令:nand read 0x30007FC0 0x100000 0x200000;bootm 0x30007FC0 意思就是,先去读取nand flash,从0x100000开始,长度为0x200000的数据到memory的0x30007FC0处,然后bootm表示从memory的0x30007FC0开始运行。 也就是去运行内核镜像了。 然后,内核会自己解压缩,然后执行, 初始化硬件, 加载驱动模块, 最后去挂载rootfs, #define CONFIG_BOOTARGS "root=/dev/mtdblock2 rw init=/linuxrc console=ttyS0,115200 mem=16M rootfstype=yafffs2" 此文件系统,也是你实现自己用相应的文件系统制作工具,制作的,然后烧写到对应的位置的。 上面中root=/dev/mtdblock2,表示,要去/dev/mtdblock2,也就是mtd的第3个分区,去加载。 而这里的mtd的第3个分区具体对应的nand flash中的的地址,是你在内核中,一般是在core.c自己定义的的nand flash的分区。 一般是uboot是第一个分区,内核kernel是第二个,然后就是rootfs是第三个分区,也就是/dev/mtdblock2。 例如分区:static struct mtd_partition rm9200_partitions[3] ={{ /* uboot 256K */ .name = "uboot", .size = 0x40000, .offset = 0}, { /* kernel 1.768M */ .name = "kernel", .size = 0x1C0000, .offset = 0x40000}, { /* rootfs 2M */ .name = "rootfs", .size = 0x200000, .offset = 0x200000}, };如果按照上面分区,定义的/dev/mtdblock2的起始地址是0x200000,还算成大小是2M的位置,然后,内核启动挂载rootfs的时候,就是,以上面从uboot传过来的参数中yaffs2格式,到nand flash 的2M的地址读取并加载rootfs,加载完成后,这样,里面对应的根目录,以及所有的文件,文件夹就都可以识别了。 然后才会去读取并运行初始化脚本相关的东西,最后初始化console控制台,然后才能看到那个常见的#,才可以输入命令,比如ls,才可以和系统交互。所以,实际就是这个rootfs,对应着mtdblock2,对应的某个nand flash上的地址,比如此处的2M的地方。而不是内核kernel这个文件映射的。
相关文章推荐
- 与人工智能相关的创业公司或团队
- gdb调试正在运行的进程
- 宽搜,noip2013华容道,醉了。。
- 浅谈 PreparedStatement 和 Statement区别!!!!!
- 剑指offer-替换空格
- 使用Intent传递数据
- Markdown编辑器使用方法
- Linux下安装php环境并且配置Nginx支持php-fpm模块
- View6.2中viewPM和微软用户配置漫游的应用 推荐
- queue队列容器
- 关注的机器视觉领域信息
- XmlSerializer的使用
- linux 帮助命令
- 汇编语言学习笔记(5)——[bx]和loop
- tomcat jvm内存调优,OutOfMemoryError
- cxf web service 解决返回的json格式数据乱码问题
- bzoj3676【APIO2014】回文串
- 为什么涨工资的是我和他
- 生成N个节点随机二叉查找树的函数 具有从1到N的不同的关键字
- jquery 制作无缝轮播的焦点图