[PATCH] libata: propogate host private data from probe function
authorAlan Cox <alan@lxorguk.ukuu.org.uk>
Tue, 8 Nov 2005 14:09:44 +0000 (14:09 +0000)
committerJeff Garzik <jgarzik@pobox.com>
Fri, 11 Nov 2005 13:19:55 +0000 (08:19 -0500)
This will let me chop the code size of several drivers right down. In
many cases the actual private data is very useful and constant for a
given host controller so being able to just pass it at probe time would
be very useful indeed (eg with the via driver would could pass the udma
clocking and reduce the code size, or with the AMD one the UDMA
multiplier and the offset)

Signed-off-by: Alan Cox <alan@redhat.com>
Signed-off-by: Jeff Garzik <jgarzik@pobox.com>
drivers/scsi/libata-core.c
include/linux/libata.h

index a74b4071a662f6169debc3123cf86b7a6808e3be..e51d9a8a2796fc076eff174fcb16ebffd9e5ffe9 100644 (file)
@@ -4563,6 +4563,7 @@ ata_pci_init_native_mode(struct pci_dev *pdev, struct ata_port_info **port, int
 
        probe_ent->irq = pdev->irq;
        probe_ent->irq_flags = SA_SHIRQ;
+       probe_ent->private_data = port[0]->private_data;
 
        if (ports & ATA_PORT_PRIMARY) {
                probe_ent->port[p].cmd_addr = pci_resource_start(pdev, 0);
@@ -4599,6 +4600,7 @@ static struct ata_probe_ent *ata_pci_init_legacy_port(struct pci_dev *pdev, stru
        probe_ent->legacy_mode = 1;
        probe_ent->n_ports = 1;
        probe_ent->hard_port_no = port_num;
+       probe_ent->private_data = port->private_data;
 
        switch(port_num)
        {
index a5390313c7b446722b5457baa53e848eebabc511..1464a7586de843fd5cf256ce622b79353bb3fd9c 100644 (file)
@@ -405,6 +405,7 @@ struct ata_port_info {
        unsigned long           mwdma_mask;
        unsigned long           udma_mask;
        const struct ata_port_operations *port_ops;
+       void                    *private_data;
 };
 
 struct ata_timing {