Module Name: src
Committed By: jmcneill
Date: Mon Feb 24 12:21:27 UTC 2014
Modified Files:
src/sys/arch/arm/allwinner: awin_ahcisata.c
Log Message:
Save initial CAP/CAP2/PI config over reset. Provide channel_start callback
that sets up awin specific DMA regs.
To generate a diff of this commit:
cvs rdiff -u -r1.8 -r1.9 src/sys/arch/arm/allwinner/awin_ahcisata.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/arch/arm/allwinner/awin_ahcisata.c
diff -u src/sys/arch/arm/allwinner/awin_ahcisata.c:1.8 src/sys/arch/arm/allwinner/awin_ahcisata.c:1.9
--- src/sys/arch/arm/allwinner/awin_ahcisata.c:1.8 Sun Sep 8 11:47:50 2013
+++ src/sys/arch/arm/allwinner/awin_ahcisata.c Mon Feb 24 12:21:27 2014
@@ -31,7 +31,7 @@
#include <sys/cdefs.h>
-__KERNEL_RCSID(1, "$NetBSD: awin_ahcisata.c,v 1.8 2013/09/08 11:47:50 matt Exp $");
+__KERNEL_RCSID(1, "$NetBSD: awin_ahcisata.c,v 1.9 2014/02/24 12:21:27 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -167,6 +167,17 @@ awin_ahci_enable(bus_space_tag_t bst, bu
}
static void
+awin_ahci_channel_start(struct ahci_softc *sc, struct ata_channel *chp)
+{
+ uint32_t dma;
+
+ dma = AHCI_READ(sc, AWIN_AHCI_DMA_REG);
+ dma &= ~0xff00;
+ dma |= 0x4400;
+ AHCI_WRITE(sc, AWIN_AHCI_DMA_REG, dma);
+}
+
+static void
awin_ahci_attach(device_t parent, device_t self, void *aux)
{
struct awin_ahci_softc * const asc = device_private(self);
@@ -181,6 +192,9 @@ awin_ahci_attach(device_t parent, device
sc->sc_ahcit = aio->aio_core_bst;
sc->sc_ahcis = loc->loc_size;
sc->sc_ahci_ports = 1;
+ sc->sc_ahci_quirks = AHCI_QUIRK_BADPMP;
+ sc->sc_save_init_data = true;
+ sc->sc_channel_start = awin_ahci_channel_start;
bus_space_subregion(aio->aio_core_bst, aio->aio_core_bsh,
loc->loc_offset, loc->loc_size, &sc->sc_ahcih);