Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys Replace the HDAUDIO_32BIT_ACCESS option with a runtime o...



details:   https://anonhg.NetBSD.org/src/rev/27384012538d
branches:  trunk
changeset: 462105:27384012538d
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Thu Jul 25 00:30:45 2019 +0000

description:
Replace the HDAUDIO_32BIT_ACCESS option with a runtime option. Set it for
tegra_hdaudio, but not for the pci attachment. Add hdaudio@pci to GENERIC64

diffstat:

 sys/arch/arm/nvidia/tegra_hdaudio.c |   5 +-
 sys/arch/evbarm/conf/GENERIC        |   3 +-
 sys/arch/evbarm/conf/GENERIC64      |   4 +-
 sys/dev/hdaudio/files.hdaudio       |   3 +-
 sys/dev/hdaudio/hdaudiovar.h        |  69 ++++++++++++++++++++----------------
 5 files changed, 46 insertions(+), 38 deletions(-)

diffs (195 lines):

diff -r 6cc27b360fe0 -r 27384012538d sys/arch/arm/nvidia/tegra_hdaudio.c
--- a/sys/arch/arm/nvidia/tegra_hdaudio.c       Thu Jul 25 00:02:55 2019 +0000
+++ b/sys/arch/arm/nvidia/tegra_hdaudio.c       Thu Jul 25 00:30:45 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tegra_hdaudio.c,v 1.10 2018/07/16 23:11:47 christos Exp $ */
+/* $NetBSD: tegra_hdaudio.c,v 1.11 2019/07/25 00:30:45 jmcneill Exp $ */
 
 /*-
  * Copyright (c) 2015 Jared D. McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: tegra_hdaudio.c,v 1.10 2018/07/16 23:11:47 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: tegra_hdaudio.c,v 1.11 2019/07/25 00:30:45 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -156,6 +156,7 @@
            size - TEGRA_HDAUDIO_OFFSET, &sc->sc.sc_memh);
        sc->sc.sc_memvalid = true;
        sc->sc.sc_dmat = faa->faa_dmat;
+       sc->sc.sc_flags = HDAUDIO_FLAG_32BIT;
 
        aprint_naive("\n");
        aprint_normal(": HDA\n");
diff -r 6cc27b360fe0 -r 27384012538d sys/arch/evbarm/conf/GENERIC
--- a/sys/arch/evbarm/conf/GENERIC      Thu Jul 25 00:02:55 2019 +0000
+++ b/sys/arch/evbarm/conf/GENERIC      Thu Jul 25 00:30:45 2019 +0000
@@ -1,5 +1,5 @@
 #
-#      $NetBSD: GENERIC,v 1.44 2019/07/23 12:32:40 jmcneill Exp $
+#      $NetBSD: GENERIC,v 1.45 2019/07/25 00:30:45 jmcneill Exp $
 #
 #      GENERIC ARM (aarch32) kernel
 #
@@ -507,7 +507,6 @@
 hdaudio*       at fdt?                 # Intel HDA
 hdafg*         at hdaudiobus?
 options        HDAUDIOVERBOSE
-options        HDAUDIO_32BIT_ACCESS
 options        HDAUDIO_ENABLE_HDMI
 options        HDAUDIO_ENABLE_DISPLAYPORT
 sun8icodec*    at fdt?                 # Audio codec (sun8i)
diff -r 6cc27b360fe0 -r 27384012538d sys/arch/evbarm/conf/GENERIC64
--- a/sys/arch/evbarm/conf/GENERIC64    Thu Jul 25 00:02:55 2019 +0000
+++ b/sys/arch/evbarm/conf/GENERIC64    Thu Jul 25 00:30:45 2019 +0000
@@ -1,5 +1,5 @@
 #
-#      $NetBSD: GENERIC64,v 1.102 2019/07/16 09:47:41 jmcneill Exp $
+#      $NetBSD: GENERIC64,v 1.103 2019/07/25 00:30:45 jmcneill Exp $
 #
 #      GENERIC ARM (aarch64) kernel
 #
@@ -403,9 +403,9 @@
 
 # Audio support
 hdaudio*       at fdt?                 # Intel HDA
+hdaudio*       at pci? dev ? function ?
 hdafg*         at hdaudiobus?
 options        HDAUDIOVERBOSE
-options        HDAUDIO_32BIT_ACCESS
 options        HDAUDIO_ENABLE_HDMI
 options        HDAUDIO_ENABLE_DISPLAYPORT
 ausoc*         at fdt?                 # Simple SoC audio card
diff -r 6cc27b360fe0 -r 27384012538d sys/dev/hdaudio/files.hdaudio
--- a/sys/dev/hdaudio/files.hdaudio     Thu Jul 25 00:02:55 2019 +0000
+++ b/sys/dev/hdaudio/files.hdaudio     Thu Jul 25 00:30:45 2019 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.hdaudio,v 1.4 2019/05/08 13:40:18 isaki Exp $
+# $NetBSD: files.hdaudio,v 1.5 2019/07/25 00:30:45 jmcneill Exp $
 
 #
 # Intel High Definition Audio (Revision 1.0)
@@ -7,7 +7,6 @@
 defflag opt_hdaudio.h  HDAUDIO_ENABLE_HDMI
 defflag opt_hdaudio.h  HDAUDIO_ENABLE_DISPLAYPORT
 defflag opt_hdaudio.h  HDAUDIO_DEBUG
-defflag opt_hdaudio.h  HDAUDIO_32BIT_ACCESS
 defflag opt_hdaudio.h  HDAFG_DEBUG
 defflag opt_hdaudio.h  HDAFG_HDMI_DEBUG
 
diff -r 6cc27b360fe0 -r 27384012538d sys/dev/hdaudio/hdaudiovar.h
--- a/sys/dev/hdaudio/hdaudiovar.h      Thu Jul 25 00:02:55 2019 +0000
+++ b/sys/dev/hdaudio/hdaudiovar.h      Thu Jul 25 00:30:45 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: hdaudiovar.h,v 1.7 2019/05/08 13:40:18 isaki Exp $ */
+/* $NetBSD: hdaudiovar.h,v 1.8 2019/07/25 00:30:45 jmcneill Exp $ */
 
 /*
  * Copyright (c) 2009 Precedence Technologies Ltd <support%precedence.co.uk@localhost>
@@ -145,6 +145,9 @@
        bus_size_t              sc_memsize;
        bool                    sc_memvalid;
 
+       uint32_t                sc_flags;
+#define        HDAUDIO_FLAG_32BIT      __BIT(0)
+
        uint32_t                sc_subsystem;
 
        kmutex_t                sc_corb_mtx;
@@ -184,58 +187,64 @@
 int    hdaudio_stream_tag(struct hdaudio_stream *);
 uint16_t hdaudio_stream_param(struct hdaudio_stream *, const audio_params_t *);
 
-#ifdef HDAUDIO_32BIT_ACCESS
 static __inline uint8_t
 _hda_read1(struct hdaudio_softc *sc, bus_size_t off)
 {
-       return bus_space_read_4(sc->sc_memt, sc->sc_memh, off & -4) >>
-           (8 * (off & 3));
+       if (ISSET(sc->sc_flags, HDAUDIO_FLAG_32BIT)) {
+               return bus_space_read_4(sc->sc_memt, sc->sc_memh, off & -4) >>
+                   (8 * (off & 3));
+       } else {
+               return bus_space_read_1(sc->sc_memt, sc->sc_memh, off);
+       }
 }
+
 static __inline uint16_t
 _hda_read2(struct hdaudio_softc *sc, bus_size_t off)
 {
-       return bus_space_read_4(sc->sc_memt, sc->sc_memh, off & -4) >>
-           (8 * (off & 2));
+       if (ISSET(sc->sc_flags, HDAUDIO_FLAG_32BIT)) {
+               return bus_space_read_4(sc->sc_memt, sc->sc_memh, off & -4) >>
+                   (8 * (off & 2));
+       } else {
+               return bus_space_read_2(sc->sc_memt, sc->sc_memh, off);
+       }
 }
+
 #define hda_read1                      _hda_read1
 #define hda_read2                      _hda_read2
 #define        hda_read4(sc, off)              \
        bus_space_read_4((sc)->sc_memt, (sc)->sc_memh, (off))
+
 static __inline void
 _hda_write1(struct hdaudio_softc *sc, bus_size_t off, uint8_t val)
 {
-       const size_t shift = 8 * (off & 3);
-       off &= -4;
-       uint32_t tmp = bus_space_read_4(sc->sc_memt, sc->sc_memh, off);
-       tmp = (val << shift) | (tmp & ~(0xff << shift));
-       bus_space_write_4(sc->sc_memt, sc->sc_memh, off, tmp);
+       if (ISSET(sc->sc_flags, HDAUDIO_FLAG_32BIT)) {
+               const size_t shift = 8 * (off & 3);
+               off &= -4;
+               uint32_t tmp = bus_space_read_4(sc->sc_memt, sc->sc_memh, off);
+               tmp = (val << shift) | (tmp & ~(0xff << shift));
+               bus_space_write_4(sc->sc_memt, sc->sc_memh, off, tmp);
+       } else {
+               bus_space_write_1(sc->sc_memt, sc->sc_memh, off, val);
+       }
 }
+
 static __inline void
 _hda_write2(struct hdaudio_softc *sc, bus_size_t off, uint16_t val)
 {
-       const size_t shift = 8 * (off & 2);
-       off &= -4;
-       uint32_t tmp = bus_space_read_4(sc->sc_memt, sc->sc_memh, off);
-       tmp = (val << shift) | (tmp & ~(0xffff << shift));
-       bus_space_write_4(sc->sc_memt, sc->sc_memh, off, tmp);
+       if (ISSET(sc->sc_flags, HDAUDIO_FLAG_32BIT)) {
+               const size_t shift = 8 * (off & 2);
+               off &= -4;
+               uint32_t tmp = bus_space_read_4(sc->sc_memt, sc->sc_memh, off);
+               tmp = (val << shift) | (tmp & ~(0xffff << shift));
+               bus_space_write_4(sc->sc_memt, sc->sc_memh, off, tmp);
+       } else {
+               bus_space_write_2(sc->sc_memt, sc->sc_memh, off, val);
+       }
 }
+
 #define hda_write1                     _hda_write1
 #define hda_write2                     _hda_write2
 #define        hda_write4(sc, off, val)        \
        bus_space_write_4((sc)->sc_memt, (sc)->sc_memh, (off), (val))
-#else
-#define        hda_read1(sc, off)              \
-       bus_space_read_1((sc)->sc_memt, (sc)->sc_memh, (off))
-#define        hda_read2(sc, off)              \
-       bus_space_read_2((sc)->sc_memt, (sc)->sc_memh, (off))
-#define        hda_read4(sc, off)              \
-       bus_space_read_4((sc)->sc_memt, (sc)->sc_memh, (off))
-#define        hda_write1(sc, off, val)        \
-       bus_space_write_1((sc)->sc_memt, (sc)->sc_memh, (off), (val))
-#define        hda_write2(sc, off, val)        \
-       bus_space_write_2((sc)->sc_memt, (sc)->sc_memh, (off), (val))
-#define        hda_write4(sc, off, val)        \
-       bus_space_write_4((sc)->sc_memt, (sc)->sc_memh, (off), (val))
-#endif
 
 #endif /* !_HDAUDIOVAR_H */



Home | Main Index | Thread Index | Old Index