2024-05-30 12:00:41 +10:00

32 KiB

QMK Breaking Changes - 2023 November 26 Changelog

Notable Features

As per last few breaking changes cycles, there have been a lot of behind-the-scenes changes, mainly around consolidation of config into info.json files, cleanup of info.json files, cleaning up driver naming, as well as addressing technical debt.

As a followup to last cycle's notable changes, as qmk/qmk_firmware is no longer accepting PRs for keymaps we're pleased to announce that storing and building keymaps externally from the normal QMK Firmware repository is now possible. This is done through the new External Userspace feature, more details below!

Changes Requiring User Action

Updated Keyboard Codebases

Old Keyboard Name New Keyboard Name
adm42 adm42/rev4
dp3000 dp3000/rev1
handwired/dactyl_manuform/dmote/62key handwired/dmote
keychron/q0/rev_0130 keychron/q0/base
keychron/q0/rev_0131 keychron/q0/plus
keychron/q1/ansi keychron/q1v1/ansi
keychron/q1/ansi_encoder keychron/q1v1/ansi_encoder
keychron/q1/iso keychron/q1v1/iso
keychron/q1/iso_encoder keychron/q1v1/iso_encoder
keychron/q4/ansi_v1 keychron/q4/ansi
kprepublic/bm40hsrgb kprepublic/bm40hsrgb/rev1
matchstickworks/southpad matchstickworks/southpad/rev2
soda/mango magic_force/mf17
soda/pocket magic_force/mf34
studiokestra/line_tkl studiokestra/line_friends_tkl
ymdk/melody96 ymdk/melody96/soldered

Notable core changes

