-
Notifications
You must be signed in to change notification settings - Fork 54
Building a binary
This page tells you to prepare a development environment on your host computer.
If you want to use docker instead, see Docker.
You need CRuby (MRI) because "Static type checking" by Steep will be invoked in the build process.
See the page below and install CRuby if you don't have it yet:
https://www.ruby-lang.org/en/downloads/
The following material includes everything you need:
https://datasheets.raspberrypi.com/pico/getting-started-with-pico.pdf
You need both pico-sdk
cloned and toolchain for your platform.
- Follow the instruction on "Chapter 2. The SDK" of the material
- Follow the instruction on "9.1.1. Installing the Toolchain"
- In addition to that, you probably need to read "Chapter 2. The SDK" to grab the overall
- Preparing VSCode is optional. You don't need it if you just want to build PRK Firmware
- Follow the instruction on "9.2.1. Installing the Toolchain"
- In addition to that, you probably need to read "Chapter 2. The SDK" to grab the overall
Regardless of your platform, confirm that you have these requirements:
-
Submodules of pico-sdk. Make sure to run
git submodule update --init
inpico-sdk
directory- You will sometimes need to upgrade the SDK due to inconsistency between the SDK and the newest PRK Firmware:
git pull origin master --recurse-submodules
- You will sometimes need to upgrade the SDK due to inconsistency between the SDK and the newest PRK Firmware:
-
PICO_SDK_PATH
environment variable. Read the material above again if you are not sure
-
Clone the
prk_firmware
wherever you like(be sure to add
--recursive
)git clone --recursive https://github.com/picoruby/prk_firmware.git
If you forgot to add
--recursive
, you can recover it bygit submodule update --init
-
Setup for the first time
cd prk_firmware/ rake setup
-
Upgrading the PRK
git pull origin master rake deep_clean rake setup
A binary that doesn't include a keymap is the same format as the releases of PRK.
-
Build
rake
Now you should have
prk_firmware-[version]-[date]-[hash].uf2
file inprk_firmware/build/
directory. -
Clean the build
rake clean
You may want PRK Firmware not to be a mass storage device in case that your employer doesn't allow you to bring a USB memory 🙈
If so, you can build a binary including your keymap.rb in this way:
-
Clone a keymap repository, for example, "meishi2" which is a 2x2 matrix card-shaped keyboard in
prk_firmware/keyboards
directorycd keyboards git clone https://github.com/picoruby/prk_meishi2.git
-
Build
cd .. # back to prk_firmware/ rake build_with_keymap[prk_meishi2]
Now you should have
prk_firmware-[version]-[date]-no_msc.uf2
file inprk_firmware/keyboards/prk_meishi2/build/
directory which includes your keymap in code. -
Clean the build
rake clean_with_keymap[prk_meishi2]
You are likely having problems while developing PRK.
These files may give you a clue regarding PRK build system:
prk_firmware
├── CMakeLists.txt
├── Dockerfile # If you want to use docker
├── Rakefile
├── compose.yml # If you want to use docker
└── lib
└── picoruby
└── Rakefile
- Getting started
- Keyboard features
- Keycodes (ja)
- Mouse (ja)
- Layers and mode key (ja)
- Debounce
- Composite key
- Split-type keyboard
- Keyscan matrix
- Num Lock, Caps Lock and Scroll Lock
- Useful methods that make you free
- BIOS mode
- Other features
- Examples
- Development
- Contribute to the Wiki
- FAQ