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.

586 lines
17 KiB

Merge ChibiOS and LUFA descriptor support (#2362) * Move lufa descriptor to protocol/usb_descriptor * Try to compile usb_descriptor on ChibiOS * Add lufa_utils for ChibiOS Lufa USB descriptors for ChibiOS * More lufa_util compatibility fixes * First compiling version of shared USB descriptor * Send the usb descriptors * Fix the CONSOLE output on ChibiOS * Add errors for unsupported interfaces * Enable support for vitual serial port USB descriptors * Implement virtual serial port for ChibiOS * Cleanup the lufa_utils Use the default lufa header files * Add raw hid support for ChibiOS This is completely untested * Enable midi compilation on ChibiOS * Move midi functionality out of lufa.c * Don't register sysex callback when not needed * ChibiOS compilation fixes * Update ChibiOS submodule * Fix the Midi USB descriptor It didn't work properly when both Midi and Virtual serial port was enabled. * Add MIDI support for ChibiOS * Fix USB descriptor strings on ChibiOS * Use serial usb driver for raw hid * Generalize the ChibiOS stream like drivers This makes the initialization much more simple and eliminates a lot of the code duplication. * Convert console output to chibios stream driver * Fixes for ChibiOS update * Update the ChibiOS contrib submodule To include the usb data toggle synchronization fixes * Fix duplicate reset enumeration on ChibiOS * Add missing include * Add number of endpoints check for ChibiOS * Enable serial USB driver on all keyboards * Add missing includes when API is enabled withot midi * Add another missing inlcude
6 years ago
Merge ChibiOS and LUFA descriptor support (#2362) * Move lufa descriptor to protocol/usb_descriptor * Try to compile usb_descriptor on ChibiOS * Add lufa_utils for ChibiOS Lufa USB descriptors for ChibiOS * More lufa_util compatibility fixes * First compiling version of shared USB descriptor * Send the usb descriptors * Fix the CONSOLE output on ChibiOS * Add errors for unsupported interfaces * Enable support for vitual serial port USB descriptors * Implement virtual serial port for ChibiOS * Cleanup the lufa_utils Use the default lufa header files * Add raw hid support for ChibiOS This is completely untested * Enable midi compilation on ChibiOS * Move midi functionality out of lufa.c * Don't register sysex callback when not needed * ChibiOS compilation fixes * Update ChibiOS submodule * Fix the Midi USB descriptor It didn't work properly when both Midi and Virtual serial port was enabled. * Add MIDI support for ChibiOS * Fix USB descriptor strings on ChibiOS * Use serial usb driver for raw hid * Generalize the ChibiOS stream like drivers This makes the initialization much more simple and eliminates a lot of the code duplication. * Convert console output to chibios stream driver * Fixes for ChibiOS update * Update the ChibiOS contrib submodule To include the usb data toggle synchronization fixes * Fix duplicate reset enumeration on ChibiOS * Add missing include * Add number of endpoints check for ChibiOS * Enable serial USB driver on all keyboards * Add missing includes when API is enabled withot midi * Add another missing inlcude
6 years ago
Velocikey: Match RGB animation speed to typing speed (#3754) * Draft commit of typing speed RGB control * More information in the readme * Support all RGB animation modes (Fixes #1) * Added support for all RGB light modes to use typing speed Except christmas lights because that is seizure-inducing at high speeds! * Introduced a value range specific to each RGB mode Because some modes are a little too much when running at full speed! * Update readme.md * Update readme.md * Re-arrange typing_speed definitions (Fixes #5) (#6) * Re-arrange variable definitions to avoid including quantum.h from rgblight.c * Fix a compilation error when trying to run make test:all * Tweaks to the typing speed decay rate * Renamed to momentum; moved implementation into dedicated files * Groundwork for toggling momentum on/off (currently always on) * Add EEPROM toggle for momentum-matching * Moved momentum out of RGBLIGHT_ENABLE toggles so it's more generic * Move momentum decay task out of rgblight_task() * Fix missing momentum.h in lufa.c * Experimental LED support (untested) * Draft commit of typing speed RGB control * More information in the readme * Support all RGB animation modes (Fixes #1) * Added support for all RGB light modes to use typing speed Except christmas lights because that is seizure-inducing at high speeds! * Introduced a value range specific to each RGB mode Because some modes are a little too much when running at full speed! * Update readme.md * Update readme.md * Re-arrange typing_speed definitions (Fixes #5) (#6) * Re-arrange variable definitions to avoid including quantum.h from rgblight.c * Fix a compilation error when trying to run make test:all * Tweaks to the typing speed decay rate * Renamed to momentum; moved implementation into dedicated files * Groundwork for toggling momentum on/off (currently always on) * Add EEPROM toggle for momentum-matching * Moved momentum out of RGBLIGHT_ENABLE toggles so it's more generic * Move momentum decay task out of rgblight_task() * Fix missing momentum.h in lufa.c * Added documentation * Renamed feature to velocikey * Reverted readme to original state * Correct the readme title * Updated feature name in the docs * Update EECONFIG name * Add compile-time toggles for velocikey * Update feature documentation * Revert "Merge branch 'led-support' into master" This reverts commit e123ff5febf61639b9a9020748e1c2e2313460ff, reversing changes made to df111a55b9d4929182e16108b1c0ead15b16df97. * Move velocikey EECONFIG definition to depend on VELOCIKEY_ENABLE * Rename decay_task function to decelerate * Apply suggestions from code review Co-Authored-By: chrislewisdev <chris@chrislewisdev.com> * Re-order eeconfig definitions * Apply coding conventions * Apply #ifdef check in lufa.c * Refactored interval time checks into one functionc * Small rename * Fix unused function error for layouts not using all rgb effects * Only update EEPROM if Velocikey is enabled * Incorporate code review feedback * Small adjustment to top-end decay rate * Add Velocikey documentation to table of contents * Bring tetris:default keymap size down by disabling audio
5 years ago
Velocikey: Match RGB animation speed to typing speed (#3754) * Draft commit of typing speed RGB control * More information in the readme * Support all RGB animation modes (Fixes #1) * Added support for all RGB light modes to use typing speed Except christmas lights because that is seizure-inducing at high speeds! * Introduced a value range specific to each RGB mode Because some modes are a little too much when running at full speed! * Update readme.md * Update readme.md * Re-arrange typing_speed definitions (Fixes #5) (#6) * Re-arrange variable definitions to avoid including quantum.h from rgblight.c * Fix a compilation error when trying to run make test:all * Tweaks to the typing speed decay rate * Renamed to momentum; moved implementation into dedicated files * Groundwork for toggling momentum on/off (currently always on) * Add EEPROM toggle for momentum-matching * Moved momentum out of RGBLIGHT_ENABLE toggles so it's more generic * Move momentum decay task out of rgblight_task() * Fix missing momentum.h in lufa.c * Experimental LED support (untested) * Draft commit of typing speed RGB control * More information in the readme * Support all RGB animation modes (Fixes #1) * Added support for all RGB light modes to use typing speed Except christmas lights because that is seizure-inducing at high speeds! * Introduced a value range specific to each RGB mode Because some modes are a little too much when running at full speed! * Update readme.md * Update readme.md * Re-arrange typing_speed definitions (Fixes #5) (#6) * Re-arrange variable definitions to avoid including quantum.h from rgblight.c * Fix a compilation error when trying to run make test:all * Tweaks to the typing speed decay rate * Renamed to momentum; moved implementation into dedicated files * Groundwork for toggling momentum on/off (currently always on) * Add EEPROM toggle for momentum-matching * Moved momentum out of RGBLIGHT_ENABLE toggles so it's more generic * Move momentum decay task out of rgblight_task() * Fix missing momentum.h in lufa.c * Added documentation * Renamed feature to velocikey * Reverted readme to original state * Correct the readme title * Updated feature name in the docs * Update EECONFIG name * Add compile-time toggles for velocikey * Update feature documentation * Revert "Merge branch 'led-support' into master" This reverts commit e123ff5febf61639b9a9020748e1c2e2313460ff, reversing changes made to df111a55b9d4929182e16108b1c0ead15b16df97. * Move velocikey EECONFIG definition to depend on VELOCIKEY_ENABLE * Rename decay_task function to decelerate * Apply suggestions from code review Co-Authored-By: chrislewisdev <chris@chrislewisdev.com> * Re-order eeconfig definitions * Apply coding conventions * Apply #ifdef check in lufa.c * Refactored interval time checks into one functionc * Small rename * Fix unused function error for layouts not using all rgb effects * Only update EEPROM if Velocikey is enabled * Incorporate code review feedback * Small adjustment to top-end decay rate * Add Velocikey documentation to table of contents * Bring tetris:default keymap size down by disabling audio
5 years ago
Backlighting for JJ40 and underglow initialisation code (#2260) * Cleanup Mechmini keymap. Once the custom RGB function is defined, there is no need to manually handle RGB code. * Change default to KEYMAP_MIT, not KEYMAP_OFFSET * Add custom RGB code for JJ40 * Reset Mechmini advertised power draw to 500. Will have to test actual maximum power draw later. * RGB working on JJ40. * Fix: saturation increase/decrease flipped * Add new directory for my custom keymap with RGB keycodes * Swap LAlt and LGUI * Update JJ40 max power draw with measured value * Update: fun40 rules.mk to enable underglow; earlier failed Travis CI * Fix: init RGB LEDs on boot. Also added HHKB-like keymap for XD60. * Super rudimentary backlight test, init RGB LEDs on boot * Backlighting works - stays on for now * Toggling working * Now can override backlight.c functions. Problem was functions in backlight.c weren't called before due to a lack of matrix_scan_quantum() in matrix.c * Timers not working * Delete global.h * Cleanup * Compiles * Good sign: LEDs stop working again * Handle timer1 overflow * Progress: fix: forgot to init * Backlighting fully working now except breathing. * Revert keymap to original keycodes * Update XD60 keymap README * Update JJ40 keymap with backlight toggles * Breathing working just fine. * Update references * Add backlight_set() call * Cleanup code to disable backlight * Fix: does not compile * Fix: missing call to rgblight_task. * Testing with BACKLIGHT_BREATHING * Cleanup * Cleanup comments * More commenting cleanup. * Do not enable BACKLIGHT_BREATHING by default
6 years ago
Process combos earlier & overlapping combos (#8591) * Combo processing improvements. Now it is possible to use ModTap and LayerTap keys as part of combos. Overlapping combos also don't trigger all the combos, just exactly the one that you press. New settings: - COMBO_MUST_HOLD_MODS - COMBO_MOD_TERM - COMBO_TERM_PER_COMBO - COMBO_MUST_HOLD_PER_COMBO - COMBO_STRICT_TIMER - COMBO_NO_TIMER * Remove the size flags from combo_t struct boolean members. This in the end actually saves space as the members are accessed so many times. The amount of operations needed to access the bits uses more memory than setting the size saves. * Fix `process_combo_key_release` not called correctly with tap-only combos * Fix not passing a pointer when NO_ACTION_TAPPING is defined. * Docs for `COMBO_ONLY_FROM_LAYER` * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update quantum/process_keycode/process_combo.c Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Add `EXTRA_SHORT_COMBOS` option. Stuff combo's `disabled` and `active` flags into `state`. Possibly can save some space. * Add more examples and clarify things with dict management system. - Simple examples now has a combo that has modifiers included. - The slightly more advanced examples now are actually more advanced instead of just `tap_code16(<modded-keycode>)`. - Added a note that `COMBO_ACTION`s are not needed anymore as you can just use custom keycodes. - Added a note that the `g/keymap_combo.h` macros use the `process_combo_event` function and that it is not usable in one's keymap afterwards. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Change "the" combo action example to "email" example. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Fix sneaky infinite loop with `combo_disable()` No need to call `dump_key_buffer` when disabling combos because the buffer is either being dumped if a combo-key was pressed, or the buffer is empty if a non-combo-key is pressed. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> Co-authored-by: Drashna Jaelre <drashna@live.com>
2 years ago
Process combos earlier & overlapping combos (#8591) * Combo processing improvements. Now it is possible to use ModTap and LayerTap keys as part of combos. Overlapping combos also don't trigger all the combos, just exactly the one that you press. New settings: - COMBO_MUST_HOLD_MODS - COMBO_MOD_TERM - COMBO_TERM_PER_COMBO - COMBO_MUST_HOLD_PER_COMBO - COMBO_STRICT_TIMER - COMBO_NO_TIMER * Remove the size flags from combo_t struct boolean members. This in the end actually saves space as the members are accessed so many times. The amount of operations needed to access the bits uses more memory than setting the size saves. * Fix `process_combo_key_release` not called correctly with tap-only combos * Fix not passing a pointer when NO_ACTION_TAPPING is defined. * Docs for `COMBO_ONLY_FROM_LAYER` * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update quantum/process_keycode/process_combo.c Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Add `EXTRA_SHORT_COMBOS` option. Stuff combo's `disabled` and `active` flags into `state`. Possibly can save some space. * Add more examples and clarify things with dict management system. - Simple examples now has a combo that has modifiers included. - The slightly more advanced examples now are actually more advanced instead of just `tap_code16(<modded-keycode>)`. - Added a note that `COMBO_ACTION`s are not needed anymore as you can just use custom keycodes. - Added a note that the `g/keymap_combo.h` macros use the `process_combo_event` function and that it is not usable in one's keymap afterwards. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Change "the" combo action example to "email" example. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Fix sneaky infinite loop with `combo_disable()` No need to call `dump_key_buffer` when disabling combos because the buffer is either being dumped if a combo-key was pressed, or the buffer is empty if a non-combo-key is pressed. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> Co-authored-by: Drashna Jaelre <drashna@live.com>
2 years ago
Process combos earlier & overlapping combos (#8591) * Combo processing improvements. Now it is possible to use ModTap and LayerTap keys as part of combos. Overlapping combos also don't trigger all the combos, just exactly the one that you press. New settings: - COMBO_MUST_HOLD_MODS - COMBO_MOD_TERM - COMBO_TERM_PER_COMBO - COMBO_MUST_HOLD_PER_COMBO - COMBO_STRICT_TIMER - COMBO_NO_TIMER * Remove the size flags from combo_t struct boolean members. This in the end actually saves space as the members are accessed so many times. The amount of operations needed to access the bits uses more memory than setting the size saves. * Fix `process_combo_key_release` not called correctly with tap-only combos * Fix not passing a pointer when NO_ACTION_TAPPING is defined. * Docs for `COMBO_ONLY_FROM_LAYER` * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update quantum/process_keycode/process_combo.c Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Add `EXTRA_SHORT_COMBOS` option. Stuff combo's `disabled` and `active` flags into `state`. Possibly can save some space. * Add more examples and clarify things with dict management system. - Simple examples now has a combo that has modifiers included. - The slightly more advanced examples now are actually more advanced instead of just `tap_code16(<modded-keycode>)`. - Added a note that `COMBO_ACTION`s are not needed anymore as you can just use custom keycodes. - Added a note that the `g/keymap_combo.h` macros use the `process_combo_event` function and that it is not usable in one's keymap afterwards. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Change "the" combo action example to "email" example. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Fix sneaky infinite loop with `combo_disable()` No need to call `dump_key_buffer` when disabling combos because the buffer is either being dumped if a combo-key was pressed, or the buffer is empty if a non-combo-key is pressed. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> Co-authored-by: Drashna Jaelre <drashna@live.com>
2 years ago
Process combos earlier & overlapping combos (#8591) * Combo processing improvements. Now it is possible to use ModTap and LayerTap keys as part of combos. Overlapping combos also don't trigger all the combos, just exactly the one that you press. New settings: - COMBO_MUST_HOLD_MODS - COMBO_MOD_TERM - COMBO_TERM_PER_COMBO - COMBO_MUST_HOLD_PER_COMBO - COMBO_STRICT_TIMER - COMBO_NO_TIMER * Remove the size flags from combo_t struct boolean members. This in the end actually saves space as the members are accessed so many times. The amount of operations needed to access the bits uses more memory than setting the size saves. * Fix `process_combo_key_release` not called correctly with tap-only combos * Fix not passing a pointer when NO_ACTION_TAPPING is defined. * Docs for `COMBO_ONLY_FROM_LAYER` * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update quantum/process_keycode/process_combo.c Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Add `EXTRA_SHORT_COMBOS` option. Stuff combo's `disabled` and `active` flags into `state`. Possibly can save some space. * Add more examples and clarify things with dict management system. - Simple examples now has a combo that has modifiers included. - The slightly more advanced examples now are actually more advanced instead of just `tap_code16(<modded-keycode>)`. - Added a note that `COMBO_ACTION`s are not needed anymore as you can just use custom keycodes. - Added a note that the `g/keymap_combo.h` macros use the `process_combo_event` function and that it is not usable in one's keymap afterwards. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Change "the" combo action example to "email" example. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Fix sneaky infinite loop with `combo_disable()` No need to call `dump_key_buffer` when disabling combos because the buffer is either being dumped if a combo-key was pressed, or the buffer is empty if a non-combo-key is pressed. * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> * Update docs/feature_combo.md Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> Co-authored-by: precondition <57645186+precondition@users.noreply.github.com> Co-authored-by: Drashna Jaelre <drashna@live.com>
2 years ago
Velocikey: Match RGB animation speed to typing speed (#3754) * Draft commit of typing speed RGB control * More information in the readme * Support all RGB animation modes (Fixes #1) * Added support for all RGB light modes to use typing speed Except christmas lights because that is seizure-inducing at high speeds! * Introduced a value range specific to each RGB mode Because some modes are a little too much when running at full speed! * Update readme.md * Update readme.md * Re-arrange typing_speed definitions (Fixes #5) (#6) * Re-arrange variable definitions to avoid including quantum.h from rgblight.c * Fix a compilation error when trying to run make test:all * Tweaks to the typing speed decay rate * Renamed to momentum; moved implementation into dedicated files * Groundwork for toggling momentum on/off (currently always on) * Add EEPROM toggle for momentum-matching * Moved momentum out of RGBLIGHT_ENABLE toggles so it's more generic * Move momentum decay task out of rgblight_task() * Fix missing momentum.h in lufa.c * Experimental LED support (untested) * Draft commit of typing speed RGB control * More information in the readme * Support all RGB animation modes (Fixes #1) * Added support for all RGB light modes to use typing speed Except christmas lights because that is seizure-inducing at high speeds! * Introduced a value range specific to each RGB mode Because some modes are a little too much when running at full speed! * Update readme.md * Update readme.md * Re-arrange typing_speed definitions (Fixes #5) (#6) * Re-arrange variable definitions to avoid including quantum.h from rgblight.c * Fix a compilation error when trying to run make test:all * Tweaks to the typing speed decay rate * Renamed to momentum; moved implementation into dedicated files * Groundwork for toggling momentum on/off (currently always on) * Add EEPROM toggle for momentum-matching * Moved momentum out of RGBLIGHT_ENABLE toggles so it's more generic * Move momentum decay task out of rgblight_task() * Fix missing momentum.h in lufa.c * Added documentation * Renamed feature to velocikey * Reverted readme to original state * Correct the readme title * Updated feature name in the docs * Update EECONFIG name * Add compile-time toggles for velocikey * Update feature documentation * Revert "Merge branch 'led-support' into master" This reverts commit e123ff5febf61639b9a9020748e1c2e2313460ff, reversing changes made to df111a55b9d4929182e16108b1c0ead15b16df97. * Move velocikey EECONFIG definition to depend on VELOCIKEY_ENABLE * Rename decay_task function to decelerate * Apply suggestions from code review Co-Authored-By: chrislewisdev <chris@chrislewisdev.com> * Re-order eeconfig definitions * Apply coding conventions * Apply #ifdef check in lufa.c * Refactored interval time checks into one functionc * Small rename * Fix unused function error for layouts not using all rgb effects * Only update EEPROM if Velocikey is enabled * Incorporate code review feedback * Small adjustment to top-end decay rate * Add Velocikey documentation to table of contents * Bring tetris:default keymap size down by disabling audio
5 years ago
2020 November 28 Breaking Changes Update (#11053) * Branch point for 2020 November 28 Breaking Change * Remove matrix_col_t to allow MATRIX_ROWS > 32 (#10183) * Add support for soft serial to ATmega32U2 (#10204) * Change MIDI velocity implementation to allow direct control of velocity value (#9940) * Add ability to build a subset of all keyboards based on platform. * Actually use eeprom_driver_init(). * Make bootloader_jump weak for ChibiOS. (#10417) * Joystick 16-bit support (#10439) * Per-encoder resolutions (#10259) * Share button state from mousekey to pointing_device (#10179) * Add hotfix for chibios keyboards not wake (#10088) * Add advanced/efficient RGB Matrix Indicators (#8564) * Naming change. * Support for STM32 GPIOF,G,H,I,J,K (#10206) * Add milc as a dependency and remove the installed milc (#10563) * ChibiOS upgrade: early init conversions (#10214) * ChibiOS upgrade: configuration file migrator (#9952) * Haptic and solenoid cleanup (#9700) * XD75 cleanup (#10524) * OLED display update interval support (#10388) * Add definition based on currently-selected serial driver. (#10716) * New feature: Retro Tapping per key (#10622) * Allow for modification of output RGB values when using rgblight/rgb_matrix. (#10638) * Add housekeeping task callbacks so that keyboards/keymaps are capable of executing code for each main loop iteration. (#10530) * Rescale both ChibiOS and AVR backlighting. * Reduce Helix keyboard build variation (#8669) * Minor change to behavior allowing display updates to continue between task ticks (#10750) * Some GPIO manipulations in matrix.c change to atomic. (#10491) * qmk cformat (#10767) * [Keyboard] Update the Speedo firmware for v3.0 (#10657) * Maartenwut/Maarten namechange to evyd13/Evy (#10274) * [quantum] combine repeated lines of code (#10837) * Add step sequencer feature (#9703) * aeboards/ext65 refactor (#10820) * Refactor xelus/dawn60 for Rev2 later (#10584) * add DEBUG_MATRIX_SCAN_RATE_ENABLE to common_features.mk (#10824) * [Core] Added `add_oneshot_mods` & `del_oneshot_mods` (#10549) * update chibios os usb for the otg driver (#8893) * Remove HD44780 References, Part 4 (#10735) * [Keyboard] Add Valor FRL TKL (+refactor) (#10512) * Fix cursor position bug in oled_write_raw functions (#10800) * Fixup version.h writing when using SKIP_VERSION=yes (#10972) * Allow for certain code in the codebase assuming length of string. (#10974) * Add AT90USB support for serial.c (#10706) * Auto shift: support repeats and early registration (#9826) * Rename ledmatrix.h to match .c file (#7949) * Split RGB_MATRIX_ENABLE into _ENABLE and _DRIVER (#10231) * Split LED_MATRIX_ENABLE into _ENABLE and _DRIVER (#10840) * Merge point for 2020 Nov 28 Breaking Change
3 years ago
Hid joystick interface (#4226) * add support for hid gamepad interface add documentation for HID joystick Add joystick_task to read analog axes values even when no key is pressed or release. update doc Update docs/feature_joystick.md Manage pin setup and read to maintain matrix scan after analog read * Incorporates patches and changes to HID reporting There are some patches provided by @a-chol incorporated on this commit, and also some changes I made to the HID Report structure. The most interesting is the one dealing with number of buttons: Linux doesn't seem to care, but Windows requires the HID structure to be byte aligned (that's in the spec). So if one declares 8/16/32... buttons they should not have any issues, but this is what happens when you have 9 buttons: ``` bits |0|1|2|3|4|5|6|7| |*|*|*|*|*|*|*|*| axis 0 (report size 8) |*|*|*|*|*|*|*|*| ... |*|*|*|*|*|*|*|*| |*|*|*|*|*|*|*|*| |*|*|*|*|*|*|*|*| |*|*|*|*|*|*|*|*| |*|*|*|*|*|*|*|*| axis 6 |*|*|*|*|*|*|*|*| first 8 buttons (report size 1) |*| | | | | | | | last of 9 buttons, not aligned ``` So for that I added a conditonal that will add a number of reports with size 1 to make sure it aligns to the next multiple of 8. Those reports send dummy inputs that don't do anything aside from aligning the data. Tested on Linux, Windows 10 and Street Fighter (where the joystick is recognized as direct-input) * Add save and restore of each pin used in reading joystick (AVR). Allow output pin to be JS_VIRTUAL_AXIS if the axis is connected to Vcc instead of an output pin from the MCU. Fix joystick report id Fix broken v-usb hid joystick interface. Make it more resilient to unusual settings (none multiple of eight button count, 0 buttons or 0 axes) Correct adc reading for multiple axes. Piecewise range conversion for uncentered raw value range. Input, output and ground pin configuration per axis. Documentation fixes * Fix port addressing for joystick analog read * The other required set of changes As per the PR, the changes still holding it up. Add onekey for testing. Fix ARM builds. Fix device descriptor when either axes or buttons is zero. Add compile-time check for at least one axis or button. Move definition to try to fix conflict. PR review comments. qmk cformat * avoid float functions to compute range mapping for axis adc reading * Remove V-USB support for now. Updated docs accordingly. * Update tmk_core/protocol/lufa/lufa.c Co-Authored-By: Ryan <fauxpark@gmail.com> * Update tmk_core/protocol/usb_descriptor.c Co-Authored-By: Ryan <fauxpark@gmail.com> * Update tmk_core/protocol/usb_descriptor.c Co-Authored-By: Ryan <fauxpark@gmail.com> * Update tmk_core/protocol/usb_descriptor.c Co-Authored-By: Ryan <fauxpark@gmail.com> * Add support for joystick adc reading for stm32 MCUs. Fix joystick hid report sending for chibios * Fix HID joystick report sending for ChibiOS. Add one analog axis to the onekey:joystick keymap. Fix pin state save and restore during joystick analog read for STM32 MCUs. * Update tmk_core/protocol/chibios/usb_main.c Co-Authored-By: Ryan <fauxpark@gmail.com> * Update tmk_core/protocol/lufa/lufa.c Co-Authored-By: Ryan <fauxpark@gmail.com> * Add missing mcuconf.h and halconf.h to onekey:joystick keymap. Add suggested fixes from PR. * Switch saveState and restoreState signature to use pin_t type. onekey:joystick : add a second axis, virtual and programmatically animated. * Update docs/feature_joystick.md Co-Authored-By: Ryan <fauxpark@gmail.com> * Update docs/feature_joystick.md Co-Authored-By: Ryan <fauxpark@gmail.com> * Add PR corrections * Remove halconf.h and mcuconf.h from onekey keymaps * Change ADC_PIN to A0 Co-authored-by: achol <allecooll@hotmail.com> Co-authored-by: José Júnior <jose.junior@gmail.com> Co-authored-by: a-chol <achol@notamail.com> Co-authored-by: Nick Brassel <nick@tzarc.org> Co-authored-by: Ryan <fauxpark@gmail.com>
3 years ago
  1. /* Copyright 2016-2017 Jack Humbert
  2. *
  3. * This program is free software: you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License as published by
  5. * the Free Software Foundation, either version 2 of the License, or
  6. * (at your option) any later version.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU General Public License
  14. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  15. */
  16. #include "quantum.h"
  17. #ifdef BLUETOOTH_ENABLE
  18. # include "outputselect.h"
  19. #endif
  20. #ifdef BACKLIGHT_ENABLE
  21. # include "backlight.h"
  22. #endif
  23. #ifdef MIDI_ENABLE
  24. # include "process_midi.h"
  25. #endif
  26. #ifdef VELOCIKEY_ENABLE
  27. # include "velocikey.h"
  28. #endif
  29. #ifdef HAPTIC_ENABLE
  30. # include "haptic.h"
  31. #endif
  32. #ifdef AUDIO_ENABLE
  33. # ifndef GOODBYE_SONG
  34. # define GOODBYE_SONG SONG(GOODBYE_SOUND)
  35. # endif
  36. float goodbye_song[][2] = GOODBYE_SONG;
  37. # ifdef DEFAULT_LAYER_SONGS
  38. float default_layer_songs[][16][2] = DEFAULT_LAYER_SONGS;
  39. # endif
  40. #endif
  41. uint8_t extract_mod_bits(uint16_t code) {
  42. switch (code) {
  43. case QK_MODS ... QK_MODS_MAX:
  44. break;
  45. default:
  46. return 0;
  47. }
  48. uint8_t mods_to_send = 0;
  49. if (code & QK_RMODS_MIN) { // Right mod flag is set
  50. if (code & QK_LCTL) mods_to_send |= MOD_BIT(KC_RIGHT_CTRL);
  51. if (code & QK_LSFT) mods_to_send |= MOD_BIT(KC_RIGHT_SHIFT);
  52. if (code & QK_LALT) mods_to_send |= MOD_BIT(KC_RIGHT_ALT);
  53. if (code & QK_LGUI) mods_to_send |= MOD_BIT(KC_RIGHT_GUI);
  54. } else {
  55. if (code & QK_LCTL) mods_to_send |= MOD_BIT(KC_LEFT_CTRL);
  56. if (code & QK_LSFT) mods_to_send |= MOD_BIT(KC_LEFT_SHIFT);
  57. if (code & QK_LALT) mods_to_send |= MOD_BIT(KC_LEFT_ALT);
  58. if (code & QK_LGUI) mods_to_send |= MOD_BIT(KC_LEFT_GUI);
  59. }
  60. return mods_to_send;
  61. }
  62. void do_code16(uint16_t code, void (*f)(uint8_t)) {
  63. f(extract_mod_bits(code));
  64. }
  65. __attribute__((weak)) void register_code16(uint16_t code) {
  66. if (IS_MOD(code) || code == KC_NO) {
  67. do_code16(code, register_mods);
  68. } else {
  69. do_code16(code, register_weak_mods);
  70. }
  71. register_code(code);
  72. }
  73. __attribute__((weak)) void unregister_code16(uint16_t code) {
  74. unregister_code(code);
  75. if (IS_MOD(code) || code == KC_NO) {
  76. do_code16(code, unregister_mods);
  77. } else {
  78. do_code16(code, unregister_weak_mods);
  79. }
  80. }
  81. __attribute__((weak)) void tap_code16(uint16_t code) {
  82. register_code16(code);
  83. if (code == KC_CAPS_LOCK) {
  84. wait_ms(TAP_HOLD_CAPS_DELAY);
  85. } else if (TAP_CODE_DELAY > 0) {
  86. wait_ms(TAP_CODE_DELAY);
  87. }
  88. unregister_code16(code);
  89. }
  90. __attribute__((weak)) bool process_action_kb(keyrecord_t *record) {
  91. return true;
  92. }
  93. __attribute__((weak)) bool process_record_kb(uint16_t keycode, keyrecord_t *record) {
  94. return process_record_user(keycode, record);
  95. }
  96. __attribute__((weak)) bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  97. return true;
  98. }
  99. __attribute__((weak)) void post_process_record_kb(uint16_t keycode, keyrecord_t *record) {
  100. post_process_record_user(keycode, record);
  101. }
  102. __attribute__((weak)) void post_process_record_user(uint16_t keycode, keyrecord_t *record) {}
  103. void shutdown_quantum(void) {
  104. clear_keyboard();
  105. #if defined(MIDI_ENABLE) && defined(MIDI_BASIC)
  106. process_midi_all_notes_off();
  107. #endif
  108. #ifdef AUDIO_ENABLE
  109. # ifndef NO_MUSIC_MODE
  110. music_all_notes_off();
  111. # endif
  112. uint16_t timer_start = timer_read();
  113. PLAY_SONG(goodbye_song);
  114. shutdown_user();
  115. while (timer_elapsed(timer_start) < 250)
  116. wait_ms(1);
  117. stop_all_notes();
  118. #else
  119. shutdown_user();
  120. wait_ms(250);
  121. #endif
  122. #ifdef HAPTIC_ENABLE
  123. haptic_shutdown();
  124. #endif
  125. }
  126. void reset_keyboard(void) {
  127. shutdown_quantum();
  128. bootloader_jump();
  129. }
  130. void soft_reset_keyboard(void) {
  131. shutdown_quantum();
  132. mcu_reset();
  133. }
  134. /* Convert record into usable keycode via the contained event. */
  135. uint16_t get_record_keycode(keyrecord_t *record, bool update_layer_cache) {
  136. #ifdef COMBO_ENABLE
  137. if (record->keycode) {
  138. return record->keycode;
  139. }
  140. #endif
  141. return get_event_keycode(record->event, update_layer_cache);
  142. }
  143. /* Convert event into usable keycode. Checks the layer cache to ensure that it
  144. * retains the correct keycode after a layer change, if the key is still pressed.
  145. * "update_layer_cache" is to ensure that it only updates the layer cache when
  146. * appropriate, otherwise, it will update it and cause layer tap (and other keys)
  147. * from triggering properly.
  148. */
  149. uint16_t get_event_keycode(keyevent_t event, bool update_layer_cache) {
  150. #if !defined(NO_ACTION_LAYER) && !defined(STRICT_LAYER_RELEASE)
  151. /* TODO: Use store_or_get_action() or a similar function. */
  152. if (!disable_action_cache) {
  153. uint8_t layer;
  154. if (event.pressed && update_layer_cache) {
  155. layer = layer_switch_get_layer(event.key);
  156. update_source_layers_cache(event.key, layer);
  157. } else {
  158. layer = read_source_layers_cache(event.key);
  159. }
  160. return keymap_key_to_keycode(layer, event.key);
  161. } else
  162. #endif
  163. return keymap_key_to_keycode(layer_switch_get_layer(event.key), event.key);
  164. }
  165. /* Get keycode, and then process pre tapping functionality */
  166. bool pre_process_record_quantum(keyrecord_t *record) {
  167. if (!(
  168. #ifdef COMBO_ENABLE
  169. process_combo(get_record_keycode(record, true), record) &&
  170. #endif
  171. true)) {
  172. return false;
  173. }
  174. return true; // continue processing
  175. }
  176. /* Get keycode, and then call keyboard function */
  177. void post_process_record_quantum(keyrecord_t *record) {
  178. uint16_t keycode = get_record_keycode(record, false);
  179. post_process_record_kb(keycode, record);
  180. }
  181. /* Core keycode function, hands off handling to other functions,
  182. then processes internal quantum keycodes, and then processes
  183. ACTIONs. */
  184. bool process_record_quantum(keyrecord_t *record) {
  185. uint16_t keycode = get_record_keycode(record, true);
  186. // This is how you use actions here
  187. // if (keycode == KC_LEAD) {
  188. // action_t action;
  189. // action.code = ACTION_DEFAULT_LAYER_SET(0);
  190. // process_action(record, action);
  191. // return false;
  192. // }
  193. #if defined(SECURE_ENABLE)
  194. if (!preprocess_secure(keycode, record)) {
  195. return false;
  196. }
  197. #endif
  198. #ifdef VELOCIKEY_ENABLE
  199. if (velocikey_enabled() && record->event.pressed) {
  200. velocikey_accelerate();
  201. }
  202. #endif
  203. #ifdef WPM_ENABLE
  204. if (record->event.pressed) {
  205. update_wpm(keycode);
  206. }
  207. #endif
  208. #ifdef TAP_DANCE_ENABLE
  209. preprocess_tap_dance(keycode, record);
  210. #endif
  211. if (!(
  212. #if defined(KEY_LOCK_ENABLE)
  213. // Must run first to be able to mask key_up events.
  214. process_key_lock(&keycode, record) &&
  215. #endif
  216. #if defined(DYNAMIC_MACRO_ENABLE) && !defined(DYNAMIC_MACRO_USER_CALL)
  217. // Must run asap to ensure all keypresses are recorded.
  218. process_dynamic_macro(keycode, record) &&
  219. #endif
  220. #if defined(AUDIO_ENABLE) && defined(AUDIO_CLICKY)
  221. process_clicky(keycode, record) &&
  222. #endif
  223. #ifdef HAPTIC_ENABLE
  224. process_haptic(keycode, record) &&
  225. #endif
  226. #if defined(VIA_ENABLE)
  227. process_record_via(keycode, record) &&
  228. #endif
  229. process_record_kb(keycode, record) &&
  230. #if defined(SECURE_ENABLE)
  231. process_secure(keycode, record) &&
  232. #endif
  233. #if defined(SEQUENCER_ENABLE)
  234. process_sequencer(keycode, record) &&
  235. #endif
  236. #if defined(MIDI_ENABLE) && defined(MIDI_ADVANCED)
  237. process_midi(keycode, record) &&
  238. #endif
  239. #ifdef AUDIO_ENABLE
  240. process_audio(keycode, record) &&
  241. #endif
  242. #if defined(BACKLIGHT_ENABLE) || defined(LED_MATRIX_ENABLE)
  243. process_backlight(keycode, record) &&
  244. #endif
  245. #ifdef STENO_ENABLE
  246. process_steno(keycode, record) &&
  247. #endif
  248. #if (defined(AUDIO_ENABLE) || (defined(MIDI_ENABLE) && defined(MIDI_BASIC))) && !defined(NO_MUSIC_MODE)
  249. process_music(keycode, record) &&
  250. #endif
  251. #ifdef KEY_OVERRIDE_ENABLE
  252. process_key_override(keycode, record) &&
  253. #endif
  254. #ifdef TAP_DANCE_ENABLE
  255. process_tap_dance(keycode, record) &&
  256. #endif
  257. #if defined(UNICODE_COMMON_ENABLE)
  258. process_unicode_common(keycode, record) &&
  259. #endif
  260. #ifdef LEADER_ENABLE
  261. process_leader(keycode, record) &&
  262. #endif
  263. #ifdef PRINTING_ENABLE
  264. process_printer(keycode, record) &&
  265. #endif
  266. #ifdef AUTO_SHIFT_ENABLE
  267. process_auto_shift(keycode, record) &&
  268. #endif
  269. #ifdef DYNAMIC_TAPPING_TERM_ENABLE
  270. process_dynamic_tapping_term(keycode, record) &&
  271. #endif
  272. #ifdef TERMINAL_ENABLE
  273. process_terminal(keycode, record) &&
  274. #endif
  275. #ifdef CAPS_WORD_ENABLE
  276. process_caps_word(keycode, record) &&
  277. #endif
  278. #ifdef SPACE_CADET_ENABLE
  279. process_space_cadet(keycode, record) &&
  280. #endif
  281. #ifdef MAGIC_KEYCODE_ENABLE
  282. process_magic(keycode, record) &&
  283. #endif
  284. #ifdef GRAVE_ESC_ENABLE
  285. process_grave_esc(keycode, record) &&
  286. #endif
  287. #if defined(RGBLIGHT_ENABLE) || defined(RGB_MATRIX_ENABLE)
  288. process_rgb(keycode, record) &&
  289. #endif
  290. #ifdef JOYSTICK_ENABLE
  291. process_joystick(keycode, record) &&
  292. #endif
  293. #ifdef PROGRAMMABLE_BUTTON_ENABLE
  294. process_programmable_button(keycode, record) &&
  295. #endif
  296. true)) {
  297. return false;
  298. }
  299. if (record->event.pressed) {
  300. switch (keycode) {
  301. #ifndef NO_RESET
  302. case QK_BOOTLOADER:
  303. reset_keyboard();
  304. return false;
  305. case QK_REBOOT:
  306. soft_reset_keyboard();
  307. return false;
  308. #endif
  309. #ifndef NO_DEBUG
  310. case QK_DEBUG_TOGGLE:
  311. debug_enable ^= 1;
  312. if (debug_enable) {
  313. print("DEBUG: enabled.\n");
  314. } else {
  315. print("DEBUG: disabled.\n");
  316. }
  317. #endif
  318. return false;
  319. case QK_CLEAR_EEPROM:
  320. eeconfig_init();
  321. #ifndef NO_RESET
  322. soft_reset_keyboard();
  323. #endif
  324. return false;
  325. #ifdef VELOCIKEY_ENABLE
  326. case VLK_TOG:
  327. velocikey_toggle();
  328. return false;
  329. #endif
  330. #ifdef BLUETOOTH_ENABLE
  331. case OUT_AUTO:
  332. set_output(OUTPUT_AUTO);
  333. return false;
  334. case OUT_USB:
  335. set_output(OUTPUT_USB);
  336. return false;
  337. case OUT_BT:
  338. set_output(OUTPUT_BLUETOOTH);
  339. return false;
  340. #endif
  341. #ifndef NO_ACTION_ONESHOT
  342. case ONESHOT_TOGGLE:
  343. oneshot_toggle();
  344. break;
  345. case ONESHOT_ENABLE:
  346. oneshot_enable();
  347. break;
  348. case ONESHOT_DISABLE:
  349. oneshot_disable();
  350. break;
  351. #endif
  352. #ifdef ENABLE_COMPILE_KEYCODE
  353. case QK_MAKE: // Compiles the firmware, and adds the flash command based on keyboard bootloader
  354. {
  355. # ifdef NO_ACTION_ONESHOT
  356. const uint8_t temp_mod = mod_config(get_mods());
  357. # else
  358. const uint8_t temp_mod = mod_config(get_mods() | get_oneshot_mods());
  359. clear_oneshot_mods();
  360. # endif
  361. clear_mods();
  362. SEND_STRING_DELAY("qmk", TAP_CODE_DELAY);
  363. if (temp_mod & MOD_MASK_SHIFT) { // if shift is held, flash rather than compile
  364. SEND_STRING_DELAY(" flash ", TAP_CODE_DELAY);
  365. } else {
  366. SEND_STRING_DELAY(" compile ", TAP_CODE_DELAY);
  367. }
  368. SEND_STRING_DELAY("-kb " QMK_KEYBOARD " -km " QMK_KEYMAP SS_TAP(X_ENTER), TAP_CODE_DELAY);
  369. }
  370. #endif
  371. }
  372. }
  373. return process_action_kb(record);
  374. }
  375. void set_single_persistent_default_layer(uint8_t default_layer) {
  376. #if defined(AUDIO_ENABLE) && defined(DEFAULT_LAYER_SONGS)
  377. PLAY_SONG(default_layer_songs[default_layer]);
  378. #endif
  379. eeconfig_update_default_layer((layer_state_t)1 << default_layer);
  380. default_layer_set((layer_state_t)1 << default_layer);
  381. }
  382. layer_state_t update_tri_layer_state(layer_state_t state, uint8_t layer1, uint8_t layer2, uint8_t layer3) {
  383. layer_state_t mask12 = ((layer_state_t)1 << layer1) | ((layer_state_t)1 << layer2);
  384. layer_state_t mask3 = (layer_state_t)1 << layer3;
  385. return (state & mask12) == mask12 ? (state | mask3) : (state & ~mask3);
  386. }
  387. void update_tri_layer(uint8_t layer1, uint8_t layer2, uint8_t layer3) {
  388. layer_state_set(update_tri_layer_state(layer_state, layer1, layer2, layer3));
  389. }
  390. // TODO: remove legacy api
  391. void matrix_init_quantum() {
  392. matrix_init_kb();
  393. }
  394. void matrix_scan_quantum() {
  395. matrix_scan_kb();
  396. }
  397. //------------------------------------------------------------------------------
  398. // Override these functions in your keymap file to play different tunes on
  399. // different events such as startup and bootloader jump
  400. __attribute__((weak)) void startup_user() {}
  401. __attribute__((weak)) void shutdown_user() {}
  402. void suspend_power_down_quantum(void) {
  403. suspend_power_down_kb();
  404. #ifndef NO_SUSPEND_POWER_DOWN
  405. // Turn off backlight
  406. # ifdef BACKLIGHT_ENABLE
  407. backlight_set(0);
  408. # endif
  409. # ifdef LED_MATRIX_ENABLE
  410. led_matrix_task();
  411. # endif
  412. # ifdef RGB_MATRIX_ENABLE
  413. rgb_matrix_task();
  414. # endif
  415. // Turn off LED indicators
  416. led_suspend();
  417. // Turn off audio
  418. # ifdef AUDIO_ENABLE
  419. stop_all_notes();
  420. # endif
  421. // Turn off underglow
  422. # if defined(RGBLIGHT_SLEEP) && defined(RGBLIGHT_ENABLE)
  423. rgblight_suspend();
  424. # endif
  425. # if defined(LED_MATRIX_ENABLE)
  426. led_matrix_set_suspend_state(true);
  427. # endif
  428. # if defined(RGB_MATRIX_ENABLE)
  429. rgb_matrix_set_suspend_state(true);
  430. # endif
  431. # ifdef OLED_ENABLE
  432. oled_off();
  433. # endif
  434. # ifdef ST7565_ENABLE
  435. st7565_off();
  436. # endif
  437. # if defined(POINTING_DEVICE_ENABLE)
  438. // run to ensure scanning occurs while suspended
  439. pointing_device_task();
  440. # endif
  441. #endif
  442. }
  443. __attribute__((weak)) void suspend_wakeup_init_quantum(void) {
  444. // Turn on backlight
  445. #ifdef BACKLIGHT_ENABLE
  446. backlight_init();
  447. #endif
  448. // Restore LED indicators
  449. led_wakeup();
  450. // Wake up underglow
  451. #if defined(RGBLIGHT_SLEEP) && defined(RGBLIGHT_ENABLE)
  452. rgblight_wakeup();
  453. #endif
  454. #if defined(LED_MATRIX_ENABLE)
  455. led_matrix_set_suspend_state(false);
  456. #endif
  457. #if defined(RGB_MATRIX_ENABLE)
  458. rgb_matrix_set_suspend_state(false);
  459. #endif
  460. suspend_wakeup_init_kb();
  461. }
  462. /** \brief converts unsigned integers into char arrays
  463. *
  464. * Takes an unsigned integer and converts that value into an equivalent char array
  465. * A padding character may be specified, ' ' for leading spaces, '0' for leading zeros.
  466. */
  467. const char *get_numeric_str(char *buf, size_t buf_len, uint32_t curr_num, char curr_pad) {
  468. buf[buf_len - 1] = '\0';
  469. for (size_t i = 0; i < buf_len - 1; ++i) {
  470. char c = '0' + curr_num % 10;
  471. buf[buf_len - 2 - i] = (c == '0' && i == 0) ? '0' : (curr_num > 0 ? c : curr_pad);
  472. curr_num /= 10;
  473. }
  474. return buf;
  475. }
  476. /** \brief converts uint8_t into char array
  477. *
  478. * Takes an uint8_t, and uses an internal static buffer to render that value into a char array
  479. * A padding character may be specified, ' ' for leading spaces, '0' for leading zeros.
  480. *
  481. * NOTE: Subsequent invocations will reuse the same static buffer and overwrite the previous
  482. * contents. Use the result immediately, instead of caching it.
  483. */
  484. const char *get_u8_str(uint8_t curr_num, char curr_pad) {
  485. static char buf[4] = {0};
  486. static uint8_t last_num = 0xFF;
  487. static char last_pad = '\0';
  488. if (last_num == curr_num && last_pad == curr_pad) {
  489. return buf;
  490. }
  491. last_num = curr_num;
  492. last_pad = curr_pad;
  493. return get_numeric_str(buf, sizeof(buf), curr_num, curr_pad);
  494. }
  495. /** \brief converts uint16_t into char array
  496. *
  497. * Takes an uint16_t, and uses an internal static buffer to render that value into a char array
  498. * A padding character may be specified, ' ' for leading spaces, '0' for leading zeros.
  499. *
  500. * NOTE: Subsequent invocations will reuse the same static buffer and overwrite the previous
  501. * contents. Use the result immediately, instead of caching it.
  502. */
  503. const char *get_u16_str(uint16_t curr_num, char curr_pad) {
  504. static char buf[6] = {0};
  505. static uint16_t last_num = 0xFF;
  506. static char last_pad = '\0';
  507. if (last_num == curr_num && last_pad == curr_pad) {
  508. return buf;
  509. }
  510. last_num = curr_num;
  511. last_pad = curr_pad;
  512. return get_numeric_str(buf, sizeof(buf), curr_num, curr_pad);
  513. }
  514. #if defined(SECURE_ENABLE)
  515. void secure_hook_quantum(secure_status_t secure_status) {
  516. // If keys are being held when this is triggered, they may not be released properly
  517. // this can result in stuck keys, mods and layers. To prevent that, manually
  518. // clear these, when it is triggered.
  519. if (secure_status == SECURE_PENDING) {
  520. clear_keyboard();
  521. layer_clear();
  522. }
  523. }
  524. #endif