}
 #endif /* CONFIG_SND_HDA_DSP_LOADER */
 
+/*
+ * Easy macros for widget capabilities
+ */
+#define snd_hdac_get_wcaps(codec, nid) \
+       snd_hdac_read_parm(codec, nid, AC_PAR_AUDIO_WIDGET_CAP)
+
+/* get the widget type from widget capability bits */
+static inline int snd_hdac_get_wcaps_type(unsigned int wcaps)
+{
+       if (!wcaps)
+               return -1; /* invalid type */
+       return (wcaps & AC_WCAP_TYPE) >> AC_WCAP_TYPE_SHIFT;
+}
+
+/* get the number of supported channels */
+static inline unsigned int snd_hdac_get_wcaps_channels(u32 wcaps)
+{
+       unsigned int chans;
+
+       chans = (wcaps & AC_WCAP_CHAN_CNT_EXT) >> 13;
+       chans = (chans + 1) * 2;
+
+       return chans;
+}
 
 /*
  * generic array helpers
 
 /* return CONNLIST_LEN parameter of the given widget */
 static unsigned int get_num_conns(struct hdac_device *codec, hda_nid_t nid)
 {
-       unsigned int wcaps = get_wcaps(codec, nid);
+       unsigned int wcaps = snd_hdac_get_wcaps(codec, nid);
        unsigned int parm;
 
        if (!(wcaps & AC_WCAP_CONN_LIST) &&
-           get_wcaps_type(wcaps) != AC_WID_VOL_KNB)
+           snd_hdac_get_wcaps_type(wcaps) != AC_WID_VOL_KNB)
                return 0;
 
        parm = snd_hdac_read_parm(codec, nid, AC_PAR_CONNLIST_LEN);
        unsigned int val = 0;
 
        if (nid != codec->afg &&
-           (get_wcaps(codec, nid) & AC_WCAP_FORMAT_OVRD))
+           (snd_hdac_get_wcaps(codec, nid) & AC_WCAP_FORMAT_OVRD))
                val = snd_hdac_read_parm(codec, nid, AC_PAR_PCM);
        if (!val || val == -1)
                val = snd_hdac_read_parm(codec, codec->afg, AC_PAR_PCM);
 {
        unsigned int i, val, wcaps;
 
-       wcaps = get_wcaps(codec, nid);
+       wcaps = snd_hdac_get_wcaps(codec, nid);
        val = query_pcm_param(codec, nid);
 
        if (ratesp) {
 
 static ssize_t caps_show(struct hdac_device *codec, hda_nid_t nid,
                        struct widget_attribute *attr, char *buf)
 {
-       return sysfs_emit(buf, "0x%08x\n", get_wcaps(codec, nid));
+       return sysfs_emit(buf, "0x%08x\n", snd_hdac_get_wcaps(codec, nid));
 }
 
 static ssize_t pin_caps_show(struct hdac_device *codec, hda_nid_t nid,
                             struct widget_attribute *attr, char *buf)
 {
-       if (get_wcaps_type(get_wcaps(codec, nid)) != AC_WID_PIN)
+       if (snd_hdac_get_wcaps_type(snd_hdac_get_wcaps(codec, nid)) != AC_WID_PIN)
                return 0;
        return sysfs_emit(buf, "0x%08x\n",
                          snd_hdac_read_parm(codec, nid, AC_PAR_PIN_CAP));
 {
        unsigned int val;
 
-       if (get_wcaps_type(get_wcaps(codec, nid)) != AC_WID_PIN)
+       if (snd_hdac_get_wcaps_type(snd_hdac_get_wcaps(codec, nid)) != AC_WID_PIN)
                return 0;
        if (snd_hdac_read(codec, nid, AC_VERB_GET_CONFIG_DEFAULT, 0, &val))
                return 0;
 {
        if (nid == codec->afg || nid == codec->mfg)
                return true;
-       switch (get_wcaps_type(get_wcaps(codec, nid))) {
+       switch (snd_hdac_get_wcaps_type(snd_hdac_get_wcaps(codec, nid))) {
        case AC_WID_AUD_OUT:
        case AC_WID_AUD_IN:
                return true;
 static ssize_t amp_in_caps_show(struct hdac_device *codec, hda_nid_t nid,
                                struct widget_attribute *attr, char *buf)
 {
-       if (nid != codec->afg && !(get_wcaps(codec, nid) & AC_WCAP_IN_AMP))
+       if (nid != codec->afg && !(snd_hdac_get_wcaps(codec, nid) & AC_WCAP_IN_AMP))
                return 0;
        return sysfs_emit(buf, "0x%08x\n",
                          snd_hdac_read_parm(codec, nid, AC_PAR_AMP_IN_CAP));
 static ssize_t amp_out_caps_show(struct hdac_device *codec, hda_nid_t nid,
                                 struct widget_attribute *attr, char *buf)
 {
-       if (nid != codec->afg && !(get_wcaps(codec, nid) & AC_WCAP_OUT_AMP))
+       if (nid != codec->afg && !(snd_hdac_get_wcaps(codec, nid) & AC_WCAP_OUT_AMP))
                return 0;
        return sysfs_emit(buf, "0x%08x\n",
                          snd_hdac_read_parm(codec, nid, AC_PAR_AMP_OUT_CAP));
 static ssize_t power_caps_show(struct hdac_device *codec, hda_nid_t nid,
                               struct widget_attribute *attr, char *buf)
 {
-       if (nid != codec->afg && !(get_wcaps(codec, nid) & AC_WCAP_POWER))
+       if (nid != codec->afg && !(snd_hdac_get_wcaps(codec, nid) & AC_WCAP_POWER))
                return 0;
        return sysfs_emit(buf, "0x%08x\n",
                          snd_hdac_read_parm(codec, nid, AC_PAR_POWER_STATE));
 
 #ifndef __HDAC_LOCAL_H
 #define __HDAC_LOCAL_H
 
-#define get_wcaps(codec, nid) \
-       snd_hdac_read_parm(codec, nid, AC_PAR_AUDIO_WIDGET_CAP)
-
-/* get the widget type from widget capability bits */
-static inline int get_wcaps_type(unsigned int wcaps)
-{
-       if (!wcaps)
-               return -1; /* invalid type */
-       return (wcaps & AC_WCAP_TYPE) >> AC_WCAP_TYPE_SHIFT;
-}
-
-static inline unsigned int get_wcaps_channels(u32 wcaps)
-{
-       unsigned int chans;
-
-       chans = (wcaps & AC_WCAP_CHAN_CNT_EXT) >> 13;
-       chans = (chans + 1) * 2;
-
-       return chans;
-}
-
 extern const struct attribute_group *hdac_dev_attr_groups[];
 int hda_widget_sysfs_init(struct hdac_device *codec);
 int hda_widget_sysfs_reinit(struct hdac_device *codec, hda_nid_t start_nid,
 
 #include <sound/hda_i915.h>
 #include <sound/pcm_drm_eld.h>
 #include <sound/hda_chmap.h>
-#include "../../hda/local.h"
 #include "hdac_hdmi.h"
 
 #define NAME_SIZE      32
        unsigned int caps;
        unsigned int type, param;
 
-       caps = get_wcaps(hdev, nid);
-       type = get_wcaps_type(caps);
+       caps = snd_hdac_get_wcaps(hdev, nid);
+       type = snd_hdac_get_wcaps_type(caps);
 
        if (!(caps & AC_WCAP_DIGITAL) || (type != AC_WID_PIN))
                return 0;
                                        struct hdac_hdmi_pin *pin,
                                        struct hdac_hdmi_port *port)
 {
-       if (!(get_wcaps(hdev, pin->nid) & AC_WCAP_CONN_LIST)) {
+       if (!(snd_hdac_get_wcaps(hdev, pin->nid) & AC_WCAP_CONN_LIST)) {
                dev_warn(&hdev->dev,
                        "HDMI: pin %d wcaps %#x does not support connection list\n",
-                       pin->nid, get_wcaps(hdev, pin->nid));
+                       pin->nid, snd_hdac_get_wcaps(hdev, pin->nid));
                return -EINVAL;
        }
 
        struct hdac_hdmi_priv *hdmi = hdev_to_hdmi_priv(hdev);
        int err;
 
-       chans = get_wcaps(hdev, cvt->nid);
-       chans = get_wcaps_channels(chans);
+       chans = snd_hdac_get_wcaps(hdev, cvt->nid);
+       chans = snd_hdac_get_wcaps_channels(chans);
 
        cvt->params.channels_min = 2;
 
        int count;
        unsigned int state;
 
-       if (get_wcaps(hdev, nid) & AC_WCAP_POWER) {
+       if (snd_hdac_get_wcaps(hdev, nid) & AC_WCAP_POWER) {
                if (!snd_hdac_check_power_state(hdev, nid, pwr_state)) {
                        for (count = 0; count < 10; count++) {
                                snd_hdac_codec_read(hdev, nid, 0,
 static void hdac_hdmi_set_amp(struct hdac_device *hdev,
                                   hda_nid_t nid, int val)
 {
-       if (get_wcaps(hdev, nid) & AC_WCAP_OUT_AMP)
+       if (snd_hdac_get_wcaps(hdev, nid) & AC_WCAP_OUT_AMP)
                snd_hdac_codec_write(hdev, nid, 0,
                                        AC_VERB_SET_AMP_GAIN_MUTE, val);
 }
                unsigned int caps;
                unsigned int type;
 
-               caps = get_wcaps(hdev, nid);
-               type = get_wcaps_type(caps);
+               caps = snd_hdac_get_wcaps(hdev, nid);
+               type = snd_hdac_get_wcaps_type(caps);
 
                if (!(caps & AC_WCAP_DIGITAL))
                        continue;