static int __init ali14xx_probe(void)
 {
        static u8 idx[4] = { 0, 1, 0xff, 0xff };
+       hw_regs_t hw[2];
 
        printk(KERN_DEBUG "ali14xx: base=0x%03x, regOn=0x%02x.\n",
                          basePort, regOn);
                return 1;
        }
 
+       memset(&hw, 0, sizeof(hw));
+
+       ide_std_init_ports(&hw[0], 0x1f0, 0x3f6);
+       hw[0].irq = 14;
+
+       ide_std_init_ports(&hw[1], 0x170, 0x376);
+       hw[1].irq = 15;
+
+       ide_init_port_hw(&ide_hwifs[0], &hw[0]);
+       ide_init_port_hw(&ide_hwifs[1], &hw[1]);
+
        ide_hwifs[0].set_pio_mode = &ali14xx_set_pio_mode;
        ide_hwifs[1].set_pio_mode = &ali14xx_set_pio_mode;
 
 
        unsigned long flags;
        ide_hwif_t *hwif, *mate;
        static u8 idx[4] = { 0, 1, 0xff, 0xff };
+       hw_regs_t hw[2];
 
        hwif = &ide_hwifs[0];
        mate = &ide_hwifs[1];
 #endif
        local_irq_restore(flags);
 
+       memset(&hw, 0, sizeof(hw));
+
+       ide_std_init_ports(&hw[0], 0x1f0, 0x3f6);
+       hw[0].irq = 14;
+
+       ide_std_init_ports(&hw[1], 0x170, 0x376);
+       hw[1].irq = 15;
+
+       ide_init_port_hw(hwif, &hw[0]);
+       ide_init_port_hw(mate, &hw[1]);
+
        hwif->set_pio_mode = &dtc2278_set_pio_mode;
 
        ide_device_add(idx, &dtc2278_port_info);
 
 {
        ide_hwif_t *hwif, *mate;
        static u8 idx[4] = { 0, 1, 0xff, 0xff };
+       hw_regs_t hw[2];
 
        if (probe_ht6560b == 0)
                return -ENODEV;
                goto release_region;
        }
 
+       memset(&hw, 0, sizeof(hw));
+
+       ide_std_init_ports(&hw[0], 0x1f0, 0x3f6);
+       hw[0].irq = 14;
+
+       ide_std_init_ports(&hw[1], 0x170, 0x376);
+       hw[1].irq = 15;
+
+       ide_init_port_hw(hwif, &hw[0]);
+       ide_init_port_hw(mate, &hw[1]);
+
        hwif->selectproc = &ht6560b_selectproc;
        hwif->set_pio_mode = &ht6560b_set_pio_mode;
 
 
 {
        ide_hwif_t *hwif, *mate;
        u8 idx[4] = { 0, 1, 0xff, 0xff };
+       hw_regs_t hw;
 
        if (probe_4drives == 0)
                return -ENODEV;
        hwif = &ide_hwifs[0];
        mate = &ide_hwifs[1];
 
-       memcpy(mate->io_ports, hwif->io_ports, sizeof(hwif->io_ports));
+       memset(&hw, 0, sizeof(hw));
 
-       mate->irq = hwif->irq;
+       ide_std_init_ports(&hw, 0x1f0, 0x3f6);
+       hw.irq = 14;
+       hw.chipset = ide_4drives;
 
-       mate->chipset = hwif->chipset = ide_4drives;
+       ide_init_port_hw(hwif, &hw);
+       ide_init_port_hw(mate, &hw);
 
        mate->drives[0].select.all ^= 0x20;
        mate->drives[1].select.all ^= 0x20;
 
 static int __init qd_probe(int base)
 {
        ide_hwif_t *hwif;
+       u8 config, unit;
        u8 idx[4] = { 0xff, 0xff, 0xff, 0xff };
-       u8 config;
-       u8 unit;
+       hw_regs_t hw[2];
 
        config = inb(QD_CONFIG_PORT);
 
 
        unit = ! (config & QD_CONFIG_IDE_BASEPORT);
 
+       memset(&hw, 0, sizeof(hw));
+
+       ide_std_init_ports(&hw[0], 0x1f0, 0x3f6);
+       hw[0].irq = 14;
+
+       ide_std_init_ports(&hw[1], 0x170, 0x376);
+       hw[1].irq = 15;
+
        if ((config & 0xf0) == QD_CONFIG_QD6500) {
 
                if (qd_testreg(base)) return 1;         /* bad register */
                        return 1;
                }
 
+               ide_init_port_hw(hwif, &hw[unit]);
+
                qd_setup(hwif, base, config);
 
                hwif->port_init_devs = qd6500_port_init_devs;
                        printk(KERN_INFO "%s: qd6580: single IDE board\n",
                                         hwif->name);
 
+                       ide_init_port_hw(hwif, &hw[unit]);
+
                        qd_setup(hwif, base, config | (control << 8));
 
                        hwif->port_init_devs = qd6580_port_init_devs;
                        printk(KERN_INFO "%s&%s: qd6580: dual IDE board\n",
                                        hwif->name, mate->name);
 
+                       ide_init_port_hw(hwif, &hw[0]);
+                       ide_init_port_hw(mate, &hw[1]);
+
                        qd_setup(hwif, base, config | (control << 8));
 
                        hwif->port_init_devs = qd6580_port_init_devs;
 
 {
        unsigned long flags;
        static u8 idx[4] = { 0, 1, 0xff, 0xff };
+       hw_regs_t hw[2];
 
        if (!request_region(0x108, 2, "umc8672")) {
                printk(KERN_ERR "umc8672: ports 0x108-0x109 already in use.\n");
        umc_set_speeds (current_speeds);
        local_irq_restore(flags);
 
+       memset(&hw, 0, sizeof(hw));
+
+       ide_std_init_ports(&hw[0], 0x1f0, 0x3f6);
+       hw[0].irq = 14;
+
+       ide_std_init_ports(&hw[1], 0x170, 0x376);
+       hw[1].irq = 15;
+
+       ide_init_port_hw(&ide_hwifs[0], &hw[0]);
+       ide_init_port_hw(&ide_hwifs[1], &hw[1]);
+
        ide_hwifs[0].set_pio_mode = &umc_set_pio_mode;
        ide_hwifs[1].set_pio_mode = &umc_set_pio_mode;