Small fixes for audio-thru support.

Removing a not used menu.
pull/32/head
Holger Wirtz 4 years ago
parent 872c5e9594
commit c24bdb4cfd
  1. 9
      MicroDexed.ino
  2. 34
      UI.hpp
  3. 75
      UI_FX.h
  4. 67
      UI_NO_FX.h
  5. 6
      config.h
  6. 9
      dexed_sd.cpp

@ -104,9 +104,11 @@ AudioOutputI2S i2s1;
AudioConnection patchCord12(stereo2mono, 0, i2s1, 0);
AudioConnection patchCord13(stereo2mono, 1, i2s1, 1);
AudioControlSGTL5000 sgtl5000_1;
#ifdef SGTL5000_AUDIO_THRU
AudioInputI2S i2s1in;
AudioConnection patchCord17(i2s1in, 0, master_mixer_r, 2);
AudioConnection patchCord18(i2s1in, 1, master_mixer_l, 2);
#endif
#elif defined (I2S_AUDIO_ONLY)
AudioOutputI2S i2s1;
AudioConnection patchCord12(stereo2mono, 0, i2s1, 0);
@ -291,6 +293,11 @@ void setup()
sgtl5000_1.volume(SGTL5000_HEADPHONE_VOLUME, SGTL5000_HEADPHONE_VOLUME); // Headphone volume
sgtl5000_1.audioProcessorDisable();
sgtl5000_1.audioPostProcessorEnable();
#ifdef SGTL5000_AUDIO_THRU
sgtl5000_1.inputSelect(AUDIO_INPUT_LINEIN);
sgtl5000_1.lineInLevel(5);
sgtl5000_1.adcHighPassFilterEnable();
#endif
#ifdef SGTL5000_AUDIO_ENHANCE
sgtl5000_1.enhanceBassEnable();
sgtl5000_1.enhanceBass(1.0, 1.5); // enhanceBass(1.0, 1.0, 1, 2); // Configures the bass enhancement by setting the levels of the original stereo signal and the bass-enhanced mono level which will be mixed together. The high-pass filter may be enabled (0) or bypassed (1).
@ -459,11 +466,13 @@ void setup()
master_mixer_l.gain(0, 1.0);
#endif
#ifdef TEENSY_AUDIO_BOARD
#ifdef SGTL5000_AUDIO_THRU
master_mixer_r.gain(2, 1.0); // I2S Input
master_mixer_l.gain(2, 1.0); // I2S Input
#else
master_mixer_r.gain(2, 0.0); // I2S Input
master_mixer_l.gain(2, 0.0); // I2S Input
#endif
#endif
master_mixer_r.gain(3, 0.0);
master_mixer_l.gain(3, 0.0);

