blob: 5aa7e93cfd312ab7ee8a143d8c5dd4f4e59d4bc3 [file] [log] [blame]
Bartlomiej Zolnierkiewiczffd4f6f2008-04-18 00:46:34 +02001
2#include <linux/kernel.h>
3#include <linux/init.h>
4#include <linux/module.h>
5#include <linux/ide.h>
6
7int probe_4drives = 0;
8
9module_param_named(probe, probe_4drives, bool, 0);
10MODULE_PARM_DESC(probe, "probe for generic IDE chipset with 4 drives/port");
11
12static int __init ide_4drives_init(void)
13{
14 ide_hwif_t *hwif, *mate;
15 u8 idx[4] = { 0, 1, 0xff, 0xff };
16
17 if (probe_4drives == 0)
18 return -ENODEV;
19
20 hwif = &ide_hwifs[0];
21 mate = &ide_hwifs[1];
22
23 memcpy(mate->io_ports, hwif->io_ports, sizeof(hwif->io_ports));
24
25 mate->irq = hwif->irq;
26
27 mate->chipset = hwif->chipset = ide_4drives;
28
29 mate->drives[0].select.all ^= 0x20;
30 mate->drives[1].select.all ^= 0x20;
31
32 hwif->mate = mate;
33 mate->mate = hwif;
34
35 hwif->serialized = mate->serialized = 1;
36
37 ide_device_add(idx, NULL);
38
39 return 0;
40}
41
42module_init(ide_4drives_init);
43
44MODULE_AUTHOR("Bartlomiej Zolnierkiewicz");
45MODULE_DESCRIPTION("generic IDE chipset with 4 drives/port support");
46MODULE_LICENSE("GPL");