summaryrefslogtreecommitdiffstats
path: root/sys/dev
diff options
context:
space:
mode:
authorcg <cg@FreeBSD.org>2001-01-24 01:27:31 +0000
committercg <cg@FreeBSD.org>2001-01-24 01:27:31 +0000
commit99127615ba434a5e19a536d2b5388b1069c97d7a (patch)
treec531285d1d7d386f6857d5c34c4e8d8f256b6fbf /sys/dev
parent456c0fc978869a36de39b3f37e7bd25b38545795 (diff)
downloadFreeBSD-src-99127615ba434a5e19a536d2b5388b1069c97d7a.zip
FreeBSD-src-99127615ba434a5e19a536d2b5388b1069c97d7a.tar.gz
fix certain cards failing to attach
Submitted by: Russell Cattelan <cattelan@thebarn.com>
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/sound/pci/es137x.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/sys/dev/sound/pci/es137x.c b/sys/dev/sound/pci/es137x.c
index dc37803..75e0f9f 100644
--- a/sys/dev/sound/pci/es137x.c
+++ b/sys/dev/sound/pci/es137x.c
@@ -111,7 +111,7 @@ static u_int es1371_wait_src_ready(struct es_info *);
static void es1371_src_write(struct es_info *, u_short, unsigned short);
static u_int es1371_adc_rate(struct es_info *, u_int, int);
static u_int es1371_dac_rate(struct es_info *, u_int, int);
-static int es1371_init(struct es_info *es, int);
+static int es1371_init(struct es_info *, device_t);
static int es1370_init(struct es_info *);
static int es1370_wrcodec(struct es_info *, u_char, u_char);
@@ -474,9 +474,11 @@ es1370_init(struct es_info *es)
/* ES1371 specific */
int
-es1371_init(struct es_info *es, int rev)
+es1371_init(struct es_info *es, device_t dev)
{
int idx;
+ int devid = pci_get_devid(dev);
+ int revid = pci_get_revid(dev);
if (debug > 0) printf("es_init\n");
@@ -484,7 +486,7 @@ es1371_init(struct es_info *es, int rev)
es->ctrl = 0;
es->sctrl = 0;
/* initialize the chips */
- if (rev == 7 || rev >= 9 || rev == 2) {
+ if (revid == 7 || revid >= 9 || (devid == ES1371_PCI_ID3 && revid == 2)) {
#define ES1371_BINTSUMM_OFF 0x07
bus_space_write_4(es->st, es->sh, ES1371_BINTSUMM_OFF, 0x20);
if (debug > 0) printf("es_init rev == 7 || rev >= 9\n");
@@ -788,7 +790,7 @@ es_pci_attach(device_t dev)
if (pci_get_devid(dev) == ES1371_PCI_ID ||
pci_get_devid(dev) == ES1371_PCI_ID2 ||
pci_get_devid(dev) == ES1371_PCI_ID3) {
- if(-1 == es1371_init(es, pci_get_revid(dev))) {
+ if(-1 == es1371_init(es, dev)) {
device_printf(dev, "unable to initialize the card\n");
goto bad;
}
OpenPOWER on IntegriCloud