mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-10-29 05:40:27 -04:00
The alsa/acp code already supports getting a user-friendly monitor name
using the EDID-Like Data (ELD) information available from cards that follow
the Intel HDA specification.
This patch adds support for also parsing the SAD fields of the ELD, and
exposing the results as a "iec958.codecs.detected" property on the
corresponding node, which should make it possible to provide more
user-friendly configuration UIs and defaults.
The default value will take effect if the session manager does not set a
different value.
Brief example:
test@test:~/checkouts/pipewire$ pw-dump | grep -E "(iec958.codecs.detected|iec958.codecs)\":"
"iec958.codecs": "[\"PCM\",\"AC3\",\"EAC3\",\"TrueHD\"]",
"iec958.codecs.detected": "[\"PCM\",\"AC3\",\"EAC3\",\"TrueHD\"]",
<after powering on my receiver>
test@test:~/checkouts/pipewire$ pw-dump | grep -E "(iec958.codecs.detected|iec958.codecs)\":"
"iec958.codecs": "[\"PCM\",\"DTS\",\"AC3\",\"EAC3\",\"TrueHD\",\"DTS-HD\"]",
"iec958.codecs.detected": "[\"PCM\",\"DTS\",\"AC3\",\"EAC3\",\"TrueHD\",\"DTS-HD\"]",
Big thanks to Pauli Virtanen <pav@iki.fi>, who also wrote large paths of the
code for this patch.
183 lines
7.5 KiB
C
183 lines
7.5 KiB
C
#ifndef fooalsautilhfoo
|
|
#define fooalsautilhfoo
|
|
|
|
/***
|
|
This file is part of PulseAudio.
|
|
|
|
Copyright 2004-2006 Lennart Poettering
|
|
Copyright 2006 Pierre Ossman <ossman@cendio.se> for Cendio AB
|
|
|
|
PulseAudio is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU Lesser General Public License as published
|
|
by the Free Software Foundation; either version 2.1 of the License,
|
|
or (at your option) any later version.
|
|
|
|
PulseAudio is distributed in the hope that it will be useful, but
|
|
WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public License
|
|
along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.
|
|
***/
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <alsa/asoundlib.h>
|
|
|
|
#include "compat.h"
|
|
|
|
#include "alsa-mixer.h"
|
|
|
|
enum {
|
|
PA_ALSA_ERR_UNSPECIFIED = 1,
|
|
PA_ALSA_ERR_UCM_OPEN = 1000,
|
|
PA_ALSA_ERR_UCM_NO_VERB = 1001,
|
|
PA_ALSA_ERR_UCM_LINKED = 1002
|
|
};
|
|
|
|
int pa_alsa_set_hw_params(
|
|
snd_pcm_t *pcm_handle,
|
|
pa_sample_spec *ss, /* modified at return */
|
|
snd_pcm_uframes_t *period_size, /* modified at return */
|
|
snd_pcm_uframes_t *buffer_size, /* modified at return */
|
|
snd_pcm_uframes_t tsched_size,
|
|
bool *use_mmap, /* modified at return */
|
|
bool *use_tsched, /* modified at return */
|
|
bool require_exact_channel_number);
|
|
|
|
int pa_alsa_set_sw_params(
|
|
snd_pcm_t *pcm,
|
|
snd_pcm_uframes_t avail_min,
|
|
bool period_event);
|
|
|
|
#if 0
|
|
/* Picks a working mapping from the profile set based on the specified ss/map */
|
|
snd_pcm_t *pa_alsa_open_by_device_id_auto(
|
|
const char *dev_id,
|
|
char **dev, /* modified at return */
|
|
pa_sample_spec *ss, /* modified at return */
|
|
pa_channel_map* map, /* modified at return */
|
|
int mode,
|
|
snd_pcm_uframes_t *period_size, /* modified at return */
|
|
snd_pcm_uframes_t *buffer_size, /* modified at return */
|
|
snd_pcm_uframes_t tsched_size,
|
|
bool *use_mmap, /* modified at return */
|
|
bool *use_tsched, /* modified at return */
|
|
pa_sample_format_t **query_supported_formats, /* modified at return */
|
|
unsigned int **query_supported_rates, /* modified at return */
|
|
pa_alsa_profile_set *ps,
|
|
pa_alsa_mapping **mapping); /* modified at return */
|
|
#endif
|
|
|
|
/* Uses the specified mapping */
|
|
snd_pcm_t *pa_alsa_open_by_device_id_mapping(
|
|
const char *dev_id,
|
|
char **dev, /* modified at return */
|
|
pa_sample_spec *ss, /* modified at return */
|
|
pa_channel_map* map, /* modified at return */
|
|
int mode,
|
|
snd_pcm_uframes_t *period_size, /* modified at return */
|
|
snd_pcm_uframes_t *buffer_size, /* modified at return */
|
|
snd_pcm_uframes_t tsched_size,
|
|
bool *use_mmap, /* modified at return */
|
|
bool *use_tsched, /* modified at return */
|
|
pa_sample_format_t **query_supported_formats, /* modified at return */
|
|
unsigned int **query_supported_rates, /* modified at return */
|
|
pa_alsa_mapping *mapping);
|
|
|
|
/* Opens the explicit ALSA device */
|
|
snd_pcm_t *pa_alsa_open_by_device_string(
|
|
const char *dir,
|
|
char **dev, /* modified at return */
|
|
pa_sample_spec *ss, /* modified at return */
|
|
pa_channel_map* map, /* modified at return */
|
|
int mode,
|
|
snd_pcm_uframes_t *period_size, /* modified at return */
|
|
snd_pcm_uframes_t *buffer_size, /* modified at return */
|
|
snd_pcm_uframes_t tsched_size,
|
|
bool *use_mmap, /* modified at return */
|
|
bool *use_tsched, /* modified at return */
|
|
pa_sample_format_t **query_supported_formats, /* modified at return */
|
|
unsigned int **query_supported_rates, /* modified at return */
|
|
bool require_exact_channel_number);
|
|
|
|
/* Opens the explicit ALSA device with a fallback list */
|
|
snd_pcm_t *pa_alsa_open_by_template(
|
|
char **template,
|
|
const char *dev_id,
|
|
char **dev, /* modified at return */
|
|
pa_sample_spec *ss, /* modified at return */
|
|
pa_channel_map* map, /* modified at return */
|
|
int mode,
|
|
snd_pcm_uframes_t *period_size, /* modified at return */
|
|
snd_pcm_uframes_t *buffer_size, /* modified at return */
|
|
snd_pcm_uframes_t tsched_size,
|
|
bool *use_mmap, /* modified at return */
|
|
bool *use_tsched, /* modified at return */
|
|
pa_sample_format_t **query_supported_formats, /* modified at return */
|
|
unsigned int **query_supported_rates, /* modified at return */
|
|
bool require_exact_channel_number);
|
|
|
|
#if 0
|
|
void pa_alsa_dump(pa_log_level_t level, snd_pcm_t *pcm);
|
|
void pa_alsa_dump_status(snd_pcm_t *pcm);
|
|
#endif
|
|
int pa_alsa_close(snd_pcm_t **pcm);
|
|
|
|
void pa_alsa_refcnt_inc(void);
|
|
void pa_alsa_refcnt_dec(void);
|
|
|
|
void pa_alsa_init_proplist_pcm_info(pa_core *c, pa_proplist *p, snd_pcm_info_t *pcm_info);
|
|
void pa_alsa_init_proplist_card(pa_core *c, pa_proplist *p, int card);
|
|
void pa_alsa_init_proplist_pcm(pa_core *c, pa_proplist *p, snd_pcm_t *pcm);
|
|
void pa_alsa_init_proplist_ctl(pa_proplist *p, const char *name);
|
|
bool pa_alsa_init_description(pa_proplist *p, pa_card *card);
|
|
|
|
#if 0
|
|
int pa_alsa_recover_from_poll(snd_pcm_t *pcm, int revents);
|
|
|
|
pa_rtpoll_item* pa_alsa_build_pollfd(snd_pcm_t *pcm, pa_rtpoll *rtpoll);
|
|
|
|
snd_pcm_sframes_t pa_alsa_safe_avail(snd_pcm_t *pcm, size_t hwbuf_size, const pa_sample_spec *ss);
|
|
int pa_alsa_safe_delay(snd_pcm_t *pcm, snd_pcm_status_t *status, snd_pcm_sframes_t *delay, size_t hwbuf_size, const pa_sample_spec *ss, bool capture);
|
|
int pa_alsa_safe_mmap_begin(snd_pcm_t *pcm, const snd_pcm_channel_area_t **areas, snd_pcm_uframes_t *offset, snd_pcm_uframes_t *frames, size_t hwbuf_size, const pa_sample_spec *ss);
|
|
#endif
|
|
|
|
char *pa_alsa_get_driver_name(int card);
|
|
char *pa_alsa_get_driver_name_by_pcm(snd_pcm_t *pcm);
|
|
|
|
char *pa_alsa_get_reserve_name(const char *device);
|
|
|
|
unsigned int *pa_alsa_get_supported_rates(snd_pcm_t *pcm, unsigned int fallback_rate);
|
|
pa_sample_format_t *pa_alsa_get_supported_formats(snd_pcm_t *pcm, pa_sample_format_t fallback_format);
|
|
|
|
bool pa_alsa_pcm_is_hw(snd_pcm_t *pcm);
|
|
bool pa_alsa_pcm_is_modem(snd_pcm_t *pcm);
|
|
|
|
const char* pa_alsa_strerror(int errnum);
|
|
|
|
#if 0
|
|
bool pa_alsa_may_tsched(bool want);
|
|
#endif
|
|
|
|
snd_mixer_elem_t *pa_alsa_mixer_find_card(snd_mixer_t *mixer, struct pa_alsa_mixer_id *alsa_id, unsigned int device);
|
|
snd_mixer_elem_t *pa_alsa_mixer_find_pcm(snd_mixer_t *mixer, const char *name, unsigned int device);
|
|
|
|
snd_mixer_t *pa_alsa_open_mixer(pa_hashmap *mixers, int alsa_card_index, bool probe);
|
|
snd_mixer_t *pa_alsa_open_mixer_by_name(pa_hashmap *mixers, const char *dev, bool probe);
|
|
snd_mixer_t *pa_alsa_open_mixer_for_pcm(pa_hashmap *mixers, snd_pcm_t *pcm, bool probe);
|
|
#if 0
|
|
void pa_alsa_mixer_set_fdlist(pa_hashmap *mixers, snd_mixer_t *mixer, pa_mainloop_api *ml);
|
|
#endif
|
|
void pa_alsa_mixer_free(pa_alsa_mixer *mixer);
|
|
|
|
typedef struct pa_hdmi_eld pa_hdmi_eld;
|
|
struct pa_hdmi_eld {
|
|
char monitor_name[17];
|
|
uint64_t iec958_codecs;
|
|
};
|
|
|
|
int pa_alsa_get_hdmi_eld(snd_hctl_elem_t *elem, pa_hdmi_eld *eld);
|
|
|
|
#endif
|