summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGilles Chehade <gilles@cvs.openbsd.org>2014-01-02 08:00:36 +0000
committerGilles Chehade <gilles@cvs.openbsd.org>2014-01-02 08:00:36 +0000
commitae4be7bda5e76515d91c68a9ac09d0012b699869 (patch)
tree813f66a6fbf209a33bccfd381b70aeb4c4ad6602
parent8d2b9d1ccd56919d9e1663c4a0c129a6da1409f6 (diff)
disable MSI for Samsung XP941.
This is so I can use the machine to figure out the others things on it, the quirk will go away when interrupt routing gets fixed. ok dlg@, jmatthew@
-rw-r--r--sys/dev/ic/ahcivar.h3
-rw-r--r--sys/dev/pci/ahci_pci.c20
2 files changed, 20 insertions, 3 deletions
diff --git a/sys/dev/ic/ahcivar.h b/sys/dev/ic/ahcivar.h
index ec358ead7e5..dd1e6d98b70 100644
--- a/sys/dev/ic/ahcivar.h
+++ b/sys/dev/ic/ahcivar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: ahcivar.h,v 1.2 2013/07/09 11:55:55 jmatthew Exp $ */
+/* $OpenBSD: ahcivar.h,v 1.3 2014/01/02 08:00:35 gilles Exp $ */
/*
* Copyright (c) 2006 David Gwynne <dlg@openbsd.org>
@@ -176,6 +176,7 @@ struct ahci_softc {
#define AHCI_F_NO_NCQ (1<<0)
#define AHCI_F_IPMS_PROBE (1<<1) /* IPMS on failed PMP probe */
#define AHCI_F_NO_PMP (1<<2) /* ignore PMP capability */
+#define AHCI_F_NO_MSI (1<<3) /* disable MSI */
u_int sc_ncmds;
diff --git a/sys/dev/pci/ahci_pci.c b/sys/dev/pci/ahci_pci.c
index d5f1e4767ac..0b9f4648951 100644
--- a/sys/dev/pci/ahci_pci.c
+++ b/sys/dev/pci/ahci_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ahci_pci.c,v 1.2 2013/02/19 15:29:27 brad Exp $ */
+/* $OpenBSD: ahci_pci.c,v 1.3 2014/01/02 08:00:35 gilles Exp $ */
/*
* Copyright (c) 2006 David Gwynne <dlg@openbsd.org>
@@ -77,6 +77,8 @@ int ahci_amd_hudson2_attach(struct ahci_softc *,
struct pci_attach_args *);
int ahci_intel_attach(struct ahci_softc *,
struct pci_attach_args *);
+int ahci_samsung_attach(struct ahci_softc *,
+ struct pci_attach_args *);
static const struct ahci_device ahci_devices[] = {
{ PCI_VENDOR_AMD, PCI_PRODUCT_AMD_HUDSON2_SATA_1,
@@ -144,6 +146,9 @@ static const struct ahci_device ahci_devices[] = {
{ PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_EP80579_AHCI,
NULL, ahci_intel_attach },
+ { PCI_VENDOR_SAMSUNG2, PCI_PRODUCT_SAMSUNG2_XP941,
+ NULL, ahci_samsung_attach },
+
{ PCI_VENDOR_VIATECH, PCI_PRODUCT_VIATECH_VT8251_SATA,
ahci_no_match, ahci_vt8251_attach }
};
@@ -286,6 +291,13 @@ ahci_intel_attach(struct ahci_softc *sc, struct pci_attach_args *pa)
}
int
+ahci_samsung_attach(struct ahci_softc *sc, struct pci_attach_args *pa)
+{
+ sc->sc_flags |= AHCI_F_NO_MSI;
+ return (0);
+}
+
+int
ahci_pci_match(struct device *parent, void *match, void *aux)
{
struct pci_attach_args *pa = aux;
@@ -316,6 +328,7 @@ ahci_pci_attach(struct device *parent, struct device *self, void *aux)
struct pci_attach_args *pa = aux;
const struct ahci_device *ad;
pci_intr_handle_t ih;
+ int mapped = 0;
psc->psc_pc = pa->pa_pc;
psc->psc_tag = pa->pa_tag;
@@ -329,7 +342,10 @@ ahci_pci_attach(struct device *parent, struct device *self, void *aux)
}
}
- if (pci_intr_map_msi(pa, &ih) != 0 && pci_intr_map(pa, &ih) != 0) {
+ if (!(sc->sc_flags & AHCI_F_NO_MSI))
+ mapped = pci_intr_map_msi(pa, &ih) != 0 ? 0 : 1;
+
+ if (!mapped && pci_intr_map(pa, &ih) != 0) {
printf(": unable to map interrupt\n");
return;
}