linux升级内核,出现:mount:could not find filesystem‘/dev/root’的解决方法

简介:
+关注继续查看

linux升级内核,出现:mount:could not find filesystem‘/dev/root’的解决方法


A: 是由于无法加载磁盘硬件的模块驱动。

解决方式主要是通过make menuconfig中加载sata sici的devices设备模块驱动。常用的驱动模块如下:


insmod /lib/uhci-hcd.ko 

insmod /libohci-hcd.ko 

insmod /lib/ehci-hcd.ko 

insmod /lib/jbd.ko

insmod /lib/ext3.ko

insmod /lib/scsi_mod.ko

insmod /lib/sd_mod.ko

insmod /lib/libata.ko

insmod /lib/ahci.ko

B: initrd是旧版本mkinitrd生成的。

  解决方法就是加入对旧版sysfs路径的支持,方法如下:


  1)、通过make menuconfig选中以下对应的选项

1
2
General setup -->
              [*] enable deprecated sysfs features to support old userspace tools

2)、修改.config文件

  修改.config文件中CONFIG_SYSFS_DEPRECATED_V2,将原本被注释掉的


       

1
CONFIG_SYSFS_DEPRECATED_V2 改成CONFIG_SYSFS_DEPRECATED_V2=y


注 : 修改这项是因为旧版的mkinitrd及其nash在内核没有CONFIG_SYSFS_DEPRECATED_V2参数时默认使用旧版sysfs路径格式,然后重新编译内核,从而在新内核下无法正确访问/sys内的硬盘信息节点。


    由于我编译内核所使用的配置文件是/boot/config-2.6.18-53.el5,也就是当前正在使用的内核的配置文件,所以,是由B原因引起的,而不是A原因。


    在百度中,搜到别人编译linux-2.6.33的内核在initrd中还有一个问题,虽然在linux-2.6.34中这个bug被修正了。但还是通过这篇文章学习了一个命令cpio。


    在linux-2.6.33中,假如在升级重启后会报的错误insmod: error inserting ‘/lib/dm-region-hash.ko’: –1 File exits,这是 由于initrd里面的init中加载dm-region-hash.ko这 个模块重复了,因此需要修改生成的initrd文件(不是所有的机器都会出现这个错), 修改的方式如下


a) 解压initrd

1
2
3
4
5
6
7
8
9
# cp /boot/initrd-2.6.33.img /tmp
# cd /tmp/
# ls
initrd-2.6.33.img
# mkdir newinitrd
# cd newinitrd/
# zcat ../initrd-2.6.33.img |cpio -i
# ls
bin  dev  etc  init  lib  proc  sbin  sys  sysroot


b) 编辑init, 删掉重复的两行

1
2
3
4
echo "Loading dm-region-hash.ko module"
insmod /lib/dm-region-hash.ko
echo "Loading dm-region-hash.ko module"
insmod /lib/dm-region-hash.ko

c) 重新打包initrd

1
2
3
# find .|cpio -c -o > ../initrd
# cd ..
# gzip -9 < initrd > initrd-2.6.33.img


d) 将initrd重 新复制到/boot目录下

1
#cp initrd-2.6.33.img /boot


11) 重新启动


启动成功。




      本文转自灬落魄灬  51CTO博客,原文链接:http://blog.51cto.com/smoke520/1892984,如需转载请自行联系原作者



相关文章
|
4天前
|
安全 Linux 数据安全/隐私保护
Linux DirtyPipe 内核提权漏洞 (CVE-2022-0847)
它是自 5.8 以来 Linux 内核中的一个漏洞,它允许覆盖任意只读文件中的数据。这会导致权限提升,因为非特权进程可以将代码注入根进程。
29 1
|
4天前
|
安全 Linux
Linux内核OverlayFS子系统权限提升漏洞(CVE-2023-0386)
Linux内核OverlayFS子系统权限提升漏洞,在Linux内核的 OverlayFS子系统中,当用户将一个具有权限的文件从一个nosuid挂载点复制到另一个挂载点时,未经授权的攻击者可以执行setuid文件,导致权限提升。
24 1
|
5天前
|
缓存 安全 Linux
Linux内核提权漏洞—CVE-2022-0874
Linux内核提权漏洞—CVE-2022-0874
40 1
|
11天前
|
存储 Ubuntu Linux
查看 Linux 内核以及系统版本的几种方法
查看 Linux 内核以及系统版本的几种方法,以 Ubuntu 为例,介绍几个用来查看系统与内核版本的命令,拿起小本本记录下来!
197 1
|
18天前
|
Linux Android开发 C++
一个超棒的开源解读项目【Linux内核揭秘】,一定不要错过啦!
一个超棒的开源解读项目【Linux内核揭秘】,一定不要错过啦!
25 0
|
20天前
|
Linux
使用Linux内核里的spi屏驱动-fbtft
使用Linux内核里的spi屏驱动-fbtft
27 0
|
9月前
|
Linux
Linux CentOS7.x 升级内核的方法
Linux CentOS7.x 升级内核的方法
|
Linux 测试技术 虚拟化
重大升级!英特尔 CPU 内购功能 (SDSI)已添加至 Linux 5.18 内核中
重大升级!英特尔 CPU 内购功能 (SDSI)已添加至 Linux 5.18 内核中
112 0
重大升级!英特尔 CPU 内购功能 (SDSI)已添加至 Linux 5.18 内核中
|
Linux
小白Linux教程——手动升级内核
    作为一个底层的硬件工程师,免不了和Linux打交道,而曾经有一段时间,升级Linux内核让很多用户打心里有所畏惧。在那个时候,升级内核包含了很多步骤,也需要很多时间。
1411 0
相关产品
云迁移中心
推荐文章
更多