Time for Slackware 12.0
Yesterday I had to install Linux on a Intel Core 2 Duo machine with SATA disks. So, I figured I need both SMP and SATA support. My trustworthy Slackware 10.2 seemed out of the question, or shall I rather say: out of date. So I went for 11.0 as I didn't have 12.0 DVD at hand and this was supposed to be a quick installation. Well, it turned into a 9-hour marathon, ending in me giving up on SMP at the end (until I try with Slackware 12.0).
Slackware 11.0 comes with 15 or so kernels. All but two of those are 2.4 kernels. Non of those 2.4 kernels supports the SATA controller in that machine. So, I had huge26 and test26 to test. The huge one should work on any machine? Couldn't boot this one (Asus/Intel965, JMicron SATA controller). Pluging SATA disk into Intel ICH8 rather than JMicron fixed that and I was able to boot with test26.s. Unfortunately, after booting, there was no way for it to see the DVD ROM that was connected to PATA IDE. Going back to Bios and trying both compatibility and enhanced modes didn't help at all - most of experiments with BIOS settings ended up in not being able to boot with any kernel. BTW, each time we changed a single setting in BIOS we rebooted and tried all of: sata.i, bare.i, test26.s, huge26.s and the only one that would sometimes work in test26.s. I'm inclined to say that sata.i kernel in Slackware 11.0 is next to useless.
In the end, we managed to find an USB DVD reader and decided to copy the DVD image to hard disk (as we had to return the USB DVD reader, we couldn't affort to play and try to install from it). Now, we learned some more interesting things. For example, I ran fdisk and created 3 partitions. Formatted one of them as xfs (default option in Slack11) and ran:
dd if=/dev/sdb of=slack11dvd.iso
All was going nice until slack11dvd.iso reached 2GB file size. Now, it was my first time using XFS and even though I know I read people having huge files on it, I just figured that something might be wrong and reformatted the partition to ext3 and start over. No luck, at 2GB mark we got the same error. Ok, at this point I concluded that dd on Slackware 11.0 installation disk does not support files larger than 2GB. So I mounted the DVD and used 'cp -a' to copy it over.
Next, I started 'setup' and go to the point to select media. Tried with 'directory on local disk' option (can't recall the exact wording) and it gave me various errors before I gave up on it and selected the 'pre-mounted CD or DVD' or whatever it is called exactly. In the end I had just deleted the /var/log/mount (or something like that) directory where the installer expected to find the directory structure and symlinked that to that DVD copy I made with 'cp -a' earlier. It's so cool that Slackware's installer is a shell script and you can use 'vi' to peek inside and find easy ways to trick it into doing what you want it to do. Another cool thing is that Slackware gives you usable consoles while installing (available via alt+Fn combinations). Finally the Slackware installed.
Rebooting is a whole new story. As I was scared to choose kernel from CD during install (didn't know if it was going to try searching the CD device again), I told it to just go with vmlinuz. It couldn't boot, so I booted from DVD, went in, replaced default kernel with test26.s, run lilo and rebooted again. Now we now had a running Slackware 11.0 with SATA support. Great? Not yet.
Of course, test26.s kernel doesn't have SMP support some one of our CPUs was simply just lying there dead doing nothing at all. Looking at various precompiled kernel options, I found 2.6.17.13-smp. Tried it - of course - no SATA support. At this point, some 4 hours have already passed, and I was looking at a choice: add SATA support to SMP kernel, or add SMP support to SATA kernel. The former seamed feasible, the latter impossible. Ok, I just figured that I need to add some modules for SATA stuff into kernel core and be done with it. But that would require to compile the entire kernel and I wasn't really in a mood for that. Then I figured that we have to use initrd anyway, so why not just load sata drivers in it. Seemed like a best idea of the day. BTW, by now I learned the mkinitrd line by heart:
mkinitrd -c -k 2.6.13.17-smp -m jbd:ext3 -r /dev/sda1
This is the default line. To add more modules, simply add their names (filenames of .ko files) to the list in -m option. So I added sata_mv as I mistakenly thought that SATA controller was involved.
Ran mkinitrd, lilo, rebooted... kernel panic.
Booted from DVD again...this time reading all the output of boot process (and later analyzing dmesg). It's nice that test26.s successfully loads almost all SATA stuff (not modules - it's built in) without errors - so it's really hard to determine which of those is really used. lsmod cannot help at this time. If you knows how to get 'lsmod' for stuff that is compiled into the kernel PLEASE LET ME KNOW.
So, I started adding stuff to the -m line of mkinitrd. Some of the modules I recognized instantly, for others I used 'grep' in /lib/modules to find out. I the end I had about 12 modules, output of loading process was quite similar to the one of test26.s but still it wasn't able to see the SATA disk, and still wasn't able to boot. The only module making problems was ipr (some IBM's SATA controller I believe), but I wasn't able to determine why it cannot load. Looking at modules.dep it didn't seem that it has some dependent modules that I need to preload before it.
I also had problem with my network card not being supported by test26.s, which is (if someone wonders) kernel 2.6.18. But that's a minor issue as the card is supported in 2.6.20, and one RTL8139 is doing the job in the meantime.
The current state is that we're running with SATA disk and one CPU and PCI Ethernet card. I'm looking forward to Slackware 12.0 and 2.6.21 kernel which should solve this.