External Userspace (#22222)

As mentioned above, the new External Userspace feature allows for keymaps to be stored and built externally from the main QMK Firmware repository. This allows for keymaps to be stored separately -- usually in their own repository -- and for users to be able to maintain and build their keymaps without needing to fork the main QMK Firmware repository.

See the External Userspace documentation for more details.

A significant portion of user keymaps have already been removed from qmk/qmk_firmware and more will follow in coming weeks. You can still recover your keymap from the tag user-keymaps-still-present if required -- a perfect time to migrate to the new External Userspace!

::: warning This feature is still in beta, and we're looking for feedback on it. Please try it out and let us know what you think -- a new #help-userspace channel has been set up on Discord. :::

Improve and Cleanup Shutdown callbacks (#21060)

Shutdown callbacks at the keyboard level were never present, preventing safe shutdown sequencing for peripherals such as OLEDs, RGB LEDs, and other devices. This PR adds a new shutdown_kb function, as well as amending shutdown_user, allowing for safe shutdown of peripherals at both keyboard and keymap level.

See the Keyboard Shutdown/Reboot Code documentation for more details.

OLED Force Flush (#20953)

Along with the new shutdown_kb function, a new API oled_render_dirty(bool) function has been added. This allows OLED contents to be written deterministically when supplied with true -- that is, the OLED will be updated immediately, rather than waiting for the next OLED update cycle. This allows for OLEDs to show things such as "BOOTLOADER MODE" and the like if resetting to bootloader from QMK.

Switch statement helpers for keycode ranges (#20059)

Predefined ranges usable within switch statements have been added for groups of similar keycodes, where people who wish to handle entire blocks at once can do so. This allows keymaps to be immune to changes in keycode values, and also allows for more efficient code generation.

The ranges are as follows:

Name Mapping
INTERNAL_KEYCODE_RANGE KC_NO ... KC_TRANSPARENT
BASIC_KEYCODE_RANGE KC_A ... KC_EXSEL
SYSTEM_KEYCODE_RANGE KC_SYSTEM_POWER ... KC_SYSTEM_WAKE
CONSUMER_KEYCODE_RANGE KC_AUDIO_MUTE ... KC_LAUNCHPAD
MOUSE_KEYCODE_RANGE KC_MS_UP ... KC_MS_ACCEL2
MODIFIER_KEYCODE_RANGE KC_LEFT_CTRL ... KC_RIGHT_GUI
SWAP_HANDS_KEYCODE_RANGE QK_SWAP_HANDS_TOGGLE ... QK_SWAP_HANDS_ONE_SHOT
MAGIC_KEYCODE_RANGE QK_MAGIC_SWAP_CONTROL_CAPS_LOCK ... QK_MAGIC_TOGGLE_ESCAPE_CAPS_LOCK
MIDI_KEYCODE_RANGE QK_MIDI_ON ... QK_MIDI_PITCH_BEND_UP
SEQUENCER_KEYCODE_RANGE QK_SEQUENCER_ON ... QK_SEQUENCER_STEPS_CLEAR
JOYSTICK_KEYCODE_RANGE QK_JOYSTICK_BUTTON_0 ... QK_JOYSTICK_BUTTON_31
PROGRAMMABLE_BUTTON_KEYCODE_RANGE QK_PROGRAMMABLE_BUTTON_1 ... QK_PROGRAMMABLE_BUTTON_32
AUDIO_KEYCODE_RANGE QK_AUDIO_ON ... QK_AUDIO_VOICE_PREVIOUS
STENO_KEYCODE_RANGE QK_STENO_BOLT ... QK_STENO_COMB_MAX
MACRO_KEYCODE_RANGE QK_MACRO_0 ... QK_MACRO_31
BACKLIGHT_KEYCODE_RANGE QK_BACKLIGHT_ON ... QK_BACKLIGHT_TOGGLE_BREATHING
RGB_KEYCODE_RANGE RGB_TOG ... RGB_MODE_TWINKLE
QUANTUM_KEYCODE_RANGE QK_BOOTLOADER ... QK_ALT_REPEAT_KEY
KB_KEYCODE_RANGE QK_KB_0 ... QK_KB_31
USER_KEYCODE_RANGE QK_USER_0 ... QK_USER_31

Usage:

    switch (keycode) {
        case KC_A ... KC_EXSEL:
        case KC_LEFT_CTRL ... KC_RIGHT_GUI:
        /* do stuff with basic and modifier keycodes */

Becomes:

    switch (keycode) {
        case BASIC_KEYCODE_RANGE:
        case MODIFIER_KEYCODE_RANGE:
        /* do stuff with basic and modifier keycodes */

Quantum Painter OLED support (#19997)

Quantum Painter has picked up support for SH1106 displays -- commonly seen as 128x64 OLEDs. Support for both I2C and SPI displays is available.

If you're already using OLED through OLED_DRIVER_ENABLE = yes or equivalent in info.json and wish to use Quantum Painter instead, you'll need to disable the old OLED system, instead enabling Quantum Painter as well as enabling the appropriate SH1106 driver. See the Quantum Painter driver documentation for more details. The old OLED driver is still available, and keymaps do not require migrating to Quantum Painter if you don't want to do so.

RGB/LED lighting driver naming and cleanup (#21890, #21891, #21892, #21903, #21904, #21905, #21918, #21929, #21938, #22004, #22008, #22009, #22071, #22090, #22099, #22126, #22133, #22163, #22200, #22308, #22309, #22311, #22325, #22365, #22379, #22380, #22381, #22383, #22436)

As you can probably tell by the list of PRs just above, there has been a lot of cleanup and consolidation this cycle when it comes to RGB/LED lighting drivers. The number of changes is too large to list here, but the general theme has been focusing on consistency of naming, both of drivers themselves and their respective implementation and configuration. Most changes only affect keyboard designers -- if you find that your in-development keyboard is no longer building due to naming of defines changing, your best bet is to refer to another board already in the repository which has had the changes applied.

Peripheral subsystem enabling (#22253, #22448, #22106)

When enabling peripherals such as I2C, SPI, or Analog/ADC, some required manual inclusion of source files in order to provide driver support, and in some cases, when multiple drivers were using the same underlying peripheral, files were being added to the build multiple times.

Most systems requiring other peripherals now mark their respective dependencies as "required", allowing the build system to check whether peripherals are necessary before including them in the build rather than having each location enable them manually.

For a concrete example, users or keyboard designers who previously added SRC += analog.c in order to allow for analog readings via an ADC now should specify ANALOG_DRIVER_REQUIRED = yes instead. The full list of added options is as follows:

New option Old Equivalent
ANALOG_DRIVER_REQUIRED = yes SRC += analog.c
APA102_DRIVER_REQUIRED = yes SRC += apa102.c
I2C_DRIVER_REQUIRED = yes SRC += i2c_master.c or QUANTUM_LIB_SRC += i2c_master.c
SPI_DRIVER_REQUIRED = yes SRC += spi_master.c or QUANTUM_LIB_SRC += spi_master.c
UART_DRIVER_REQUIRED = yes SRC += uart.c
WS2812_DRIVER_REQUIRED = yes SRC += ws2812.c

NKRO on V-USB boards (#22398)

NKRO is now available for ATmega32A and 328P-based keyboards (including PS2AVRGB/Bootmapper boards), thanks to some internal refactoring and cleanup. To enable it, the process is the same as always - add NKRO_ENABLE = yes to your rules.mk, then assign and press the NK_TOGG keycode to switch modes.

Full changelist

Core:

  • Compilation warning if both keymap.json and keymap.c exist (#19939)
  • [QP] Add support for OLED, variable framebuffer bpp (#19997)
  • Generate switch statement helpers for keycode ranges (#20059)
  • Chibios SPI driver: allow some SPI pins to be left unassigned (#20315)
  • Take care of scroll divisor remainders for PS/2 drag scroll (#20732)
  • Add RGBLIGHT_DEFAULT_ON macro configuration option (#20857)
  • Allow force flush of oled display. (#20953)
  • Improve and Cleanup Shutdown callbacks (#21060)
  • [Enhancement] QP Getters (#21171)
  • Russian typewriter keymap file for popular legacy layout. (#21174)
  • Improve directional transition of overlapping mouse keys (#21494)
  • Add full solenoid support on split keyboards (#21583)
  • Reduce popping during audio initialization using the additive DAC (#21642)
  • [Maintenance] USB HID control packet as struct (#21688)
  • Bump mouse endpoint packet size to 16 bytes (#21711)
  • Allow customizing PWM frequency (#21717)
  • Add simpler method for relocating functions to RAM. (#21804)
  • Clean up RGB LED type (#21859)
  • is31fl3741: Allow changing config register (#21861)
  • Add _DEFAULT_ON lighting configuration options (#21865)
  • Modify split config is_keyboard_master/left checks. (#21875)
  • Remove old IS_LED_ON/OFF() macros (#21878)
  • ckled2001: driver naming cleanups (#21890)
  • aw20216: driver naming cleanups (#21891)
  • is31fl3218: driver naming cleanups (#21892)
  • is31fl3736: driver naming cleanups (#21903)
  • is31fl3737: driver naming cleanups (#21904)
  • is31fl3733: driver naming cleanups (#21905)
  • Enable RP2040 support for apa102 RGB LED driver (#21908)
  • is31fl3731: driver naming cleanups (#21918)
  • is31fl3741: driver naming cleanups (#21929)
  • refactor: move default RGB/LED matrix #defines (#21938)
  • Added flower blooming on RGB Matrix effect (#21948)
  • Remove 'Firmware size check does not yet support' message (#21977)
  • chibios: mark boot2 bootlader data readonly (#21986)
  • Complete RGB Matrix support for IS31FL3218 (#22004)
  • Default wear leveling logical size to half backing (#22006)
  • chibios: disable RWX segment warning on newer GNU lds (#22007)
  • Add and use I2C address defines for ISSI LED drivers (#22008)
  • Add and use PWM frequency defines for ISSI LED drivers (#22009)
  • directly use object files when linking ELF (#22025)
  • Lvgl rate control (#22049)
  • Rename CKLED2001 driver to SNLED27351 (#22071)
  • Move PACKED define to util.h (#22074)
  • Simplify more feature driver defines (#22090)
  • Update ISSI LED types (#22099)
  • Move velocikey to within rgblight (#22123)
  • is31fl3218: Add LED Matrix support (#22126)
  • Set default board files for uf2boot bootloader (#22129)
  • is31fl3736: extract single-color API (#22133)
  • is31fl3737/3741: add LED Matrix support (#22163)
  • Rename DRIVER_ADDR_n defines (#22200)
  • New RGB Animations - 4 "Starlight" Animation Variations (#22212)
  • QMK Userspace (#22222)
  • Dedupe I2C, SPI, UART driver inclusions (#22253)
  • Add "AC Next Keyboard Layout Select" consumer usage entry (macOS Globe key) (#22256)
  • Separate 6KRO and NKRO report structs (#22267)
  • Azoteq IQS5xx support (#22280)
  • Add _flush() functions to LED drivers (#22308)
  • Add _LED_COUNT defines to LED drivers (#22309)
  • Infer LED DRIVER_COUNT from configured addresses (#22311)
  • Added gamma values for ST7735 displays (#22313)
  • Consolidate some EEPROM Driver configuration (#22321)
  • V-USB: Add generic send_report() function (#22323)
  • V-USB: Implement GET_PROTOCOL and SET_PROTOCOL handling (#22324)
  • RGB/LED matrix use limits size optimisation (#22325)
  • Relocate LED driver init code (#22365)
  • WT RGB cleanups (#22379)
  • LED drivers: use PACKED define from util.h (#22380)
  • LED drivers: clean up SWx/CSy pullup/down resistor config (#22381)
  • LED drivers: add defines for PWM and LED control register counts (#22383)
  • V-USB: implement NKRO (#22398)
  • Allow generic_features to handle subdirectories (#22400)
  • Migrate some common features to generic (#22403)
  • Remove requirement for keymap_steno.h include in keymaps (#22423)
  • LED drivers: register naming cleanups (#22436)
  • Slight refactor of joystick axis type into typedef (#22445)
  • Generalise analog SRC inclusion (#22448)
  • Revert "chibios: disable RWX segment warning on newer GNU lds" (#22469)
  • chibios: disable RWX segment warning on newer GNU lds (#22471)

CLI:

  • Implement data driven lighting defaults (#21825)
  • Generate keymap.json config options more forcefully (#21960)
  • Implement data driven dip switches (#22017)
  • Improve argument handling of c2json (#22170)
  • Support additional split sync items for info.json (#22193)
  • CLI refactoring for common build target APIs (#22221)
  • Add dd mapping for hardware based split handedness (#22369)
  • CLI parallel search updates (#22525)
  • Remove duplicates from search results (#22528)

Keyboards:

  • Add KPRepublic/BM40hsrgb rev2 (#16689)
  • update to data driven - superseeds part of https://github.com/qmk/qmk… (#20220)
  • Modernize dactyl_manuform/dmote keyboard (#20427)
  • add Skyloong/GK61_V1 keyboard (#21364)
  • [Refactor] Make changes to some pins (#21380)
  • Add missing fullsize extended default layouts (#21402)
  • Add Skyloong/Gk61 PRO keyboard (#21450)
  • Added skyloong/Qk21 v1 Number Pad (#21467)
  • matchstickworks/southpad - Move files to rev1, add rev2 (#21574)
  • partially modernize dactyl_minidox (#21576)
  • tominabox1/le_chiffre oled rework (#21611)
  • Add Skyloong/Gk61_pro_48 keyboard (#21654)
  • Adding support for new Waffling60 revision (#21664)
  • Leeloo revision 2 updates. (#21671)
  • rename og60 to tofu60 (#21684)
  • add tofujr v2 keyboard (#21740)
  • Rotary numpad (#21744)
  • Update era/divine (#21767)
  • 1UpKeyboards Pi60 Layout Additions (#21874)
  • BIOI keyboards: use core UART driver (#21879)
  • Resolve some "Layout should not contain name of keyboard" lint warnings (#21898)
  • fc660c/fc980c: clean up actuation point adjustment code (#21964)
  • Chromatonemini info json revised to support qmk 0.22.2 (#21966)
  • Migrate spi_flash WEAR_LEVELING_DRIVER to info.json (#21978)
  • Remove duplication of RP2040 EEPROM defaults (#21979)
  • Remove duplication of STM32L432 EEPROM defaults (#21981)
  • Migrate spi EEPROM_DRIVER to info.json (#21991)
  • Update Keychron Q1v1 (#21993)
  • Update Keychron Q2 (#21994)
  • Update Keychron Q3 (#21995)
  • Update Keychron Q4 (#21996)
  • Migrate WEAR_LEVELING_*_SIZE to info.json (#22010)
  • Remove duplication of EEPROM defaults (#22011)
  • Migrate i2c EEPROM_DRIVER to info.json (#22013)
  • Remove config.h which only set DYNAMIC_KEYMAP_LAYER_COUNT (#22034)
  • Add community layout support to tofu60 (#22041)
  • Update Keychron Q0 (#22068)
  • Remove custom ISSI lighting code (#22073)
  • add dp3000 rev2 featuring rgblight (#22084)
  • Remove ALLOW_WARNINGS and PICO_INTRINSICS_ENABLED (#22085)
  • Partially migrate DYNAMIC_KEYMAP_LAYER_COUNT (#22087)
  • feat(eyeohdesigns/babyv): rgb matrix (#22105)
  • input_club/infinity60: remove custom 3731 code, convert to LED Matrix (#22117)
  • YMDK Melody96 Break-Up (#22121)
  • Remove duplicated rgblight implementation from mxss (#22122)
  • KC60 Layout Standardization and Cleanup (#22125)
  • Convert adm42 to data driven (#22144)
  • Update Drop keyboards for develop (#22145)
  • move soda/mango and soda/pocket to magic_force/mf17 and magic_force/mf34 (#22151)
  • GMMK2 65% ISO Community Layout Support (#22152)
  • Leeloo v2.1 revision 3 updates. (#22236)
  • jian/rev1: convert to DIP Switch (#22248)
  • Enable linking of encoders to switch within layout macros (#22264)
  • Migrate recently introduced sync items (#22305)
  • Rename LINE FRIENDS TKL keyboard (#22310)
  • feat(mechwild/clunker): new layouts (#22342)
  • Remove use of broken split.main (#22363)
  • whitefox: remove pointless file (#22366)
  • Migrate some EEPROM config to info.json (#22434)
  • Remove unnecessary driver counts (#22435)
  • Migrate some dip switch config to info.json (#22437)
  • Remove userspace keymaps (#22544)
  • Stub out community layout directory structure (#22545)
  • Remove symbolic linked userspace folder (#22548)

Keyboard fixes:

  • fix unxmaal for 60_iso (#21975)
  • Fix input_club/k_type when RGB Matrix disabled (#22021)
  • Fixup snes_macropad on develop (#22444)
  • Fix missed shutdown callbacks (#22549)

Others:

  • Implement data driven wear leveling (#21906)
  • More data driven RGB/LED Matrix config (#21939)
  • Update WS2812 docs and add APA102 docs (#22106)
  • Add DD mappings for locking switch (#22242)

Bugs:

  • Improve test invocation, fix Retro Shift bugs, and add Auto+Retro Shift test cases (#15889)
  • [Bugfix] qp_ellipse overflow (#19005)
  • Cater for ECC failures in EFL wear-leveling. (#19749)
  • Fix OSM on a OSL activated layer (#20410)
  • Fixed WB32 MCU remote wakeup issue (#20863)
  • Optimize the additive DAC code, fixing performance-related hangs (#21662)
  • [Enhancement] Improvements for debounce test coverage + bug fixes for sym_defer_g and sym_eager_pr (#21667)
  • fix: make clicky delay silent (#21866)
  • Add mousekey.h include to quantum.h (#21897)
  • Fix default layer value in eeconfig_init (#21909)
  • Add RTC IRQ Priority to RP2040 board files (#21926)
  • Update AW20216S LED type (#22072)
  • LED/RGB Matrix: prefix driver defines (#22088)
  • RGBLight/Backlight: add prefixed driver defines (#22089)
  • Fix lower cpi bound on PMW33XX (#22108)
  • Fix parsing/validation for 21939 (#22148)
  • is31fl3733: complete LED Matrix support (#22149)
  • Fix memory leak in realloc failure handling (#22188)
  • avrdude: Version 7.2 changes the text output (#22235)
  • Resolve invalid keyboard alias targets (#22239)
  • Prep work for NKRO report separation (#22268)
  • ChibiOS pin defs: use only vendor if present (#22297)
  • Fix invalid LED driver config (#22312)
  • Fix compilation error when led/rgb process limit is zero. (#22328)
  • V-USB: Fix GET_IDLE/SET_IDLE (#22332)
  • QP getters correction (#22357)
  • Fix 'to_c' for config.h mappings (#22364)
  • snled27351: fix missing i2c_init() (#22446)
  • Move BACKLIGHT_PWM_PERIOD to correct docs section (#22480)
  • qmk find: Fix failure with multiple filters (#22497)
  • Fix qmk find failure due to circular imports (#22523)