mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-16 02:01:18 -04:00
ALSA: hda: Avoid WARN_ON() for HDMI chmap slot checks
At parsing the channel mapping for HDMI, the current code may spew WARN_ON() unnecessarily for the case where only invalid (zero) channel maps are given from the hardware. Drop WARN_ON() and reorganize the code a bit for avoiding the hdmi_slot over the array size. Closes: https://bugzilla.kernel.org/show_bug.cgi?id=221390 Signed-off-by: Takashi Iwai <tiwai@suse.de> Link: https://patch.msgid.link/20260428061800.80527-1-tiwai@suse.de Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
@@ -353,13 +353,16 @@ static void hdmi_std_setup_channel_mapping(struct hdac_chmap *chmap,
|
||||
if (hdmi_channel_mapping[ca][1] == 0) {
|
||||
int hdmi_slot = 0;
|
||||
/* fill actual channel mappings in ALSA channel (i) order */
|
||||
for (i = 0; i < ch_alloc->channels; i++) {
|
||||
while (!WARN_ON(hdmi_slot >= 8) &&
|
||||
!ch_alloc->speakers[7 - hdmi_slot])
|
||||
hdmi_slot++; /* skip zero slots */
|
||||
for (i = 0; i < ch_alloc->channels && hdmi_slot < 8; i++) {
|
||||
while (!ch_alloc->speakers[7 - hdmi_slot]) {
|
||||
/* skip zero slots */
|
||||
if (++hdmi_slot >= 8)
|
||||
goto out;
|
||||
}
|
||||
|
||||
hdmi_channel_mapping[ca][i] = (i << 4) | hdmi_slot++;
|
||||
}
|
||||
out:
|
||||
/* fill the rest of the slots with ALSA channel 0xf */
|
||||
for (hdmi_slot = 0; hdmi_slot < 8; hdmi_slot++)
|
||||
if (!ch_alloc->speakers[7 - hdmi_slot])
|
||||
|
||||
Reference in New Issue
Block a user