ALSA: pcmcia: Fix resource leak in snd_pdacf_probe error path

When pdacf_config() fails, snd_pdacf_probe() returns the error code
directly without freeing the sound card resources allocated by
snd_card_new(), which leads to a memory leak.

Add proper error handling to free the sound card and clear the card
list entry when pdacf_config() fails.

Fixes: 15b99ac17295 ("[PATCH] pcmcia: add return value to _config() functions")
Suggested-by: Takashi Iwai <tiwai@suse.de>
Signed-off-by: Haotian Zhang <vulab@iscas.ac.cn>
Link: https://patch.msgid.link/20251215090433.211-1-vulab@iscas.ac.cn
Signed-off-by: Takashi Iwai <tiwai@suse.de>

authored by Haotian Zhang and committed by Takashi Iwai 5032347c 2a03b40d

+7 -1
+7 -1
sound/pcmcia/pdaudiocf/pdaudiocf.c
··· 131 131 link->config_index = 1; 132 132 link->config_regs = PRESENT_OPTION; 133 133 134 - return pdacf_config(link); 134 + err = pdacf_config(link); 135 + if (err < 0) { 136 + card_list[i] = NULL; 137 + snd_card_free(card); 138 + return err; 139 + } 140 + return 0; 135 141 } 136 142 137 143