ALSA hardware input of SysEx is being separated into 256 byte chunks
Posted: Wed Nov 11, 2020 3:09 am
I've noticed an issue with my Edirol USB MIDI interfaces, or their Linux kernel modules: SysEx messages longer than 256 bytes read from MIDI input (and perhaps output, but that seems impossible to tell) are split into 256 byte chunks. /sys/module/snd_seq_midi/parameters/input_buffer_size & output_buffer_size show that 4096 bytes should work, but I've even tried a megabyte for each parameter.
I suppose I should check the kernel source or ask that list, but if anyone knows a solution, it would be nice to get it straight before I have done that.
This makes certain initial SysEx files I'd created not work when qmidiroute SysEx delays are on. I'm waiting for another USB MIDI interface to see if it really is a hardware limitation, though I think it's the kernel.
Upon further reflection, it occurs to me that I could recreate my initial SysEx files virtually using qmidiroute to perform the delaying, because virtual port connections don't seem to have the issue.
The way I had been converting .syx files to SMF, is through unix's cat terminal command to pipe it out the MIDI interface. In which case, I'd need to input the output (as loopback), and that causes the splitting.
Well, I was able to create a delayed .mid file from SILPHEED.SYX, using the method I explained about converting SysEx banks with cakewalk: viewtopic.php?f=11&t=17796&sid=e96c04c2 ... 309#p18328. I then played that non-delayed resultant .mid, through qmidiroute with delays set at 140ms while re-recording it to get a nice file, with complete messages, that the MT-32 (old) can cope with, which won't get improperly split up if re-delayed in qmidiroute. I don't like using non-free programs, though, so I hope to find or create another way, preferably without modifying qmidiroute to cope with and concatenate these partial messages whole again.
I suppose I should check the kernel source or ask that list, but if anyone knows a solution, it would be nice to get it straight before I have done that.
This makes certain initial SysEx files I'd created not work when qmidiroute SysEx delays are on. I'm waiting for another USB MIDI interface to see if it really is a hardware limitation, though I think it's the kernel.
Upon further reflection, it occurs to me that I could recreate my initial SysEx files virtually using qmidiroute to perform the delaying, because virtual port connections don't seem to have the issue.
The way I had been converting .syx files to SMF, is through unix's cat terminal command to pipe it out the MIDI interface. In which case, I'd need to input the output (as loopback), and that causes the splitting.
Well, I was able to create a delayed .mid file from SILPHEED.SYX, using the method I explained about converting SysEx banks with cakewalk: viewtopic.php?f=11&t=17796&sid=e96c04c2 ... 309#p18328. I then played that non-delayed resultant .mid, through qmidiroute with delays set at 140ms while re-recording it to get a nice file, with complete messages, that the MT-32 (old) can cope with, which won't get improperly split up if re-delayed in qmidiroute. I don't like using non-free programs, though, so I hope to find or create another way, preferably without modifying qmidiroute to cope with and concatenate these partial messages whole again.