Switch to ESP32 Arduino core native USB MIDI API (USB.h + USBMIDI.h), remove Adafruit TinyUSB dependency

This commit is contained in:
2026-06-24 00:31:15 +00:00
parent 9ebd568b9c
commit 9fd0231b48
3 changed files with 15 additions and 31 deletions
-3
View File
@@ -1,3 +0,0 @@
Import("env")
env.Append(LINKFLAGS=["-Wl,--allow-multiple-definition"])
+5 -11
View File
@@ -6,19 +6,13 @@ platform = espressif32
board = esp32-s3-devkitc-1 board = esp32-s3-devkitc-1
framework = arduino framework = arduino
lib_deps = lib_deps =
adafruit/Adafruit TinyUSB Library@3.1.0
fastled/FastLED@^3.9.0 fastled/FastLED@^3.9.0
build_unflags = monitor_speed = 115200
-DARDUINO_USB_MODE=1
board_build.partitions = default_8MB.csv
build_flags = board_build.arduino.memory_type = qio_opi
-DARDUINO_USB_MODE=0
-DARDUINO_USB_CDC_ON_BOOT=1
-DUSE_TINYUSB=1
extra_scripts = pre:extra_script.py
monitor_speed = 115200 monitor_speed = 115200
board_build.partitions = default_8MB.csv board_build.partitions = default_8MB.csv
+10 -17
View File
@@ -1,8 +1,9 @@
#include "midi_transport.h" #include "midi_transport.h"
#include <Arduino.h> #include <Arduino.h>
#include "Adafruit_TinyUSB.h" #include "USB.h"
#include "USBMIDI.h"
static Adafruit_USBD_MIDI usb_midi; static USBMIDI usb_midi;
UsbMidiTransport::UsbMidiTransport() : initialized(false) { UsbMidiTransport::UsbMidiTransport() : initialized(false) {
} }
@@ -18,14 +19,10 @@ bool UsbMidiTransport::begin() {
return false; return false;
} }
if (TinyUSBDevice.mounted()) { USB.begin();
Serial.println("[MIDI] Re-enumerating with MIDI interface...");
TinyUSBDevice.detach();
delay(10);
TinyUSBDevice.attach();
}
initialized = true; initialized = true;
Serial.println("[MIDI] USB MIDI ready - enumerating...");
return true; return true;
} }
@@ -36,8 +33,7 @@ void UsbMidiTransport::update() {
uint32_t now = millis(); uint32_t now = millis();
if (now - last_status > 5000) { if (now - last_status > 5000) {
last_status = now; last_status = now;
Serial.printf("[MIDI] USB mounted: %s\n", Serial.printf("[MIDI] USB ready: %s\n", USB.ready() ? "YES" : "NO");
TinyUSBDevice.mounted() ? "YES" : "NO");
} }
while (usb_midi.available()) { while (usb_midi.available()) {
@@ -70,27 +66,24 @@ void UsbMidiTransport::on_midi_receive(std::function<void(const MidiEvent&)> cal
void UsbMidiTransport::send_note_on(uint8_t channel, uint8_t note, uint8_t velocity) { void UsbMidiTransport::send_note_on(uint8_t channel, uint8_t note, uint8_t velocity) {
if (!initialized) return; if (!initialized) return;
uint8_t packet[4] = {0x09, (uint8_t)(0x90 | (channel - 1)), note, velocity}; usb_midi.noteOn(note, velocity, channel);
usb_midi.writePacket(packet);
Serial.printf("[MIDI OUT] Ch:%d NOTE_ON:%d:%d\n", channel, note, velocity); Serial.printf("[MIDI OUT] Ch:%d NOTE_ON:%d:%d\n", channel, note, velocity);
} }
void UsbMidiTransport::send_note_off(uint8_t channel, uint8_t note, uint8_t velocity) { void UsbMidiTransport::send_note_off(uint8_t channel, uint8_t note, uint8_t velocity) {
if (!initialized) return; if (!initialized) return;
uint8_t packet[4] = {0x08, (uint8_t)(0x80 | (channel - 1)), note, velocity}; usb_midi.noteOff(note, velocity, channel);
usb_midi.writePacket(packet);
Serial.printf("[MIDI OUT] Ch:%d NOTE_OFF:%d:%d\n", channel, note, velocity); Serial.printf("[MIDI OUT] Ch:%d NOTE_OFF:%d:%d\n", channel, note, velocity);
} }
void UsbMidiTransport::send_cc(uint8_t channel, uint8_t cc, uint8_t value) { void UsbMidiTransport::send_cc(uint8_t channel, uint8_t cc, uint8_t value) {
if (!initialized) return; if (!initialized) return;
uint8_t packet[4] = {0x0B, (uint8_t)(0xB0 | (channel - 1)), cc, value}; usb_midi.controlChange(cc, value, channel);
usb_midi.writePacket(packet);
Serial.printf("[MIDI OUT] Ch:%d CC:%d:%d\n", channel, cc, value); Serial.printf("[MIDI OUT] Ch:%d CC:%d:%d\n", channel, cc, value);
} }
bool UsbMidiTransport::is_connected() { bool UsbMidiTransport::is_connected() {
return initialized && TinyUSBDevice.mounted(); return initialized && USB.ready();
} }
void UsbMidiTransport::parse_midi_packet(const uint8_t* buffer, uint32_t size, MidiEvent& event) { void UsbMidiTransport::parse_midi_packet(const uint8_t* buffer, uint32_t size, MidiEvent& event) {