Co-authored-by: Drashna Jaelre <drashna@live.com> Co-authored-by: Ryan <fauxpark@gmail.com>
32 KiB
QMK Breaking Changes - 2023 November 26 Changelog
Notable Features :id=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 :id=changes-requiring-user-action
Updated Keyboard Codebases :id=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 :id=notable-core
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!
!> 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) :id=improve-and-cleanup-shutdown-callbacks
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) :id=oled-force-flush
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) :id=switch-statement-helpers-for-keycode-ranges
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) :id=quantum-painter-oled-support
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) :id=peripheral-subsystem-enabling
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) :id=vusb-nkro
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 :id=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)