@ -230,7 +230,6 @@ void UI_func_midi_soft_thru(uint8_t param);
void UI_func_velocity_level(uint8_t param);
void UI_func_voice_select(uint8_t param);
void UI_func_sysex_send_voice(uint8_t param);
void UI_func_sysex_receive_voice(uint8_t param);
void UI_func_sysex_receive_bank(uint8_t param);
void UI_func_sysex_send_bank(uint8_t param);
void UI_func_eq_bass(uint8_t param);
@ -5104,39 +5103,6 @@ void UI_func_sysex_send_voice(uint8_t param)
}
}
void UI_func_sysex_receive_voice(uint8_t param)
{
if (LCDML.FUNC_setup()) // ****** SETUP *********
{
encoderDir[ENC_R].reset();
lcd.setCursor(0, 0);
lcd.print(F("MIDI Receive Voice"));
lcd.setCursor(0, 1);
lcd.print(F("Not implemented."));
}
if (LCDML.FUNC_loop()) // ****** LOOP *********
{
if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up()))
{
if (LCDML.BT_checkDown())
{
;
}
else if (LCDML.BT_checkUp())
{
;
}
}
}
if (LCDML.FUNC_close()) // ****** STABLE END *********
{
encoderDir[ENC_R].reset();
}
}
void UI_func_eq_bass(uint8_t param)
{
#ifndef SGTL5000_AUDIO_ENHANCE

@ -75,42 +75,41 @@ LCDML_add(46, LCDML_0_1, 4, "MIDI", NULL);
LCDML_add(47, LCDML_0_1_4, 1, "MIDI Channel", UI_func_midi_channel);
LCDML_add(48, LCDML_0_1_4, 2, "Lowest Note", UI_func_lowest_note);
LCDML_add(49, LCDML_0_1_4, 3, "Highest Note", UI_func_highest_note);
LCDML_add(50, LCDML_0_1_4, 4, "Send Voice", UI_func_sysex_send_voice);
LCDML_add(51, LCDML_0_1_4, 5, "Receive Voice", UI_func_sysex_receive_voice);
LCDML_add(52, LCDML_0_1, 5, "Setup", NULL);
LCDML_add(53, LCDML_0_1_5, 1, "Portamento", NULL);
LCDML_add(54, LCDML_0_1_5_1, 1, "Port. Mode", UI_func_portamento_mode);
LCDML_add(55, LCDML_0_1_5_1, 2, "Port. Gliss", UI_func_portamento_glissando);
LCDML_add(56, LCDML_0_1_5_1, 3, "Port. Time", UI_func_portamento_time);
LCDML_add(57, LCDML_0_1_5, 2, "Polyphony", UI_func_polyphony);
LCDML_add(58, LCDML_0_1_5, 3, "Transpose", UI_func_transpose);
LCDML_add(59, LCDML_0_1_5, 4, "Fine Tune", UI_func_tune);
LCDML_add(60, LCDML_0_1_5, 5, "Mono/Poly", UI_func_mono_poly);
LCDML_add(61, LCDML_0_1, 6, "Internal", NULL);
LCDML_add(62, LCDML_0_1_6, 1, "Note Refresh", UI_func_note_refresh);
LCDML_add(63, LCDML_0_1_6, 2, "Velocity Lvl", UI_func_velocity_level);
LCDML_add(64, LCDML_0_1_6, 3, "Engine", UI_func_engine);
LCDML_add(65, LCDML_0_1, 7, "Operator", UI_handle_OP);
LCDML_add(66, LCDML_0_1, 8, "Save Voice", UI_func_save_voice);
LCDML_add(67, LCDML_0, 3, "Load/Save", NULL);
LCDML_add(68, LCDML_0_3, 1, "Performance", NULL);
LCDML_add(69, LCDML_0_3_1, 1, "Load Perf.", UI_func_load_performance);
LCDML_add(70, LCDML_0_3_1, 2, "Save Perf.", UI_func_save_performance);
LCDML_add(71, LCDML_0_3, 2, "Voice Config", NULL);
LCDML_add(72, LCDML_0_3_2, 1, "Load Voice Cfg", UI_func_load_voiceconfig);
LCDML_add(73, LCDML_0_3_2, 2, "Save Voice Cfg", UI_func_save_voiceconfig);
LCDML_add(74, LCDML_0_3, 3, "Effects", NULL);
LCDML_add(75, LCDML_0_3_3, 1, "Load Effects", UI_func_load_fx);
LCDML_add(76, LCDML_0_3_3, 2, "Save Effects", UI_func_save_fx);
LCDML_add(77, LCDML_0_3, 5, "MIDI", NULL);
LCDML_add(78, LCDML_0_3_5, 1, "MIDI Recv Bank", UI_func_sysex_receive_bank);
LCDML_add(79, LCDML_0_3_5, 2, "MIDI Snd Bank", UI_func_sysex_send_bank);
LCDML_add(80, LCDML_0_3_5, 3, "MIDI Snd Voice", UI_func_sysex_send_voice);
LCDML_add(81, LCDML_0, 4, "System", NULL);
LCDML_add(82, LCDML_0_4, 1, "Volume", UI_func_volume);
LCDML_add(83, LCDML_0_4, 2, "Stereo/Mono", UI_func_stereo_mono);
LCDML_add(84, LCDML_0_4, 3, "MIDI Soft THRU", UI_func_midi_soft_thru);
LCDML_add(85, LCDML_0_4, 4, "EEPROM Reset", UI_func_eeprom_reset);
LCDML_add(86, LCDML_0, 6, "Info", UI_func_information);
#define _LCDML_DISP_cnt 86
LCDML_add(50, LCDML_0_1_4, 4, "MIDI Send Voice", UI_func_sysex_send_voice);
LCDML_add(51, LCDML_0_1, 5, "Setup", NULL);
LCDML_add(52, LCDML_0_1_5, 1, "Portamento", NULL);
LCDML_add(53, LCDML_0_1_5_1, 1, "Port. Mode", UI_func_portamento_mode);
LCDML_add(54, LCDML_0_1_5_1, 2, "Port. Gliss", UI_func_portamento_glissando);
LCDML_add(55, LCDML_0_1_5_1, 3, "Port. Time", UI_func_portamento_time);
LCDML_add(56, LCDML_0_1_5, 2, "Polyphony", UI_func_polyphony);
LCDML_add(57, LCDML_0_1_5, 3, "Transpose", UI_func_transpose);
LCDML_add(58, LCDML_0_1_5, 4, "Fine Tune", UI_func_tune);
LCDML_add(59, LCDML_0_1_5, 5, "Mono/Poly", UI_func_mono_poly);
LCDML_add(60, LCDML_0_1, 6, "Internal", NULL);
LCDML_add(61, LCDML_0_1_6, 1, "Note Refresh", UI_func_note_refresh);
LCDML_add(62, LCDML_0_1_6, 2, "Velocity Lvl", UI_func_velocity_level);
LCDML_add(63, LCDML_0_1_6, 3, "Engine", UI_func_engine);
LCDML_add(64, LCDML_0_1, 7, "Operator", UI_handle_OP);
LCDML_add(65, LCDML_0_1, 8, "Save Voice", UI_func_save_voice);
LCDML_add(66, LCDML_0, 3, "Load/Save", NULL);
LCDML_add(67, LCDML_0_3, 1, "Performance", NULL);
LCDML_add(68, LCDML_0_3_1, 1, "Load Perf.", UI_func_load_performance);
LCDML_add(69, LCDML_0_3_1, 2, "Save Perf.", UI_func_save_performance);
LCDML_add(70, LCDML_0_3, 2, "Voice Config", NULL);
LCDML_add(71, LCDML_0_3_2, 1, "Load Voice Cfg", UI_func_load_voiceconfig);
LCDML_add(72, LCDML_0_3_2, 2, "Save Voice Cfg", UI_func_save_voiceconfig);
LCDML_add(73, LCDML_0_3, 3, "Effects", NULL);
LCDML_add(74, LCDML_0_3_3, 1, "Load Effects", UI_func_load_fx);
LCDML_add(75, LCDML_0_3_3, 2, "Save Effects", UI_func_save_fx);
LCDML_add(76, LCDML_0_3, 5, "MIDI", NULL);
LCDML_add(77, LCDML_0_3_5, 1, "MIDI Recv Bank", UI_func_sysex_receive_bank);
LCDML_add(78, LCDML_0_3_5, 2, "MIDI Snd Bank", UI_func_sysex_send_bank);
LCDML_add(79, LCDML_0_3_5, 3, "MIDI Snd Voice", UI_func_sysex_send_voice);
LCDML_add(80, LCDML_0, 4, "System", NULL);
LCDML_add(81, LCDML_0_4, 1, "Volume", UI_func_volume);
LCDML_add(82, LCDML_0_4, 2, "Stereo/Mono", UI_func_stereo_mono);
LCDML_add(83, LCDML_0_4, 3, "MIDI Soft THRU", UI_func_midi_soft_thru);
LCDML_add(84, LCDML_0_4, 4, "EEPROM Reset", UI_func_eeprom_reset);
LCDML_add(85, LCDML_0, 6, "Info", UI_func_information);
#define _LCDML_DISP_cnt 85
#endif

@ -55,39 +55,38 @@ LCDML_add(26, LCDML_0_1_4, 1, "MIDI Channel", UI_func_midi_channel);
LCDML_add(27, LCDML_0_1_4, 2, "Lowest Note", UI_func_lowest_note);
LCDML_add(28, LCDML_0_1_4, 3, "Highest Note", UI_func_highest_note);
LCDML_add(29, LCDML_0_1_4, 4, "Send Voice", UI_func_sysex_send_voice);
LCDML_add(30, LCDML_0_1_4, 5, "Receive Voice", UI_func_sysex_receive_voice);
LCDML_add(31, LCDML_0_1, 5, "Setup", NULL);
LCDML_add(32, LCDML_0_1_5, 1, "Portamento", NULL);
LCDML_add(33, LCDML_0_1_5_1, 1, "Port. Mode", UI_func_portamento_mode);
LCDML_add(34, LCDML_0_1_5_1, 2, "Port. Gliss", UI_func_portamento_glissando);
LCDML_add(35, LCDML_0_1_5_1, 3, "Port. Time", UI_func_portamento_time);
LCDML_add(36, LCDML_0_1_5, 2, "Polyphony", UI_func_polyphony);
LCDML_add(37, LCDML_0_1_5, 3, "Transpose", UI_func_transpose);
LCDML_add(38, LCDML_0_1_5, 4, "Fine Tune", UI_func_tune);
LCDML_add(39, LCDML_0_1_5, 5, "Mono/Poly", UI_func_mono_poly);
LCDML_add(40, LCDML_0_1, 6, "Internal", NULL);
LCDML_add(41, LCDML_0_1_6, 1, "Note Refresh", UI_func_note_refresh);
LCDML_add(42, LCDML_0_1_6, 2, "Velocity Lvl", UI_func_velocity_level);
LCDML_add(43, LCDML_0_1_6, 3, "Engine", UI_func_engine);
LCDML_add(44, LCDML_0_1, 7, "Operator", UI_handle_OP);
LCDML_add(45, LCDML_0_1, 8, "Save Voice", UI_func_save_voice);
LCDML_add(46, LCDML_0, 2, "Load/Save", NULL);
LCDML_add(47, LCDML_0_2, 1, "Performance", NULL);
LCDML_add(48, LCDML_0_2_1, 1, "Load Perf.", UI_func_load_performance);
LCDML_add(49, LCDML_0_2_1, 2, "Save Perf.", UI_func_save_performance);
LCDML_add(50, LCDML_0_2, 2, "Voice Config", NULL);
LCDML_add(51, LCDML_0_2_2, 1, "Load Voice Cfg", UI_func_load_voiceconfig);
LCDML_add(52, LCDML_0_2_2, 2, "Save Voice Cfg", UI_func_save_voiceconfig);
LCDML_add(53, LCDML_0_2, 4, "MIDI", NULL);
LCDML_add(54, LCDML_0_2_4, 1, "MIDI Recv Bank", UI_func_sysex_receive_bank);
LCDML_add(55, LCDML_0_2_4, 2, "MIDI Snd Bank", UI_func_sysex_send_bank);
LCDML_add(56, LCDML_0_2_4, 3, "MIDI Snd Voice", UI_func_sysex_send_voice);
LCDML_add(57, LCDML_0, 3, "System", NULL);
LCDML_add(58, LCDML_0_3, 1, "Volume", UI_func_volume);
LCDML_add(59, LCDML_0_3, 2, "Stereo/Mono", UI_func_stereo_mono);
LCDML_add(60, LCDML_0_3, 3, "MIDI Soft THRU", UI_func_midi_soft_thru);
LCDML_add(61, LCDML_0_3, 4, "EEPROM Reset", UI_func_eeprom_reset);
LCDML_add(62, LCDML_0, 4, "Info", UI_func_information);
#define _LCDML_DISP_cnt 62
LCDML_add(30, LCDML_0_1, 5, "Setup", NULL);
LCDML_add(31, LCDML_0_1_5, 1, "Portamento", NULL);
LCDML_add(32, LCDML_0_1_5_1, 1, "Port. Mode", UI_func_portamento_mode);
LCDML_add(33, LCDML_0_1_5_1, 2, "Port. Gliss", UI_func_portamento_glissando);
LCDML_add(34, LCDML_0_1_5_1, 3, "Port. Time", UI_func_portamento_time);
LCDML_add(35, LCDML_0_1_5, 2, "Polyphony", UI_func_polyphony);
LCDML_add(36, LCDML_0_1_5, 3, "Transpose", UI_func_transpose);
LCDML_add(37, LCDML_0_1_5, 4, "Fine Tune", UI_func_tune);
LCDML_add(38, LCDML_0_1_5, 5, "Mono/Poly", UI_func_mono_poly);
LCDML_add(39, LCDML_0_1, 6, "Internal", NULL);
LCDML_add(40, LCDML_0_1_6, 1, "Note Refresh", UI_func_note_refresh);
LCDML_add(41, LCDML_0_1_6, 2, "Velocity Lvl", UI_func_velocity_level);
LCDML_add(42, LCDML_0_1_6, 3, "Engine", UI_func_engine);
LCDML_add(43, LCDML_0_1, 7, "Operator", UI_handle_OP);
LCDML_add(44, LCDML_0_1, 8, "Save Voice", UI_func_save_voice);
LCDML_add(45, LCDML_0, 2, "Load/Save", NULL);
LCDML_add(46, LCDML_0_2, 1, "Performance", NULL);
LCDML_add(47, LCDML_0_2_1, 1, "Load Perf.", UI_func_load_performance);
LCDML_add(48, LCDML_0_2_1, 2, "Save Perf.", UI_func_save_performance);
LCDML_add(49, LCDML_0_2, 2, "Voice Config", NULL);
LCDML_add(50, LCDML_0_2_2, 1, "Load Voice Cfg", UI_func_load_voiceconfig);
LCDML_add(51, LCDML_0_2_2, 2, "Save Voice Cfg", UI_func_save_voiceconfig);
LCDML_add(52, LCDML_0_2, 4, "MIDI", NULL);
LCDML_add(53, LCDML_0_2_4, 1, "MIDI Recv Bank", UI_func_sysex_receive_bank);
LCDML_add(54, LCDML_0_2_4, 2, "MIDI Snd Bank", UI_func_sysex_send_bank);
LCDML_add(55, LCDML_0_2_4, 3, "MIDI Snd Voice", UI_func_sysex_send_voice);
LCDML_add(56, LCDML_0, 3, "System", NULL);
LCDML_add(57, LCDML_0_3, 1, "Volume", UI_func_volume);
LCDML_add(58, LCDML_0_3, 2, "Stereo/Mono", UI_func_stereo_mono);
LCDML_add(59, LCDML_0_3, 3, "MIDI Soft THRU", UI_func_midi_soft_thru);
LCDML_add(60, LCDML_0_3, 4, "EEPROM Reset", UI_func_eeprom_reset);
LCDML_add(61, LCDML_0, 4, "Info", UI_func_information);
#define _LCDML_DISP_cnt 61
#endif

@ -56,7 +56,7 @@
// sed -i.orig 's/^#define USB_MIDI_SYSEX_MAX 290/#define USB_MIDI_SYSEX_MAX 4104/' /usr/local/arduino-teensy-1.8.12/hardware/teensy/avr/cores/teensy3/usb_midi.h
//#define USB_MIDI_SYSEX_MAX 4104
#define VERSION "0.9.9m"
#define VERSION "0.9.9n"
//*************************************************************************************************
//* DEVICE SETTINGS
@ -93,7 +93,7 @@
//*************************************************************************************************
//* DEBUG OUTPUT SETTINGS
//*************************************************************************************************
#define DEBUG 1
//#define DEBUG 1
#define SERIAL_SPEED 230400
#define SHOW_XRUN 1
#define SHOW_CPU_LOAD_MSEC 5000
@ -116,7 +116,7 @@
#define REVERB_ANTIALIAS_FRQ 7500
// SGTL5000
#define SGTL5000_AUDIO_ENHANCE 1
#define SGTL5000_AUDIO_THRU 1
//*************************************************************************************************
//* AUDIO SOFTWARE SETTINGS
//*************************************************************************************************

@ -71,7 +71,7 @@ bool load_sd_voice(uint8_t b, uint8_t v, uint8_t instance_id)
Serial.print(voice_name);
Serial.println(F("]"));
#endif
bool ret = MicroDexed[instance_id]->decodeVoice(data,MicroDexed[instance_id]->data);
bool ret = MicroDexed[instance_id]->decodeVoice(data, MicroDexed[instance_id]->data);
#ifdef DEBUG
show_patch(instance_id);
#endif
@ -821,7 +821,7 @@ uint8_t calc_checksum(uint8_t* data, uint16_t len)
return (bulk_checksum_calc & 0x7f);
}
void strip_extension(char* s, char* target)
void strip_extension(char* s, char* target, uint8_t len)
{
char tmp[FILENAME_LEN];
char* token;
@ -832,6 +832,8 @@ void strip_extension(char* s, char* target)
strcpy(target, "*ERROR*");
else
strcpy(target, token);
target[len] = '\0';
}
bool get_bank_name(uint8_t b, char* name, uint8_t len)
@ -860,7 +862,8 @@ bool get_bank_name(uint8_t b, char* name, uint8_t len)
if (entry.isDirectory())
return (false);
strip_extension(entry.name(), name);
strip_extension(entry.name(), name, len);
#ifdef DEBUG
Serial.print(F("Found bank-name ["));
Serial.print(name);

Loading…
Cancel
Save