linux 系统调试工具,Linux 系统调试...

1. 编译内核后不能启动.GRUB提示Error 13

尝试重编了2,3次,也修改了一些配置,最后发现还是不行.虽然2.6.18-8的内核不需要make bzImage,只需要make然后就可以

make modules_install了,但是实际上还是要生成bzImage的...仍然是在arch/i386/boot下..

但是我编译并没有产生bzImage...产生的另一个文件虽然make install之后也叫vmlinuzxxx但是不能作为

内核启动,所以GRUB会提示Error 13..所以这个问题,首先不是GRUB的问题,其次也不是Kernel config的问题.

而是没有bzImage的问题.今天终于成功编译了一个能用的内核,其他过程大同小异.最大的变动在于我将硬盘从

SATA1插到SATA0了,然后在make的最后终于看到bzImage is ready...

没有再多试一次确定硬盘插的位置就是主要原因..但是应该差不多.因为在bzImage产生时,打印出一些信息显示

boot disk之类的东西,估计是bzImage需要确定这些东西才行,如果插在SATA1而不是SATA0的话,可能就不行了,

可能也和MBR master boot region有关系.

make install之后grub.conf文件是会自动改变的,不需要手动去改

2. SATA硬盘不能打开DMA.

这个问题也很麻烦,硬盘速度太慢了 hdparm -tT是1000+M/s 和3M/s,因为IDE驱动是特殊的.在编译前已经patch,

而且已经将对应模块config了.但是还是不能hdparm -d1,提示

not permitted..

最后是修改bios,将IDE还是什么设置成ACHI模式,硬盘变成sda之后就快很多了..1000+和70+

3. 从网络读写数据会死机.

找不到原因,后来CPU多加了点散热胶就OK了....ft

虽然这些问题都很奇怪,而且不太好解决,网上的资料也不多,但是在过程中还是学到很多东西,在有很多因素和问题有关,而且

不能确定的时候,最好的办法就是一个一个排除这些因素,然后缩小范围,并适当扩展可能性...

没有思路的乱想/试一气是没有效率的

顺便贴点资料参考:

hdparm 开启 dma 出现 HDIO_SET_DMA failed: Operation not permitted 错误的解决方法

以 intel 芯片主板为例,在内核中将 "general/default IDE chipset support" 和 "Intel PIIXn chipsets support" 编译成模块

0818b9ca8b590ca3270a3433284dd417.png

然后在  /etc/modules.autoload.d/kernel-2.6 中将 "piix" 模块放在最前。

FAQ:如果硬盘设备名称变更进不去系统该怎么办?

