Skip to content
/ PicoMK Public

Configurable firmware for RP2040 powered mechanical keyboard

License

Notifications You must be signed in to change notification settings

zli117/PicoMK

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PicoMK

PicoMK is a highly configurable mechanical keyboard firmware designed for Raspberry Pi Foundation's RP2040. The chip features two Cortex-M0 processors. Based on the smp branch of FreeRTOS, PicoMK supports multicore execution on RP2040. It currently powers these boards:

Table of Contents

Features

  • Configurable keymaps with multiple layers and compile time validation.

  • Full NKRO support.

  • C++ registration based customization.

  • Supports multiple peripherals such as rotary encoder, SSD1306 OLED screen, joysticks, WS2812 LED and more to come.

  • Self-contained, runtime configuration menu (screen required). Change keyboard configuration on-the-fly with the keys or the knob.

    Config Menu Demo
    Turn off LED
  • Arbitrary multiplex scan matrix (Japanese duplex, Charlieplexing etc.). See Anatomy of layout.cc

  • Inter-Board Protocol (IBP) for communication between multiple modules (i.e. Pico <-> Pico, Pico <-> Pi Zero). See CyberKeeb2040 for the demo.

Quick Start

Get the Code

This guide assumes you're using one of the followings: Linux (including Raspbian), Windows WSL, MacOS.

First, install the dependencies for pico-sdk

  • Arch Linux:

    pacman -S git cmake arm-none-eabi-gcc
  • Ubuntu:

    sudo apt update
    sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi build-essential libstdc++-arm-none-eabi-newlib
  • Raspbian:

    Note the installation script requires ~2.5GB of disk space on the SD card.

    sudo apt install wget
    wget https://raw.githubusercontent.com/raspberrypi/pico-setup/master/pico_setup.sh
    chmod +x pico_setup.sh
    ./pico_setup.sh

    For details on what this script does, please see Pi Pico Getting started guide chapter 1.

  • Alpine:

    apk add git cmake gcc-arm-none-eabi newlib-arm-none-eabi
  • MacOS:

    # Install Homebrew
    /bin/bash -c "$(curl -fsSL
    https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
    
    brew install cmake
    brew tap ArmMbed/homebrew-formulae
    brew install arm-none-eabi-gcc
    
    # For M1 Mac only: install Rosetta 2
    /usr/sbin/softwareupdate --install-rosetta --agree-to-license

Then checkout the code

git clone https://github.com/zli117/PicoMK.git
cd PicoMK
git submodule update --init && git -C pico-sdk submodule update --init

The last command will checkout all the dependencies such as pico-sdk and FreeRTOS, so it might take a while depending on your internet connection.

Build a Firmware

To create a custom firmware, you can make a copy of the existing config in the configs/ folder. For this guide, we will copy the default config in configs/default.

mkdir -p configs/tutorial/my_new_config
cp configs/default/* configs/tutorial/my_new_config

Each config consists of two files: config.h and layout.cc. Please see the comments in the file and the documentations for information on how to configure them.

The following commands builds the firmware:

mkdir build
cd build
cmake -DBOARD_CONFIG=<board_config> ..
make -j 4

<board_config> is the relative path of the custom config folder we have just created w.r.t the configs/ folder. In our case, to build the configs/tutorial/my_new_config config, you can use this command:

cmake -DBOARD_CONFIG=tutorial/my_new_config ..

Once you successfully build the firmware, you can find the firmware.uf2 file under the current (build/) folder. Now take the Pico board (or other RP2040 boards you have) and put it into the bootloader mode (for Pico board, you can just hold down the bootsel button and replug the USB cable). Mount the board as USB mass storage device, if not done automatically. Copy over the firmware.uf2 to the storage device folder and you're all set.

Please take a look at the following documentations on how to customize different parts of the firmware, including implementing your own custom keycode handler and more.

Build and install the Linux Kernel Module (for Raspberry Pi OS)

The Kernel Module works for the latest kernel on Raspberry Pi OS (6.1.21).

  1. Install kernel headers:
    sudo apt install raspberrypi-kernel-headers
  2. Build the driver and device tree overlay:
    cd linux/
    make -j
    make device_tree
  3. Install the driver:
    sudo -E make install
    sudo depmod -a
  4. Copy over the device tree overlay:
    sudo cp spi1-picomk.dtbo /boot/overlays
  5. Add this line to the /boot/config.txt to enable the overlay. Make sure SPI1 is not enabled.
    dtoverlay=spi1-picomk
  6. Add this line to the /etc/modules file for loading the kernel module:
    spi_picomk

Documentations

Basic intro to configuring a keyboard layout with layout.cc file.

Details on the Inter-Board Protocol and how it's designed.

Description of the currently supported devices and their registration functions.

Information on how the config menu works and how to add more to it.

Documents the overall code design, and some decisions.

Example Configurations

Name Description
default Default config for the Pico-Keyboard
examples/home_screen An example of customizing the home screen, and overall how to customize a default device and register it.
examples/bare_minimum Show that registration is like conditional compilation. If you don't register something, it'll be stripped from the binary. default config binary size: 542208 bytes, examples/bare_minimum binary size: 394240 bytes
examples/custom_keycode Create three custom keycodes that translate keyboard up/down/enter keys to config mode curser up/down/select.
cyberkeeb_2040 Example for setting up IBP for sending keycodes to Pi Zero.

Future Roadmaps

  • USB mass storage mode for importing and exporting json config file.
  • Support charlieplexing to save pins for other things such as driving an LED matrix.
  • Keyboard as a wifi dongle with Pico W (Nice for RPi2 and lower but is this too crazy?)
  • More peripherals such as SK6805, bigger screen, LED matrix, trackpad, etc.
  • USB hub
  • A way for people to check in their configs like in QMK