Shortly: it works -) Now with more details. Module 'ata_generic' (CONFIG_ATA_GENERIC) may drive IDER controller. Though, it will not take over this device without option 'all_generic_ide=1' (perhaps, because IDER controller match with "any" alias, but not device-specific one?): # modinfo ata_generic .. alias: pci:v*d*sv*sd*bc01sc01i* .. So, we should load it like # modprobe ata_generic all_generic_ide=1 Now we can check, that it successfully takes over IDER controller # lspci -nn | grep IDER 00:03.2 IDE interface [0101]: Intel Corporation Mobile PM965/GM965 PT IDER Controller [8086:2a06] (rev 0c) # ls -l /sys/bus/pci/devices/0000:00:03.2/driver lrwxrwxrwx 1 root root 0 Jan 31 17:44 /sys/bus/pci/devices/0000:00:03.2/driver -> ../../../bus/pci/drivers/ata_generic But in order to have kernel see scsi targets on this IDER controller, we need to enable IDE Redirection in remote management console (you may use Manageability Commander Tool from Intel Manageability Developer Tool Kit for testing). There will be two scsi targets on this scsi host: floppy (bus=0, id=0, lun=0) and cdrom (bus=0, id=1, lun=0). Floppy will be handled by sd, and cdrom by sr_mod: # ls -l /sys/bus/pci/devices/0000:00:03.2/host21/ total 0 drwxr-xr-x 2 root root 0 Jan 31 18:16 power drwxr-xr-x 3 root root 0 Jan 31 18:16 scsi_host lrwxrwxrwx 1 root root 0 Jan 31 17:44 subsystem -> ../../../../bus/scsi drwxr-xr-x 4 root root 0 Jan 31 17:44 target21:0:0 drwxr-xr-x 4 root root 0 Jan 31 17:44 target21:0:1 -rw-r--r-- 1 root root 4096 Jan 31 17:44 uevent # ls -l /sys/bus/pci/devices/0000:00:03.2/host21/target21:0:0/21:0:0:0/driver lrwxrwxrwx 1 root root 0 Jan 31 17:44 /sys/bus/pci/devices/0000:00:03.2/host21/target21:0:0/21:0:0:0/driver -> ../../../../../../bus/scsi/drivers/sd # ls -l /sys/bus/pci/devices/0000:00:03.2/host21/target21:0:1/21:0:1:0/driver lrwxrwxrwx 1 root root 0 Jan 31 17:45 /sys/bus/pci/devices/0000:00:03.2/host21/target21:0:1/21:0:1:0/driver -> ../../../../../../bus/scsi/drivers/sr And now the only left is to make these modules autoload during boot. Here is one thing to note: we should load all specific ata modules (for other hardware, if any) _before_ 'ata_generic'. Otherwise with parameter 'all_generic_ide' it'll take over all available ata controllers. Order of ata drivers and scsi drivers (sr_mod, sd) does not matter. So, something like this should be written in modprobe.conf: modprobe.conf: options ata_generic all_generic_ide=1 install ata_generic /sbin/modprobe ata_piix ; /sbin/modprobe --ignore-install ata_generic or modprobe.conf: options ata_generic all_generic_ide=1 install ata_generic /sbin/modprobe ata_piix ; /sbin/modprobe --ignore-install ata_generic $CMDLINE_OPTS though, adding $CMDLINE_OPTS (to add all options from the command line) is useless here - 'ata_generic' has only one option. Also there is another one module, which can drive IDER controller - 'ide_pci_generic' (CONFIG_BLK_DEV_GENERIC). Unlike 'ata_generic', which uses libata, this module uses old ATA subsystem (CONFIG_IDE) (are terms here used correctly?). If you use this driver, cdrom drive will no longer be present as scsi device. Now it'll be handled by 'ide_cd' driver (CONFIG_BLK_DEV_IDECD). 'ide_pci_generic' driver also requires option 'all_generic_ide' set in order to take over any device. Here are some results from booting linux with different ATA drivers used (though root partition in these tests is on the hard drive). All three boot scenarios require SATA AHCI controller to be in compatibility mode, otherwise ATA drivers can not work with it and kernel can't access root partition. 1. ata_piix. Here ata_piix driver is compiled in and handles all ATA controllers. It correctly takes over AHCI controller (in compatiblility mode) and over PATA controller. ata_generic was loaded as module later to handle IDER controller. Here is some info about such system config: # ls -l /sys/bus/pci/devices/*/driver .. lrwxrwxrwx 1 root root 0 Feb 1 13:06 /sys/bus/pci/devices/0000:00:03.2/driver -> ../../../bus/pci/drivers/ata_generic .. lrwxrwxrwx 1 root root 0 Feb 1 13:06 /sys/bus/pci/devices/0000:00:1f.2/driver -> ../../../bus/pci/drivers/ata_piix .. # lspci -nn | grep IDE 00:03.2 IDE interface [0101]: Intel Corporation Mobile PM965/GM965 PT IDER Controller [8086:2a06] (rev 0c) 00:1f.2 IDE interface [0101]: Intel Corporation 82801HBM/HEM (ICH8M/ICH8M-E) SATA IDE Controller [8086:2828] (rev 03) # ls -l /sys/bus/pci/devices/0000\:00\:1f.2/ total 0 .. lrwxrwxrwx 1 root root 0 Feb 1 13:06 driver -> ../../../bus/pci/drivers/ata_piix .. drwxr-xr-x 5 root root 0 Feb 1 2011 host0 drwxr-xr-x 5 root root 0 Feb 1 2011 host1 .. # ls -l /sys/bus/pci/devices/0000\:00\:1f.2/host0/ total 0 drwxr-xr-x 2 root root 0 Feb 1 13:13 power drwxr-xr-x 3 root root 0 Feb 1 2011 scsi_host lrwxrwxrwx 1 root root 0 Feb 1 2011 subsystem -> ../../../../bus/scsi drwxr-xr-x 4 root root 0 Feb 1 2011 target0:0:0 -rw-r--r-- 1 root root 4096 Feb 1 2011 uevent # ls -l /sys/bus/pci/devices/0000\:00\:1f.2/host0/target0\:0\:0/0\:0\:0\:0/driver lrwxrwxrwx 1 root root 0 Feb 1 13:13 /sys/bus/pci/devices/0000:00:1f.2/host0/target0:0:0/0:0:0:0/driver -> ../../../../../../bus/scsi/drivers/sd # ls -l /sys/bus/pci/devices/0000\:00\:1f.2/host1/ total 0 drwxr-xr-x 2 root root 0 Feb 1 13:11 power drwxr-xr-x 3 root root 0 Feb 1 2011 scsi_host lrwxrwxrwx 1 root root 0 Feb 1 2011 subsystem -> ../../../../bus/scsi drwxr-xr-x 4 root root 0 Feb 1 2011 target1:0:0 -rw-r--r-- 1 root root 4096 Feb 1 2011 uevent # ls -l /sys/bus/pci/devices/0000\:00\:1f.2/host1/target1\:0\:0/1\:0\:0\:0/driver lrwxrwxrwx 1 root root 0 Feb 1 13:09 /sys/bus/pci/devices/0000:00:1f.2/host1/target1:0:0/1:0:0:0/driver -> ../../../../../../bus/scsi/drivers/sr 2. ata_generic. Here ata_generic driver is compiled in and handles all ATA controllers. It successfully takes over AHCI controller (in compatibility mode), PATA controller and IDER controller. Though, if IDE Redirection is enabled in management console (kernel can see devices attached to IDER controller), ATA devices may be named in not the order you expect, so 'root=' kernel parameter should be adjust correspondingly (or udev from initramfs should be used). To take over any device this driver requires 'all-generic-ide' option set at kernel command line: ata_generic.all_generic_ide=1 or ata-generic.all-generic-ide=1 Here is some info about such system config: # ls -l /sys/bus/pci/devices/*/driver .. lrwxrwxrwx 1 root root 0 Feb 1 14:20 /sys/bus/pci/devices/0000:00:03.2/driver -> ../../../bus/pci/drivers/ata_generic .. lrwxrwxrwx 1 root root 0 Feb 1 14:20 /sys/bus/pci/devices/0000:00:1f.2/driver -> ../../../bus/pci/drivers/ata_generic .. # lspci -nn | grep IDE 00:03.2 IDE interface [0101]: Intel Corporation Mobile PM965/GM965 PT IDER Controller [8086:2a06] (rev 0c) 00:1f.2 IDE interface [0101]: Intel Corporation 82801HBM/HEM (ICH8M/ICH8M-E) SATA IDE Controller [8086:2828] (rev 03) # ls -l /sys/bus/pci/devices/0000\:00\:03.2/ .. lrwxrwxrwx 1 root root 0 Feb 1 14:20 driver -> ../../../bus/pci/drivers/ata_generic .. drwxr-xr-x 6 root root 0 Feb 1 2011 host0 drwxr-xr-x 4 root root 0 Feb 1 2011 host1 .. # readlink -f /sys/class/block/sda/device /sys/devices/pci0000:00/0000:00:03.2/host0/target0:0:0/0:0:0:0 # ls -l /sys/bus/pci/devices/0000\:00\:1f.2/host2/ total 0 drwxr-xr-x 2 root root 0 Feb 1 14:23 power drwxr-xr-x 3 root root 0 Feb 1 2011 scsi_host lrwxrwxrwx 1 root root 0 Feb 1 2011 subsystem -> ../../../../bus/scsi drwxr-xr-x 4 root root 0 Feb 1 2011 target2:0:0 -rw-r--r-- 1 root root 4096 Feb 1 2011 uevent # ls -l /sys/bus/pci/devices/0000:00:1f.2/host2/target2:0:0/2:0:0:0/driver lrwxrwxrwx 1 root root 0 Feb 1 14:23 /sys/bus/pci/devices/0000:00:1f.2/host2/target2:0:0/2:0:0:0/driver -> ../../../../../../bus/scsi/drivers/sd # ls -l /sys/bus/pci/devices/0000:00:1f.2/host3/ total 0 drwxr-xr-x 2 root root 0 Feb 1 14:24 power drwxr-xr-x 3 root root 0 Feb 1 2011 scsi_host lrwxrwxrwx 1 root root 0 Feb 1 2011 subsystem -> ../../../../bus/scsi drwxr-xr-x 4 root root 0 Feb 1 2011 target3:0:0 -rw-r--r-- 1 root root 4096 Feb 1 2011 uevent # ls -l /sys/bus/pci/devices/0000:00:1f.2/host3/target3:0:0/3:0:0:0/driver lrwxrwxrwx 1 root root 0 Feb 1 14:24 /sys/bus/pci/devices/0000:00:1f.2/host3/target3:0:0/3:0:0:0/driver -> ../../../../../../bus/scsi/drivers/sr # ls -l /sys/class/block/sd* lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/sda -> ../../devices/pci0000:00/0000:00:03.2/host0/target0:0:0/0:0:0:0/block/sda lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/sdb -> ../../devices/pci0000:00/0000:00:1f.2/host2/target2:0:0/2:0:0:0/block/sdb lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/sdb1 -> ../../devices/pci0000:00/0000:00:1f.2/host2/target2:0:0/2:0:0:0/block/sdb/sdb1 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/sdb2 -> ../../devices/pci0000:00/0000:00:1f.2/host2/target2:0:0/2:0:0:0/block/sdb/sdb2 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/sdb3 -> ../../devices/pci0000:00/0000:00:1f.2/host2/target2:0:0/2:0:0:0/block/sdb/sdb3 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/sdb4 -> ../../devices/pci0000:00/0000:00:1f.2/host2/target2:0:0/2:0:0:0/block/sdb/sdb4 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/sdb5 -> ../../devices/pci0000:00/0000:00:1f.2/host2/target2:0:0/2:0:0:0/block/sdb/sdb5 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/sdb6 -> ../../devices/pci0000:00/0000:00:1f.2/host2/target2:0:0/2:0:0:0/block/sdb/sdb6 3. ide_pci_generic. Here ide_pci_generic driver is compiled in and handles all ATA controllers. This driver represents old IDE subsystem, and noticeable difference from new ATA subsystem (libata) is that it names devices as /dev/hd* instead of /dev/sd*. As well as ata_generic it successfully takes over all AHCI, PATA and IDER controllers. Device names here are also different from all what was before, so, 'root=' kernel parameter should be adjusted. To take over any device this driver requires 'all-generic-ide' option set at kernel command line: ide-pci-generic.all-generic-ide or ide-pci-generic.all-generic-ide Here is some info about such system config: # ls -l /sys/bus/pci/devices/*/driver .. lrwxrwxrwx 1 root root 0 Feb 1 14:49 /sys/bus/pci/devices/0000:00:03.2/driver -> ../../../bus/pci/drivers/PCI_IDE .. lrwxrwxrwx 1 root root 0 Feb 1 14:49 /sys/bus/pci/devices/0000:00:1f.2/driver -> ../../../bus/pci/drivers/PCI_IDE .. # ls -l /sys/bus/pci/devices/0000:00:03.2/ total 0 .. lrwxrwxrwx 1 root root 0 Feb 1 14:49 driver -> ../../../bus/pci/drivers/PCI_IDE .. drwxr-xr-x 6 root root 0 Feb 1 2011 ide0 drwxr-xr-x 4 root root 0 Feb 1 2011 ide1 .. # ls -l /sys/bus/pci/devices/0000:00:03.2/ide0/ total 0 drwxr-xr-x 3 root root 0 Feb 1 2011 0.0 drwxr-xr-x 5 root root 0 Feb 1 2011 0.1 drwxr-xr-x 3 root root 0 Feb 1 2011 ide_port drwxr-xr-x 2 root root 0 Feb 1 14:49 power -rw-r--r-- 1 root root 4096 Feb 1 2011 uevent # ls -l /sys/bus/pci/devices/0000:00:03.2/ide0/0.0/ (no 'driver' symlink - module required for floppy to work was not compiled (what module is needed?)) # ls -l /sys/bus/pci/devices/0000:00:03.2/ide0/0.1/ .. lrwxrwxrwx 1 root root 0 Feb 1 14:50 driver -> ../../../../../bus/ide/drivers/ide-cdrom .. # ls -l /sys/bus/pci/devices/0000:00:1f.2/ .. lrwxrwxrwx 1 root root 0 Feb 1 14:49 driver -> ../../../bus/pci/drivers/PCI_IDE .. drwxr-xr-x 5 root root 0 Feb 1 2011 ide2 drwxr-xr-x 5 root root 0 Feb 1 2011 ide3 .. # ls -l /sys/bus/pci/devices/0000:00:1f.2/ide2/ total 0 drwxr-xr-x 5 root root 0 Feb 1 2011 2.0 drwxr-xr-x 3 root root 0 Feb 1 2011 ide_port drwxr-xr-x 2 root root 0 Feb 1 14:51 power -rw-r--r-- 1 root root 4096 Feb 1 2011 uevent # ls -l /sys/bus/pci/devices/0000:00:1f.2/ide2/2.0/ .. lrwxrwxrwx 1 root root 0 Feb 1 14:51 driver -> ../../../../../bus/ide/drivers/ide-gd .. # ls -l /sys/bus/pci/devices/0000:00:1f.2/ide2/2.0/block/ total 0 drwxr-xr-x 12 root root 0 Feb 1 2011 hde # ls -l /sys/bus/pci/devices/0000:00:1f.2/ide3/ total 0 drwxr-xr-x 5 root root 0 Feb 1 2011 3.0 drwxr-xr-x 3 root root 0 Feb 1 2011 ide_port drwxr-xr-x 2 root root 0 Feb 1 14:51 power -rw-r--r-- 1 root root 4096 Feb 1 2011 uevent # ls -l /sys/bus/pci/devices/0000:00:1f.2/ide3/3.0/ .. lrwxrwxrwx 1 root root 0 Feb 1 14:52 driver -> ../../../../../bus/ide/drivers/ide-cdrom .. # ls -l /sys/bus/pci/devices/0000:00:1f.2/ide3/3.0/block/ total 0 drwxr-xr-x 6 root root 0 Feb 1 2011 hdg # ls -l /sys/class/block/hd* lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/hdb -> ../../devices/pci0000:00/0000:00:03.2/ide0/0.1/block/hdb lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/hde -> ../../devices/pci0000:00/0000:00:1f.2/ide2/2.0/block/hde lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/hde1 -> ../../devices/pci0000:00/0000:00:1f.2/ide2/2.0/block/hde/hde1 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/hde2 -> ../../devices/pci0000:00/0000:00:1f.2/ide2/2.0/block/hde/hde2 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/hde3 -> ../../devices/pci0000:00/0000:00:1f.2/ide2/2.0/block/hde/hde3 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/hde4 -> ../../devices/pci0000:00/0000:00:1f.2/ide2/2.0/block/hde/hde4 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/hde5 -> ../../devices/pci0000:00/0000:00:1f.2/ide2/2.0/block/hde/hde5 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/hde6 -> ../../devices/pci0000:00/0000:00:1f.2/ide2/2.0/block/hde/hde6 lrwxrwxrwx 1 root root 0 Feb 1 2011 /sys/class/block/hdg -> ../../devices/pci0000:00/0000:00:1f.2/ide3/3.0/block/hdg # ls -l /sys/bus/pci/drivers/PCI_IDE/module lrwxrwxrwx 1 root root 0 Feb 1 15:01 /sys/bus/pci/drivers/PCI_IDE/module -> ../../../../module/ide_pci_generic Hence, to boot linux from cdrom drive on IDER controller, we just need to have compiled into the kernel either ata_generic or ide_pci_generic driver. I test this with gentoo livecd and SystemRescueCd. First one has ide_pci_generic driver compiled in and should be booted like gentoo ide-pci-generic.all-generic-ide second one has ata_generic driver compiled and should be booted like <..system rescue cd boot options..> ata-generic.all-generic-ide=1 PS. This was tested on motherboard with Intel PM965 chipset (Centrino vPro) with AMT 2.6 (or 2.5?) and kernel 2.6.36.
DISCLAIMER. English language used here only for compatibility (ASCII only), so any suggestions about my bad grammar (and not only it) will be greatly appreciated.
вторник, 1 февраля 2011 г.
Intel AMT IDE Redirection and linux
(updated version)
Подписаться на:
Сообщения (Atom)