Super MIDI Pak Documentation

Table of Contents

Introduction

Thank you for purchasing Super MIDI Pak! Super MIDI Pak is a cartridge that turns your SNES/SFC into a standard MIDI synthesizer. Here is a list of available features:

Getting Started

Super MIDI Pak conforms to the MIDI standard very carefully so you should be able to hook it up to your existing MIDI gear and get started immediately. If you are less familiar with MIDI this section will briefly acquaint you with how to hook it up.

Super MIDI Pak has three ports. A USB port and two 3.5" TRS ports. The USB port is provided to make it easy to connect Super MIDI Pak to your computer. USB cannot be used with another MIDI device unless it's a MIDI host, doing so may damage both devices. The two 3.5" TRS ports are MIDI ports that can be used with other MIDI devices, these are not audio ports. It's important to note that both the USB port and the pair of TRS ports provide equivalent functionality, everything you can do with the USB port can be done with the two TRS ports and vice versa. While it's safe, unless you know what you're doing, it's not recommended to have both the TRS ports and the USB port connected as they can interfere with each other.

Some MIDI devices may use traditional DIN MIDI ports instead of 3.5" TRS ports. To connect Super MIDI Pak to these devices you need to use a Type A 3.5" TRS to DIN adapter, such as this one.

To get audio out of the SNES/SFC, you use the normal audio output from the multi-out connector. If you are recording audio from the SNES/SFC into an audio interface, avoid having the video simultaneously connected to a separate TV or monitor as this may cause ground loop noise into your audio interface.

Here is one example setup that you may use when sequencing your SNES/SFC from your computer:

Here is another example that you may use when playing the Super MIDI Pak live from a MIDI controller:

Button Masher has put together a step-by-step video tutorial on how to use Super MIDI Pak to compose music from your computer.

Web Application

The web application is available at https://www.supermidipak.com/app. It provides easy access to the advanced features of Super MIDI pak, in particular converting and uploading custom samples.

Uploading Samples

The "Sample Uploader" page of the web application allows you to import and upload custom samples onto Super MIDI Pak.

The right pane shows the "sample catalogue." This is the catalogue of all samples that have been imported into the web application. These samples are not uploaded to Super MIDI Pak, they are simply available to choose from when deciding which samples you want to actually upload. Samples must first be imported into the catalogue before they can be selected in the "sample directory." You can import samples by pressing the "Import Samples" button and selecting the source file. To remove a sample catalogue entry, select the "X" button.

The left pane shows the "sample directory." These are the samples that will actually be uploaded to Super MIDI Pak.

The numbers to the left of each entry specify the index of the directory entry. This is the value that should be used to select this sample when changing the program using the MIDI "Program Change" message. To change the index of the directory entry, just click the index number button and enter a new value.

You can use the dropdown to select the specific sample that you'd like to occupy the directory entry. You may select any sample that you have imported into the sample catalogue.

You can edit the Volume ADSR and Pitch AD settings of each directory entry by selecting the corresponding "Patch Settings" button. These settings are automatically used by the channel when the program directory entry's program is selected on the channel, as long as CC#83 is disabled. You may also edit the patch settings of multiple directory entries at once by selecting the checkbox on the left of the desired directory entries and pressing the "Edit Selected Patch Settings" button.

To remove a sample directory entry, select the "X" button.

Once you are done setting up your desired sample directory, you can upload your samples by pressing the "Upload" button at the bottom of the pane. Be sure that the correct "MIDI Input Port" and "MIDI Output Port" have been selected at the top of the application. This takes approximately 30 seconds when using the entire SNES sample memory.

Web App MIDI Input

When managing Super MIDI Pak's settings using the the web application while also composing using your DAW or sequencer, you will quickly run into the issue of settings that you set in your DAW via MIDI CC events becoming out of sync with the settings that are contained in the web application. This can lead to confusing scenarios where you forget if your DAW or the web app has the authoritative settings. To deal with this issue, the web application exposes a MIDI input port to which you can connect your DAW. All MIDI messages sent to this port update the state of the web app and are also forwarded to Super MIDI pak (via the set MIDI Output Port).

You will find this setting near the other MIDI ports settings under the label "Web App MIDI Input Port." You can either create a virtual MIDI port in your OS and then assign the output of that virtual port to the "Web App MIDI Input Port," or you can select the output port of your DAW (if it exposes one).

Modulating the Web App's Band Pass Filter Generator

The web app contains a band pass filter generator in the "Echo Settings" section. You simply provide a center frequency and a filter width and the web app will compute the best FIRx register values that reflect the given parameters. You may want to modulate the filter generator parameters in real-time from your DAW or MIDI sequencer. To support this use case the web app maps CC#92 and CC#95 on its input port to the center frequency and filter width parameters, respectively. Be aware that these two specific MIDI messages are not forwarded onto the MIDI output port.

The web app also contains a feedback-based band pass filter generator. Due to the limitations of the feedback machinery of the SPC700, the width of this filter is not configurable but there is a "resonance" setting which has a simultaneous effect on both the width of the peak but also the peak amplification. A resonance setting of 0 makes the peak amplification always 0dB. This filter can be preferable over the non-feedback-based band pass filter because it only has a single peak and no ripple in the magnitude plot. You can modulate the center frequency of the filter by sending CC#94 to the input port of the web app, you can modulate the resonance by sending CC#93 to the input port of the web app,

Sample Encoding Parameters

When importing sample files that must first be encoded into the SNES's compressed sample format (e.g. WAV files), the web application provides few parameters that may help you obtain better sounding samples.

Loop Duration

Loop duration is the length of time from the end of the sample to a point earlier in the sample that constitutes the looping portion of the sample. This parameter is specified in milliseconds. Due to the SNES's sample format, the loop duration can only be in increments of 0.5 ms, e.g. 0.5 ms, 1 ms, 1.5 ms, etc. A value of 0 means the sample does not loop.

Dither Seed

Since encoding to the SNES's sample format is a lossy process, some dither is usually required so that the encoded sample sounds as clean as possible. Dither is a small amount of random noise added to the sample before encoding to make the noise due to a reduced bit-depth sound like white noise instead of added harmonics. The exact stream of random noise that is added to the sample is fully defined by the "dither seed." You may find that some dither seeds work better than others, especially for harmonically poor samples (i.e. pure tones). A value of 1 is the default.

Dither Gain

The dither noise that is added to the sample has a power that is proportional to the lowest significant bit of a 16-bit sample. You can tweak the power of the dither noise by applying a gain to the dither, which is defined by this parameter. In certain cases more dither may sound better and in other cases less dither may sound better, but generally the default dither gain works well. This parameter is specified in bits. A value of 0 is the default.

Pad Sample

The SNES sample decoding process has two quirks. The first quirk is that the first 16 samples of a full sample must be encoded using the most lossy method, making it sound less than optimal. The other quirk is that the last 28 samples of a full sample are ignored. If you pad your sample with zeros at the beginning and end of your full sample you can avoid these quirks from impacting your sample. The downside is that this causes a 0.5 ms delay to your sample, so you may want to take that into account in your compositions. It also takes up a marginal amount of memory. If you are mastering your samples yourself, then it's recommended you apply this padding yourself before importing into the web application but if you are importing pre-mastered samples from another source, you can enable this parameter to have the web application provide this padding for you. By default this parameter is disabled.

Compensate for Interpolation

After sample decoding, the SNES passes the sample data through an interpolation filter as part of the pitch-shifting process. This interpolation filter has the effect of attenuating high-frequency components in your sample. There are two reasons for this:

  1. BRR encoding often adds some high frequency noise to the sample due to reducing the bit-depth and quantization noise.
  2. To pitch shift upward, frequency components above a certain cutoff must be completely attenuated to avoid aliasing. Since the SNES allows pitch shifting upward by a max of two octaves, this requires all frequency components above 4 KHz to be completely attenuated.

For samples that you don't intend to pitch-shift, e.g. drum samples, you may actually want to keep the high frequency components in your input sample. This parameter allows that by amplifying the high frequency components in your sample by the exact amount that they would be attenuated before encoding. By default this parameter is disabled.

Factory Session

CosmicGem has provided the factory session for download. You can use this as a template when creating your own sample sessions.

Operation from Windows

Please note that Windows currently only allows a single application to access a MIDI device at a time. For example, if you are accessing Super MIDI Pak from the web application, you will not be able to use it from another Windows application. This is not a limitation of Super MIDI Pak, it is a limitation of Windows. Oftentimes you must quit the application using the device completely to free it, e.g. if Chrome has claimed the device you must quit Chrome entirely to allow your DAW to claim the device afterwards.

The simplest workaround is to use the Web App MIDI Input feature of the web app. Set the "Web App MIDI Input Port" to the output port of your DAW and then set the "MIDI Output Port" in the web app to the port that corresponds to Super MIDI Pak. This makes it so that only your browser is accessing the Super MIDI Pak device and your DAW is interacting with your browser.

Another possible workaround is to use the loopMIDI application to create a virtual MIDI port for each application that you plan to use concurrently with Super MIDI Pak. CosmicGem has provided a guide on how to use loopMIDI to workaround this limitation on Windows.

Echo System

The echo system is modified by the EON, FLG, EVOLL, EVOLR, ESA, EDL, EFB, FIR0, FIR1, FIR2, FIR3, FIR4, FIR5, FIR6, and FIR7 registers. Here is a quick map of how they are all interrelated (source):

          ________                        _____                   _____
  c0 --->| ADD    |                      |MVOLc| Master Volume   |     |
  c1 --->| Output |--------------------->| MUL |---------------->|     |
  c2 --->| Mixing |                      |_____|                 |     |
  c3 --->|        |                       _____                  | ADD |--> c
  c4 --->|        |                      |EVOLc| Echo Volume     |     |
  c5 --->|        |   Feedback   .------>| MUL |---------------->|     |
  c6 --->|        |   Volume     |       |_____|                 |_____|
  c7 --->|________|    _____     |                      _________________
                      | EFB |    |                     |                 |
     EON  ________    | MUL |<---+---------------------|   Add FIR Sum   |
  c0 -:->|        |   |_____|                          |_________________|
  c1 -:->|        |      |                              _|_|_|_|_|_|_|_|_
  c2 -:->|        |      |                             |   MUL FIR7..0   |
  c3 -:->|        |      |         ESA=Addr, EDL=Len   |_7_6_5_4_3_2_1_0_|
  c4 -:->| ADD    |    __V__  FLG   _______________     _|_|_|_|_|_|_|_|_
  c5 -:->| Echo   |   |     | ECEN | Echo Buffer c |   | FIR Buffer c    |
  c6 -:->| Mixing |-->| ADD |--:-->|   RAM         |-->| (Hardware regs) |
  c7 -:->|________|   |_____|      |_______________|   |_________________|
                                   Newest --> Oldest    Newest --> Oldest
    

Super MIDI Pak does not interfere with these registers except in a couple of cases. CC#102 will cause Super MIDI Pak to automatically modify EON to enable/disable echo on voices triggered by the channel. Super MIDI Pak will also not allow ESA/EDL to overlap the first 256 bytes of the SPC700 memory. Any writes to those registers that would cause the echo buffer to overlap that memory space are undefined.

It is up to the user to select their desired echo parameters. A common echo setting to get started is:

Drum Kit Mode

In Drum Kit Mode, Super MIDI Pak will choose the sample to play based on a direct mapping from note played to sample number. In this mode all program settings are ignored.

This mode can be used to create custom mappings from keys to samples. Potential applications include:

See the section on Drum Kit Mode Switch NRPN#0 for more information on how to use this mode.

Test Mode

Super MIDI Pak includes a basic test mode that allows you to trigger notes with your SNES/SFC control pad. This mode is primarily intended for testing but can be used for performances as well.

To access this mode, hold down start and press the right shoulder button. This activates the menu. In the menu, select "Test Mode." Please note that while test mode is activated, the behavior of Super MIDI Pak in response to MIDI events coming in on channel 0 is undefined.

Basic Controls

In test mode, each d-pad direction and the four front-facing buttons, A, B, X, and Y map to a specific degree in a predefined scale. The mapping from button to scale degree was chosen to maximize the ease of playing the triads of the scale. The mapping is as follows:

Button Scale Degree C Major (example)
X1C
Down2D
Up3E
Y4F
A5G
Right6A
Left7B
B8C

Playing Accidentals

To pitch shift the currently playing notes up by a half step hold the left shoulder button. To pitch shift downward by a half step, hold the right shoulder button.

Changing Scales

To scroll through different scales, hold select and press either the X button or Y button.

Changing Key

To scroll through different keys, hold select and press either the left or right shoulder buttons.

Control Pad Keycombos

The following keycombos are permitted when Super MIDI Pak is at the title screen. They are designed to be easy to trigger even when no video output is connected to the system. They are also designed to be unlikely to be triggered accidentally, i.e. each keycombo requires a front-facing button to be held while pressing the Left and/or Right shoulder buttons.

Reset Unit to Factory Settings

Hold Select, Press Left Shoulder + Right Shoulder.

This clears the synth state that was saved with Save Settings #9 so that it powers on with default factory state. It also loads the default factory state.

Load Factory Settings

Hold Up, Press Left Shoulder + Right Shoulder.

This puts Super MIDI Pak into the default factory state but does not modify the settings that were saved with Save Settings #9.

Load Saved Settings

Hold Down, Press Left Shoulder + Right Shoulder.

This puts Super MIDI Pak into the exact state that was saved with Save Settings #9.

Increment Device ID

Hold Left, Press Right Shoulder.

This increments the device ID. Device ID dictates which SysEx messages the unit accepts and responds to. It is not recommended to change this except in advanced use cases.

Decrement Device ID

Hold Left, Press Left Shoulder.

This decrements the device ID. Device ID dictates which SysEx messages the unit accepts and responds to. It is not recommended to change this except in advanced use cases.

Reset Device ID

Hold Left, Press Left Shoulder + Right Shoulder.

This resets the device ID to 0. Device ID dictates which SysEx messages the unit accepts and responds to. It is not recommended to change this except in advanced use cases.

Increment Basic Channel

Hold Right, Press Right Shoulder.

This increments the basic channel. Basic Channel dictates which MIDI messages the unit accepts when omni mode is off. It is not recommended to change this except in advanced use cases.

Decrement Basic Channel

Hold Right, Press Left Shoulder.

This increments the basic channel. Basic Channel dictates which MIDI messages the unit accepts when omni mode is off. It is not recommended to change this except in advanced use cases.

Reset Basic Channel

Hold Right, Press Left Shoulder + Right Shoulder.

This resets the basic channel to channel 1, which is the first MIDI channel. Basic Channel dictates which MIDI messages the unit accepts when omni mode is off. It is not recommended to change this except in advanced use cases.

Controller Reference

Channel Voice Controllers

Vibrato CC#1

This CC controls the amplitude of the vibrato. At max value (127) the vibrato shifts the pitch by +-50 cents, with a total swing of 100 cents, i.e. 1 semitone. At min value, no vibrato can be detected. It works on a linear scale, i.e. at a value of 64, the vibrato shifts the pitch by +- 25 cents.

Portamento Time CC#5

This value multiplied by 128 and added to Portamento Time Fine CC#37 makes up the duration in milliseconds of a portamento note transition.

Data Entry MSB CC#6

This value multiplied by 128 and added to Data Entry LSB CC#38 make up the value to be set for the parameter specified by RPN LSB CC#100 and RPN MSB CC#101. See RPN Reference for more information.

Volume CC#7

At max value (127), no attenuation occurs, i.e. the channel is at max volume. The min value (0) is special, infinite attenuation occurs, i.e. the channel is silenced. The power of the signal is attenuated according to this equation: dB = 40 * log(volume / 127).

Pan CC#10

Pan maintains constant signal power. Min value (0) shifts all output to the left channel, max value (127) shifts all output to the right channel.

This setting only takes effect if CC#89 is disabled.

Expression CC#11

At max value (127), no attenuation occurs. The min value (0) is special, infinite attenuation occurs, i.e. the channel is silenced. The power of the signal is attenuated according to this equation: dB = 40 * log(expression / 127).

Left Balance CC#12

Left/Right Balance CCs are an alternative to using Pan CC#10. These CCs map more naturally to the DSP voice registers VOLL and VOLR, giving the musician greater control over left/right levels. In particular, this allows musicians to access negative amplitudes. The exact mapping to VOLL is as follows:

VOLL = ((Value * 2) - 128 + (Value_Fine >> 6)) * Volume_Velocity_Expression_Scalar

When all of volume, expression, and velocity are at their max value (127), then no scaling is done, i.e. Volume_Velocity_Expression_Scalar = 1.

A value of 64 results in silence, while min value (0) is maximum negative amplitude and max value (127) is maximum positive amplitude.

This setting only takes effect if CC#89 is enabled.

Right Balance CC#13

This CC functions similarly to Left Balance CC#12 except it applies to the DSP voice register VOLR.

This setting only takes effect if CC#89 is enabled.

Portamento Time Fine CC#37

Portamento Time CC#5 multiplied by 128 then added to this value makes up the duration in milliseconds of a portamento note transition.

Data Entry LSB CC#38

This value added to to 128 multiplied by Data Entry MSB CC#6 make up the value to be set for the parameter specified by RPN LSB CC#100 and RPN MSB CC#101. See RPN Reference for more information.

Left Balance Fine CC#44

This CC fine tunes Left Balance. In practice when it is >= 64 then 1 will be added to the scaled value set in VOLL when a note is triggered. See Left Balance CC#12 for more info.

This setting only takes effect if CC#89 is enabled.

Right Balance Fine CC#45

This is the same as Left Balance Fine CC#44 except it applies to the right audio channel.

This setting only takes effect if CC#89 is enabled.

Sustain Pedal CC#64

When this value is >= 64, sustain is active. That means that notes that are turned off while sustain is active are left on. When this value < 64, sustain is off.

Portamento Pedal CC#65

When this value is >= 64, portamento is enabled. This means that notes played legato will transition in a portamento fashion. When this value < 64, portamento is disabled.

Sostenuto Pedal CC#66

When this value becomes >= 64, sostenuto is activated. This means that all notes that are currently held will continue to be held once released. When this value becomes < 64, then all notes that were held due to sostenuto will be released.

Legato Pedal CC#68

When this value is >= 64, new notes will take over the last played still active note in a legato fashion. When this value is < 64, new notes are played according to the current poly or mono mode.

Note that notes played in a legato fashion will transition to the new pitch using portamento if it is enabled.

This pedal is primarily for live performance in polyphonic mode. It gives the musician the ability to temporarily play new notes in a legato fashion.

Vibrato Rate CC#76

At min value (0) vibrato oscillates at 1Hz, at mid value (64) the vibrato oscillates at 6.5Hz, at max value (127) vibrato oscillates at 15Hz. This CC is on logarithmic scale.

Attack Time CC#81

This CC chooses the attack time that the channel will use. At the min value (0), attack lasts for 0 milliseconds, at max value (127) attack lasts 4.1 seconds.

This setting only takes effect if CC#83 is enabled.

Decay Time CC#82

This CC chooses the decay time that the channel will use. At the min value (0), decay lasts for 37 milliseconds, at max value (127) decay lasts 1.2 seconds.

This setting only takes effect if CC#83 is enabled.

Use Channel Synth Parameters CC#83

When the value of this CC is >= 64 then the this channel will use CC#81, CC#82, CC#85, CC#86, NRPN#1, NRPN#2, and NRPN#3 for the Volume ADSR and Pitch AD settings, respectively. When the value of this CC < 64, then it will use the Volume ADSR and Pitch AD settings that are bundled with the current program.

Set this CC to >= 64 when you want to interactively design how a patch should sound.

Portamento Control CC#84

This CC specifies from which note the portamento should shift. It only applies to the next "Note On" message received on this channel and is reset afterward.

This has the extra effect that if a currently sounding voice is playing the note specified by this CC, then the new note will trigger without re-attacking in a legato fashion, even in polyphonic mode without the legato pedal enabled. This gives the player extra control over which currently sounding voice is used for a legato transition instead of just the most recently played voice.

Sustain Time CC#85

This CC chooses the sustain time that the channel will use. At the min value (0), sustain lasts for 18ms, at max value (127) sustain lasts forever.

This setting only takes effect if CC#83 is enabled.

Sustain Level CC#86

This CC chooses the sustain level that the channel will use. At the min value (0), the sustain level is 1/8 of the max envelope amplitude, at max value (127) the sustain level is the same as the max envelope amplitude.

This setting only takes effect if CC#83 is enabled.

Noise Frequency Slider CC#87

Noise frequency is typically controlled by the FLG register but the bits of that register are shared with other functions. This CC makes changes only the noise frequency bits of that register, making it convenient for using with a physical knob.

Use Left/Right Balance Pedal CC#89

This pedal decides whether to set relative left/right audio channels using the Pan CC or the Left/Right balance CCs. When it is <64 the Pan CC will be used to control left/right audio levels, when it is >=64 the Left/Right balance CCs will be used.

Echo Delay (EDL) CC#90

EDL is a 4-bit value while MIDI CCs are 7-bit values, This CC maps the CC range of values to the EDL range. Specifically EDL will take on the value of this CC shifted to the right by 3 bits. This makes it convenient to modify echo delay from a physical knob. If you decrease EDL you must wait 300ms before increasing ESA, otherwise the write to ESA results in undefined behavior. Setting EDL to a value that would result in the first 256 bytes of SPC memory being overwritten is undefined.

NRPN LSB CC#98

This sets the LSB of the NRPN that is affected by Data Entry MSB CC#6, and Data Entry LSB CC#38. See NRPN Reference for more information.

NRPN MSB CC#99

This sets the MSB of the NRPN that is affected by Data Entry MSB CC#6, and Data Entry LSB CC#38. See NRPN Reference for more information.

RPN LSB CC#100

This sets the LSB of the RPN that is affected by Data Entry MSB CC#6, and Data Entry LSB CC#38. See RPN Reference for more information.

RPN MSB CC#101

This sets the MSB of the RPN that is affected by Data Entry MSB CC#6, and Data Entry LSB CC#38. See RPN Reference for more information.

Echo Pedal CC#102

When this value is >= 64, all notes played on this channel will be echoed. When this value < 64, all notes will not be echoed.

Noise Pedal CC#103

When this value is >= 64, all notes played on this channel will instead use the SPC700's white noise generation with no correspondence to the specific note played. When this value < 64, all notes will play as normal.

DSP Register Controllers

Super MIDI Pak maps all of the SPC700 DSP registers to MIDI CCs. This enables directly programming the SPC700 DSP without any interference from Super MIDI Pak's MIDI functionality. When MIDI running status is used, this allows a max throughput of approximately 1500 register writes per second.

Because the maximum number of data bits allowed by MIDI is 7 and all the SPC700 DSP registers are 8 bits wide, two MIDI CCs are allocated per register. The first CC multiplies the MIDI value by two and stores that as the register value. The second CC multiplies the MIDI value by two then adds one and stores that as the register value:

    Register = MIDI_CC_Value * 2
    if (is_second_cc) {
        Register = Register + 1
    }
    

The result of writing to these registers is out of the scope of this manual. Please consult an SNES/SFC programming guide to understand how modifying these registers affects sound production. One useful reference is the SFC Development Wiki.

Voice Registers

Each voice register can be written to by sending the corresponding CC to the channel that corresponds to the sum of the basic channel and the desired voice. For example, if the basic channel is channel 1 and you want to modify the register of the 2nd voice, then send the corresponding CC to channel 2.

Sending voice register CCs to channels past the 8th channel, starting at the basic channel, is undefined.

Channel Mode Messages

Reset All Controllers CC#121

This CC is primarily used to reset the state of all performance controllers and pedals of the channel. It is not intended as a way to reset the synth to a default state. It's useful after abruptly stopping a sequencer. Specifically for Super MIDI Pak it resets:

All Notes Off CC#123

This CC immediately sets all voices to the release stage of the envelope, exactly as if a "Note Off" message had been received for that voice. If sustain or sostenuto is active for that voice, the voice is held in sustain.

Omni Mode Off CC#124

By default Super MIDI Pak listens and reponds to messages on all 16 MIDI channels. To only listen to MIDI messages on the basic channel (often channel 1, the first channel), send this CC. In mono mode, it will listen to as many channels as requested, starting from the basic channel. Per the MIDI standard, this message causes an implicit "All Notes Off" command.

Omni Mode On CC#125

To get Super MIDI Pak back into a state where it listens to messages on all channels, send this CC. Per the MIDI standard, this message causes an implicit "All Notes Off" command.

Mono Mode On CC#126

By default Super MIDI Pak is in polyphonic mode. This means that multiple voices can play simultaneously. When in mono mode polyphony is restricted but exact operation depends on whether omni mode is enabled or not.

When omni mode is enabled, only a single voice can play simultaneously across all channels.

When omni mode is disabled, multiple channels are enabled and each channel is mapped to a voice. All channels are monophonic on their own but can play their respective voices in tandem. This mode is primarily intended for use with specific MIDI controllers, for example a guitar controller. In that example, each guitar string would be mapped to a different channel and only trigger at most once voice per channel.

The control value sent by this CC message, known as M, tells Super MIDI Pak how many channels will be active while in this mode and omni mode is disabled, starting at the basic channel (often channel 1, the first channel). The value of 0 is special and signals to activate as many channels as there are voices, which for Super MIDI pak is 8. Setting M to a value larger than 8 is undefined. Sending MIDI messages to channels past the Mth channel, starting at the basic channel, is undefined.

Mono mode results in legato transition between notes by default, as long as the consecutive "note on" is sent before the "note off" for the preceding note.

Per the MIDI standard, this message causes an implicit "All Notes Off" command.

Poly Mode On CC#127

This CC puts Super MIDI Pak back into default polyphonic state. Per the MIDI standard, this message causes an implicit "All Notes Off" command.

RPN Reference

RPNs are a standard way of specifying a large amount of synth parameters beyond what is possible using CC messages. They require multiple CC messages which make them slower than CCs.

To send an RPN you must first send the MSB of the specific RPN to CC#101, then the corresponding LSB to CC#100. Then send the MSB of the desired RPN value to CC#6, then the LSB of the desired RPN value to CC#38.

Pitch Bend Sensitivity RPN#0

To access this RPN, send 0 to CC#101 and then 0 to CC#100.

Behaves the same as in the MIDI standard. For example, a data entry value of MSB=01 LSB=00 results in a pitch bend range of +/- one semitone (a total range of two semitones) for the channel.

Fine Tuning RPN#1

To access this RPN, send 0 to CC#101 and then 1 to CC#100.

Behaves the same as in the MIDI standard. More precisely, the MSB and LSB of the data entry value result in pitch shifting the channel by ((128 * MSB + LSB) - 8192) / 8192 semitones. For example, if MSB=65 and LSB=00, the channel is shifted by (65 * 128 - 8192) / 8192 = 0.015625 semitones, which is 0.015625 * 100 = 1.5625 cents.

Course Tuning RPN#2

To access this RPN, send 0 to CC#101 and then 2 to CC#100.

Behaves the same as in the MIDI standard. More precisely, the MSB of the data entry value results in pitch shifting the channel by MSB - 64 semitones, LSB is ignored. For example, if MSB=65, the channel is shifted by 65 - 64 = 1 semitone.

NRPN Reference

NRPNs are a standard way of specifying a large amount of propritary synth parameters beyond what is possible using CC messages. They require multiple CC messages which make them slower than CCs.

To send an NRPN you must first send the MSB of the specific NRPN to CC#99, then the corresponding LSB to CC#98. Then send the MSB of the desired NRPN value to CC#6, then the LSB of the desired NRPN value to CC#38.

Drum Kit Mode Switch NRPN#0

To access this NRPN, send 0 to CC#99 and then 0 to CC#98.

To enable Drum Kit Mode send a value of >= 8192 (MSB >= 64, LSB can be anything). When Drum Kit Mode is enabled, current Bank and Program settings are ignored, instead the sample played is 128 plus the MIDI value of the note triggered. E.g. when middle C is triggered (60), sample 188 in the sample directory is used.

Pitch Attack Time NRPN#1

To access this NRPN, send 0 to CC#99 and then 1 to CC#98.

This controls the amount of time that the attack phase of the pitch envelope takes to reach the max amount (chosen by Pitch Envelope Amount NRPN#3). At min value (0) the attack phase is 46.875ms, at max value (16383) the attack phase is 12 seconds. The CC is on a logarithmic scale.

This setting only takes effect if CC#83 is enabled.

Pitch Decay Time NRPN#2

To access this NRPN, send 0 to CC#99 and then 2 to CC#98.

This controls the amount of time that the decay phase of the pitch envelope takes to reach zero from the max amount (chosen by Pitch Envelope Amount NRPN#3). At min value (0) the decay phase is 46.875ms, at max value (16383) the decay phase is 12 seconds. The CC is on a logarithmic scale.

This setting only takes effect if CC#83 is enabled.

Pitch Envelope Amount NRPN#3

To access this NRPN, send 0 to CC#99 and then 3 to CC#98.

This is the max amount that the pitch of a new note is shifted by the pitch envelope when it is triggered. A value of 8192 results in no shifting. A value of 16383 results in a max shift upward by 31.5 semitones, a value of 0 results in a max shift downward by 32 semitones.

This setting only takes effect if CC#83 is enabled.

Set Unavailable Voices NRPN#4

To access this NRPN, send 0 to CC#99 and then 4 to CC#98.

You can prevent the channel from using specific voices at "note on" with this NRPN. The format is a bitmask, when the corresponding bit is 1 that voice can not be used, when that bit is 0 then that voice can be used. E.g. if you send the value 255 (11111111 in binary) to this NRPN, that will prevent "note on" events from using any voices. If you send the value 0 to this NRPN, that will allow "note on" events to use any voice for this channel. If you send the value 165 (10100101 in binary), that will prevent the channel from using voices 0, 2, 5, and 7.

The default value is 0, that means the channel will be able to make use of any voice.

This NRPN is useful when you need more fine-grain control over how Super MIDI Pak allocates voices. This is particularly useful when composing music that will be converted into an SPC file.

MIDI Tuning SysEx Reference

Super MIDI Pak supports a subset of the MIDI Tuning standard which allows custom "microtunings" (user-defined scales other than the 12-tone equal temperament).

Single Note Tuning Change #2

This is a "real-time" SysEx message that specifies new frequencies for the specified MIDI notes. It takes place immediately. The format of this SysEx is as follows:

F0 7F <device ID> 08 02 00 ll [kk xx yy zz] ... F7

F0 7F Universal Real Time SysEx header
<device ID> ID of target device, usually 0
08 02 MIDI Tuning Standard, Single Note Tuning Change code
00 Tuning program number, must be 0
ll number of changes (1 change = 1 set of [kk xx yy zz])
kk MIDI key number
xx yy zz New frequency, format described below
F7 SysEx footer (EOX)

Frequency Format

Frequencies are specified in terms of fractional semitones, where xx=69 yy=00 zz=00 corresponds to A440. Given a target frequency of f, the expressions to compute xx yy zz are as below:

s = 12 * log(f / 440) / log(2) + 69
xx = floor(s)
yy = floor(s * 2 ^ 7) % (2 ^ 7)
zz = floor(s * 2 ^ 14) % (2 ^ 7)

SysEx Reference

Reset Complete #1

This SysEx is sent by Super MIDI Pak after it has finished initializing when it is powered on or reset. The format is as follows:

F0 00 02 3E <device ID> 00 01 F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
01 Reset Complete SysEx code
F7 SysEx footer (EOX)

Handshake #3

Handshake packets are intended to be used with long-running SysExs that require the user to pause sending MIDI events until a handshake SysEx is received over the ouput MIDI port, or predefined amount of time passes. This SysEx is generally received from Super MIDI Pak rather than sent to it.

The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 03 tt <packet index> F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
03 Handshake SysEx code
tt Handshake code
<packet index> Packet index from the initiating SysEx
F7 SysEx footer (EOX)

The different handshake codes and their meanings are summarized below:

Name Code Meaning
ACK 7F Returned when the initiating SysEx completed successfully.
NAK 7E Returned when the data of the initiating SysEx was corrupted. User should resend initiating packet.
CANCEL 7D Returned when the initiating SysEx was incorrect, this usually indicates an erroneous client program. Resending will not fix the issue.
WAIT 7C Returned when the initiating SysEx may take longer than the predefined time to complete. User must wait for a subsequent ACK, NAK, CANCEL, or FAILURE Handshake SysEx.
FAILURE 7B Returned when the unit encountered an error while trying to complete the SysEx. Retrying may or may not solve the problem.

SPC Jump #6

This SysEx suspends normal operation of Super MIDI Pak and instructs the SPC to start executing code at the specified address. Before the SPC executes code, the specified values are written to the APU0{0,1,2,3} registers on the CPU side. Once any new MIDI message is received the custom SPC program will halt and operation will continue as normal. Note that Super MIDI Pak will not modify any SPC state once normal operation is resumed, allowing the user to make use of the leftover state, e.g. with DSP Jam Mode.

This SysEx is primarily intended to make it easy for users to run their own custom programs on the SPC. In particular it makes it easy to run existing SPC music files on Super MIDI Pak.

The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 06 aa bb cc dd ee ff gg F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
06 SPC Jump SysEx code
aa bb cc dd ee ff gg 7-bit encoding of [ ADDR_LOW, ADDR_HIGH, APU00, APU01, APU02, APU03 ]
F7 SysEx footer (EOX)

Save Settings #9

This SysEx causes Super MIDI Pak to save the current settings to internal memory. Please note that these settings will be loaded whenever the unit is powered on or reset. The settings include all channel settings, program settings, DSP registers, and SPC memory. The end result is that Super MIDI Pak will respond identically to MIDI messages when these settings are reloaded as when they were saved.

This SysEx is useful for when you are performing live or touring with Super MIDI Pak and need to minimize setup time.

This is a long-running SysEx. Do not send any MIDI messages after sending this SysEx until a Handshake message is received with the corresponding packet index. The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 09 <packet index> F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
09 Save Settings SysEx code
<packet index> Packet index
F7 SysEx footer (EOX)

Load Saved Settings #10

This is the SysEx equivalent of the Load Saved Settings control pad keycombo. Unlike the control pad keycombo, the device ID is not altered. This is a long-running SysEx. Do not send any MIDI messages after sending this SysEx until a Handshake message is received with the corresponding packet index. The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 0A <packet index> 00 F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
0A Load Saved Settings SysEx code
<packet index> Packet index
00 Reserved, must be set to 0
F7 SysEx footer (EOX)

Set Basic Channel #11

This SysEx allows the user to change the basic channel of the unit. The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 0B <basic channel> F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
0B Set Basic Channel SysEx code
<basic channel> Desired basic channel of the unit. Operation is undefined if this is not in range of 0 to 15, inclusive.
F7 SysEx footer (EOX)

DSP Jam Mode Switch #14

This SysEx allows the user to prevent Super MIDI Pak from modifying any register aside from KON, KOFF, and P when handling the "Note On" MIDI Message. This is useful when wanting to jam off the leftover state of a custom SPC program that was run using SPC Jump #6. In practice it often makes sense to additionally disable omni mode and enable mono mode.

The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 0D <enable DSP Jam Mode> F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
0D DSP Jam Mode Switch SysEx code
<enable DSP Jam Mode> If this value is >= 64 then DSP Jam Mode will be enabled, it will be disabled otherwise
F7 SysEx footer (EOX)

Write SPC Memory #15

This SysEx allows the user to write to the memory of the SPC700. This is primarily intended for the user to upload custom samples but may also be used to upload custom programs to the SPC700, which can be run using the SPC Jump #6 SysEx.

Once the user sends this SysEx, they should not send any more MIDI events until either a Handshake SysEx is received on the output MIDI port or 100ms have passed. Doing otherwise will result in undefined behavior.

This SysEx can be used in either a "closed-loop" or "open-loop" configuration. An open-loop configuration is when the MIDI client is ignoring the output MIDI port of the Super MIDI Pak. In that case, the client should wait at least 100ms before sending subsequent MIDI events. This allows the user to include these SysExs in ".mid" files that can be played into the synth by a dumb player.

This SysEx can be sent while the synthesizer is normally operating. If timed correctly, this allows the user to dynamically swap out samples during a live performance.

All memory can be written except for the first 256 bytes of memory. Writes to that region are undefined.

The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 0F ii ll hh ss [ dd ] ... cc F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
0F Write SPC Memory SysEx code
ii (SPC_TARGET_ADDRESS & 0x3) << 5) | PACKET_IDX
ll (SPC_TARGET_ADDRESS >> 2) & 0x7f
hh (SPC_TARGET_ADDRESS >> 9) & 0x7f
ss Number of pre-encoded data bytes minus 1
dd A data byte, there will be ceil((ss + 1) * 8 / 7) of them.
cc XOR checksum of all preceding bytes, not included initial 0xF0
F7 SysEx footer (EOX)

If the checksum does not match, Super MIDI Pak will send a NAK Handshake SysEx back over the MIDI output port. Nothing will have been written. If it does match, Super MIDI Pak will send an ACK Handshake SysEx back. If Super MIDI Pak needs more time to process the data packet, it will return a WAIT Handshake SysEx. In this case, the user should not send any more data even if 100ms passes. The user should wait for an ACK or NAK Handshake.

7-bit Data Encoding

Since the data bytes cannot have their high bit set, a conversion must happen to the source data before being transmitted over MIDI. A simple 7-bit encoding algorithm is used, For every group of 7 input bytes, the bottom bits are shifted out and are used to make up the bits of a "header" byte from the least significant bit to the most significant bit. Python-like pseudocode to do the encoding is presented below:

buffer = []
header_byte = 0
while True:
  input_byte = read_byte()
  if input_byte is None: # no more data to encode
    break

  header_byte = ((input_byte & 0x1) << 6) | (header_byte >> 1)
  buffer.append(input_byte >> 1)

  if len(buffer) == 7:
    write_byte(header_byte)
    for byt in buffer:
      write_byte(byt)
    buffer = []
    header_byte = 0

# write out left over data
if buffer:
  write_byte(header_byte >> (7 - len(buffer)))
  for byt in buffer:
    write_byte(byt)
      

For example, consider the following group of 7 bytes:

aaaaaaaA bbbbbbbB cccccccC dddddddD eeeeeeeE fffffffF gggggggG

You would send that over the MIDI interface as:

0GFEDCBA 0aaaaaaa 0bbbbbbb 0ccccccc 0ddddddd 0eeeeeee 0fffffff 0ggggggg

Set Sample Root Pitch #16, #17

This SysEx allows the user to set the root pitch associated with a sample. The root pitch is the fundamental pitch of the sample when it is played at normal rate, i.e. 32000Hz. This information enables Super MIDI Pak to set the correct pitch when a note is triggered with the "Note On" MIDI Message.

Since the DSP allows for 256 samples but only 128 different values can be selected with a MIDI byte, two SysEx codes are allocated to this function. The code 0x10 (16 in decimal) modifies the root pitch for samples 0-127 and the code 0x11 (17 in decimal) modifies the root pitch for samples 128-255.

The pitch format is the same as in the Single Note Tuning Change #2 SysEx. The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 <sysex code> <sample index> xx yy zz F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
<sysex code> Set Sample Root Pitch SysEx code. Use 0x10 for lower 128 samples, 0x11 for upper 128 samples.
<sample index> Sample index. Added to 128 if SysEx code is 0x11.
xx yy zz Desired root pitch, in MIDI Tuning Standard format
F7 SysEx footer (EOX)

Load Factory Settings #18

This is the SysEx equivalent of the Load Factory Settings control pad keycombo. Unlike the control pad keycombo, the device ID is not altered. It puts Super MIDI Pak into default factory state but it does not modify the settings that were saved with Save Settings #9. This is a long-running SysEx. Do not send any MIDI messages after sending this SysEx until a Handshake message is received with the corresponding packet index. The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 12 <packet index> 00 F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
12 Load Factory Settings SysEx code
<packet index> Packet index
00 Reserved, must be set to 0
F7 SysEx footer (EOX)

Set Sample Volume ADSR #19, #20

This SysEx allows the user to change the default volume ADSR settings associated with a sample. These settings are used whenever the the channel is configured to use the sample synth parameters instead of the channel synth parameters.

Since the DSP allows for 256 samples but only 128 different values can be selected with a MIDI byte, two SysEx codes are allocated to this function. The code 0x13 (19 in decimal) modifies the volume ADSR settings for samples 0-127 and the code 0x14 (20 in decimal) modifies the volume ADSR settings for samples 128-255.

The meaning of the values used correspond exactly to the values used in CC#81, CC#82, CC#85, and CC#86. The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 <sysex code> <sample index> aa dd ll ss F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
<sysex code> Set Sample Volume ADSR SysEx code. Use 0x13 for lower 128 samples, 0x14 for upper 128 samples.
<sample index> Sample index. Added to 128 if SysEx code is 0x14.
aa Attack time value, same meaning as in CC#81.
dd Decay time value, same meaning as in CC#81.
ll Sustain level value, same meaning as in CC#86.
ss Sustain time value, same meaning as in CC#85.
F7 SysEx footer (EOX)

Set Sample Pitch AD #21, #22

This SysEx allows the user to change the default pitch AD settings associated with a sample. These settings are used whenever the the channel is configured to use the sample synth parameters instead of the channel synth parameters.

Since the DSP allows for 256 samples but only 128 different values can be selected with a MIDI byte, two SysEx codes are allocated to this function. The code 0x13 (19 in decimal) modifies the volume ADSR settings for samples 0-127 and the code 0x14 (20 in decimal) modifies the volume ADSR settings for samples 128-255.

The meaning of the values used correspond exactly to the MSB values used in NRPN#1, NRPN#2, and NRPN#3. The format of this SysEx is as follows:

F0 00 02 3E <device ID> 00 <sysex code> <sample index> aa dd mm 00 00 F7

F0 00 02 3E SysEx header
<device ID> ID of target device, usually 0
00 Product ID
<sysex code> Set Sample Pitch AD SysEx code. Use 0x15 for lower 128 samples, 0x16 for upper 128 samples.
<sample index> Sample index. Added to 128 if SysEx code is 0x14.
aa Attack time value, same meaning as MSB in NRPN#1.
dd Decay time value, same meaning as MSB in NRPN#2.
mm Envelope amount value, same meaning as MSB in NRPN#3.
00 00 Reserved bytes, must be 0
F7 SysEx footer (EOX)

Troubleshooting

Super MIDI Pak Doesn't Show up in Web Application

You should only expect to see "Super MIDI Pak" as an option for the MIDI input and output ports in the web application if you have it connected to your computer over USB. If you are connecting it over an auxiliary MIDI interface, then the name of your interface should show up as an option in the input / output ports.

If you don't see "Super MIDI Pak" as an option for the MIDI input and output ports in the web application after plugging it in over USB, there are a couple of potential reasons why. Either the USB connection is bad or, if you are on Windows, then another application has already claimed the device.

Many USB Micro-B cables are charging-only cables so if your computer is not detecting Super MIDI Pak this is the most likely reason. It's also possible that a normal cable is too low quality. Try a high quality USB cable that you know is intended to carry data.

Timeout Error in Web App

Timeout errors occur when your MIDI input and output ports in the web application are configured incorrectly. The input and output ports must point to the MIDI interface over which your Super MIDI Pak is connected.

If both options are set to "Super MIDI Pak" and you are still seeing timeout errors, it's been reported that a few PC USB ports don' behave correctly with Super MIDI Pak. In that case, select the "Use without input port" option for the input port and try again.

Copyright © 2022 Cejetvole, LLC