得到的内核错误信息:Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-
block(0,0)。从错误信息字面意思来分析,就是内核试图挂载根文件系统时失败,失败的原因是
unknown-block(不能识别的块设备)
Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(0,0)下面是打印的是
报错的的函数。
错误信息的来源:dump_backtrace在dump_stack里面,dump_stack在panic里面,panic在
mount_block_root里面,mount_block_root在mount_root里面,mount_root在
prepare_namespace里面,prepare_namespace在kernel_init里面,最终找到了kernel_init函数。
分析这个错误出现的原因。unknown-block(0,0)。在kernel启动时uboot会传给内核一个cmdline,
其中用root=xx来指定了rootfs在哪个设备上,内核就会到相应的地方去挂载rootfs。譬如我们传参
中:root=/dev/mmcblk0p2,这里的/dev/mmcblk0p2就是rootfs的设备地址,这个设备文件编号的
含义就是mmc设备0的第2个分区(设备0就是在SD0通道上的设备,也就是iNand),这里的问题
就是没找到mmc设备0的第2分区。
下一步问题:为什么没找到mmc设备0的第2分区。一定是因为kernel启动过程中加载mmc驱动的
时候有问题,驱动没有发现mmc设备0.问题定位在MMC相关的驱动方面。
分析问题的方法:用正常启动的kernel打印的信息做对比。
正常启动的kernel找到iNand:
正常启动的kernel找到外支的SD卡:
对比九鼎版本的内核启动信息,启动异常并没有打印出这些信息出来,即可发现我们的内核启动并
没有找到MMC设备(内置的iNand和外置的SD卡都没找到),没找到肯定是驱动的问题,这就要
去移植MMC驱动了。
2.网卡驱动的移植
网卡驱动移植ok时,启动信息为:
网卡驱动移植异常时,启动信息为:
确认make menuconfig中添加DM9000是否等于Y
mach-smdkc110.c中的smdkc110_machine_init是整个开发板的所有硬件的初始化函数,在这里加载了的硬件将来启动时就会被初始化,在这里没有的将来启动时就不管。
里面的smdkc110_devices和smdkc110_dm9000_set()这两个地方是和DM9000有关的,要分别去
做移植。
移植思路:参考别人移植好了的,对比自己的代码看哪里不一样,读懂代码进行移植。
修改相应的配置参数:
DM9000相关的数据配置在arch/arm/plat-s5p/devs.c中更改。
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年嵌入式&物联网开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!
有帮助,需要这份全套学习资料的朋友可以戳我获取!!**](https://bbs.csdn.net/topics/618654289)
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!