XFORMER is a fork of the Phazerville PER|FORMER firmware with XFORMER-specific track types and sequencing enhancements. It assumes familiarity with the standard PER|FORMER workflow.
-
Algo Track (inspired by TINRS Tuesday): Generative sequencing with deterministic behavior.
-
Discrete Track (inspired by New Systems Instruments Discrete Map): Threshold-based sequencing mapping inputs to stages.
-
Indexed Track (inspired by Orthogonal Devices ER-101/102): Duration-based sequencing with independent step lengths.
-
T9Type Track (a mildly stripped down version of Monome Teletype: Full TT VM running withing a track, yes you can have 8 T9types running. No USB keyboard support, no I2C, No Grid.
-
Note Circus Track Enhancements: Accumulator (inspired by Intellijel Metropolix). Harmony Engine (inspired by Instruo Harmonaig). Pulse Count,Modes, ReRene and Ikra playmodes
-
Curve Studio Track Enhancements: Global Phase, Wavefolder, Chaos Engine, advanced playback features.
-
Scope View: Monitor page oscilloscope for track CV with optional second track overlay.
-
Routing:
- additional BUS 1-4 routing Targets
- CV/Gate Output Rotation, Run, Reset.
- Advanced Bias/Depth/Shaper system.
- Independent interpolating CV Router (think Vostok Trace
-
XFORMER Manual - Complete guide to XFORMER firmware features
-
TUESDAY Manual - Algo track (generative sequencing) documentation
-
DISCRETE Manual - Discrete track (threshold-based sequencing) guide
-
INDEXED Manual - Indexed track (duration-based sequencing) guide
-
CURVE Studio - Curve track enhancements and features
-
ROUTES - Routing and signal flow documentation
-
Scala (.scl) to .SCA (performer SCA) - conversion script
-
HTML Shapes Visualizer - helper to visualize Curve Studio shapes and routing additions with a sound engine
- Based on the Phazerville fork of the original firmware.
- MIDI support exists for the new tracks; Launchpad support is not fully tested.
- It is important to note that 99,5% of the code was written by musician little helpers, that you can by for couple of dollars a month.
- I have tested it on my unit and it seems that everything that I care about works. The firmware is provided AS IS, I'd appreciate feedback, but not sure if will be able to fix many things.
From Phazerville with Love <3
I'm working to bring this firmware up-to-date, and make myself at home with the UI controls. I've managed to update the toolchain to gcc 14.2, libopencm3 to the latest from October 2024, and the GitHub Actions CI workflow will produce an artifact file with the binaries for every push.
After encountering instability on the mebitek fork, I've decided to start from the known-good master branch of the original firmware, and carefully work in some of the new features from other forks.
| Change | Documentation |
|---|---|
| Noise reduction | docs |
| Shape improvements | docs |
| MIDI improvements | docs |
--- original documentation below ---
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/westlicht/performer.git
After cloning, enter the performer directory:
cd performer
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/westlicht/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
The PEW|FORMER firmware now includes an advanced accumulator feature that provides powerful parameter modulation capabilities:
- Stateful Counter: Increments/decrements based on configurable parameters
- Step-Triggered: Updates when specific sequence steps are triggered
- Multi-Mode Operation: Supports four distinct operational modes
- Real-Time Modulation: Applies modulation to note pitch in real-time
- Wrap: Values wrap from max to min and vice versa
- Pendulum: Bidirectional counting with direction reversal at boundaries
- Random: Generates random values within min/max range when triggered
- Hold: Clamps at min/max boundaries without wrapping
- ACCUM Page: Dedicated parameter editing interface with "ACCUM" header
- ACCST Page: Per-step trigger configuration with "ACCST" header
- Integration: Accessible via existing sequence navigation (Sequence key cycles: NoteSequence → Accumulator → AccumulatorSteps → NoteSequence)
- Enable/Disable control
- Direction (Up, Down, Freeze)
- Order (Wrap, Pendulum, Random, Hold)
- Polarity (Unipolar, Bipolar)
- Value Range (-100 to 100)
- Step Size (1-100)
- Trigger mapping per step
For complete implementation details, see QWEN.md.
A Metropolix-style pulse count feature that allows each step to repeat for a configurable number of clock pulses (1-8) before advancing to the next step.
- Variable Step Duration: Each step can play for 1-8 clock pulses
- Independent Control: Per-step configuration without changing global divisor
- Seamless Integration: Works with all play modes and existing features
- Navigate to STEPS page
- Press Retrigger button (F2) twice to reach "PULSE COUNT" layer
- Select steps with S1-S16 buttons
- Adjust pulse count (1-8) with encoder
- Create polyrhythmic patterns
- Add emphasis to specific steps
- Generate complex timing without changing tempo
- Combine with retrigger for intricate rhythmic structures
Gate mode controls how gates are fired during pulse count repetitions, providing fine-grained rhythmic control.
- A (ALL): Fires gates on every pulse (default)
- 1 (FIRST): Single gate on first pulse only
- H (HOLD): One long continuous gate for entire step duration
- 1L (FIRSTLAST): Gates on first and last pulse only
- Navigate to STEPS page
- Press Gate button (F1) five times to reach "GATE MODE" layer
- Select steps with S1-S16 buttons
- Adjust gate mode with encoder (displays A/1/H/1L)
- Create accent patterns with FIRST mode
- Sustain notes across pulses with HOLD mode
- Generate bouncing rhythms with FIRSTLAST mode
- Mix different gate modes across steps for complex patterns
- Works seamlessly with pulse count feature
- Compatible with retrigger, gate offset, and gate probability
- Backward compatible (default mode maintains existing behavior)
- Fully integrated with all play modes
For complete technical documentation, see CLAUDE.md.
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.
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 gameengine- 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.


