Deluge Firmware 1.3.0
Build date: 2025.11.26
Loading...
Searching...
No Matches
midi_engine.h
1/*
2 * Copyright © 2014-2023 Synthstrom Audible Limited
3 *
4 * This file is part of The Synthstrom Audible Deluge Firmware.
5 *
6 * The Synthstrom Audible Deluge Firmware is free software: you can redistribute it and/or modify it under the
7 * terms of the GNU General Public License as published by the Free Software Foundation,
8 * either version 3 of the License, or (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
11 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
12 * See the GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License along with this program.
15 * If not, see <https://www.gnu.org/licenses/>.
16 */
17
18#pragma once
19
20#ifdef __cplusplus
21
22#include "OSLikeStuff/scheduler_api.h"
23#include "definitions_cxx.hpp"
24#include "io/midi/learned_midi.h"
25#include "playback/playback_handler.h"
26
27class MIDICable;
28class MIDIDrum;
29class MIDIInstrument;
30class MidiFollow;
31class PlaybackHandler;
32
35struct MIDISource {
36 void const* source_{nullptr};
37
38 MIDISource() = default;
39 ~MIDISource() = default;
40
41 MIDISource(MIDICable const* cable) : source_(cable) {};
42 MIDISource(MIDIInstrument const* instrument) : source_(instrument) {};
43 MIDISource(PlaybackHandler const* handler) : source_(handler) {};
44 MIDISource(MidiFollow const* follow) : source_(follow) {};
45 MIDISource(MIDIDrum const* drum) : source_(drum) {};
46 MIDISource(Sound const* sound) : source_(sound) {};
47
48 MIDISource(MIDICable const& cable) : source_(&cable) {};
49 MIDISource(MIDIInstrument const& instrument) : source_(&instrument) {};
50 MIDISource(MIDIDrum const& drum) : source_(&drum) {};
51 MIDISource(Sound const& sound) : source_(&sound) {};
52 MIDISource(MidiFollow const& follow) : source_(&follow) {};
53 MIDISource(PlaybackHandler const& handler) : source_(&handler) {};
54
55 MIDISource(MIDISource const& other) = default;
56 MIDISource(MIDISource&& other) = default;
57
58 MIDISource& operator=(MIDISource const& other) = default;
59 MIDISource& operator=(MIDISource&& other) = default;
60
61 bool operator==(MIDISource const& other) const { return source_ == other.source_; }
62};
63
64class MidiEngine {
65public:
66 MidiEngine();
67
68 void sendNote(MIDISource source, bool on, int32_t note, uint8_t velocity, uint8_t channel, int32_t filter);
69 void sendCC(MIDISource source, int32_t channel, int32_t cc, int32_t value, int32_t filter);
70
71 void sendMidi(MIDISource source, MIDIMessage message, int32_t filter = kMIDIOutputFilterNoMPE, bool sendUSB = true);
72 void sendClock(MIDISource source, bool sendUSB = true, int32_t howMany = 1);
73 void sendStart(MIDISource source);
74 void sendStop(MIDISource source);
75 void sendPositionPointer(MIDISource source, uint16_t positionPointer);
76 void sendContinue(MIDISource source);
77
78 void checkIncomingMidi();
79 void flushMIDI();
80 void sendUsbMidi(MIDIMessage message, int32_t filter);
81
82 void sendPGMChange(MIDISource source, int32_t channel, int32_t pgm, int32_t filter);
83 void sendAllNotesOff(MIDISource source, int32_t channel, int32_t filter);
84 void sendBank(MIDISource source, int32_t channel, int32_t num, int32_t filter);
85 void sendSubBank(MIDISource source, int32_t channel, int32_t num, int32_t filter);
89 void sendPitchBend(MIDISource source, int32_t channel, uint16_t bend, int32_t filter);
90 void sendChannelAftertouch(MIDISource source, int32_t channel, uint8_t value, int32_t filter);
91 void sendPolyphonicAftertouch(MIDISource source, int32_t channel, uint8_t value, uint8_t noteCode, int32_t filter);
92 bool anythingInOutputBuffer();
93
94 // If bit "16" (actually bit 4) is 1, this is a program change. (Wait, still?)
95 LearnedMIDI globalMIDICommands[kNumGlobalMIDICommands];
96
97 bool midiThru;
98 LearnedMIDI midiFollowChannelType[kNumMIDIFollowChannelTypes]; // A, B, C
99 MIDIFollowChannelType midiFollowFeedbackChannelType; // A, B, C, NONE
100 uint8_t midiFollowKitRootNote;
101 bool midiFollowDisplayParam;
102 MIDIFollowFeedbackAutomationMode midiFollowFeedbackAutomation;
103 bool midiFollowFeedbackFilter;
104 MIDITakeoverMode midiTakeover;
105 bool midiSelectKitRow;
106 TaskID routine_task_id;
107
108 // shared buffer for formatting sysex messages.
109 // Not safe for use in interrupts.
110 uint8_t sysex_fmt_buffer[1024];
111
121 void midiMessageReceived(MIDICable& cable, uint8_t statusType, uint8_t channel, uint8_t data1, uint8_t data2,
122 uint32_t* timer = nullptr);
123
129 void midiSysexReceived(MIDICable& cable, uint8_t* data, int32_t len);
130
131private:
132 uint8_t serialMidiInput[3];
133 uint8_t numSerialMidiInput;
134
135 bool currentlyReceivingSysExSerial;
136
137 using EventStackStorage = std::array<MIDISource, 16>;
140 EventStackStorage eventStack_;
142 EventStackStorage::iterator eventStackTop_;
143};
144
145extern MidiEngine midiEngine;
146
147extern "C" {
148#endif
149#ifdef __cplusplus
150}
151#endif
A MIDI cable connection. Stores all state specific to a given cable and its contained ports and chann...
Definition midi_device.h:94
Definition midi_drum.h:22
Definition midi_instrument.h:37
Definition midi_follow.h:39
Definition playback_handler.h:54