27 releases (5 breaking)

new 0.6.6 Jul 15, 2025
0.6.3 Jun 18, 2025
0.4.2 Jan 23, 2025
0.4.0 Dec 16, 2024
0.1.7 Jul 25, 2024

#2270 in Hardware support

Download history 26/week @ 2025-03-25 237/week @ 2025-04-01 259/week @ 2025-04-08 65/week @ 2025-04-15 59/week @ 2025-04-22 108/week @ 2025-04-29 94/week @ 2025-05-06 103/week @ 2025-05-13 40/week @ 2025-05-20 34/week @ 2025-05-27 395/week @ 2025-06-03 238/week @ 2025-06-10 284/week @ 2025-06-17 131/week @ 2025-06-24 396/week @ 2025-07-01 99/week @ 2025-07-08

930 downloads per month
Used in rmk

MIT/Apache

325KB
7.5K SLoC


Logo

A feature-rich keyboard firmware written in Rust.

👉 Join our Discord server for discussions, support, and community collaboration!


中文

Features

  • Broad microcontroller compatibility: Leveraging embassy, RMK supports a comprehensive range of microcontrollers, including stm32, nRF, rp2040(w), esp32, etc
  • Dynamic keymap customization: RMK offers native Vial support, enabling real-time keymap modifications. You can even edit keymaps over BLE connections wirelessly
  • Advanced keyboard functionality: RMK comes with lots of advanced keyboard features by default, including layer switching, media controls, system commands, mouse control, and more
  • Wireless connectivity: BLE wireless support with automatic reconnection and multi-device capabilities for nRF52 and esp32 microcontrollers, tested on nRF52840, esp32c3, esp32s3, Pi Pico W
  • Easy configuration: RMK simplifies keyboard development through a single keyboard.toml configuration file. For Rust enthusiasts, the firmware remains highly customizable using Rust code
  • Optimized performance: RMK achieves approximately 2ms latency in wired mode and 10ms in wireless mode. With the async_matrix feature enabled, power consumption is significantly reduced—a 2000mAh battery can power your keyboard for several months

News

  • 2025-06-04: v0.7.0 is released! Check out the migration guide to upgrade!

User Documentation | API Reference | FAQs | Changelog

Real-World Implementations

rmk-ble-keyboard

dactyl-lynx-rmk

Getting Started

Option 1: Start with a Template

Quickly bootstrap your project using rmkit and the official RMK project template.

cargo install rmkit flip-link
# If you encounter installation issues on Windows, try this alternative command:
# powershell -ExecutionPolicy ByPass -c "irm https://github.com/haobogu/rmkit/releases/download/v0.0.13/rmkit-installer.ps1 | iex"
rmkit init

For comprehensive guidance, refer to the User Guide.

Option 2: Explore Built-in Examples

Browse the examples in the examples directory. Below are step-by-step instructions for rp2040 development. The process is similar for other microcontrollers when using a debug probe.

rp2040 Setup

  1. Install probe-rs

    curl --proto '=https' --tlsv1.2 -LsSf https://github.com/probe-rs/probe-rs/releases/latest/download/probe-rs-tools-installer.sh | sh
    
  2. Build the firmware

    cd examples/use_rust/rp2040
    cargo build --release
    
  3. Flash using a debug probe

    With a debug probe connected to your rp2040 board, simply run:

    cd examples/use_rust/rp2040
    cargo run --release
    
  4. (Optional) Flash via USB

    Without a debug probe, you can use elf2uf2-rs to flash via USB:

    1. Install the tool: cargo install elf2uf2-rs
    2. Modify examples/use_rust/rp2040/.cargo/config.toml to use elf2uf2:
      - runner = "probe-rs run --chip RP2040"
      + runner = "elf2uf2-rs -d"
      
    3. Connect your rp2040 board while holding the BOOTSEL button until the USB drive appears
    4. Flash the firmware:
      cd examples/use_rust/rp2040
      cargo run --release
      
      Upon successful completion, you'll see output similar to:
      Finished release [optimized + debuginfo] target(s) in 0.21s
      Running `elf2uf2-rs -d 'target\thumbv6m-none-eabi\release\rmk-rp2040'`
      Found pico uf2 disk G:\
      Transfering program to pico
      173.00 KB / 173.00 KB [=======================] 100.00 % 193.64 KB/s  
      

Development Roadmap

Current roadmap of RMK can be found here.

Minimum Supported Rust Version (MSRV)

RMK is developed against the latest stable Rust release. While other versions may work, they are not fully tested.

License

RMK is licensed under either of

at your option.

Dependencies

~6MB
~133K SLoC