FluidFeatures - FluidSynth/fluidsynth GitHub Wiki
This is a list of MIDI events that fluidsynth handles by default. That "handling" is either given by
- the SoundFont spec, or
- the General MIDI standard.
While the explanations in the SoundFont spec are very precise in terms of the intended audio-synthetic articulation, the descriptions in the MIDI standard are very vague when it comes to sound articulation. Thus you cannot expect that fluidsynth behaves in a certain way (which you may know from other synths) just because you send some MIDI CCs.
In order to control those "underspecifed" aspects of the sound synthesis (like ADSR, low pass filter cutoff & resonance, tremolo & vibrato depth, etc.) custom SoundFont modulators must be used! The SoundFont spec wants the SoundFont designer to define those modulators in the SoundFont file itself. Doing so will give you great portability between any SF2 compliant synth, i.e. you would get the same sound articulation when sending your custom CCs to any SF2 compliant synth to trigger your custom effects. Unfortunately, defining those modulators must be done for every single instrument or preset in the SoundFont, which can be tiresome and error-prone. Alternatively, you can use fluidsynth's API for manipulating default modulators (see fluid_synth_add_default_mod()
and fluid_synth_remove_default_mod()
resp.). This will allow you to insert or remove your own custom modulators, which will then affect all loaded SoundFonts equally. However, this technique is not portable and limited to fluidsynth.
Legend
:heavy_check_mark: Implemented according to MIDI or SoundFont spec and usable by default
:white_check_mark: Partially or customly implemented and usable by default
:warning: Attention, this may require special setup of fluidsynth to be usable by default
:x: Not handled by default, but usable via custom SoundFont modulators
MIDI Message Implementation Chart
MIDI Message | Implementation Status |
---|---|
NOTE_OFF | :heavy_check_mark: |
NOTE_ON | :heavy_check_mark: |
CONTROL_CHANGE | :white_check_mark: See related table below. |
MIDI_SET_TEMPO | :heavy_check_mark: |
PROGRAM_CHANGE | :heavy_check_mark: |
CHANNEL_PRESSURE | :heavy_check_mark: SF2 default modulator |
KEY_PRESSURE | :x: |
PITCH_BEND | :heavy_check_mark: SF2 default modulator |
MIDI_SYSTEM_RESET | :heavy_check_mark: |
MIDI Control Change Implementation Chart
Note that unless otherwise documented, CCs are interpreted individually, i.e. as 7-bit values.
MIDI CC | Implementation Status |
---|---|
(000) Bank Select | :heavy_check_mark: Interpretation of MSB and LSB depends on synth.midi-bank-select |
(001) Modulation Wheel | :heavy_check_mark: SF2 default modulator |
(002) Breath Controller | :warning: Usable in breathmode, see PolyMono documentation |
(004) Foot Controller | :x: |
(005) Portamento Time | :heavy_check_mark: MSB and LSB (i.e. 14-bit value!), see PolyMono documentation |
(006) Data Entry | :heavy_check_mark: MSB and LSB (i.e. 14-bit value!). |
(007) Channel Volume | :heavy_check_mark: SF2 default modulator |
(008) Balance | :white_check_mark: non-standard default SF2 modulator |
(010) Pan | :heavy_check_mark: SF2 default modulator |
(011) Expression | :heavy_check_mark: SF2 default modulator |
(064) Sustain Pedal | :heavy_check_mark: See Sostenuto documentation |
(065) Portamento Switch | :heavy_check_mark: See PolyMono documentation |
(066) Sostenuto Pedal | :heavy_check_mark: See Sostenuto documentation |
(068) Legato Switch | :heavy_check_mark: See PolyMono documentation |
(072) Sound Controller 3 (default: Release Time) | :x: |
(073) Sound Controller 4 (default: Attack Time) | :x: |
(074) Sound Controller 5 (default: Brightness) | :x: |
(084) Portamento Control (PTC) | :heavy_check_mark: See PolyMono documentation |
(091) Effects 1 Depth (Reverb Send Level) | :heavy_check_mark: SF2 default modulator |
(092) Effects 2 Depth (Tremolo Depth) | :x: |
(093) Effects 3 Depth (Chorus Send Level) | :heavy_check_mark: SF2 default modulator |
(094) Effects 4 Depth (Celeste (Detune) Depth) | :x: |
(095) Effects 5 Depth (Phaser Depth) | :x: |
(098) NRPN LSB | :heavy_check_mark: See related table below |
(099) NRPN MSB | :heavy_check_mark: See related table below |
(100) RPN LSB | :white_check_mark: See related table below |
(101) RPN MSB | :white_check_mark: See related table below |
(120) All Sound Off | :heavy_check_mark: |
(121) Reset All Controllers | :heavy_check_mark: |
(121) Local Control | :heavy_check_mark: Ignored, because not applicable |
(123) All Notes Off | :heavy_check_mark: |
(124) Omni Mode Off | :heavy_check_mark: See PolyMono documentation |
(125) Omni Mode On | :heavy_check_mark: See PolyMono documentation |
(126) Mono Mode | :heavy_check_mark: See PolyMono documentation |
(127) Poly Mode | :heavy_check_mark: See PolyMono documentation |
RPN Control Change Implementation Chart
RPN CC | Implementation Status |
---|---|
(000) RPN_PITCH_BEND_RANGE | :heavy_check_mark: SF2 default modulator |
(001) RPN_CHANNEL_FINE_TUNE | :heavy_check_mark: |
(002) RPN_CHANNEL_COARSE_TUNE | :heavy_check_mark: |
(003) Tuning Program Select | :heavy_check_mark: |
(004) Tuning Bank Select | :heavy_check_mark: |
(005) Modulation Depth Range | :x: Not yet implemented |
(006) MPE Configuration Message | :x: Not yet implemented |
NRPN Control Change Implementation Chart
SF2 NRPNs
:heavy_check_mark: All SF2 generators can be altered with NRPN Control Change messages. See section 8.1.2 in the spec.
AWE32 NRPNs
As of version 2.4.5, fluidsynth also supports NPRN control found in the AWE32. Most of it is implemented according to the "AWE32 Developer's Information Pack", which however was found to be quite buggy, so fluidsynth's behavior may differ from that of real SoundBlaster card. Unless otherwise noted, the data value received by any of these NRPNs overrides the initial generator value of the corresponding SF2 generator.
NRPN MSB | NRPN LSB | Implementation Status |
---|---|---|
127 | 0 | :white_check_mark: overrides Modulation LFO delay generator |
127 | 1 | :white_check_mark: overrides Modulation LFO frequency generator |
127 | 2 | :white_check_mark: overrides Vibrato LFO delay generator |
127 | 3 | :white_check_mark: overrides Vibrato LFO frequency generator |
127 | 4 | :white_check_mark: overrides Modulation envelope delay generator |
127 | 5 | :white_check_mark: overrides Modulation envelope attack generator |
127 | 6 | :white_check_mark: overrides Modulation envelope hold generator |
127 | 7 | :white_check_mark: overrides Modulation envelope decay generator |
127 | 8 | :white_check_mark: overrides Modulation envelope sustain generator |
127 | 9 | :white_check_mark: overrides Modulation envelope release generator |
127 | 10 | :white_check_mark: overrides Volume envelope delay generator |
127 | 11 | :white_check_mark: overrides Volume envelope attack generator |
127 | 12 | :white_check_mark: overrides Volume envelope hold generator |
127 | 13 | :white_check_mark: overrides Volume envelope decay generator |
127 | 14 | :white_check_mark: overrides Volume envelope sustain generator |
127 | 15 | :white_check_mark: overrides Volume envelope release generator |
127 | 16 | :warning: treated as if a regular MIDI Pitch Wheel event is received |
127 | 17 | :white_check_mark: overrides Modulation LFO to pitch generator |
127 | 18 | :white_check_mark: overrides Vibrato LFO to pitch generator |
127 | 19 | :white_check_mark: overrides Modulation envelope to pitch generator |
127 | 20 | :white_check_mark: overrides Modulation LFO to volume generator |
127 | 21 | :heavy_check_mark: overrides Filter cutoff generator, ranges verified through listening tests (AWE32 documentation is incorrect) |
127 | 22 | :heavy_check_mark: overrides Filter Q generator, ranges verified through listening tests (AWE32 documentation is incorrect) |
127 | 23 | :white_check_mark: overrides Modulation LFO to filter cutoff generator |
127 | 24 | :white_check_mark: overrides Modulation envelope to filter cutoff generator |
127 | 25 | :warning: received data value is transformed by default SF2 chorus modulator before applied to chorus generator |
127 | 26 | :warning: received data value is transformed by default SF2 reverb modulator before applied to reverb generator |
Roland NRPNs
Additionally, as of version 2.5.0, fluidsynth maps the following Roland NRPNs to regular CCs, allowing them to be overridden in a Soundfont by using modulators. The mapping was implemented according to the SC8850 owner's manual pages 227 and 228.
NRPN MSB | NRPN LSB | Implementation Status |
---|---|---|
0x01 | 0x08 | :white_check_mark: mapped to CC 76 (vibrato rate) |
0x01 | 0x09 | :white_check_mark: mapped to CC 77 (vibrato depth) |
0x01 | 0x0A | :white_check_mark: mapped to CC 78 (vibrato delay) |
SysEx Messages
Note: fluidsynth only processes those SysEx messages, if the "device-id" in the SysEx message matches the synth.device-id
setting the synth has been initialized with! Broadcast SysEx messages are always processed.
SysEx | Implementation Status |
---|---|
MIDI Tuning Standard | :heavy_check_mark: See enum midi_sysex_tuning_msg_id for supported messages |
GS DT1 | :white_check_mark: Only rhythm / melodic part selection messages are supported (since fluidsynth 2.2.0, see the "Patch Part parameters section in SC-88Pro/8850 owner's manual") |
GM/GM2 mode on | :heavy_check_mark: |
GS reset | :heavy_check_mark: |
XG reset | :heavy_check_mark: |