#在 grub 启动 gentoo 的 kernel 项尾添加 init=/bin/sh,进入单用户模式  mount -o remount,rw / mount /boot  #修改 /etc/fstab 和 /boot/grub/grub.conf装完系统后,第一次打开应用程序总是特别的慢,而且从windows分区拷贝文件也是特别慢,同一台机器装的magiclinux就没有这个问题。怀疑是硬盘的DMA没有设置好,而记得当初编译2.6.6内核的时候选择了默认打开硬盘的DMA模式,尝试解决这个问题: 从网上搜索相关发现有hdparm命令可以用,用法如下: #hdparm -i /dev/hda 查看硬盘的物理参数和支持的工作模式 #hdparm -v /dev/hda 查看当前硬盘的工作模式 #hdparm -Tt /dev/hda 测试一下优化前和优化后的硬盘读写速率 测试了自己的硬盘: Timing buffered disk reads: 64 MB in 24 seconds = 2.5 MB/sec 只有可怜的2.5MB,肯定了自己的猜测。 那就接着根据网上搜到的命令用hdparm命令来把它调好: #hdparm -d1 -c3 -X66 -m16 /dev/hda 可是出现了以下字符: /dev/hda: setting using_dma to 1 (on) HDIO_SET_DMA failed: Operation not permitted using_dma = 0 (off) 然后测试硬盘速度还是可怜的2.5MB,尝试失败。 于是仔细研究这些参数的意义: # /sbin/hdparm -x66 -d1 -u1 -m16 -c3 /dev/hda 选项说明: ① c3 :就是把硬盘的16位格式转换为32位模式(32-bit mode w/sync)。控制数据如何从pci总线传递到控制器。 ② m16 :改变硬盘的多路扇区的读功能,-m16可以使得硬盘在一次i/o中断中读入16个扇区的数据。但是不是所有的硬盘都支持这个功能。使用hdparm -i /dev/hda 可以察看您的硬盘最大能读写的扇区数目。 ③ d1:打开DMA模式。 ④ x66 :在支持UDMA-capable的硬盘中,这个参数可以支持双DMA通道的数据传输模式。X34 在支持DMA-capable的硬盘中,这个参数可以支持双DMA通道的数据传输模式。支持 ATA33 可以加上 -X66 这个参数,ATA66则是 -X68,-X69是mode 5(ATA100), -X68是mode 4(ATA66)可用于光驱。 ⑤ u1 :Linux在处理磁盘中断时,可以unmask其他的中断或者响应其他中断相关的任务。 于是不断的拿X66.X68.X69等参数来实验后立即用#hdparm -tT /dev/hda来测试性能,仍然不成功。再找网上的方法,有如下: 1./etc/rc.d/rc.local 最后面加上一行 /sbin/hdparm -d1 -c3 -X66 -m16 -q /dev/hda 建议加上-q参数,因为man里面说的,这样可以开机即是DMA模式,不用手动设定,但此方法和命令其实是一样的,解决不了我的问题。 2.修改/etc/sysconfig/harddisks也可以打开DMA模式 我的slackware9.1没有这个文件,不行。 3.要靠手工在/etc/conf.d/hdparm里面写好,然后rc-update add hdparm default。 和方法1目的一样,对我没有。 4.编辑/etc/conf.d/local.start加入 hdparm -d1 -c1 -X69 /dev/hda 重启即可,也类似方法3 5.#hdparm -d1 -c1 -X69 -k1 -K1 /dev/hda 直接命令设定,比较简单,但对偶还是没用。 再搜,有人说要重新编译内核才行,我只好重新编译,幸亏有原来编译备份的.config文件,在相关的地方好像是IDE chipset support根据感觉选了一通,重新生成bzImage,重启电脑,还是失败,,,,, 不甘心,继续努力在网上找答案,来到linuxsir.org用搜索功能的只搜主题选项,搜索“硬盘DMA”,把所有的结果仔细看了一遍,发现解决办法还是要编译内核,但之前要运行#lspci命令来确定自己电脑的IDE控制芯片是什么。 运行#lspci,结果如下: 00:00.0 Host bridge: Advanced Micro Devices [AMD] AMD-760 [IGD4-1P] System Controller (rev 13) 00:01.0 PCI bridge: Advanced Micro Devices [AMD] AMD-760 [IGD4-1P] AGP Bridge 00:07.0 ISA bridge: VIA Technologies, Inc. VT82C686 [Apollo Super South] (rev 40) 00:07.1 IDE interface: VIA Technologies, Inc. VT82C586/B/686A/B PIPC Bus Master IDE (rev 06) 00:07.2 USB Controller: VIA Technologies, Inc. USB (rev 1a) 00:07.3 USB Controller: VIA Technologies, Inc. USB (rev 1a) 00:07.4 SMBus: VIA Technologies, Inc. VT82C686 [Apollo Super ACPI] (rev 40) 00:09.0 Multimedia audio controller: C-Media Electronics Inc CM8338A (rev 10) 00:0d.0 Ethernet controller: Realtek Semiconductor Co., Ltd. RTL-8139/8139C/8139C+ (rev 10) 00:13.0 Unknown mass storage controller: Triones Technologies, Inc. HPT366/368/370/370A/372 (rev 04) 01:05.0 VGA compatible controller: nVidia Corporation NV20 [GeForce3 Ti 200] (rev a3) 找到答案,我编译内核凭的是模糊的记忆,没有真正按照自己的硬件来编译,结果造成IDE interface: VIA Technologies, Inc. VT82C586/B/686A/B PIPC Bus Master IDE 没有编译进支持,导致DMA不可用。接下来就好办了,重新编译内核,重启电脑,测试结果如下: #hdparm -tT /dev/hda /dev/hda: Timing buffer-cache reads: 128 MB in 0.57 seconds =225.78 MB/sec Timing buffered disk reads: 64 MB in 1.74 seconds = 36.81 MB/sec 终于搞定,而且2.6内核是自动开机即运行,默认开启DMA,所以不用做任何设置了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值