mirror of
https://github.com/italicsjenga/usbd-midi.git
synced 2025-01-11 04:41:31 +11:00
Attempts at restoring windows compatibility
This commit is contained in:
parent
b06d1dcb50
commit
42b1efa16b
|
@ -4,7 +4,7 @@ use crate::data::usb::constants::*;
|
|||
use crate::data::usb_midi::usb_midi_event_packet::{UsbMidiEventPacket, MidiPacketParsingError};
|
||||
|
||||
const MIDI_IN_SIZE: u8 = 0x06;
|
||||
const MIDI_OUT_SIZE: u8 = 0x07;
|
||||
const MIDI_OUT_SIZE: u8 = 0x09;
|
||||
|
||||
pub const MIDI_PACKET_SIZE: usize = 4;
|
||||
pub const MAX_PACKET_SIZE: usize = 64;
|
||||
|
@ -104,7 +104,7 @@ impl<B: UsbBus> UsbClass<B> for MidiClass<'_, B> {
|
|||
let midi_streaming_start_byte = writer.position();
|
||||
let midi_streaming_total_length =
|
||||
7 + self.n_in_jacks as usize * MIDI_IN_SIZE as usize + self.n_out_jacks as usize * MIDI_OUT_SIZE as usize
|
||||
+ 7 + (4+self.n_in_jacks as usize) + 7 + (4+self.n_out_jacks as usize);
|
||||
+ 9 + (4+self.n_in_jacks as usize) + 9 + (4+self.n_out_jacks as usize);
|
||||
|
||||
//Streaming extra info
|
||||
writer.write( // len = 7
|
||||
|
@ -137,6 +137,7 @@ impl<B: UsbBus> UsbClass<B> for MidiClass<'_, B> {
|
|||
EMBEDDED,
|
||||
self.out_jack_id(i), //id
|
||||
0x00, // no pins
|
||||
0x00, 0x00, // windows wants these two bytes, no idea why. they don't belong here.
|
||||
0x00
|
||||
]
|
||||
)?;
|
||||
|
@ -148,7 +149,7 @@ impl<B: UsbBus> UsbClass<B> for MidiClass<'_, B> {
|
|||
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 // jack mappings. must be filled in and cropped.
|
||||
];
|
||||
|
||||
writer.endpoint(&self.standard_bulkout)?; // len = 7
|
||||
writer.endpoint(&self.standard_bulkout)?; // len = 9
|
||||
|
||||
endpoint_data[1] = self.n_in_jacks;
|
||||
for i in 0..self.n_in_jacks {
|
||||
|
@ -159,7 +160,7 @@ impl<B: UsbBus> UsbClass<B> for MidiClass<'_, B> {
|
|||
&endpoint_data[0..2+self.n_in_jacks as usize]
|
||||
)?;
|
||||
|
||||
writer.endpoint(&self.standard_bulkin)?; // len = 7
|
||||
writer.endpoint(&self.standard_bulkin)?; // len = 9
|
||||
endpoint_data[1] = self.n_out_jacks;
|
||||
for i in 0..self.n_out_jacks {
|
||||
endpoint_data[2 + i as usize] = self.out_jack_id(i);
|
||||
|
|
Loading…
Reference in a new issue