summaryrefslogtreecommitdiffstats
path: root/sound/usb/mixer.h
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2024-08-06 14:46:50 +0200
committerTakashi Iwai <tiwai@suse.de>2024-08-06 18:27:08 +0200
commit901e85677ec0bb9a69fb9eab1feafe0c4eb7d07e (patch)
tree85df0b1e4caa8ec18eed26d89f8c7d81ec72a8a2 /sound/usb/mixer.h
parentALSA: ump: Handle MIDI 1.0 Function Block in MIDI 2.0 protocol (diff)
downloadlinux-901e85677ec0bb9a69fb9eab1feafe0c4eb7d07e.tar.xz
linux-901e85677ec0bb9a69fb9eab1feafe0c4eb7d07e.zip
ALSA: usb-audio: Add input value sanity checks for standard types
For an invalid input value that is out of the given range, currently USB-audio driver corrects the value silently and accepts without errors. This is no wrong behavior, per se, but the recent kselftest rather wants to have an error in such a case, hence a different behavior is expected now. This patch adds a sanity check at each control put for the standard mixer types and returns an error if an invalid value is given. Note that this covers only the standard mixer types. The mixer quirks that have own control callbacks would need different coverage. Link: https://patch.msgid.link/20240806124651.28203-1-tiwai@suse.de Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/usb/mixer.h')
-rw-r--r--sound/usb/mixer.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/sound/usb/mixer.h b/sound/usb/mixer.h
index d43895c1ae5c..167fbfcf01ac 100644
--- a/sound/usb/mixer.h
+++ b/sound/usb/mixer.h
@@ -88,6 +88,7 @@ struct usb_mixer_elem_info {
int channels;
int val_type;
int min, max, res;
+ int max_exposed; /* control API exposes the value in 0..max_exposed */
int dBmin, dBmax;
int cached;
int cache_val[MAX_CHANNELS];