ALSA: ctxfi: cthw20k2: fix mask on conf to allow 4 bits
authorColin Ian King <colin.king@canonical.com>
Sat, 27 Feb 2021 00:15:27 +0000 (00:15 +0000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 9 Mar 2021 10:11:14 +0000 (11:11 +0100)
commit253b7a11ce26d30f375fb8b7d51e988bc2dc9cd0
tree219727820cccb559095cafbeb31d3e8511b74eaf
parent4d7ed9a49b0ce079af2255b0c49b0d4b5a5ceff0
ALSA: ctxfi: cthw20k2: fix mask on conf to allow 4 bits

[ Upstream commit 26a9630c72ebac7c564db305a6aee54a8edde70e ]

Currently the mask operation on variable conf is just 3 bits so
the switch statement case value of 8 is unreachable dead code.
The function daio_mgr_dao_init can be passed a 4 bit value,
function dao_rsc_init calls it with conf set to:

     conf = (desc->msr & 0x7) | (desc->passthru << 3);

so clearly when desc->passthru is set to 1 then conf can be
at least 8.

Fix this by changing the mask to 0xf.

Fixes: 8cc72361481f ("ALSA: SB X-Fi driver merge")
Signed-off-by: Colin Ian King <colin.king@canonical.com>
Link: https://lore.kernel.org/r/20210227001527.1077484-1-colin.king@canonical.com
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Signed-off-by: Sasha Levin <sashal@kernel.org>
sound/pci/ctxfi/cthw20k2.c