Skip to content

Commit

Permalink
kselftest: alsa: Use private alsa-lib configuration in mixer test
Browse files Browse the repository at this point in the history
As mentined by Takashi Sakamoto, the system-wide alsa-lib configuration
may override the standard device declarations. This patch use the private
alsa-lib configuration to set the predictable environment.

Signed-off-by: Jaroslav Kysela <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
[Restructure version test to keep the preprocessor happy -- broonie]
Reviewed-by: Shuah Khan <[email protected]>
Signed-off-by: Mark Brown <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Takashi Iwai <[email protected]>
  • Loading branch information
perexg authored and tiwai committed Dec 12, 2021
1 parent 7cc994f commit b73dad8
Showing 1 changed file with 55 additions and 1 deletion.
56 changes: 55 additions & 1 deletion tools/testing/selftests/alsa/mixer-test.c
Original file line number Diff line number Diff line change
Expand Up @@ -46,30 +46,82 @@ struct ctl_data {
struct ctl_data *next;
};

static const char *alsa_config =
"ctl.hw {\n"
" @args [ CARD ]\n"
" @args.CARD.type string\n"
" type hw\n"
" card $CARD\n"
"}\n"
;

int num_cards = 0;
int num_controls = 0;
struct card_data *card_list = NULL;
struct ctl_data *ctl_list = NULL;

#ifdef SND_LIB_VER
#if SND_LIB_VERSION >= SND_LIB_VER(1, 2, 6)
#define LIB_HAS_LOAD_STRING
#endif
#endif

#ifndef LIB_HAS_LOAD_STRING
int snd_config_load_string(snd_config_t **config, const char *s, size_t size)
{
snd_input_t *input;
snd_config_t *dst;
int err;

assert(config && s);
if (size == 0)
size = strlen(s);
err = snd_input_buffer_open(&input, s, size);
if (err < 0)
return err;
err = snd_config_top(&dst);
if (err < 0) {
snd_input_close(input);
return err;
}
err = snd_config_load(dst, input);
snd_input_close(input);
if (err < 0) {
snd_config_delete(dst);
return err;
}
*config = dst;
return 0;
}
#endif

void find_controls(void)
{
char name[32];
int card, ctl, err;
struct card_data *card_data;
struct ctl_data *ctl_data;
snd_config_t *config;

card = -1;
if (snd_card_next(&card) < 0 || card < 0)
return;

err = snd_config_load_string(&config, alsa_config, strlen(alsa_config));
if (err < 0) {
ksft_print_msg("Unable to parse custom alsa-lib configuration: %s\n",
snd_strerror(err));
ksft_exit_fail();
}

while (card >= 0) {
sprintf(name, "hw:%d", card);

card_data = malloc(sizeof(*card_data));
if (!card_data)
ksft_exit_fail_msg("Out of memory\n");

err = snd_ctl_open(&card_data->handle, name, 0);
err = snd_ctl_open_lconf(&card_data->handle, name, 0, config);
if (err < 0) {
ksft_print_msg("Failed to get hctl for card %d: %s\n",
card, snd_strerror(err));
Expand Down Expand Up @@ -137,6 +189,8 @@ void find_controls(void)
break;
}
}

snd_config_delete(config);
}

/*
Expand Down

0 comments on commit b73dad8

Please sign in to comment.