ALSA: ump: Fix evaluation of MIDI 1.0 FB info

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Takashi Iwai <tiwai@xxxxxxx>

commit 7be34f6feedd60e418de1c2c48e661d70416635f upstream.

The m1.0 field of UMP Function Block info specifies whether the given
FB is a MIDI 1.0 port or not.  When implementing the UMP support on
Linux, I somehow interpreted as if it were bit flags, but the field is
actually an enumeration from 0 to 2, where 2 means MIDI 1.0 *and* low
speed.

This patch corrects the interpretation and sets the right bit flags
depending on the m1.0 field of FB Info.  This effectively fixes the
missing detection of MIDI 1.0 FB when m1.0 is 2.

Fixes: 37e0e14128e0 ("ALSA: ump: Support UMP Endpoint and Function Block parsing")
Cc: <stable@xxxxxxxxxxxxxxx>
Link: https://patch.msgid.link/20241127070059.8099-1-tiwai@xxxxxxx
Signed-off-by: Takashi Iwai <tiwai@xxxxxxx>
Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>
---
 sound/core/ump.c |    5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

--- a/sound/core/ump.c
+++ b/sound/core/ump.c
@@ -788,7 +788,10 @@ static void fill_fb_info(struct snd_ump_
 	info->ui_hint = buf->fb_info.ui_hint;
 	info->first_group = buf->fb_info.first_group;
 	info->num_groups = buf->fb_info.num_groups;
-	info->flags = buf->fb_info.midi_10;
+	if (buf->fb_info.midi_10 < 2)
+		info->flags = buf->fb_info.midi_10;
+	else
+		info->flags = SNDRV_UMP_BLOCK_IS_MIDI1 | SNDRV_UMP_BLOCK_IS_LOWSPEED;
 	info->active = buf->fb_info.active;
 	info->midi_ci_version = buf->fb_info.midi_ci_version;
 	info->sysex8_streams = buf->fb_info.sysex8_streams;


Patches currently in stable-queue which might be from tiwai@xxxxxxx are

queue-6.12/alsa-hda-realtek-fix-mute-micmute-leds-don-t-work-for-elitebook-x-g1i.patch
queue-6.12/alsa-pcm-add-sanity-null-check-for-the-default-mmap-fault-handler.patch
queue-6.12/alsa-hda-realtek-set-pcbeep-to-default-value-for-alc274.patch
queue-6.12/alsa-6fire-release-resources-at-card-release.patch
queue-6.12/alsa-hda-realtek-apply-quirk-for-medion-e15433.patch
queue-6.12/alsa-hda-realtek-enable-speaker-pins-for-medion-e15443-platform.patch
queue-6.12/alsa-ump-fix-evaluation-of-midi-1.0-fb-info.patch
queue-6.12/alsa-usx2y-use-snd_card_free_when_closed-at-disconne.patch
queue-6.12/alsa-hda-realtek-fix-internal-speaker-and-mic-boost-of-infinix-y4-max.patch
queue-6.12/alsa-us122l-use-snd_card_free_when_closed-at-disconn.patch
queue-6.12/alsa-caiaq-use-snd_card_free_when_closed-at-disconne.patch
queue-6.12/alsa-usb-audio-fix-out-of-bounds-reads-when-finding-clock-sources.patch
queue-6.12/alsa-core-fix-possible-null-dereference-caused-by-ku.patch
queue-6.12/alsa-usb-audio-fix-potential-out-of-bound-accesses-for-extigy-and-mbox-devices.patch
queue-6.12/alsa-rawmidi-fix-kvfree-call-in-spinlock.patch
queue-6.12/alsa-hda-realtek-update-alc225-depop-procedure.patch
queue-6.12/alsa-hda-realtek-update-alc256-depop-procedure.patch




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux