Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/hdaudio Read GCAP and version regs after taking the ...
details: https://anonhg.NetBSD.org/src/rev/29e9234f990f
branches: trunk
changeset: 1007139:29e9234f990f
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Sat Feb 08 00:14:06 2020 +0000
description:
Read GCAP and version regs after taking the controller out of reset. Fixes
stream counts on my Radeon HD 7850.
diffstat:
sys/dev/hdaudio/hdaudio.c | 50 +++++++++++++++++++---------------------------
1 files changed, 21 insertions(+), 29 deletions(-)
diffs (90 lines):
diff -r 4d7036a636a2 -r 29e9234f990f sys/dev/hdaudio/hdaudio.c
--- a/sys/dev/hdaudio/hdaudio.c Sat Feb 08 00:11:18 2020 +0000
+++ b/sys/dev/hdaudio/hdaudio.c Sat Feb 08 00:14:06 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: hdaudio.c,v 1.9 2019/07/26 11:13:46 jmcneill Exp $ */
+/* $NetBSD: hdaudio.c,v 1.10 2020/02/08 00:14:06 jmcneill Exp $ */
/*
* Copyright (c) 2009 Precedence Technologies Ltd <support%precedence.co.uk@localhost>
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: hdaudio.c,v 1.9 2019/07/26 11:13:46 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: hdaudio.c,v 1.10 2020/02/08 00:14:06 jmcneill Exp $");
#include <sys/types.h>
#include <sys/param.h>
@@ -121,36 +121,21 @@
static void
hdaudio_init(struct hdaudio_softc *sc)
{
- uint16_t gcap;
- int nos, nis, nbidir;
-#if defined(HDAUDIO_DEBUG)
- uint8_t vmin, vmaj;
- int nsdo, addr64;
-#endif
+ const uint8_t vmaj = hda_read1(sc, HDAUDIO_MMIO_VMAJ);
+ const uint8_t vmin = hda_read1(sc, HDAUDIO_MMIO_VMIN);
+ const uint16_t gcap = hda_read2(sc, HDAUDIO_MMIO_GCAP);
+ const int nis = HDAUDIO_GCAP_ISS(gcap);
+ const int nos = HDAUDIO_GCAP_OSS(gcap);
+ const int nbidir = HDAUDIO_GCAP_BSS(gcap);
+ const int nsdo = HDAUDIO_GCAP_NSDO(gcap);
+ const int addr64 = HDAUDIO_GCAP_64OK(gcap);
-#if defined(HDAUDIO_DEBUG)
- vmaj = hda_read1(sc, HDAUDIO_MMIO_VMAJ);
- vmin = hda_read1(sc, HDAUDIO_MMIO_VMIN);
-
- hda_print(sc, "High Definition Audio version %d.%d\n", vmaj, vmin);
-#endif
-
- gcap = hda_read2(sc, HDAUDIO_MMIO_GCAP);
- nis = HDAUDIO_GCAP_ISS(gcap);
- nos = HDAUDIO_GCAP_OSS(gcap);
- nbidir = HDAUDIO_GCAP_BSS(gcap);
+ hda_print(sc, "HDA ver. %d.%d, OSS %d, ISS %d, BSS %d, SDO %d%s\n",
+ vmaj, vmin, nos, nis, nbidir, nsdo, addr64 ? ", 64-bit" : "");
/* Initialize codecs and streams */
hdaudio_codec_init(sc);
hdaudio_stream_init(sc, nis, nos, nbidir);
-
-#if defined(HDAUDIO_DEBUG)
- nsdo = HDAUDIO_GCAP_NSDO(gcap);
- addr64 = HDAUDIO_GCAP_64OK(gcap);
-
- hda_print(sc, "OSS %d ISS %d BSS %d SDO %d%s\n",
- nos, nis, nbidir, nsdo, addr64 ? " 64-bit" : "");
-#endif
}
static int
@@ -795,8 +780,6 @@
mutex_init(&sc->sc_corb_mtx, MUTEX_DEFAULT, IPL_AUDIO);
mutex_init(&sc->sc_stream_mtx, MUTEX_DEFAULT, IPL_AUDIO);
- hdaudio_init(sc);
-
/*
* Put the controller into a known state by entering and leaving
* CRST as necessary.
@@ -814,6 +797,15 @@
* In reality, we need to wait longer than this.
*/
hda_delay(HDAUDIO_CODEC_DELAY);
+
+ /*
+ * Read device capabilities
+ */
+ hdaudio_init(sc);
+
+ /*
+ * Detect codecs
+ */
if (hdaudio_codec_probe(sc) == 0) {
hda_error(sc, "no codecs found\n");
err = ENODEV;
Home |
Main Index |
Thread Index |
Old Index