summaryrefslogtreecommitdiff
path: root/sys/dev/pci
diff options
context:
space:
mode:
authorBrad Smith <brad@cvs.openbsd.org>2006-07-20 02:06:18 +0000
committerBrad Smith <brad@cvs.openbsd.org>2006-07-20 02:06:18 +0000
commitd5de3890cb536b27edfa50a791c4db8f3e85c91f (patch)
treebc69aa2083c3c166e4c1fd0d6453cdbe2abe5d5e /sys/dev/pci
parentdb7681d4a8bac729064ad1b3352397b209a637de (diff)
Don't check the CORBRPRST flag for the NVidia MCP51/55 and ALI M5461.
Based on a diff from kent@NetBSD though modified to also cover the MCP51 and M5461.
Diffstat (limited to 'sys/dev/pci')
-rw-r--r--sys/dev/pci/azalia.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/sys/dev/pci/azalia.c b/sys/dev/pci/azalia.c
index 5d14ff5d355..41d81e842b1 100644
--- a/sys/dev/pci/azalia.c
+++ b/sys/dev/pci/azalia.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: azalia.c,v 1.21 2006/06/30 17:15:04 deraadt Exp $ */
+/* $OpenBSD: azalia.c,v 1.22 2006/07/20 02:06:17 brad Exp $ */
/* $NetBSD: azalia.c,v 1.20 2006/05/07 08:31:44 kent Exp $ */
/*-
@@ -183,6 +183,7 @@ typedef struct azalia_t {
bus_space_handle_t ioh;
bus_size_t map_size;
bus_dma_tag_t dmat;
+ pcireg_t pciid;
uint32_t subid;
codec_t codecs[15];
@@ -332,6 +333,11 @@ static const char *pin_devices[16] = {
* PCI functions
* ================================================================ */
+#define PCI_ID_CODE0(v, p) PCI_ID_CODE(PCI_VENDOR_##v, PCI_PRODUCT_##v##_##p)
+#define PCIID_MCP51 PCI_ID_CODE0(NVIDIA, MCP51_HDA)
+#define PCIID_MCP55 PCI_ID_CODE0(NVIDIA, MCP55_HDA)
+#define PCIID_M5461 PCI_ID_CODE0(ALI, M5461)
+
int
azalia_pci_match(struct device *parent, void *match, void *aux)
{
@@ -392,6 +398,8 @@ azalia_pci_attach(struct device *parent, struct device *self, void *aux)
}
printf(": %s\n", intrrupt_str);
+ sc->pciid = pa->pa_id;
+
if (azalia_attach(sc)) {
printf("%s: initialization failure\n", XNAME(sc));
azalia_pci_detach(self, 0);
@@ -668,7 +676,10 @@ azalia_init_corb(azalia_t *az)
if (corbrp & HDA_CORBRP_CORBRPRST)
break;
}
- if (i <= 0) {
+ if (i <= 0 &&
+ az->pciid != PCIID_MCP51 &&
+ az->pciid != PCIID_MCP55 &&
+ az->pciid != PCIID_M5461) {
printf("%s: CORBRP reset failure\n", XNAME(az));
return -1;
}