免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5613 | 回复: 19
打印 上一主题 下一主题

[实践] rootfs时启动失败,求助! [复制链接]

论坛徽章:
4
酉鸡
日期:2014-03-21 23:19:50狮子座
日期:2014-08-01 22:11:40酉鸡
日期:2015-01-10 21:31:442015年辞旧岁徽章
日期:2015-03-03 16:54:15
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-01-25 01:05 |只看该作者 |倒序浏览
30可用积分
本帖最后由 chishanmingshen 于 2014-02-12 08:15 编辑

Q1:
用busybox1.22制作了rootfs,rootfs显示已经挂载成功了,之后就挂住了,
显示如下:request_module:runaway loop modprobe binfmt-464c
kernel是2.6.32,为何停住了?求助,谢谢!
上面的问题不打算跟了, 谢谢大家的热心帮助!!

Q2:在initramfs时使用的bash,它依赖于initramfs的lib。那么,真根挂上后,bash怎么转为依赖真根的lib?
已解决:应该是kernel_execve替换实现的。


Q3:ramdisk除了直接用作真根的嵌入式场景,现在还有哪种应用场景?求指点,谢谢!


Q4:即使不带CONFIG_INITRAMFS_SOURCE 选项,__initramfs_size也非0吧,应该有default内置。那么何时为0呢???

论坛徽章:
0
2 [报告]
发表于 2014-01-25 10:50 |只看该作者

论坛徽章:
4
酉鸡
日期:2014-03-21 23:19:50狮子座
日期:2014-08-01 22:11:40酉鸡
日期:2015-01-10 21:31:442015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2014-01-25 11:11 |只看该作者
本帖最后由 chishanmingshen 于 2014-01-25 20:25 编辑

回复 2# lenky0401

[/code]你这个网站是干啥的,没看明白。。。



   

论坛徽章:
4
酉鸡
日期:2014-03-21 23:19:50狮子座
日期:2014-08-01 22:11:40酉鸡
日期:2015-01-10 21:31:442015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2014-01-25 16:00 |只看该作者
本帖最后由 chishanmingshen 于 2014-01-25 21:51 编辑

求助了,解决了才能回家过年。。。

http://bbs.chinaunix.net/thread-2083891-1-1.html  说可能是arch不同的问题,但是我的情况是都是同一个arch的。

http://blog.csdn.net/ab198604/article/details/5755391 说可能是sh的问题,我看了下busybox的编译选项,也是ok的。

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
5 [报告]
发表于 2014-01-26 09:10 |只看该作者
/* If modprobe needs a service that is in a module, we get a recursive
         * loop.  Limit the number of running kmod threads to max_threads/2 or
         * MAX_KMOD_CONCURRENT, whichever is the smaller.  A cleaner method
         * would be to run the parents of this process, counting how many times
         * kmod was invoked.  That would mean accessing the internals of the
         * process tables to get the command line, proc_pid_cmdline is static
         * and it is not worth changing the proc code just to handle this case.
         * KAO.
         *
         * "trace the ppid" is simple, but will fail if someone's
         * parent exits.  I think this is as good as it gets. --RR
         */
        max_modprobes = min(max_threads/2, MAX_KMOD_CONCURRENT);
        atomic_inc(&kmod_concurrent);
        if (atomic_read(&kmod_concurrent) > max_modprobes) {
                /* We may be blaming an innocent here, but unlikely */
                if (kmod_loop_msg++ < 5)
                        printk(KERN_ERR
                               "request_module: runaway loop modprobe %s\n",
                               module_name);
                atomic_dec(&kmod_concurrent);
                return -ENOMEM;
        }
从代码看,看似modprobe并发数(或迭代次数)太高,不知是否有这样的情况。

论坛徽章:
208
巨蟹座
日期:2013-09-02 09:16:36卯兔
日期:2013-09-02 20:53:59酉鸡
日期:2013-09-05 21:21:45戌狗
日期:2013-10-15 20:51:17寅虎
日期:2013-10-18 21:13:16白羊座
日期:2013-10-23 21:15:19午马
日期:2013-10-25 21:22:48技术图书徽章
日期:2013-11-01 09:11:32双鱼座
日期:2013-11-01 20:29:44丑牛
日期:2013-11-01 20:40:00卯兔
日期:2013-11-11 09:21:32酉鸡
日期:2013-12-04 19:56:39
6 [报告]
发表于 2014-01-26 09:23 |只看该作者

论坛徽章:
0
7 [报告]
发表于 2014-01-26 09:23 |只看该作者
是不是反复挂载了,检查一下

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
8 [报告]
发表于 2014-01-26 10:38 |只看该作者
这个问题我遇到过。先请问lz用的是什么arch?
我以前用的是mips的。mips有不同的abi,如果只编译了支持64的,那么如果二进制的程序是n32或者o32等abi的时候就会出这个问题
建议不从busybox着手,多更改一下linux kernel的配置

论坛徽章:
1
拜羊年徽章
日期:2015-03-03 16:15:43
9 [报告]
发表于 2014-02-06 10:39 |只看该作者
是不是cross compiling?  如果是, 看看 CROSS_COMPILE flag有无设置

论坛徽章:
3
射手座
日期:2014-08-18 12:15:53戌狗
日期:2014-08-22 09:53:36寅虎
日期:2014-08-22 14:15:29
10 [报告]
发表于 2014-02-06 12:54 |只看该作者
本帖最后由 gaojl0728 于 2014-02-06 13:04 编辑

request_module 会调用rootfs里面的/sbin/modprobe程序加载驱动, 错误的信息看起来是至少有50个modprobe进程卡住了而且很长时间不返回,导致在启动第51个modprobe的时候内核给出了警告信息,
应该是你的rootfs做的有问题, 可以简单地测试下,你把init设成/bin/bash看能不能起来,如果bash也起不来说编译的rootfs就有问题了,可以检查编译选项什么的。
另外可以找个能跑起来的环境测试下你的modprobe是不是真的能run
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP