This is a personal fork of the Mebitek fork, itself based on the original Westlicht PER|FORMER firmware.
The Vinx Scorza line begins at v0.3.2-vinx.1. Everything before that point in this repository history and changelog is inherited from the Mebitek fork and kept here as upstream reference. Starting from v0.4.0, this fork uses standalone Vinx semantic versioning (v0.x.y) and no longer carries the inherited v0.3.2-vinx.* prefix. Historical entries remain unchanged as lineage reference.
If you are looking for a more conservative upstream baseline, you may prefer the original Westlicht or Mebitek lines. If you are interested in a more hands-on, performance-oriented evolution of PER|FORMER, you are in the right place. What I'm aiming for is a solid machine for live performance, but also a crazy one for experimenting.
I am very grateful to Simon Kallweit for creating and developing the original Westlicht PER|FORMER. If you would like to support this fork and the upstream work behind it financially, you can donate here:
Donate to Vinx Scorza · Donate to Mebitek · Donate to Simon Kallweit / Westlicht.
Primary documentation for this fork: Vinx Scorza fork website, user manual, LP Cheatsheet, Web Simulator, features — https://vinxscorza.github.io/performer/
Core Sequencing: Stabilized step engines acrossNote/Logic/Curve/Stochastic/Arp, including legacy crash paths, non-zero subrange shifting, CurveGate Offset/Gate Length, restored Curve undo, and scale/midi-capture consistency improvements.Chaos generators:Chaosevolved intoVandalize Sequence+Wreck Patternwith explicitA/Bsafety flow, selection-aware targeting, and machine-level defaults with separate masks.Acid generators:Acidis now consolidated asLayer+Phrase, with immediate preview-on-entry, dedicated visuals, tightened parameter behavior, and aligned ordering/mapping across machine and Launchpad.Random generator:Randomnow runs as a stable preview/apply workflow, controlledVariation, full32-bitseed handling, richer preview rendering, and footer actions that stay in-context.Launchpad: Launchpad is treated as a first-class layer (LP Style/LP Note Style), defaults toBlue + Circuit, supportsClassicandCircuit, includes many regression fixes, and adds splitGenerators Mode(Notefull map;Curve/Stochastic/Logic/Arpsubset withEntropy), plusUndo/Redo, lock policies, overlay stability, and P1 controller refactor.Clock & Sync: External clock behavior was hardened for real hardware (Reset Gate,Reset Pulse, rising-edge-only pulse handling,Reset CVdefaultOff) while keeping backward-compatible timing behavior.Generator UX: Generator families were reorganized with stronger page semantics: open on current bank, playable transport, intentionalResetGen, explicitInit Layer/Init Steps/Init Seqsplit, and safer commit/cancel flow.UI & Display: Generator and step visuals were redesigned for readability (full64-stepcontext + active16-stepbank + playhead), with clearer layer graphics and lower redraw overhead (30 fps, skip unchanged frames).System & Defaults: Settings/save flow was simplified and hardened (Systemsave flow, save prompts,Chaos Defaultspersistence,Menu Wrap, screensaver/wake refinement) with better memory posture versus upstream (SRAM/CCRAMreduction vs lineage firmwares).Simulators: Desktop and Web simulator paths were clarified; Desktop gained configurable DIN/USB MIDI routing, tracing, better Launchpad port/model handling, and firmware-aligned behavior.Documentation: Website, manual, cheatsheet, simulator docs, and ecosystem pages are maintained as a coherent layer aligned to current firmware behavior.
Current validation scope:
- Real hardware testing is still useful for
Reset Pulse/Reset Gate. - Real hardware testing is still useful for
Voltage Modeuser scales inNote,Arp, andStochastic. - Desktop Simulator USB MIDI has been validated well on
macOS / OS XwithLaunchpad Mini MK3, but not yet across other Launchpads or operating systems.
For the broader curated overview, see FEATURES. For the exact technical chronology, including inherited upstream history, see the repository CHANGELOG.
To clone this repository:
git clone https://github.com/VinxScorza/performer.git
cd performerThen follow the standard build instructions for Westlicht Performer below.
--- ORIGINAL WESTLICHT DOCUMENTATION BELOW, WITH VINX ADDITIONS WHERE RELEVANT ---
This repository contains the firmware for the PER|FORMER eurorack sequencer.
For more information on the project go here.
The hardware design files are hosted in a separate repository here.
If you want to do development on the firmware, the following is a quick guide on how to setup the development environment to get you going.
First you have to clone this repository (make sure to add the --recursive option to also clone all the submodules):
git clone --recursive https://github.com/VinxScorza/performer.git
After cloning, enter the performer directory:
cd performer
For STM32 builds, the toolchain file now resolves arm-none-eabi tools in this order:
tools/gcc-arm-none-eabi/bininside this repositoryTOOLCHAIN_ROOT(CMake variable or environment variable, expected to point to the directory containingarm-none-eabi-*)- system
PATH
This keeps clean builds deterministic across machines while still allowing explicit overrides.
Make sure you have a recent version of CMake installed. If you are on Linux, you might also want to install a few other packages. For Debian based systems, use:
sudo apt-get install libtool autoconf cmake libusb-1.0.0-dev libftdi-dev pkg-config
To compile for the hardware and allow flashing firmware you have to install the ARM toolchain and build OpenOCD:
make tools_install
Next, you have to setup the build directories:
make setup_stm32
If you also want to compile/run the simulator use:
make setup_sim
The simulator is great when developing new features. It allows for a faster development cycle and a better debugging experience.
Currently, there is no native support for compiling the firmware on Windows. As a workaround, there is a Vagrantfile to allow setting up a Vagrant virtual machine running Linux for compiling the application.
First you have to clone this repository (make sure to add the --recursive option to also clone all the submodules):
git clone --recursive https://github.com/VinxScorza/performer.git
Next, go to https://www.vagrantup.com/downloads.html and download the latest Vagrant release. Once installed, use the following to setup the Vagrant machine:
cd performer
vagrant up
This will take a while. When finished, you have a virtual machine ready to go. To open a shell, use the following:
vagrant ssh
When logged in, you can follow the development instructions below, everything is now just the same as with a native development environment on macOS or Linux. The only difference is that while you have access to all the source code on your local machine, you use the virtual machine for compiling the source.
To stop the virtual machine, log out of the shell and use:
vagrant halt
You can also remove the virtual machine using:
vagrant destroy
After successfully setting up the development environment you should now have a list of build directories found under build/[stm32|sim]/[release|debug]. The release targets are used for compiling releases (more code optimization, smaller binaries) whereas the debug targets are used for compiling debug releases (less code optimization, larger binaries, better debugging support).
You will typically use the release target when building for the hardware. So you first have to enter the release build directory:
cd build/stm32/release
To compile everything, simply use:
make -j
Using the -j option is generally a good idea as it enables parallel building for faster build times.
To compile individual applications, use the following make targets:
make -j sequencer- Main sequencer applicationmake -j sequencer_standalone- Main sequencer application running without bootloadermake -j bootloader- Bootloadermake -j tester- Hardware tester applicationmake -j tester_standalone- Hardware tester application running without bootloader
Building a target generates a list of files. For example, after building the sequencer application you should find the following files in the src/apps/sequencer directory relative to the build directory:
sequencer- ELF binary (containing debug symbols)sequencer.bin- Raw binarysequencer.hex- Intel HEX file (for flashing)sequencer.srec- Motorola SREC file (for flashing)sequencer.list- List file containing full disassemblysequencer.map- Map file containing section/offset information of each symbolsequencer.size- Size file containing size of each section
If compiling the sequencer, an additional UPDATE.DAT file is generated which can be used for flashing the firmware using the bootloader.
To simplify flashing an application to the hardware during development, each application has an associated flash target. For example, to flash the bootloader followed by the sequencer application use:
make -j flash_bootloader
make -j flash_sequencer
Flashing to the hardware is done using OpenOCD. By default, this expects an Olimex ARM-USB-OCD-H JTAG to be attached to the USB port. You can easily reconfigure this to use a different JTAG by editing the OPENOCD_INTERFACE variable in the src/platform/stm32/CMakeLists.txt file. Make sure to change both occurrences. A list of available interfaces can be found in the tools/openocd/share/openocd/scripts/interface directory (or /home/vagrant/tools/openocd/share/openocd/scripts/interface when running the virtual machine).
Note that the simulator is only supported on macOS and Linux and does not currently run in the virtual machine required on Windows.
You will typically use the debug target when building for the simulator. So you first have to enter the debug build directory:
cd build/sim/debug
To compile everything, simply use:
make -j
To run the simulator, use the following:
./src/apps/sequencer/sequencer
Note that you have to start the simulator from the build directory in order for it to find all the assets.
Desktop simulator MIDI can be configured from the command line. Use ./src/apps/sequencer/sequencer --midi to list available ports, then launch with options such as:
./src/apps/sequencer/sequencer --midi-port "Your MIDI Port"
./src/apps/sequencer/sequencer --midi-in "Your Keyboard In" --midi-out "Your Synth Out"
./src/apps/sequencer/sequencer --usb-midi-port "Your Launchpad Port"
By default, the Desktop Simulator now starts with both DIN MIDI and USB MIDI disabled, so it does not try to open missing macOS MIDI devices unless you explicitly assign them.
Use --trace-midi to inspect incoming simulator MIDI messages and --trace-dio if you want terminal output for the simulated CLK OUT and RESET OUT digital lines.
Use none, off, or - to disable a default input or output assignment, for example:
./src/apps/sequencer/sequencer --midi-out none
On macOS, some devices expose port directions from the device point of view instead of the simulator point of view. For example, a Launchpad Mini MK3 on the simulated USB MIDI port may need:
./src/apps/sequencer/sequencer --usb-midi-in "Launchpad Mini MK3 LPMiniMK3 DAW Out" --usb-midi-out "Launchpad Mini MK3 LPMiniMK3 DAW In"
In the current Vinx setup, the simulator-side USB MIDI workflow has only been validated on macOS / OS X with a Launchpad Mini MK3, since that is the only Launchpad currently available for local testing.
The simulator now also infers the Launchpad model from the selected USB port names, so a Mini MK3 is no longer exposed to the firmware as the old Mini Mk2 default device.
For Launchpad-style USB controllers, the simulator also mirrors both the matching sibling input and output ports (DAW / MIDI) when possible, so pad presses and initialization messages can still land on the endpoint the device actually uses.
The following is a quick overview of the source code directory structure:
src- Top level source directorysrc/apps- Applicationssrc/apps/bootloader- Bootloader applicationsrc/apps/hwconfig- Hardware configuration filessrc/apps/sequencer- Main sequencer applicationsrc/apps/tester- Hardware tester applicationsrc/core- Core library used by both the sequencer and hardware tester applicationsrc/libs- Third party librariessrc/os- Shared OS helperssrc/platform- Platform abstractionssrc/platform/sim- Simulator platformsrc/platform/stm32- STM32 platformsrc/test- Test infrastructuresrc/tests- Unit and integration tests
The two platforms both have a common subdirectories:
drivers- Device driverslibs- Third party librariesos- OS abstraction layertest- Test runners
The main sequencer application has the following structure:
asteroids- Asteroids game (disabled in active builds)engine- Engine responsible for running the sequencer coremodel- Data model storing the live state of the sequencer and many methods to change that statepython- Python bindings for running tests using pythontests- Python based testsui- User interface
The following third party libraries are used in this project.
- FreeRTOS
- libopencm3
- libusbhost
- NanoVG
- FatFs
- stb_sprintf
- stb_image_write
- soloud
- RtMidi
- pybind11
- tinyformat
- args
This work is licensed under a MIT License.
