aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2016-04-12 14:39:23 +0200
committerTakashi Iwai <tiwai@suse.de>2016-04-12 14:39:23 +0200
commitba095d2e5e5a9c1e20077fc2902c1e7aa919f7c0 (patch)
treec7b0fe7f484ad0447235607d627ba7185e04f798
parentaa39f588a3629bee4981e74c3e4250db6129afe2 (diff)
downloadhda-emu-ba095d2e5e5a9c1e20077fc2902c1e7aa919f7c0.tar.gz
Fix the build with the recent hda_chmap changes
Include <sound/hda_chmap.h> from the dist. Since the new code uses hweight_long(), include linux/bitops.h, too. Signed-off-by: Takashi Iwai <tiwai@suse.de>
-rw-r--r--include/sound/hda_chmap.h79
1 files changed, 3 insertions, 76 deletions
diff --git a/include/sound/hda_chmap.h b/include/sound/hda_chmap.h
index e20d219..0decbe8 100644
--- a/include/sound/hda_chmap.h
+++ b/include/sound/hda_chmap.h
@@ -1,76 +1,3 @@
-/*
- * For multichannel support
- */
-
-#ifndef __SOUND_HDA_CHMAP_H
-#define __SOUND_HDA_CHMAP_H
-
-#include <sound/pcm.h>
-#include <sound/hdaudio.h>
-
-
-#define SND_PRINT_CHANNEL_ALLOCATION_ADVISED_BUFSIZE 80
-
-struct hdac_cea_channel_speaker_allocation {
- int ca_index;
- int speakers[8];
-
- /* derived values, just for convenience */
- int channels;
- int spk_mask;
-};
-struct hdac_chmap;
-
-struct hdac_chmap_ops {
- /*
- * Helpers for producing the channel map TLVs. These can be overridden
- * for devices that have non-standard mapping requirements.
- */
- int (*chmap_cea_alloc_validate_get_type)(struct hdac_chmap *chmap,
- struct hdac_cea_channel_speaker_allocation *cap, int channels);
- void (*cea_alloc_to_tlv_chmap)(struct hdac_chmap *hchmap,
- struct hdac_cea_channel_speaker_allocation *cap,
- unsigned int *chmap, int channels);
-
- /* check that the user-given chmap is supported */
- int (*chmap_validate)(struct hdac_chmap *hchmap, int ca,
- int channels, unsigned char *chmap);
-
- void (*get_chmap)(struct hdac_device *hdac, int pcm_idx,
- unsigned char *chmap);
- void (*set_chmap)(struct hdac_device *hdac, int pcm_idx,
- unsigned char *chmap, int prepared);
- bool (*is_pcm_attached)(struct hdac_device *hdac, int pcm_idx);
-
- /* get and set channel assigned to each HDMI ASP (audio sample packet) slot */
- int (*pin_get_slot_channel)(struct hdac_device *codec,
- hda_nid_t pin_nid, int asp_slot);
- int (*pin_set_slot_channel)(struct hdac_device *codec,
- hda_nid_t pin_nid, int asp_slot, int channel);
- void (*set_channel_count)(struct hdac_device *codec,
- hda_nid_t cvt_nid, int chs);
-};
-
-struct hdac_chmap {
- unsigned int channels_max; /* max over all cvts */
- struct hdac_chmap_ops ops;
- struct hdac_device *hdac;
-};
-
-void snd_hdac_register_chmap_ops(struct hdac_device *hdac,
- struct hdac_chmap *chmap);
-int snd_hdac_channel_allocation(struct hdac_device *hdac, int spk_alloc,
- int channels, bool chmap_set,
- bool non_pcm, unsigned char *map);
-int snd_hdac_get_active_channels(int ca);
-void snd_hdac_setup_channel_mapping(struct hdac_chmap *chmap,
- hda_nid_t pin_nid, bool non_pcm, int ca,
- int channels, unsigned char *map,
- bool chmap_set);
-void snd_hdac_print_channel_allocation(int spk_alloc, char *buf, int buflen);
-struct hdac_cea_channel_speaker_allocation *snd_hdac_get_ch_alloc_from_ca(int ca);
-int snd_hdac_chmap_to_spk_mask(unsigned char c);
-int snd_hdac_spk_to_chmap(int spk);
-int snd_hdac_add_chmap_ctls(struct snd_pcm *pcm, int pcm_idx,
- struct hdac_chmap *chmap);
-#endif /* __SOUND_HDA_CHMAP_H */
+#include "wrapper.h"
+#include <linux/bitops.h>
+#include "../../dist/include/sound/hda_chmap.h"