-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
68 changed files
with
1,979 additions
and
2,107 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -16,38 +16,41 @@ on: | |
- '!shared/gen_minblep' # Skip generator script (still run CI if generated files change) | ||
- '!shared/tableGen' # Skip generator script (still run CI if generated files change) | ||
|
||
jobs: | ||
jobs: | ||
build: | ||
strategy: | ||
matrix: | ||
gcc: ['12.2.Rel1'] # can add other versions if needed | ||
name: "Build firmware" | ||
runs-on: ubuntu-latest | ||
container: ghcr.io/lnnrts/metamodule:latest | ||
steps: | ||
- name: Install Arm GNU Toolchain (arm-none-eabi-gcc) | ||
uses: carlosperate/arm-none-eabi-gcc-action@v1 | ||
with: | ||
release: ${{ matrix.gcc }} | ||
|
||
- name: Install cmake | ||
uses: jwlawson/[email protected] | ||
with: | ||
cmake-version: '3.26.x' | ||
|
||
- name: Checkout | ||
uses: actions/checkout@v3 | ||
uses: actions/checkout@v4 | ||
with: | ||
submodules: 'recursive' | ||
|
||
- name: Install linux dependencies | ||
run: | | ||
sudo apt install -y ninja-build | ||
token: ${{ secrets.CHECKOUT_TOKEN }} | ||
|
||
- name: Build and test | ||
run: cd firmware && make configure && make all | ||
|
||
- name: Upload artifact | ||
uses: actions/upload-artifact@v3 | ||
with: | ||
name: firmware | ||
path: | | ||
firmware/build/mp1corea7/medium/main.elf | ||
firmware/build/mp1corea7/medium/main.uimg | ||
# - name: Upload artifact | ||
# uses: actions/upload-artifact@v3 | ||
# with: | ||
# name: firmware | ||
# path: | | ||
# firmware/build/mp1corea7/medium/main.elf | ||
# firmware/build/mp1corea7/medium/main.uimg | ||
|
||
- name: Release | ||
uses: softprops/action-gh-release@v1 | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
# Firmware Boot Procedure | ||
|
||
The chip's ROM code reads the `BOOT0_2` DIP switch and then: | ||
|
||
- either halts (if it's set to `Debug`) | ||
- or attempts to load a bootloader from the SD Card (if it's set to `SD`) | ||
- or attempts to load a bootloader from the QSPI NOR Flash chip (if it's set to | ||
`Flash`) | ||
|
||
and then starts executing the bootloader. | ||
|
||
The bootloader (which is `mp1-boot`) initializes the DDR RAM and various system | ||
peripherals (security, MMU, clocks). After that it halts if Pin 2 and 4 of the | ||
"Control Expander" (`J102`) are shortened with a jumper. | ||
|
||
Otherwise (no jumper detected), it will check if the rotary encoder is pressed. | ||
If so, it loads an alternative firmware image from whatever media it booted | ||
from (SD or Flash). On the Flash chip, USB-DFU "second-stage bootloader" (SSBL) | ||
is preloaded. The SD card could also have an alternative firmware but this is | ||
not used yet. | ||
|
||
Otherwise (no jumper and rotary not pressed) it loads the firmware image from the | ||
default location on the selected boot media and then starts execution. | ||
|
||
### Secondary A7 core startup | ||
|
||
Both A7 cores startup at the same time, but Core 2 (aka secondary core) will go to | ||
sleep immediately. The first core (primary, aka Core 1) | ||
will proceed with the procedure descrived above. | ||
|
||
The MetaModule firmware awakens the secondary core and tells it to start executing from | ||
the `aux_core_start` assembly code in 'firmware/lib/mdrivlib/target/stm32mp1_ca7/boot/startup_ca7.s` | ||
which does some basic stack setup and then jumps to | ||
the `aux_core_main()` function in `firmware/src/core_a7/aux_core_main.cc`. Here, the | ||
secondary core handles the screen updates and runs the LVGL tasks. It also gets interrupted | ||
by the primary core to help with audio processing. | ||
|
||
|
||
### M4 startup | ||
|
||
The M4 firmware is bundled inside the A7 firmware. After power-on there is no | ||
M4 firmware running (there is no internal flash to store the M4 firmware), so | ||
the M4 core is just sitting idle. The A7 core does some early init and then | ||
loads the M4 firmware and starts that core. | ||
|
||
The M4 firmware is responsible for reading all controls and the gate jacks. It also | ||
handles all USB and SD Card transactions. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,9 +1,92 @@ | ||
If you would like to port your VCV-compatible modules to the Meta Module platform, you will need to follow a few steps for exporting artwork and ensuring binary compatibility. | ||
### Instructions for adding a new module (WIP) | ||
|
||
### Converting assets | ||
1) First step is add the module code as a git submodule: | ||
|
||
(TODO) | ||
```bash | ||
git submodule https://github.com/<user>/<repo> firmware/vcv_ports/<Brand> | ||
``` | ||
|
||
2) Create artwork folders: | ||
|
||
```bash | ||
mkdir -p firmware/src/gui/images/<Brand>/modules/ | ||
mkdir -p firmware/src/gui/images/<Brand>/components/ | ||
``` | ||
|
||
3) Create a modules.cmake file: `firmware/vcv_ports/glue/<Brand>/modules.cmake` | ||
Look at other brands examples and copy what's done there. | ||
|
||
`modules.cmake` must do a few things: | ||
|
||
- Create a list of module names call `<Brand>Modules`. | ||
These names should be the VCV Rack module slugs. Ideally, these names are | ||
also the names of the SVG faceplate files (without the .svg extension) and | ||
also the names of the C++ source files (without the .cpp or .cc extension), | ||
but if that's not the case you will just need to manually specify the SVGs | ||
and source file names manually. | ||
|
||
- Invoke the module list filtering function on the list, like this: | ||
```cmake | ||
include(${CMAKE_CURRENT_LIST_DIR}/../filter.cmake) | ||
limit_modules_built("<Brand>" <Brand>Modules) | ||
``` | ||
This allows developers to speed up build times and reduce binary sizes by specifying a white-list of | ||
modules to include in the build. | ||
- Set a list called `<BRAND>_FACEPLATE_SVGS` (<BRAND> is all caps), which | ||
contains full paths to the faceplate .svg files. This is used when | ||
(re-)generating all artwork files (convering SVG files to PNG and LVGL | ||
format). | ||
4) Create a brand CMakeLists.txt file: `firmware/vcv_ports/glue/<Brand>/CMakeLists.txt` | ||
This file tells CMake how to build your modules. | ||
- Typically at the top of the CMakeLists file, you will `include()` the | ||
`modules.cmake` file, and use the list of module names to generate the | ||
list of source files needed to compile, but that's not a strict requirement. | ||
- The CMakeLists.txt must create a CMake target OBJECT library named <Brand>Library, like this: | ||
```cmake | ||
add_library( | ||
<Brand>Library OBJECT | ||
${BRAND_SOURCE_PATHS} | ||
${OTHER_SOURCES} | ||
more_source_files.cpp | ||
) | ||
``` | ||
You can then use normal CMake commands like `target_include_directories`, | ||
`target_compile_options`, etc to specify how your modules should be built. | ||
|
||
|
||
5) Add the brand name to `firmware/vcv_ports/brands.cmake` | ||
|
||
```cmake | ||
# List of brands | ||
set(brands | ||
... | ||
<Brand> | ||
) | ||
``` | ||
|
||
|
||
5) Add the plugin to the VCV whitelist (see `vcv/src/mapping/module_directory.hh`). | ||
|
||
6) Generate faceplate artwork. | ||
You can now run `make faceplate-image` to generate the faceplate artwork. This will | ||
also re-generate all other brands artwork, so it's recommend that you a | ||
limit file (see [Firmware README.md](../firmware/README.md) ) to just | ||
specify your brands' modules, or perhaps even a subset of them just to | ||
start. This works by reading the cmake list you created `BRAND_FACEPLATE_SVGS` | ||
|
||
7) Generate component artwork. | ||
Put all SVG files for components into a folder (from the repo root) `graphics/<Brand>/components/`. | ||
Then run `make comp-images` to generate the component images. This will regenerate all brand's component images. | ||
(TODO: allow limiting this). Please only commit actually changed images. | ||
|
||
8) Connect VCV Widgets to MetaModule Elements and LVGL images. | ||
(TODO). For an example, see [this commit](https://github.com/4ms/metamodule/pull/135/commits/3d5a721e7c9beea818e58401e82ba4faf5d52321) | ||
Also, see issue #47 | ||
|
||
|
||
To create the artwork files from the SVGs, you must have Inkscape installed an on your PATH | ||
|
||
...To Be Continued... |
Oops, something went wrong.