diff options
-rw-r--r-- | sys/dev/pci/ahci.c | 75 | ||||
-rw-r--r-- | sys/dev/pci/files.pci | 6 |
2 files changed, 45 insertions, 36 deletions
diff --git a/sys/dev/pci/ahci.c b/sys/dev/pci/ahci.c index dff97c0f09e..e9c8161390f 100644 --- a/sys/dev/pci/ahci.c +++ b/sys/dev/pci/ahci.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ahci.c,v 1.122 2007/06/29 01:27:10 dlg Exp $ */ +/* $OpenBSD: ahci.c,v 1.123 2007/07/02 00:46:22 dlg Exp $ */ /* * Copyright (c) 2006 David Gwynne <dlg@openbsd.org> @@ -432,23 +432,27 @@ static const struct ahci_device ahci_devices[] = { ahci_no_match, ahci_vt8251_attach } }; -int ahci_match(struct device *, void *, void *); -void ahci_attach(struct device *, struct device *, void *); +int ahci_pci_match(struct device *, void *, void *); +void ahci_pci_attach(struct device *, struct device *, + void *); -struct cfattach ahci_ca = { - sizeof(struct ahci_softc), ahci_match, ahci_attach +struct cfattach ahci_pci_ca = { + sizeof(struct ahci_softc), ahci_pci_match, ahci_pci_attach }; struct cfdriver ahci_cd = { NULL, "ahci", DV_DULL }; +int ahci_attach(struct ahci_softc *, + struct pci_attach_args *, pci_intr_handle_t); + int ahci_map_regs(struct ahci_softc *, struct pci_attach_args *); void ahci_unmap_regs(struct ahci_softc *, struct pci_attach_args *); int ahci_map_intr(struct ahci_softc *, - struct pci_attach_args *); + struct pci_attach_args *, pci_intr_handle_t); #ifdef notyet void ahci_unmap_intr(struct ahci_softc *, struct pci_attach_args *); @@ -645,7 +649,7 @@ ahci_vt8251_attach(struct ahci_softc *sc, struct pci_attach_args *pa) } int -ahci_match(struct device *parent, void *match, void *aux) +ahci_pci_match(struct device *parent, void *match, void *aux) { struct pci_attach_args *pa = aux; const struct ahci_device *ad; @@ -668,14 +672,12 @@ ahci_match(struct device *parent, void *match, void *aux) } void -ahci_attach(struct device *parent, struct device *self, void *aux) +ahci_pci_attach(struct device *parent, struct device *self, void *aux) { struct ahci_softc *sc = (struct ahci_softc *)self; struct pci_attach_args *pa = aux; const struct ahci_device *ad; - struct atascsi_attach_args aaa; - u_int32_t cap, pi; - int i; + pci_intr_handle_t ih; ad = ahci_lookup_device(pa); if (ad != NULL && ad->ad_attach != NULL) { @@ -685,9 +687,26 @@ ahci_attach(struct device *parent, struct device *self, void *aux) } } + if (pci_intr_map(pa, &ih) != 0) { + printf(": unable to map interrupt\n"); + return; + } + printf(": %s,", pci_intr_string(pa->pa_pc, ih)); + + ahci_attach(sc, pa, ih); +} + +int +ahci_attach(struct ahci_softc *sc, struct pci_attach_args *pa, + pci_intr_handle_t ih) +{ + struct atascsi_attach_args aaa; + u_int32_t cap, pi; + int i; + if (ahci_map_regs(sc, pa) != 0) { /* error already printed by ahci_map_regs */ - return; + return (1); } if (ahci_init(sc) != 0) { @@ -695,7 +714,7 @@ ahci_attach(struct device *parent, struct device *self, void *aux) goto unmap; } - if (ahci_map_intr(sc, pa) != 0) { + if (ahci_map_intr(sc, pa, ih) != 0) { /* error already printed by ahci_map_intr */ goto unmap; } @@ -787,12 +806,12 @@ noccc: if (!(sc->sc_flags & AHCI_F_NO_NCQ) && (cap & AHCI_REG_CAP_SNCQ)) aaa.aaa_capability |= ASAA_CAP_NCQ; - sc->sc_atascsi = atascsi_attach(self, &aaa); + sc->sc_atascsi = atascsi_attach(&sc->sc_dev, &aaa); /* Enable interrupts */ ahci_write(sc, AHCI_REG_GHC, AHCI_REG_GHC_AE | AHCI_REG_GHC_IE); - return; + return (0); freeports: for (i = 0; i < AHCI_MAX_PORTS; i++) @@ -801,8 +820,8 @@ freeports: unmap: /* Disable controller */ ahci_write(sc, AHCI_REG_GHC, 0); - ahci_unmap_regs(sc, pa); + return (1); } int @@ -813,7 +832,7 @@ ahci_map_regs(struct ahci_softc *sc, struct pci_attach_args *pa) maptype = pci_mapreg_type(pa->pa_pc, pa->pa_tag, AHCI_PCI_BAR); if (pci_mapreg_map(pa, AHCI_PCI_BAR, maptype, 0, &sc->sc_iot, &sc->sc_ioh, NULL, &sc->sc_ios, 0) != 0) { - printf(": unable to map registers\n"); + printf(" unable to map registers\n"); return (1); } @@ -828,25 +847,15 @@ ahci_unmap_regs(struct ahci_softc *sc, struct pci_attach_args *pa) } int -ahci_map_intr(struct ahci_softc *sc, struct pci_attach_args *pa) +ahci_map_intr(struct ahci_softc *sc, struct pci_attach_args *pa, + pci_intr_handle_t ih) { - pci_intr_handle_t ih; - const char *intrstr; - - if (pci_intr_map(pa, &ih) != 0) { - printf(": unable to map interrupt\n"); - return (1); - } - intrstr = pci_intr_string(pa->pa_pc, ih); sc->sc_ih = pci_intr_establish(pa->pa_pc, ih, IPL_BIO, ahci_intr, sc, DEVNAME(sc)); if (sc->sc_ih == NULL) { - printf(": unable to map interrupt%s%s\n", - intrstr == NULL ? "" : " at ", - intrstr == NULL ? "" : intrstr); + printf("%s: unable to map interrupt\n", DEVNAME(sc)); return (1); } - printf(": %s", intrstr); return (0); } @@ -880,7 +889,7 @@ ahci_init(struct ahci_softc *sc) ahci_write(sc, AHCI_REG_GHC, AHCI_REG_GHC_HR); if (ahci_wait_ne(sc, AHCI_REG_GHC, AHCI_REG_GHC_HR, AHCI_REG_GHC_HR) != 0) { - printf(": unable to reset controller\n"); + printf(" unable to reset controller\n"); return (1); } } @@ -906,11 +915,11 @@ ahci_init(struct ahci_softc *sc) break; default: - printf(": unsupported AHCI revision 0x%08x\n", reg); + printf(" unsupported AHCI revision 0x%08x\n", reg); return (1); } - printf(": AHCI %s", revision); + printf(" AHCI %s", revision); return (0); } diff --git a/sys/dev/pci/files.pci b/sys/dev/pci/files.pci index 5652c5762ec..fc5f1767364 100644 --- a/sys/dev/pci/files.pci +++ b/sys/dev/pci/files.pci @@ -1,4 +1,4 @@ -# $OpenBSD: files.pci,v 1.236 2007/05/31 18:40:25 reyk Exp $ +# $OpenBSD: files.pci,v 1.237 2007/07/02 00:46:22 dlg Exp $ # $NetBSD: files.pci,v 1.20 1996/09/24 17:47:15 christos Exp $ # # Config file and device description for machine-independent PCI code. @@ -81,8 +81,8 @@ file dev/pci/arc.c arc # Advanced Host Controller Interface for Serial ATA device ahci: scsi, atascsi -attach ahci at pci -file dev/pci/ahci.c ahci +attach ahci at pci with ahci_pci +file dev/pci/ahci.c ahci | ahci_pci # AMI MegaRAID Express x00/Elite 1500/Express 1x00 RAID Controllers attach ami at pci with ami_pci |