Lines Matching full:codec
3 * Universal Interface for Intel High Definition Audio Codec
119 #define snd_hda_codec_amp_read(codec, nid, ch, dir, idx) \ argument
120 snd_hdac_regmap_get_amp(&(codec)->core, nid, ch, dir, idx)
121 int snd_hda_codec_amp_update(struct hda_codec *codec, hda_nid_t nid,
123 int snd_hda_codec_amp_stereo(struct hda_codec *codec, hda_nid_t nid,
125 int snd_hda_codec_amp_init(struct hda_codec *codec, hda_nid_t nid, int ch,
127 int snd_hda_codec_amp_init_stereo(struct hda_codec *codec, hda_nid_t nid,
129 void snd_hda_set_vmaster_tlv(struct hda_codec *codec, hda_nid_t nid, int dir,
131 struct snd_kcontrol *snd_hda_find_mixer_ctl(struct hda_codec *codec,
133 int __snd_hda_add_vmaster(struct hda_codec *codec, char *name,
137 #define snd_hda_add_vmaster(codec, name, tlv, followers, suffix, access) \ argument
138 __snd_hda_add_vmaster(codec, name, tlv, followers, suffix, true, access, NULL)
139 int snd_hda_codec_reset(struct hda_codec *codec);
140 void snd_hda_codec_disconnect_pcms(struct hda_codec *codec);
142 #define snd_hda_regmap_sync(codec) snd_hdac_regmap_sync(&(codec)->core) argument
151 struct hda_codec *codec; member
154 int snd_hda_add_vmaster_hook(struct hda_codec *codec,
166 int snd_hda_create_dig_out_ctls(struct hda_codec *codec,
169 #define snd_hda_create_spdif_out_ctls(codec, anid, cnid) \ argument
170 snd_hda_create_dig_out_ctls(codec, anid, cnid, HDA_PCM_TYPE_SPDIF)
171 int snd_hda_create_spdif_in_ctls(struct hda_codec *codec, hda_nid_t nid);
188 int snd_hda_input_mux_put(struct hda_codec *codec,
192 int snd_hda_add_imux_item(struct hda_codec *codec,
226 int snd_hda_create_spdif_share_sw(struct hda_codec *codec,
228 int snd_hda_multi_out_dig_open(struct hda_codec *codec,
230 int snd_hda_multi_out_dig_close(struct hda_codec *codec,
232 int snd_hda_multi_out_dig_prepare(struct hda_codec *codec,
237 int snd_hda_multi_out_dig_cleanup(struct hda_codec *codec,
239 int snd_hda_multi_out_analog_open(struct hda_codec *codec,
243 int snd_hda_multi_out_analog_prepare(struct hda_codec *codec,
248 int snd_hda_multi_out_analog_cleanup(struct hda_codec *codec,
255 int snd_hda_codec_proc_new(struct hda_codec *codec);
257 static inline int snd_hda_codec_proc_new(struct hda_codec *codec) { return 0; } in snd_hda_codec_proc_new() argument
266 int snd_hda_add_new_ctls(struct hda_codec *codec,
291 void (*func)(struct hda_codec *codec,
300 * for codec SSID matching, use the new HDA_CODEC_QUIRK() instead
306 bool match_codec_ssid; /* match only with codec SSID */
324 unsigned int codec; /* Codec vendor/device ID */ member
336 { .codec = _codec,\
345 { .codec = _codec,\
374 int snd_hda_add_verbs(struct hda_codec *codec, const struct hda_verb *list);
375 void snd_hda_apply_verbs(struct hda_codec *codec);
376 void snd_hda_apply_pincfgs(struct hda_codec *codec,
378 void snd_hda_apply_fixup(struct hda_codec *codec, int action);
379 void __snd_hda_apply_fixup(struct hda_codec *codec, int id, int action, int depth);
380 void snd_hda_pick_fixup(struct hda_codec *codec,
384 void snd_hda_pick_pin_fixup(struct hda_codec *codec,
420 unsigned int snd_hda_get_default_vref(struct hda_codec *codec, hda_nid_t pin);
421 unsigned int snd_hda_correct_pin_ctl(struct hda_codec *codec,
423 int _snd_hda_set_pin_ctl(struct hda_codec *codec, hda_nid_t pin,
428 * @codec: the codec instance
442 snd_hda_set_pin_ctl(struct hda_codec *codec, hda_nid_t pin, unsigned int val) in snd_hda_set_pin_ctl() argument
444 return _snd_hda_set_pin_ctl(codec, pin, val, false); in snd_hda_set_pin_ctl()
449 * @codec: the codec instance
456 snd_hda_set_pin_ctl_cache(struct hda_codec *codec, hda_nid_t pin, in snd_hda_set_pin_ctl_cache() argument
459 return _snd_hda_set_pin_ctl(codec, pin, val, true); in snd_hda_set_pin_ctl_cache()
462 int snd_hda_codec_get_pin_target(struct hda_codec *codec, hda_nid_t nid);
463 int snd_hda_codec_set_pin_target(struct hda_codec *codec, hda_nid_t nid,
466 #define for_each_hda_codec_node(nid, codec) \ argument
467 for ((nid) = (codec)->core.start_nid; (nid) < (codec)->core.end_nid; (nid)++)
469 /* Set the codec power_state flag to indicate to allow unsol event handling;
473 static inline void snd_hda_codec_allow_unsol_events(struct hda_codec *codec) in snd_hda_codec_allow_unsol_events() argument
475 codec->core.dev.power.power_state = PMSG_ON; in snd_hda_codec_allow_unsol_events()
481 static inline u32 get_wcaps(struct hda_codec *codec, hda_nid_t nid) in get_wcaps() argument
483 if (nid < codec->core.start_nid || in get_wcaps()
484 nid >= codec->core.start_nid + codec->core.num_nodes) in get_wcaps()
486 return codec->wcaps[nid - codec->core.start_nid]; in get_wcaps()
507 static inline void snd_hda_override_wcaps(struct hda_codec *codec, in snd_hda_override_wcaps() argument
510 if (nid >= codec->core.start_nid && in snd_hda_override_wcaps()
511 nid < codec->core.start_nid + codec->core.num_nodes) in snd_hda_override_wcaps()
512 codec->wcaps[nid - codec->core.start_nid] = val; in snd_hda_override_wcaps()
515 u32 query_amp_caps(struct hda_codec *codec, hda_nid_t nid, int direction);
516 int snd_hda_override_amp_caps(struct hda_codec *codec, hda_nid_t nid, int dir,
520 * @codec: the HD-auio codec
530 snd_hda_query_pin_caps(struct hda_codec *codec, hda_nid_t nid) in snd_hda_query_pin_caps() argument
532 return snd_hda_param_read(codec, nid, AC_PAR_PIN_CAP); in snd_hda_query_pin_caps()
538 * @codec: the CODEC
547 snd_hda_override_pin_caps(struct hda_codec *codec, hda_nid_t nid, in snd_hda_override_pin_caps() argument
550 return snd_hdac_override_parm(&codec->core, nid, AC_PAR_PIN_CAP, caps); in snd_hda_override_pin_caps()
553 bool snd_hda_check_amp_caps(struct hda_codec *codec, hda_nid_t nid,
556 #define nid_has_mute(codec, nid, dir) \ argument
557 snd_hda_check_amp_caps(codec, nid, dir, (AC_AMPCAP_MUTE | AC_AMPCAP_MIN_MUTE))
558 #define nid_has_volume(codec, nid, dir) \ argument
559 snd_hda_check_amp_caps(codec, nid, dir, AC_AMPCAP_NUM_STEPS)
572 int snd_hda_ctl_add(struct hda_codec *codec, hda_nid_t nid,
574 void snd_hda_ctls_clear(struct hda_codec *codec);
580 int snd_hda_create_hwdep(struct hda_codec *codec);
582 static inline int snd_hda_create_hwdep(struct hda_codec *codec) { return 0; } in snd_hda_create_hwdep() argument
585 void snd_hda_sysfs_init(struct hda_codec *codec);
586 void snd_hda_sysfs_clear(struct hda_codec *codec);
591 const char *snd_hda_get_hint(struct hda_codec *codec, const char *key);
592 int snd_hda_get_bool_hint(struct hda_codec *codec, const char *key);
593 int snd_hda_get_int_hint(struct hda_codec *codec, const char *key, int *valp);
596 const char *snd_hda_get_hint(struct hda_codec *codec, const char *key) in snd_hda_get_hint() argument
602 int snd_hda_get_bool_hint(struct hda_codec *codec, const char *key) in snd_hda_get_bool_hint() argument
608 int snd_hda_get_int_hint(struct hda_codec *codec, const char *key, int *valp) in snd_hda_get_int_hint() argument
618 void snd_hda_schedule_power_save(struct hda_codec *codec);
631 int snd_hda_check_amp_list_power(struct hda_codec *codec,
637 snd_hda_check_power_state(struct hda_codec *codec, hda_nid_t nid, in snd_hda_check_power_state() argument
640 return snd_hdac_check_power_state(&codec->core, nid, target_state); in snd_hda_check_power_state()
643 static inline unsigned int snd_hda_sync_power_state(struct hda_codec *codec, in snd_hda_sync_power_state() argument
647 return snd_hdac_sync_power_state(&codec->core, nid, target_state); in snd_hda_sync_power_state()
649 unsigned int snd_hda_codec_eapd_power_filter(struct hda_codec *codec,
653 void snd_hda_codec_shutdown(struct hda_codec *codec);
655 static inline int snd_hda_codec_init(struct hda_codec *codec) in snd_hda_codec_init() argument
657 struct hda_codec_driver *driver = hda_codec_to_driver(codec); in snd_hda_codec_init()
660 return driver->ops->init(codec); in snd_hda_codec_init()
695 int snd_hdmi_get_eld_size(struct hda_codec *codec, hda_nid_t nid);
696 int snd_hdmi_get_eld(struct hda_codec *codec, hda_nid_t nid,
712 void snd_hda_codec_display_power(struct hda_codec *codec, bool enable);
716 #define codec_err(codec, fmt, args...) \ argument
717 dev_err(hda_codec_dev(codec), fmt, ##args)
718 #define codec_warn(codec, fmt, args...) \ argument
719 dev_warn(hda_codec_dev(codec), fmt, ##args)
720 #define codec_info(codec, fmt, args...) \ argument
721 dev_info(hda_codec_dev(codec), fmt, ##args)
722 #define codec_dbg(codec, fmt, args...) \ argument
723 dev_dbg(hda_codec_dev(codec), fmt, ##args)