]> pilppa.org Git - linux-2.6-omap-h63xx.git/blobdiff - drivers/ide/legacy/gayle.c
ide: add struct ide_host (take 3)
[linux-2.6-omap-h63xx.git] / drivers / ide / legacy / gayle.c
index fed7d812761c4e9b9ba46b1c1bfbb26648cfac20..13d22bded6b42a5554428c05930ddf035e00b395 100644 (file)
@@ -31,6 +31,8 @@
 #define GAYLE_BASE_4000        0xdd2020        /* A4000/A4000T */
 #define GAYLE_BASE_1200        0xda0000        /* A1200/A600 and E-Matrix 530 */
 
+#define GAYLE_IDEREG_SIZE      0x2000
+
     /*
      *  Offsets from one of the above bases
      */
 #define GAYLE_NUM_HWIFS                1
 #define GAYLE_NUM_PROBE_HWIFS  GAYLE_NUM_HWIFS
 #define GAYLE_HAS_CONTROL_REG  1
-#define GAYLE_IDEREG_SIZE      0x2000
 #else /* CONFIG_BLK_DEV_IDEDOUBLER */
 #define GAYLE_NUM_HWIFS                2
 #define GAYLE_NUM_PROBE_HWIFS  (ide_doubler ? GAYLE_NUM_HWIFS : \
                                               GAYLE_NUM_HWIFS-1)
 #define GAYLE_HAS_CONTROL_REG  (!ide_doubler)
-#define GAYLE_IDEREG_SIZE      (ide_doubler ? 0x1000 : 0x2000)
-
-int ide_doubler = 0;   /* support IDE doublers? */
-EXPORT_SYMBOL_GPL(ide_doubler);
 
+static int ide_doubler;
 module_param_named(doubler, ide_doubler, bool, 0);
 MODULE_PARM_DESC(doubler, "enable support for IDE doublers");
 #endif /* CONFIG_BLK_DEV_IDEDOUBLER */
@@ -126,8 +124,12 @@ static void __init gayle_setup_ports(hw_regs_t *hw, unsigned long base,
 
 static int __init gayle_init(void)
 {
+    unsigned long phys_base, res_start, res_n;
+    unsigned long base, ctrlport, irqport;
+    ide_ack_intr_t *ack_intr;
+    struct ide_host *host;
     int a4000, i;
-    u8 idx[4] = { 0xff, 0xff, 0xff, 0xff };
+    hw_regs_t hw[GAYLE_NUM_HWIFS], *hws[] = { NULL, NULL, NULL, NULL };
 
     if (!MACH_IS_AMIGA)
        return -ENODEV;
@@ -150,13 +152,6 @@ found:
 #endif
                         "");
 
-    for (i = 0; i < GAYLE_NUM_PROBE_HWIFS; i++) {
-       unsigned long base, ctrlport, irqport;
-       ide_ack_intr_t *ack_intr;
-       hw_regs_t hw;
-       ide_hwif_t *hwif;
-       unsigned long phys_base, res_start, res_n;
-
        if (a4000) {
            phys_base = GAYLE_BASE_4000;
            irqport = (unsigned long)ZTWO_VADDR(GAYLE_IRQ_4000);
@@ -170,32 +165,24 @@ found:
  * FIXME: we now have selectable modes between mmio v/s iomio
  */
 
-       phys_base += i*GAYLE_NEXT_PORT;
-
        res_start = ((unsigned long)phys_base) & ~(GAYLE_NEXT_PORT-1);
        res_n = GAYLE_IDEREG_SIZE;
 
        if (!request_mem_region(res_start, res_n, "IDE"))
-           continue;
+               return -EBUSY;
 
-       base = (unsigned long)ZTWO_VADDR(phys_base);
+    for (i = 0; i < GAYLE_NUM_PROBE_HWIFS; i++) {
+       base = (unsigned long)ZTWO_VADDR(phys_base + i * GAYLE_NEXT_PORT);
        ctrlport = GAYLE_HAS_CONTROL_REG ? (base + GAYLE_CONTROL) : 0;
 
-       gayle_setup_ports(&hw, base, ctrlport, irqport, ack_intr);
-
-       hwif = ide_find_port();
-       if (hwif) {
-           u8 index = hwif->index;
-
-           ide_init_port_data(hwif, index);
-           ide_init_port_hw(hwif, &hw);
+       gayle_setup_ports(&hw[i], base, ctrlport, irqport, ack_intr);
 
-           idx[i] = index;
-       } else
-           release_mem_region(res_start, res_n);
+       hws[i] = &hw[i];
     }
 
-    ide_device_add(idx, NULL);
+    host = ide_host_alloc(NULL, hws);
+    if (host)
+       ide_host_register(host, NULL, hws);
 
     return 0;
 }