summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/pci/ahci.c41
1 files changed, 24 insertions, 17 deletions
diff --git a/sys/dev/pci/ahci.c b/sys/dev/pci/ahci.c
index 975b745611c..d4cb8f558e1 100644
--- a/sys/dev/pci/ahci.c
+++ b/sys/dev/pci/ahci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ahci.c,v 1.61 2007/03/04 14:23:08 pascoe Exp $ */
+/* $OpenBSD: ahci.c,v 1.62 2007/03/04 14:40:41 pascoe Exp $ */
/*
* Copyright (c) 2006 David Gwynne <dlg@openbsd.org>
@@ -340,6 +340,11 @@ struct ahci_port {
struct ahci_ccb *ap_ccbs;
TAILQ_HEAD(, ahci_ccb) ap_ccb_free;
+
+#ifdef AHCI_DEBUG
+ char ap_name[16];
+#define PORTNAME(_ap) ((_ap)->ap_name)
+#endif
};
struct ahci_softc {
@@ -656,6 +661,10 @@ ahci_port_alloc(struct ahci_softc *sc, u_int port)
}
bzero(ap, sizeof(struct ahci_port));
+#ifdef AHCI_DEBUG
+ snprintf(ap->ap_name, sizeof(ap->ap_name), "%s.%d",
+ DEVNAME(sc), port);
+#endif
sc->sc_ports[port] = ap;
if (bus_space_subregion(sc->sc_iot, sc->sc_ioh,
@@ -776,7 +785,6 @@ nomem:
/* Reset port */
rc = ahci_port_portreset(ap);
- printf("ahci_portreset returned %d\n", rc);
switch (rc) {
case ENODEV:
printf("%s: ", DEVNAME(sc));
@@ -800,7 +808,6 @@ nomem:
/* Try a soft reset to clear busy */
rc = ahci_port_softreset(ap);
- printf("ahci_portsoftreset returned %d\n", rc);
if (rc) {
printf("%s: unable to communicate with device on port "
"%d, disabling\n", DEVNAME(sc), port);
@@ -811,6 +818,7 @@ nomem:
default:
break;
}
+ printf("%s: detected device on port %d\n", DEVNAME(sc), port);
/* Enable command transfers on port */
if (ahci_port_start(ap, 0)) {
@@ -913,7 +921,7 @@ int
ahci_port_clo(struct ahci_port *ap)
{
struct ahci_softc *sc = ap->ap_sc;
- u_int32_t cmd;
+ u_int32_t cmd;
/* Only attempt CLO if supported by controller */
if (!ISSET(ahci_read(sc, AHCI_REG_CAP), AHCI_REG_CAP_SCLO))
@@ -923,13 +931,13 @@ ahci_port_clo(struct ahci_port *ap)
cmd = ahci_pread(ap, AHCI_PREG_CMD) & ~AHCI_PREG_CMD_ICC;
#ifdef DIAGNOSTIC
if (ISSET(cmd, AHCI_PREG_CMD_ST))
- printf("%s: CLO requested while port running\n", DEVNAME(sc));
+ printf("%s: CLO requested while port running\n", PORTNAME(ap));
#endif
ahci_pwrite(ap, AHCI_PREG_CMD, cmd | AHCI_PREG_CMD_CLO);
/* Wait for completion */
if (ahci_pwait_clr(ap, AHCI_PREG_CMD, AHCI_PREG_CMD_CLO)) {
- printf("%s: CLO did not complete\n", DEVNAME(sc));
+ printf("%s: CLO did not complete\n", PORTNAME(ap));
return (1);
}
@@ -947,7 +955,7 @@ ahci_port_softreset(struct ahci_port *ap)
u_int32_t cmd;
struct ata_xfer xa;
- DPRINTF(AHCI_D_VERBOSE, "%s: soft reset\n", DEVNAME(ap->ap_sc));
+ DPRINTF(AHCI_D_VERBOSE, "%s: soft reset\n", PORTNAME(ap));
s = splbio();
ccb = ahci_get_ccb(ap);
@@ -961,7 +969,7 @@ ahci_port_softreset(struct ahci_port *ap)
/* Idle port */
if (ahci_port_stop(ap, 0)) {
printf("%s: failed to stop port, cannot softreset\n",
- DEVNAME(ap->ap_sc));
+ PORTNAME(ap));
goto err;
}
@@ -976,14 +984,14 @@ ahci_port_softreset(struct ahci_port *ap)
/* Restart port */
if (ahci_port_start(ap, 0)) {
printf("%s: failed to start port, cannot softreset\n",
- DEVNAME(ap->ap_sc));
+ PORTNAME(ap));
goto err;
}
/* Check whether CLO worked */
if (ahci_pwait_clr(ap, AHCI_PREG_TFD,
AHCI_PREG_TFD_STS_BSY | AHCI_PREG_TFD_STS_DRQ)) {
- printf("%s: CLO %s, need port reset\n", DEVNAME(ap->ap_sc),
+ printf("%s: CLO %s, need port reset\n", PORTNAME(ap),
ISSET(ahci_read(ap->ap_sc, AHCI_REG_CAP), AHCI_REG_CAP_SCLO)
? "failed" : "unsupported");
rc = EBUSY;
@@ -1034,7 +1042,7 @@ ahci_port_softreset(struct ahci_port *ap)
if (ahci_pwait_clr(ap, AHCI_PREG_TFD, AHCI_PREG_TFD_STS_BSY |
AHCI_PREG_TFD_STS_DRQ | AHCI_PREG_TFD_STS_ERR)) {
printf("%s: device didn't come ready after reset, TFD: 0x%b\n",
- DEVNAME(ap->ap_sc), ahci_pread(ap, AHCI_PREG_TFD),
+ PORTNAME(ap), ahci_pread(ap, AHCI_PREG_TFD),
AHCI_PFMT_TFD_STS);
goto err;
}
@@ -1054,10 +1062,10 @@ err:
int
ahci_port_portreset(struct ahci_port *ap)
{
- u_int32_t cmd, r;
- int rc;
+ u_int32_t cmd, r;
+ int rc;
- DPRINTF(AHCI_D_VERBOSE, "%s: port reset\n", DEVNAME(ap->ap_sc));
+ DPRINTF(AHCI_D_VERBOSE, "%s: port reset\n", PORTNAME(ap));
/* Save previous command register state */
cmd = ahci_pread(ap, AHCI_PREG_CMD) & ~AHCI_PREG_CMD_ICC;
@@ -1120,7 +1128,7 @@ ahci_load_prdt(struct ahci_ccb *ccb, struct ata_xfer *xa)
xa->data, xa->datalen, NULL,
(xa->flags & ATA_F_NOWAIT) ? BUS_DMA_NOWAIT : BUS_DMA_WAITOK);
if (error != 0) {
- printf("%s: error %d loading dmamap\n", DEVNAME(sc), error);
+ printf("%s: error %d loading dmamap\n", PORTNAME(ap), error);
return (1);
}
@@ -1173,7 +1181,7 @@ ahci_start(struct ahci_ccb *ccb)
if (ahci_pwait_clr(ap, AHCI_PREG_CI, 1 << ccb->ccb_slot)) {
/* Command didn't go inactive. XXX: wait longer? */
printf("%s: polled command didn't go inactive\n",
- DEVNAME(sc));
+ PORTNAME(ap));
/* Shutdown port. XXX: recover via port reset? */
ahci_port_stop(ap, 0);
rc = ATA_ERROR;
@@ -1203,7 +1211,6 @@ ahci_ata_cmd(void *xsc, struct ata_xfer *xa)
return (0);
}
-
struct ahci_ccb *
ahci_get_ccb(struct ahci_port *ap)
{