* Ask snd_seq_set_client_midi_version
@ 2024-12-18 23:24 Correo Alternativo
2024-12-30 11:34 ` Takashi Iwai
2025-02-01 23:11 ` Possible bug with snd_seq_event_input_pending Carlos
0 siblings, 2 replies; 4+ messages in thread
From: Correo Alternativo @ 2024-12-18 23:24 UTC (permalink / raw)
To: alsa-devel
Hi, I'm trying out MIDI 2.0 and found a problem, when using
snd_seq_set_client_midi_version
With SND_SEQ_CLIENT_LEGACY_MIDI I get the following sequence of events
when connecting a midi device (using the method snd_seq_event_input or
snd_seq_ump_event_input) (timidity command:timidity --interface=A
--buffer-fragments=2,8 --output-mode=s1l --sampling-freq=44100):
SND_SEQ_EVENT_CLIENT_START
SND_SEQ_EVENT_PORT_START
SND_SEQ_EVENT_PORT_START
SND_SEQ_EVENT_PORT_START
SND_SEQ_EVENT_PORT_START
But with SND_SEQ_CLIENT_UMP_MIDI_1_0 and SND_SEQ_CLIENT_UMP_MIDI_2_0 I
don't get the SND_SEQ_EVENT_PORT_START events, I only get the following:
SND_SEQ_EVENT_CLIENT_START
SND_SEQ_EVENT_SYSTEM
SND_SEQ_EVENT_SYSTEM
SND_SEQ_EVENT_SYSTEM
I don't know if I'm asking this in the right place, what mistake am I
making? Just by modifying that it stops working.
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: Ask snd_seq_set_client_midi_version
2024-12-18 23:24 Ask snd_seq_set_client_midi_version Correo Alternativo
@ 2024-12-30 11:34 ` Takashi Iwai
2025-02-01 23:11 ` Possible bug with snd_seq_event_input_pending Carlos
1 sibling, 0 replies; 4+ messages in thread
From: Takashi Iwai @ 2024-12-30 11:34 UTC (permalink / raw)
To: Correo Alternativo; +Cc: alsa-devel
On Thu, 19 Dec 2024 00:24:11 +0100,
Correo Alternativo wrote:
>
> Hi, I'm trying out MIDI 2.0 and found a problem, when using
> snd_seq_set_client_midi_version
>
> With SND_SEQ_CLIENT_LEGACY_MIDI I get the following sequence of events
> when connecting a midi device (using the method snd_seq_event_input or
> snd_seq_ump_event_input) (timidity command:timidity --interface=A
> --buffer-fragments=2,8 --output-mode=s1l --sampling-freq=44100):
>
> SND_SEQ_EVENT_CLIENT_START
> SND_SEQ_EVENT_PORT_START
> SND_SEQ_EVENT_PORT_START
> SND_SEQ_EVENT_PORT_START
> SND_SEQ_EVENT_PORT_START
>
> But with SND_SEQ_CLIENT_UMP_MIDI_1_0 and SND_SEQ_CLIENT_UMP_MIDI_2_0 I
> don't get the SND_SEQ_EVENT_PORT_START events, I only get the
> following:
>
> SND_SEQ_EVENT_CLIENT_START
> SND_SEQ_EVENT_SYSTEM
> SND_SEQ_EVENT_SYSTEM
> SND_SEQ_EVENT_SYSTEM
>
> I don't know if I'm asking this in the right place, what mistake am I
> making? Just by modifying that it stops working.
Hmm, there should be no difference in this regard between the legacy
and UMP clients.
Do you mean that the destination client (i.e. timidity) doesn't
receive *_PORT_START events when you send from a UMP client?
Or how is the actual setup and the connection?
thanks,
Takashi
^ permalink raw reply [flat|nested] 4+ messages in thread
* Possible bug with snd_seq_event_input_pending
2024-12-18 23:24 Ask snd_seq_set_client_midi_version Correo Alternativo
2024-12-30 11:34 ` Takashi Iwai
@ 2025-02-01 23:11 ` Carlos
2025-02-17 11:04 ` Takashi Iwai
1 sibling, 1 reply; 4+ messages in thread
From: Carlos @ 2025-02-01 23:11 UTC (permalink / raw)
To: alsa-devel
Hi, I don't know if this is a bug or not, but I'll report it in case it is.
If I configure my client as follows:
snd_seq_set_client_midi_version(seq, SND_SEQ_CLIENT_LEGACY_MIDI);
snd_seq_set_client_ump_conversion(seq, 0);//I disable ump conversion
And then I send a midi event from a MIDI 2.0 device, the
snd_seq_event_input_pending(seq, 1) function will not respond until it
receives any other legacy event.
Now I know that with SND_SEQ_CLIENT_LEGACY_MIDI I shouldn't disable ump
conversion, but I expected it to return 0.
Thank you
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: Possible bug with snd_seq_event_input_pending
2025-02-01 23:11 ` Possible bug with snd_seq_event_input_pending Carlos
@ 2025-02-17 11:04 ` Takashi Iwai
0 siblings, 0 replies; 4+ messages in thread
From: Takashi Iwai @ 2025-02-17 11:04 UTC (permalink / raw)
To: Carlos; +Cc: alsa-devel
On Sun, 02 Feb 2025 00:11:51 +0100,
Carlos wrote:
>
> Hi, I don't know if this is a bug or not, but I'll report it in case it is.
>
> If I configure my client as follows:
>
> snd_seq_set_client_midi_version(seq, SND_SEQ_CLIENT_LEGACY_MIDI);
>
> snd_seq_set_client_ump_conversion(seq, 0);//I disable ump conversion
>
> And then I send a midi event from a MIDI 2.0 device, the
> snd_seq_event_input_pending(seq, 1) function will not respond until it
> receives any other legacy event.
>
> Now I know that with SND_SEQ_CLIENT_LEGACY_MIDI I shouldn't disable
> ump conversion, but I expected it to return 0.
This can be indeed a problem in the kernel side. It shouldn't deliver
the UMP events if the destination can't handle it.
Could you try the patch below?
thanks,
Takashi
-- 8< --
From: Takashi Iwai <tiwai@suse.de>
Subject: [PATCH] ALSA: seq: Drop UMP events when no UMP-conversion is set
When a destination client is a user client in the legacy MIDI mode and
it sets the no-UMP-conversion flag, currently the all UMP events are
still passed as-is. But this may confuse the user-space, because the
event packet size is different from the legacy mode.
Since we cannot handle UMP events in user clients unless it's running
in the UMP client mode, we should filter out those events instead of
accepting blindly. This patch addresses it by slightly adjusting the
conditions for UMP event handling at the event delivery time.
Fixes: 329ffe11a014 ("ALSA: seq: Allow suppressing UMP conversions")
Signed-off-by: Takashi Iwai <tiwai@suse.de>
---
sound/core/seq/seq_clientmgr.c | 12 +++++++++---
1 file changed, 9 insertions(+), 3 deletions(-)
diff --git a/sound/core/seq/seq_clientmgr.c b/sound/core/seq/seq_clientmgr.c
index 073b56dc2225..cb66ec42a3f8 100644
--- a/sound/core/seq/seq_clientmgr.c
+++ b/sound/core/seq/seq_clientmgr.c
@@ -678,12 +678,18 @@ static int snd_seq_deliver_single_event(struct snd_seq_client *client,
dest_port->time_real);
#if IS_ENABLED(CONFIG_SND_SEQ_UMP)
- if (!(dest->filter & SNDRV_SEQ_FILTER_NO_CONVERT)) {
- if (snd_seq_ev_is_ump(event)) {
+ if (snd_seq_ev_is_ump(event)) {
+ if (!(dest->filter & SNDRV_SEQ_FILTER_NO_CONVERT)) {
result = snd_seq_deliver_from_ump(client, dest, dest_port,
event, atomic, hop);
goto __skip;
- } else if (snd_seq_client_is_ump(dest)) {
+ } else if (dest->type == USER_CLIENT &&
+ !snd_seq_client_is_ump(dest)) {
+ result = 0; // drop the event
+ goto __skip;
+ }
+ } else if (snd_seq_client_is_ump(dest)) {
+ if (!(dest->filter & SNDRV_SEQ_FILTER_NO_CONVERT)) {
result = snd_seq_deliver_to_ump(client, dest, dest_port,
event, atomic, hop);
goto __skip;
--
2.43.0
^ permalink raw reply related [flat|nested] 4+ messages in thread
end of thread, other threads:[~2025-02-17 11:05 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-12-18 23:24 Ask snd_seq_set_client_midi_version Correo Alternativo
2024-12-30 11:34 ` Takashi Iwai
2025-02-01 23:11 ` Possible bug with snd_seq_event_input_pending Carlos
2025-02-17 11:04 ` Takashi Iwai
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.