1
0
Fork 0

Removal of bootmagic lite terminology (#22979)

This commit is contained in:
Joel Challis 2024-02-17 12:27:34 +00:00 committed by GitHub
parent 5383335717
commit e2dbe39b94
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
11 changed files with 103 additions and 78 deletions

View file

@ -20,44 +20,54 @@
#include "eeconfig.h"
#include "bootloader.h"
#ifndef BOOTMAGIC_DEBOUNCE
# if defined(DEBOUNCE) && DEBOUNCE > 0
# define BOOTMAGIC_DEBOUNCE (DEBOUNCE * 2)
# else
# define BOOTMAGIC_DEBOUNCE 30
# endif
#endif
/** \brief Reset eeprom
*
* ...just incase someone wants to only change the eeprom behaviour
*/
__attribute__((weak)) void bootmagic_lite_reset_eeprom(void) {
__attribute__((weak)) void bootmagic_reset_eeprom(void) {
eeconfig_disable();
}
/** \brief The lite version of TMK's bootmagic based on Wilba.
*
* 100% less potential for accidentally making the keyboard do stupid things.
/** \brief Decide reboot based on current matrix state
*/
__attribute__((weak)) void bootmagic_lite(void) {
// We need multiple scans because debouncing can't be turned off.
matrix_scan();
#if defined(DEBOUNCE) && DEBOUNCE > 0
wait_ms(DEBOUNCE * 2);
#else
wait_ms(30);
#endif
matrix_scan();
__attribute__((weak)) bool bootmagic_should_reset(void) {
// If the configured key (commonly Esc) is held down on power up,
// reset the EEPROM valid state and jump to bootloader.
// This isn't very generalized, but we need something that doesn't
// rely on user's keymaps in firmware or EEPROM.
uint8_t row = BOOTMAGIC_LITE_ROW;
uint8_t col = BOOTMAGIC_LITE_COLUMN;
uint8_t row = BOOTMAGIC_ROW;
uint8_t col = BOOTMAGIC_COLUMN;
#if defined(SPLIT_KEYBOARD) && defined(BOOTMAGIC_LITE_ROW_RIGHT) && defined(BOOTMAGIC_LITE_COLUMN_RIGHT)
#if defined(SPLIT_KEYBOARD) && defined(BOOTMAGIC_ROW_RIGHT) && defined(BOOTMAGIC_COLUMN_RIGHT)
if (!is_keyboard_left()) {
row = BOOTMAGIC_LITE_ROW_RIGHT;
col = BOOTMAGIC_LITE_COLUMN_RIGHT;
row = BOOTMAGIC_ROW_RIGHT;
col = BOOTMAGIC_COLUMN_RIGHT;
}
#endif
if (matrix_get_row(row) & (1 << col)) {
bootmagic_lite_reset_eeprom();
return matrix_get_row(row) & (1 << col);
}
/** \brief The abridged version of TMK's bootmagic based on Wilba.
*
* 100% less potential for accidentally making the keyboard do stupid things.
*/
__attribute__((weak)) void bootmagic_scan(void) {
// We need multiple scans because debouncing can't be turned off.
matrix_scan();
wait_ms(BOOTMAGIC_DEBOUNCE);
matrix_scan();
if (bootmagic_should_reset()) {
bootmagic_reset_eeprom();
// Jump to bootloader.
bootloader_jump();
@ -65,5 +75,5 @@ __attribute__((weak)) void bootmagic_lite(void) {
}
void bootmagic(void) {
bootmagic_lite();
bootmagic_scan();
}