QQ登录

只需一步,快速开始

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 19558|回复: 34

编译内核全过程(kernel2.6.7)(原创)

[复制链接]
发表于 2004-8-18 18:07:23 | 显示全部楼层 |阅读模式
编译内核全过程(kernel2.6.7)
    花了几天才编译成功kernel2.6.7,其过程真可谓艰辛.古语有云:"苦尽甘来!"现在终于可以乐上一阵了.由于许多朋友对操作的顺序及某些重要的配置知之甚少或知之不详,往往病急乱投医.
加之网上的信息多且烦杂,使得编译内核成功率不高,甚至造成原来的系统崩溃的也不在少数.我就是其中一个:-)其实,编译内核并不是一件难事.如果能按照正确的方法来操作,最多花上一个半小时就能搞定.是不是很受鼓舞呀!
废话少说,现在我们马上开始.我原来的系统是redhat9.0,内核2.4.20-8,编译的内核2.6.7,仅供参考.
共分为四部分:编译前准备->编译配置->编译过程->运行内核的常见问题
一 编译前准备
1)下载一份内核源代码,我下的是linux-2.6.7.tar.bz2,你可在如下地址下载它或者是更新的版本.
  http://kernel.org/pub/linux/kernel/v2.6/
2) 下载最新版本的module-init-tools( "module-init-tools-3.0.tar.gz" and "modutils-2.4.21-23.src.rpm")
  http://www.kernel.org/pub/linux/kernel/people/rusty/modules/module-init-tools-3.0.tar.gz
  http://www.kernel.org/pub/linux/kernel/people/rusty/modules/modutils-2.4.21-23.src.rpm
3)安装module-init-tools. 它会替代depmod [/sbin/depmod]和其他工具.
       tar -zxvf module-init-tools-3.0.tar.gz
        cd module-init-tools-3.0
        ./configure --prefix=/sbin
        make
        make install
        ./generate-modprobe.conf /etc/modprobe.conf
4)安装modutils-2.4.21-23.src.rpm. 你可能会看到"user rusty and group rusty not existing"的警告. 没关系,你只需强制安装就是了.如果你不对Redhat 9和Redhat 8做这几步, 你将会在"make modules_install"这一步时出现问题.
       rpm -i modutils-2.4.21-23.src.rpm
        rpmbuild -bb /usr/src/redhat/SPECS/modutils.spec
        rpm -Fi /usr/src/redhat/RPMS/i386/modutils-2.4.21-23.i386.rpm
5)解压缩内核源代码.把下载的源代码包放到目录/usr/src下,然后
cd /usr/src
tar xvfj linux-2.6.7.tar.bz2
cd linux-2.6.7
二 编译配置
  在这一部分涉及几个重要模块的配置请,特别注意.一般用"make menuconfig"命令来配置内核.
输入以上命令后出现一个菜单界面,用户可以对需要的模块.下面着重讲几个重要的配置
1)文件系统
  请务必要选中ext3文件系统,
