• Home
  • Raw
  • Download

Lines Matching +full:codec +full:- +full:3

1 /* SPDX-License-Identifier: GPL-2.0-or-later */
3 * Universal Interface for Intel High Definition Audio Codec
15 * snd_hda_ctl_add() takes the lower-bit subdev value as a valid NID.
45 HDA_CODEC_VOLUME_MONO_IDX(xname, xcidx, nid, 3, xindex, direction, 0)
51 HDA_CODEC_VOLUME_MONO(xname, nid, 3, xindex, direction)
54 HDA_CODEC_VOLUME_MONO_IDX(xname, 0, nid, 3, xindex, direction, \
66 HDA_CODEC_MUTE_MONO_IDX(xname, xcidx, nid, 3, xindex, direction)
72 HDA_CODEC_MUTE_MONO(xname, nid, 3, xindex, direction)
83 /* no digital beep - just the standard one */
92 HDA_CODEC_MUTE_BEEP_MONO(xname, nid, 3, xindex, direction)
117 #define snd_hda_codec_amp_read(codec, nid, ch, dir, idx) \ argument
118 snd_hdac_regmap_get_amp(&(codec)->core, nid, ch, dir, idx)
119 int snd_hda_codec_amp_update(struct hda_codec *codec, hda_nid_t nid,
121 int snd_hda_codec_amp_stereo(struct hda_codec *codec, hda_nid_t nid,
123 int snd_hda_codec_amp_init(struct hda_codec *codec, hda_nid_t nid, int ch,
125 int snd_hda_codec_amp_init_stereo(struct hda_codec *codec, hda_nid_t nid,
127 void snd_hda_set_vmaster_tlv(struct hda_codec *codec, hda_nid_t nid, int dir,
129 struct snd_kcontrol *snd_hda_find_mixer_ctl(struct hda_codec *codec,
131 int __snd_hda_add_vmaster(struct hda_codec *codec, char *name,
135 #define snd_hda_add_vmaster(codec, name, tlv, followers, suffix, access) \ argument
136 __snd_hda_add_vmaster(codec, name, tlv, followers, suffix, true, access, NULL)
137 int snd_hda_codec_reset(struct hda_codec *codec);
138 void snd_hda_codec_disconnect_pcms(struct hda_codec *codec);
140 #define snd_hda_regmap_sync(codec) snd_hdac_regmap_sync(&(codec)->core) argument
149 struct hda_codec *codec; member
152 int snd_hda_add_vmaster_hook(struct hda_codec *codec,
164 int snd_hda_create_dig_out_ctls(struct hda_codec *codec,
167 #define snd_hda_create_spdif_out_ctls(codec, anid, cnid) \ argument
168 snd_hda_create_dig_out_ctls(codec, anid, cnid, HDA_PCM_TYPE_SPDIF)
169 int snd_hda_create_spdif_in_ctls(struct hda_codec *codec, hda_nid_t nid);
186 int snd_hda_input_mux_put(struct hda_codec *codec,
190 int snd_hda_add_imux_item(struct hda_codec *codec,
195 * Multi-channel / digital-out PCM helper
224 int snd_hda_create_spdif_share_sw(struct hda_codec *codec,
226 int snd_hda_multi_out_dig_open(struct hda_codec *codec,
228 int snd_hda_multi_out_dig_close(struct hda_codec *codec,
230 int snd_hda_multi_out_dig_prepare(struct hda_codec *codec,
235 int snd_hda_multi_out_dig_cleanup(struct hda_codec *codec,
237 int snd_hda_multi_out_analog_open(struct hda_codec *codec,
241 int snd_hda_multi_out_analog_prepare(struct hda_codec *codec,
246 int snd_hda_multi_out_analog_cleanup(struct hda_codec *codec,
253 int snd_hda_codec_proc_new(struct hda_codec *codec);
255 static inline int snd_hda_codec_proc_new(struct hda_codec *codec) { return 0; } in snd_hda_codec_proc_new() argument
264 int snd_hda_add_new_ctls(struct hda_codec *codec,
268 * Fix-up pin default configurations and add default verbs
289 void (*func)(struct hda_codec *codec,
296 unsigned int codec; /* Codec vendor/device ID */ member
308 { .codec = _codec,\
317 { .codec = _codec,\
325 #define HDA_FIXUP_ID_NOT_SET -1
326 #define HDA_FIXUP_ID_NO_FIXUP -2
346 int snd_hda_add_verbs(struct hda_codec *codec, const struct hda_verb *list);
347 void snd_hda_apply_verbs(struct hda_codec *codec);
348 void snd_hda_apply_pincfgs(struct hda_codec *codec,
350 void snd_hda_apply_fixup(struct hda_codec *codec, int action);
351 void __snd_hda_apply_fixup(struct hda_codec *codec, int id, int action, int depth);
352 void snd_hda_pick_fixup(struct hda_codec *codec,
356 void snd_hda_pick_pin_fixup(struct hda_codec *codec,
361 /* helper macros to retrieve pin default-config values */
392 unsigned int snd_hda_get_default_vref(struct hda_codec *codec, hda_nid_t pin);
393 unsigned int snd_hda_correct_pin_ctl(struct hda_codec *codec,
395 int _snd_hda_set_pin_ctl(struct hda_codec *codec, hda_nid_t pin,
399 * _snd_hda_set_pin_ctl - Set a pin-control value safely
400 * @codec: the codec instance
402 * @val: the pin-control value (AC_PINCTL_* bits)
404 * This function sets the pin-control value to the given pin, but
405 * filters out the invalid pin-control bits when the pin has no such
407 * HP-drive capability, the HP bit is omitted.
414 snd_hda_set_pin_ctl(struct hda_codec *codec, hda_nid_t pin, unsigned int val) in snd_hda_set_pin_ctl() argument
416 return _snd_hda_set_pin_ctl(codec, pin, val, false); in snd_hda_set_pin_ctl()
420 * snd_hda_set_pin_ctl_cache - Set a pin-control value safely
421 * @codec: the codec instance
423 * @val: the pin-control value (AC_PINCTL_* bits)
428 snd_hda_set_pin_ctl_cache(struct hda_codec *codec, hda_nid_t pin, in snd_hda_set_pin_ctl_cache() argument
431 return _snd_hda_set_pin_ctl(codec, pin, val, true); in snd_hda_set_pin_ctl_cache()
434 int snd_hda_codec_get_pin_target(struct hda_codec *codec, hda_nid_t nid);
435 int snd_hda_codec_set_pin_target(struct hda_codec *codec, hda_nid_t nid,
438 #define for_each_hda_codec_node(nid, codec) \ argument
439 for ((nid) = (codec)->core.start_nid; (nid) < (codec)->core.end_nid; (nid)++)
441 /* Set the codec power_state flag to indicate to allow unsol event handling;
445 static inline void snd_hda_codec_allow_unsol_events(struct hda_codec *codec) in snd_hda_codec_allow_unsol_events() argument
447 codec->core.dev.power.power_state = PMSG_ON; in snd_hda_codec_allow_unsol_events()
453 static inline u32 get_wcaps(struct hda_codec *codec, hda_nid_t nid) in get_wcaps() argument
455 if (nid < codec->core.start_nid || in get_wcaps()
456 nid >= codec->core.start_nid + codec->core.num_nodes) in get_wcaps()
458 return codec->wcaps[nid - codec->core.start_nid]; in get_wcaps()
465 return -1; /* invalid type */ in get_wcaps_type()
479 static inline void snd_hda_override_wcaps(struct hda_codec *codec, in snd_hda_override_wcaps() argument
482 if (nid >= codec->core.start_nid && in snd_hda_override_wcaps()
483 nid < codec->core.start_nid + codec->core.num_nodes) in snd_hda_override_wcaps()
484 codec->wcaps[nid - codec->core.start_nid] = val; in snd_hda_override_wcaps()
487 u32 query_amp_caps(struct hda_codec *codec, hda_nid_t nid, int direction);
488 int snd_hda_override_amp_caps(struct hda_codec *codec, hda_nid_t nid, int dir,
491 * snd_hda_query_pin_caps - Query PIN capabilities
492 * @codec: the HD-auio codec
502 snd_hda_query_pin_caps(struct hda_codec *codec, hda_nid_t nid) in snd_hda_query_pin_caps() argument
504 return snd_hda_param_read(codec, nid, AC_PAR_PIN_CAP); in snd_hda_query_pin_caps()
509 * snd_hda_override_pin_caps - Override the pin capabilities
510 * @codec: the CODEC
519 snd_hda_override_pin_caps(struct hda_codec *codec, hda_nid_t nid, in snd_hda_override_pin_caps() argument
522 return snd_hdac_override_parm(&codec->core, nid, AC_PAR_PIN_CAP, caps); in snd_hda_override_pin_caps()
525 bool snd_hda_check_amp_caps(struct hda_codec *codec, hda_nid_t nid,
528 #define nid_has_mute(codec, nid, dir) \ argument
529 snd_hda_check_amp_caps(codec, nid, dir, (AC_AMPCAP_MUTE | AC_AMPCAP_MIN_MUTE))
530 #define nid_has_volume(codec, nid, dir) \ argument
531 snd_hda_check_amp_caps(codec, nid, dir, AC_AMPCAP_NUM_STEPS)
544 int snd_hda_ctl_add(struct hda_codec *codec, hda_nid_t nid,
546 int snd_hda_add_nid(struct hda_codec *codec, struct snd_kcontrol *kctl,
548 void snd_hda_ctls_clear(struct hda_codec *codec);
554 int snd_hda_create_hwdep(struct hda_codec *codec);
556 static inline int snd_hda_create_hwdep(struct hda_codec *codec) { return 0; } in snd_hda_create_hwdep() argument
559 void snd_hda_sysfs_init(struct hda_codec *codec);
560 void snd_hda_sysfs_clear(struct hda_codec *codec);
565 const char *snd_hda_get_hint(struct hda_codec *codec, const char *key);
566 int snd_hda_get_bool_hint(struct hda_codec *codec, const char *key);
567 int snd_hda_get_int_hint(struct hda_codec *codec, const char *key, int *valp);
570 const char *snd_hda_get_hint(struct hda_codec *codec, const char *key) in snd_hda_get_hint() argument
576 int snd_hda_get_bool_hint(struct hda_codec *codec, const char *key) in snd_hda_get_bool_hint() argument
578 return -ENOENT; in snd_hda_get_bool_hint()
582 int snd_hda_get_int_hint(struct hda_codec *codec, const char *key, int *valp) in snd_hda_get_int_hint() argument
584 return -ENOENT; in snd_hda_get_int_hint()
589 * power-management
592 void snd_hda_schedule_power_save(struct hda_codec *codec);
605 int snd_hda_check_amp_list_power(struct hda_codec *codec,
611 snd_hda_check_power_state(struct hda_codec *codec, hda_nid_t nid, in snd_hda_check_power_state() argument
614 return snd_hdac_check_power_state(&codec->core, nid, target_state); in snd_hda_check_power_state()
617 static inline unsigned int snd_hda_sync_power_state(struct hda_codec *codec, in snd_hda_sync_power_state() argument
621 return snd_hdac_sync_power_state(&codec->core, nid, target_state); in snd_hda_sync_power_state()
623 unsigned int snd_hda_codec_eapd_power_filter(struct hda_codec *codec,
627 void snd_hda_codec_shutdown(struct hda_codec *codec);
634 #define get_amp_nid(kc) get_amp_nid_((kc)->private_value)
635 #define get_amp_channels(kc) (((kc)->private_value >> 16) & 0x3)
637 #define get_amp_direction(kc) get_amp_direction_((kc)->private_value)
639 #define get_amp_index(kc) get_amp_index_((kc)->private_value)
640 #define get_amp_offset(kc) (((kc)->private_value >> 23) & 0x3f)
641 #define get_amp_min_mute(kc) (((kc)->private_value >> 29) & 0x1)
700 int snd_hdmi_get_eld_size(struct hda_codec *codec, hda_nid_t nid);
701 int snd_hdmi_get_eld(struct hda_codec *codec, hda_nid_t nid,
703 int snd_hdmi_parse_eld(struct hda_codec *codec, struct parsed_hdmi_eld *e,
705 void snd_hdmi_show_eld(struct hda_codec *codec, struct parsed_hdmi_eld *e);
709 int snd_hdmi_get_eld_ati(struct hda_codec *codec, hda_nid_t nid,
724 void snd_hda_codec_display_power(struct hda_codec *codec, bool enable);
728 #define codec_err(codec, fmt, args...) \ argument
729 dev_err(hda_codec_dev(codec), fmt, ##args)
730 #define codec_warn(codec, fmt, args...) \ argument
731 dev_warn(hda_codec_dev(codec), fmt, ##args)
732 #define codec_info(codec, fmt, args...) \ argument
733 dev_info(hda_codec_dev(codec), fmt, ##args)
734 #define codec_dbg(codec, fmt, args...) \ argument
735 dev_dbg(hda_codec_dev(codec), fmt, ##args)