Linux kernel在“make install”时的问题分析总结
编译KVM后安装时的经常有错误提示,make install 也可能会遇到类似的 “ERROR:modinfo:could not find module XXX”的问题,现在我们来分析一些这些问题然后解决掉.
在编译内核后,make install 时可能遇到“ERROR:modinfo: could not find module XXX”的问题,命令行中操作看到的内容如下:
- [root@smilejaylinux-3.12]#makemodules_install
- ..........
- INSTALLsound/soundcore.ko
- INSTALLsound/synth/emux/snd-emux-synth.ko
- INSTALLsound/synth/snd-util-mem.ko
- INSTALLsound/usb/snd-usb-audio.ko
- INSTALLsound/usb/snd-usbmidi-lib.ko
- INSTALLsound/usb/usx2y/snd-usb-usx2y.ko
- DEPMOD3.12.0
- [root@smilejaylinux-3.12]#makeinstall
- sh/root/linux-3.12/arch/x86/boot/install.sh3.12.0arch/x86/boot/bzImage
- System.map"/boot"
- ERROR:modinfo:couldnotfindmodulepower_meter
- ERROR:modinfo:couldnotfindmodulenf_conntrack_ipv4
- ERROR:modinfo:couldnotfindmodulenf_defrag_ipv4
- ERROR:modinfo:couldnotfindmodulenf_conntrack_ipv6
- ERROR:modinfo:couldnotfindmodulenf_defrag_ipv6
- ERROR:modinfo:couldnotfindmodulext_state
- ERROR:modinfo:couldnotfindmodulenf_conntrack
- ERROR:modinfo:couldnotfindmodulei2c_piix4
- ERROR:modinfo:couldnotfindmodulesg
- ERROR:modinfo:couldnotfindmoduleext4
- ERROR:modinfo:couldnotfindmodulembcache
- ERROR:modinfo:couldnotfindmodulejbd2
- ERROR:modinfo:couldnotfindmodulesr_mod
- ERROR:modinfo:couldnotfindmodulecdrom
- ERROR:modinfo:couldnotfindmodulepata_acpi
- ERROR:modinfo:couldnotfindmoduleata_generic
- ERROR:modinfo:couldnotfindmoduleata_piix
原因分析:在make install时,为了让新内核中不缺少所需module,会先检查当前系统已经加载了的module(lsmod命令可查看),然后对比新安装的内核模块,如果新的内核模块中缺少一些module(和当前lsmod命令的输出做对比),就会报“ERROR: modinfo: could not find module power_meter”这样的错误信息.
具体来说,缺少相应module而报错,大致可分为3种情况:
1.确实是缺少了某个module,其解决方法是:如果报的module对于你来说是有用,检查编译kernel时的.config文件,加上对应的配置(配为=m),重新编译和安装modules即可,如果你觉得这个module没啥用,大可不必管它了.
2.新编译的kernel已经将该选项编译进kernel了(.config中选择为=Y),从而不需要生成这个module的.ko文件,系统找不到对应的.ko文件,但是已经在新内核中了,不必理会这个报错,例如,上面的“ERROR: modinfo:could not find module ext4”是因为我将EXT4文件系统模块编译为built-in了,如下:
- [root@smilejaylinux-3.12]#grepEXT4.config
- CONFIG_EXT4_FS=y--phpfensi.com
- #CONFIG_EXT4_FS_POSIX_ACLisnotset
- #CONFIG_EXT4_FS_SECURITYisnotset
- #CONFIG_EXT4_DEBUGisnotset
3.模块的名称变了,用当前系统lsmod命令查找的模块名称,在新编译的内核中找不到module了,只需要检查确认即可,如这里的“ERROR: modinfo:could not find module power_meter”就是这种类型,检查方式如下:
- #当前系统已经加载了power_meter模块
- [root@smilejay~]#lsmod|grepmeter
- power_meter91691
- #但是kernel3.12中该module名称为acpi_power_meter,和'lsmod'查到的power_meterb不一致。
- [root@smilejay~]#find/lib/-name"*power_meter.ko"
- /lib/modules/2.6.32-358.el6.x86_64/kernel/drivers/acpi/power_meter.ko
- /lib/modules/3.12.0/kernel/drivers/hwmon/acpi_power_meter.ko
最后,如果那些错误报的内核模块,你认为不重要或者都经过上面的分析解决后,你就可以忽略这些错误提示了,尽管有这些“ERROR:modinfo:”错误提示,但是kernel还是被正确安装了的,往下继续操作使用即可.
热门评论