File systems--->
  • Ext3 journalling file system support
  •    Ext3 Security Labels
  • JBD (ext3) debugging support
    以上三项一定要选上,而且要内建(即标*). 这个非常重要,在配置完后一定要检查一下.config文件有没有"CONFIG_EXT3_FS=y"这一项. 如果不是"CONFIG_EXT3_FS=y"而是"CONFIG_EXT3_FS=m",你在运行内核时就会遇上以下错误: pivotroot: pivot_root(/sysroot,/sysroot/initrd) failed
    2)网卡驱动
      请务必把自己网卡对应的驱动编译进内核,比较普遍的网卡是realtek 8139,以下就是这种网卡的配置,以供参考
    Device Drivers--->
    Networking support--->
    Ethernet (10 or 100Mbit)  --->
    <*>  RealTek RTL-8139 C+ PCI Fast Ethernet Adapter support (EXPERIMENTAL)
    <*>  RealTek RTL-8139 PCI Fast Ethernet Adapter support
    3)声卡驱动
      也要选择自己声卡对应的驱动编译进内核,比较普遍的声卡是i810_audio,以下就是这种声卡的配置,以供参考
    Device Drivers --->
    Sound --->
    <*> Sound card support
    Advanced Linux Sound Architecture --->
    <*> Advanced Linux Sound Architecture
    <*> Sequencer support
    < > Sequencer dummy client
    <*> OSS Mixer API
    <*> OSS PCM (digital audio) API
  • OSS Sequencer API
    <*> RTC Timer support
    PCI devices --->
    <*> Intel i8x0/MX440, SiS 7012; Ali 5455; NForce Audio; AMD768/8111
    Open Sound System --->
    < > Open Sound System (DEPRECATED)
        以上三项配置关系到新内核能否正常运行,请备加注意.其他的配置如果不是很了解,大可以按默认的选择.
    三 编译过程
    按如下命令编译,大概需要一个多小时,大可以好好放松一下:-)
    make bzImage
    make modules
    make modules_install
    make install
    运行新内核之前,请检查一下/boot/grub/grub.conf的内容,下面的配置可作参考
    # grub.conf generated by anaconda
    #
    # Note that you do not have to rerun grub after making changes to this file
    # NOTICE:  You have a /boot partition.  This means that
    #          all kernel and initrd paths are relative to /boot/, eg.
    #          root (hd0,0)
    #          kernel /vmlinuz-version ro root=/dev/hdc3
    #          initrd /initrd-version.img
    #boot=/dev/hdc
    default=1
    timeout=10
    splashimage=(hd0,0)/grub/splash.xpm.gz
    title Red Hat Linux (2.6.7)
            root (hd0,0)
            kernel /vmlinuz-2.6.7 ro root=LABEL=/
            initrd /initrd-2.6.7.img
    title Red Hat Linux (2.4.20-
            root (hd0,0)
            kernel /vmlinuz-2.4.20-8 ro root=LABEL=/
            initrd /initrd-2.4.20-8.img

    四 运行内核的常见问题
    1)RPM问题

    进入编译好的内核后,与RPM相关的命令有些不能使用,并出现下列错误:

    rpmdb: unable to join the environment
    error: db4 error(11) from dbenv->open: Resource temporarily unavailable
    error: cannot open Packages index using db3 - Resource temporarily unavailable (11)
    error: cannot open Packages database in /var/lib/rpm
    no packages



    解决方法是执行“export LD_ASSUME_KERNEL =2.2.25”命令,也可以将其写入/etc/bashrc。
    2)Sound问题

    声音部分的模块名也改变了。我的笔记本原来的声卡驱动是i810_audio,现在已改为snd-intel8x0。因此需要把下面的内容添加到/etc/modprobe.conf中:

    alias char-major-14 soundcore
    alias sound snd-intel8x0
    alias sound-slot-0 snd-intel8x0
    alias snd-card-0 snd-intel8x0
    alias sound-service-0-0 snd-mixer-oss
    alias sound-service-0-1 snd-seq-oss
    alias sound-service-0-3 snd-pcm-oss
    alias sound-service-0-8 snd-seq-oss
    alias sound-service-0-12 snd-pcm-oss
    install snd-intel8x0 /sbin/modprobe --ignore-install sound-slot-0 &&
    { /bin/aumix-minimal -f /etc/.aumixrc -L >/dev/null 2>&1; /bin/true;  }
    remove snd-intel8x0
    { /bin/aumix-minimal -f /etc/.aumixrc -S >/dev/null 2>&1; /bin/true; };
    /sbin/modprobe -r --ignore-remove sound-slot-0



    然后执行“modprobe sound”加载声音模块,并使用下列命令检验声卡驱动:

    #cat /proc/asound/cards



    显示结果如下:

    0 [SI7012]: ICH - SiS SI7012
                SiS SI7012 at 0xdc00, irq 11


    3)VMware问题

    解决方法是:

    ◆ 将/usr/bin/vmware-config.pl中所有的“/proc/ksyms”替换为“/proc/kallsyms”。使用“sed”命令可以达到这个目的。

    ◆ 重新运行该脚本,使用内核头文件编译新的内核模块。在编译过程中如发生错误,应该进入/usr/lib/vmware/modules/source,使用下面的命令将vmnet.tar解包:

    #tar xvf vmnet.tar



    ◆ 进入vmnet-only目录修改bridge.c文件。将“atomic_add(skb->truesize, &sk->wmem_alloc);”修改为“atomic_add(skb->truesize, &sk->sk_wmem_alloc);”,并用类似的方式将“protinfo”改为“sk_protinfo”。

    ◆ 再次把vmnet-only目录用下面的命令重新打包为vmmon.tar:

    #tar cvf vmmon.tar vmnet-only。



    如果按照上面的操作依旧失败,另一解决方法是到http://ftp.cvut.cz/vmware/下载vmware-any-any-updateXX.tar.gz,将其解压到任何目录下,执行其中的runme.pl。

    4)USB问题

    新的2.6.0内核中使用的USB模块大多数已经改名,因此需要修改/etc/rc.sysinit中对USB子系统初始化的代码。将该文件中所有的“keybdev”改为“usbkbd”、“mousedev”改为“usbmouse”、“/proc/bus/usb”改为“/sys/bus/usb”,并在/etc/init.d/halt中进行同样的修改。此外,还要在/etc/rc.sysinit中找到“needusbstorage”,做如下修改:

    needusbstorage=
    if [ $usb = "1" ]; then
      needusbstorage=`LC_ALL=C grep -e "^I.*Cls=08" /sys/bus/usb/devices 2>/dev/null`
      action $"Initializing USB 1.1 host controller: " modprobe ohci-hcd 2> /dev/null
      action $"Initializing USB HID interface: " modprobe hid 2> /dev/null
      action $"Initializing USB keyboard: " modprobe usbkbd 2> /dev/null
      action $"Initializing USB mouse: " modprobe usbmouse 2> /dev/null
    fi



    如果USB总线是2.0的,还需将“ohci-hcd”改为“ehci-hcd”。

    5)Sysfs问题

    解决方法是:

    ◆ 建立目录/sys:#mkdir /sys

    ◆ 在/etc/rc.d/rc.sysinit文件中找到“mount -f /proc”,在其下一行加入“mount -f /sys”。

    ◆ 同样在/etc/rc.d/rc.sysinit文件中找到“action $"Mounting proc filesystem: " mount -n -t proc /proc /proc”,在其下一行加入“action $"Mounting sysfs filesystem: " mount -n -t sysfs /sys /sys”。

    ◆ 在/etc/fstab文件中加入“none /sys sysfs defaults 0 0”。

    ◆ 在/etc/init.d/halt的halt_get_remaining函数中找到“awk '$2 ~ /^\/$|^\/proc|^\/dev/{next}”,改为“awk '$2 ~ /^\/$|^\/proc|^\/sys|^\/dev/{next}”。

    6)Hotplug(热插拔)问题

    内核对热插拔功能的支持与KMOD内核线程有关。

    解决方法是将/etc/rc.sysinit中所有的/proc/ksyms替换为/proc/kallsyms。执行如下命令:

    #mv /etc/rc.d/rc.sysinit /etc/rc.d/rc.sysinit.bak
    #sed -e 's/\/proc\/ksyms/\/proc\/kallsyms/g' /etc/rc.d/rc.sysinit.bak > /etc/rc.d/rc.sysinit

    7)Glibc问题

    用户可以升级Glibc标准库的软件包来解决该问题。因为有些发行版,例如Red Hat 9.0上默认安装的Glibc可能是被Red Hat内核小组修改过的。软件包的下载地址是:

    ftp://ftp.rpmfind.net/linux/redhat/updates/9/en/os/i386/glibc-2.3.2-27.9.i386.rpm。

    可以连同以下几个软件包一起升级:

    ftp://ftp.rpmfind.net/linux/redhat/updates/9/en/os/i386/glibc-common-2.3.2-27.9.i386.rpm

    ftp://ftp.rpmfind.net/linux/redhat/updates/9/en/os/i386/glibc-devel-2.3.2-27.9.i386.rpm

    ftp://ftp.rpmfind.net/linux/redhat/updates/9/en/os/i386/glibc-utils-2.3.2-27.9.i386.rpm

    如果使用“rpm -Uvh glibc*”失败,请用命令“rpm -e”先删除旧的Glibc,然后用命令“rpm -Uvh --force glibc*”强制安装。

    其它问题

    大家也许还会遇到其它问题,但是无论遇上什么问题都可以依照下列步骤尝试解决:

    1.内核组件尽可能编译为模块。执行如下命令可以快速重建内核:

    #make all modules_install install



    2.软件失败的大多数情况是由于模块名已被更改,而/etc/rc.d/rc.sysinit和/etc/rcX.d/*下的脚本却没有修改这些值而导致的。因此,依次修改相关条目可以改进,但是这也需要相当多的背景知识。如果觉得麻烦,可以把所有加载模块的命令集中在/etc/rc.d/rc.local中。例如:

    modprobe eth0
    modprobe isofs
    modprobe loop
    modprobe vfat



    同时修改/etc/modoribe.conf文件。具体可参见“man modoribe.conf”获得更多的帮助信息。

    3.如果想知道某模块变更后的名字,可以首先在“make menuconfig”时找到该选项,选择Help找到它的配置名称(CONFIG_*),然后到源代码相关目录下的makefile中寻找CONFIG_*。一般可以找到obj-$(CONFIG_*)一项,其值就是该模块的名字。

    附:本文参考文章:http://tech.ccidnet.com/pub/article/c309_a103129_p1.html
  • 发表于 2004-8-18 19:54:14 | 显示全部楼层

    求救

    我的usb原来安装不上,按照你的方法改了以后,模块(像cp936等)都加载不进来了,请问是怎么解决?
    回复

    使用道具 举报

    发表于 2004-8-18 23:40:48 | 显示全部楼层
    支持原创

    PS:几个问题
    1.如果只使用2.6内核的话只留下module-init-tools就行了,modutils就没必要了
    2.JBD (ext3) debugging support 没必要。调试信息对一般用户没什么用阿,白白增大内核。而且能否启动还与块设备里的initrd配置有关
    3.我的网卡也是8139。不是C+的RealTek RTL-8139 C+ PCI Fast Ethernet Adapter support (EXPERIMENTAL) 就没必要选了
    4.声卡已经编译进内核了,就没必要在/etc/modprobe.conf里添加声卡模块的别名了
    5.升级内核后为什么要重装Glibc?不明白
    6.我是尽量把内核单一化,少用模块。所以我的内核总是1M以上   个人爱好不同
    回复

    使用道具 举报

    发表于 2004-8-19 11:25:51 | 显示全部楼层
    今早用文中方法升级内核到2.6.8.1。漫长等待后,终于装完了。问题也来了。

    顺利进入系统后,天呀!进不了X界面。
    输入init 5 后:

    INIT:Switching to runlevel:5
    Starting pcmcia     OK
    Starting automount: No Mountpoints Defined    OK

    接着屏幕会连续的闪。直到改到init 3。显卡驱动也装了,但安装时出现了警告,具体意思不知道。
    快帮帮我吧!!!
    回复

    使用道具 举报

    发表于 2004-8-19 14:23:05 | 显示全部楼层
    显卡驱动没装好,将警告贴出来
    回复

    使用道具 举报

    发表于 2004-8-19 15:15:35 | 显示全部楼层
    显示问题得到解决。原来是显卡driver处不能改成nvidia,必须用原来的nv。但随之问题也来了:就是N卡在linux下的屏幕偏移现象。我用的显卡驱动是5336版的,不知是不是这个版本的不支持2.6.8.1内核???

    X是顺利进入了,但更多的问题也来了:声卡没声音,以前挂载的FAT分区不能访问,usb接口不能用... ...

    linux真的有点麻烦,但我爱。问题正在解决中... ...
    回复

    使用道具 举报

    发表于 2004-8-19 16:03:04 | 显示全部楼层
    原来是显卡driver处不能改成nvidia,必须用原来的nv

    nv是XFree86自带的驱动,不支持硬3D加速,会产生屏幕偏移现象,建议还是编译安装nvidia驱动,如果编译出错,将出错信息贴出来
    声卡没声音,以前挂载的FAT分区不能访问,usb接口不能用...

    声卡没声音和fat区不能访问可能是声卡模块和fat模块没有编译,重新配置内核重新编译试试,usb接口不能用原因可能有usb模块没编译或编译了没有加载(usb模块在2.6中换了名字,而常见系统的/etc/rc.sysinit脚本里加载usb模块用的还是2.4里面的模块名,因此加载出错,搜索论坛帖子找解决方法)
    回复

    使用道具 举报

    发表于 2004-9-1 15:44:49 | 显示全部楼层
    我喜欢 linux,虽然它有时会很烦
    回复

    使用道具 举报

    发表于 2004-9-1 19:29:04 | 显示全部楼层

    2.4升级到2.6,编译时候出错

    错误信息如下:

    fs/jfs/jfs_dtree.c: In function `add_index':
    fs/jfs/jfs_dtree.c:388: parse error before `struct'
    fs/jfs/jfs_dtree.c:389: `temp_table' undeclared (first use in this function)
    fs/jfs/jfs_dtree.c:389: (Each undeclared identifier is reported only once
    fs/jfs/jfs_dtree.c:389: for each function it appears in.)
    make[2]: *** [fs/jfs/jfs_dtree.o] Error 1
    make[1]: *** [fs/jfs] Error 2
    make: *** [fs] Error 2

    不知道内核哪方面没有设置正确,还是什么驱动没有编译进去?
    小弟第一次编译内核,还请多多帮忙啊
    回复

    使用道具 举报

    发表于 2004-9-3 10:44:58 | 显示全部楼层
    商榷一下:
    i810_audio是oss模块,
    snd-intel8x0是alsa的模块,
    并不是升级内核改名了,名和以前一样的。 :-)
    回复

    使用道具 举报

    发表于 2004-9-7 15:50:46 | 显示全部楼层
    刚才在VMWare下编译了一下,在make baImage的时候出了下面的错误,请问该如何解决??
    [root@localhost linux-2.6.8]# make bzImage
    make[1]: `arch/i386/kernel/asm-offsets.s' is up to date.
      CHK     include/linux/compile.h
      AS      usr/initramfs_data.o
    /tmp/cciO0EGa.s: Assembler messages:
    /tmp/cciO0EGa.s:7: Error: Unknown pseudo-op:  `.incbin'
    make[1]: *** [usr/initramfs_data.o] Error 1
    make: *** [usr] Error 2
    回复

    使用道具 举报

    发表于 2004-9-29 22:03:17 | 显示全部楼层
    问一下楼主:

      关于rpm的问题,那个LD_ASSUME_KERNEL变量的作用是什么?在什么地方用到它的呀
    回复

    使用道具 举报

    发表于 2004-10-6 15:11:41 | 显示全部楼层

    我的Fedora 1 是用reiserfs文件系统

    我的Fedora 1 是用reiserfs文件系统,那选"ext3"那该改成怎样.
    回复

    使用道具 举报

    发表于 2004-10-8 12:24:49 | 显示全部楼层
    如果你要用initrd的话,ext2编译进内核,ext3不选
    如果你不用initrd的话,ext2也不用选
    回复

    使用道具 举报

    发表于 2004-10-8 20:25:55 | 显示全部楼层
    请教各位大虾, RH9.0,kernel-2.4.20-8升级到2.6.9-rc3,果然,RPM不能用了,安楼主的方法,没能搞定.,请问,LD_ASSUME_KERNEL 的作用是什么,依我的情况.怎么设置
    新安装的系统,除了服务器,其他包全选定安装.以后就改动了字体显示,基本没装其他东西.

    另一个问题,VIA VT6307L IEEE1394 OHCI 按默认编译为模块,启动时显示错误,启动日志如下:
    [code:1]
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 modprobe: modprobe: QM_MODULES: Function not implemented
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 modprobe: modprobe: QM_MODULES: Function not implemented
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 modprobe: modprobe: Can't locate module hid
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 rc.sysinit: 初始化 USB HID 界面: failed
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 modprobe: modprobe: QM_MODULES: Function not implemented
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 modprobe: modprobe: QM_MODULES: Function not implemented
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 modprobe: modprobe: Can't locate module keybdev
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 rc.sysinit: 初始化 USB 键盘: failed
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 modprobe: modprobe: QM_MODULES: Function not implemented
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 modprobe: modprobe: QM_MODULES: Function not implemented
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 modprobe: modprobe: Can't locate module mousedev
    Oct  7 00:07:56 tsyj 10月  7 00:07:56 rc.sysinit: 初始化 USB 鼠标: failed
    Oct  7 00:08:01 tsyj 10月  7 00:08:01 fsck: /dev/hda12 is mounted.  
    Oct  7 00:08:01 tsyj 10月  7 00:08:01 fsck: e2fsck: Cannot continue, aborting.
    Oct  7 00:08:01 tsyj 10月  7 00:08:01 fsck: [/sbin/fsck.ext3 (1) -- /] fsck.ext3 -a /dev/hda12
    Oct  7 00:08:01 tsyj 10月  7 00:08:01 rc.sysinit: 检查根文件系统 failed
    [/code:1]
    系统日志
    [code:1]
    Oct  6 18:57:42 tsyj kernel: ieee1394: raw1394: /dev/raw1394 device initialized
    Oct  6 18:57:42 tsyj kernel: ACPI: PCI interrupt 0000:00:10.3[D] -> GSI 5 (level, low) -> IRQ 5
    Oct  6 18:57:42 tsyj kernel: ehci_hcd 0000:00:10.3: VIA Technologies, Inc. USB 2.0
    Oct  6 18:57:42 tsyj kernel: ehci_hcd 0000:00:10.3: irq 5, pci mem d680c700
    Oct  6 18:57:42 tsyj kernel: ehci_hcd 0000:00:10.3: new USB bus registered, assigned bus number 1
    Oct  6 18:57:42 tsyj kernel: ehci_hcd 0000:00:10.3: USB 2.0 enabled, EHCI 1.00, driver 2004-May-10
    Oct  6 18:57:42 tsyj kernel: hub 1-0:1.0: USB hub found
    Oct  6 18:57:42 tsyj kernel: hub 1-0:1.0: 6 ports detected
    Oct  6 18:57:42 tsyj kernel: USB Universal Host Controller Interface driver v2.2
    Oct  6 18:57:42 tsyj kernel: ACPI: PCI interrupt 0000:00:10.0[A] -> GSI 11 (level, low) -> IRQ 11
    Oct  6 18:57:42 tsyj kernel: uhci_hcd 0000:00:10.0: VIA Technologies, Inc. VT82xxxxx UHCI USB 1.1 Controller
    Oct  6 18:57:42 tsyj kernel: uhci_hcd 0000:00:10.0: irq 11, io base 0000e000
    Oct  6 18:57:42 tsyj kernel: uhci_hcd 0000:00:10.0: new USB bus registered, assigned bus number 2
    Oct  6 18:57:42 tsyj kernel: hub 2-0:1.0: USB hub found
    Oct  6 18:57:42 tsyj kernel: hub 2-0:1.0: 2 ports detected
    Oct  6 18:57:42 tsyj kernel: ACPI: PCI interrupt 0000:00:10.1[B] -> GSI 10 (level, low) -> IRQ 10
    Oct  6 18:57:42 tsyj kernel: uhci_hcd 0000:00:10.1: VIA Technologies, Inc. VT82xxxxx UHCI USB 1.1 Controller (#2)
    Oct  6 18:57:42 tsyj kernel: uhci_hcd 0000:00:10.1: irq 10, io base 0000e400
    Oct  6 18:57:42 tsyj kernel: uhci_hcd 0000:00:10.1: new USB bus registered, assigned bus number 3
    Oct  6 18:57:42 tsyj kernel: hub 3-0:1.0: USB hub found
    Oct  6 18:57:42 tsyj kernel: hub 3-0:1.0: 2 ports detected
    Oct  6 18:57:42 tsyj kernel: ACPI: PCI interrupt 0000:00:10.2[C] -> GSI 11 (level, low) -> IRQ 11
    Oct  6 18:57:42 tsyj kernel: uhci_hcd 0000:00:10.2: VIA Technologies, Inc. VT82xxxxx UHCI USB 1.1 Controller (#3)
    Oct  6 18:57:42 tsyj kernel: uhci_hcd 0000:00:10.2: irq 11, io base 0000e800
    Oct  6 18:57:42 tsyj kernel: uhci_hcd 0000:00:10.2: new USB bus registered, assigned bus number 4
    [/code:1]
    编译了两次,没解决,请指教.能否卸载该模块,若能,如何进行?
    [code:1]
    ide2: Wait for ready failed before probe !
    Probing IDE interface ide3...
    ide3: Wait for ready failed before probe !
    Probing IDE interface ide4...
    ide4: Wait for ready failed before probe !
    Probing IDE interface ide5...
    ide5: Wait for ready failed before probe !
    Using anticipatory io scheduler
    ide0 at 0x1f0-0x1f7,0x3f6 on irq 14
    ide1 at 0x170-0x177,0x376 on irq 15
    [/code:1]
    这个又是怎么回事?

    谢谢!!!
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    GMT+8, 2024-4-26 17:58 , Processed in 0.260028 second(s), 15 queries .

    © 2021 Powered by Discuz! X3.5.

    快速回复 返回顶部 返回列表