You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

75 lines
4.1 KiB

  1. # QMK Breaking Change - 2020 Feb 29 Changelog
  2. Four times a year QMK runs a process for merging Breaking Changes. A Breaking Change is any change which modifies how QMK behaves in a way that is incompatible or potentially dangerous. We limit these changes to 4 times per year so that users can have confidence that updating their QMK tree will not break their keymaps.
  3. ## Update ChibiOS/ChibiOS-Contrib/uGFX submodules
  4. * General Notes
  5. * A `make git-submodule` may be required after pulling the latest QMK firmware code to update affected submodules to the upgraded revisions
  6. * Enabling link-time-optimization (`LINK_TIME_OPTIMIZATION_ENABLE = yes`) should work on a lot more boards
  7. * Upgrade to ChibiOS ver19.1.3
  8. * This will allow QMK to update to upstream ChibiOS a lot easier -- the old version was ~2 years out of date. Automated update scripts have been made available to simplify future upgrades.
  9. * Includes improved MCU support and bugfixes
  10. * ChibiOS revision is now included in Command output
  11. * Timers should now be more accurate
  12. * Upgrade to newer ChibiOS-Contrib
  13. * Also includes improved MCU support and bugfixes
  14. * ChibiOS-Contrib revision is now included in Command output
  15. * Upgrade to newer uGFX
  16. * Required in order to support updated ChibiOS
  17. ## Fix ChibiOS timer overflow for 16-bit SysTick devices
  18. * On 16-bit SysTick devices, the timer subsystem in QMK was incorrectly dealing with overflow.
  19. * When running at a 100000 SysTick frequency (possible on 16-bit devices, but uncommon), this overflow would occur after 0.65 seconds.
  20. * Timers are now correctly handling this overflow case and timing should now be correct on ChibiOS/ARM.
  21. ## Update LUFA submodule
  22. * Updates the LUFA submodule to include updates from upstream (abcminiuser/lufa)
  23. * Includes some cleanup for QMK DFU generation
  24. ## Encoder flip
  25. * Flips the encoder direction so that `clockwise == true` is for actually turning the knob clockwise
  26. * Adds `ENCODER_DIRECTION_FLIP` define, so that reversing the expected dirction is simple for users.
  27. * Cleans up documentation page for encoders
  28. ## Adding support for `BACKLIGHT_ON_STATE` for hardware PWM backlight
  29. * Previously, the define only affected software PWM, and hardware PWM always assumed an N-channel MOSFET.
  30. * The hardware PWM backlight setup has been updated to respect this option.
  31. * The default "on" state has been changed to `1` - **this impacts all keyboards using software PWM backlight that do not define it explicitly**. If your keyboard's backlight is acting strange, it may have a P-channel MOSFET, and will need to have `#define BACKLIGHT_ON_STATE 0` added to the keyboard-level `config.h`. Please see the PR for more detailed information.
  32. ## Migrating `ACTION_LAYER_TAP_KEY()` entries in `fn_actions` to `LT()` keycodes
  33. * `fn_actions` is deprecated, and its functionality has been superseded by direct keycodes and `process_record_user()`
  34. * The end result of removing this obsolete feature should result in a decent reduction in firmware size and code complexity
  35. * All keymaps affected are recommended to switch away from `fn_actions` in favour of the [custom keycode](https://docs.qmk.fm/#/custom_quantum_functions) and [macro](https://docs.qmk.fm/#/feature_macros) features
  36. ## Moving backlight keycode handling to `process_keycode/`
  37. * This refactors the backlight keycode logic to be clearer and more modular.
  38. * All backlight-related keycodes are now actioned in a single file.
  39. * The `ACTION_BACKLIGHT_*` macros have also been deleted. If you are still using these in a `fn_actions[]` block, please switch to using the backlight keycodes or functions directly.
  40. ## Refactor Planck keymaps to use Layout Macros
  41. * Refactor Planck keymaps to use layout macros instead of raw matrix assignments
  42. * Makes keymaps revision-agnostic
  43. * Should reduce noise and errors in Travis CI logs
  44. ## GON NerD codebase refactor
  45. * Splits the codebase for GON NerD 60 and NerdD TKL PCBs into two separate directories.
  46. * If your keymap is for a NerD 60 PCB, your `make` command is now `make gon/nerd60:<keymap>`.
  47. * If your keymap is for a NerD TKL PCB, your `make` command is now `make gon/nerdtkl:<keymap>`.