Skip to content

Commit

Permalink
[Keymap] Fix bootmagic compilation issue with Drashna keymaps (#18223)
Browse files Browse the repository at this point in the history
  • Loading branch information
drashna authored Sep 2, 2022
1 parent 27671d8 commit 90418b3
Show file tree
Hide file tree
Showing 3 changed files with 60 additions and 54 deletions.
56 changes: 56 additions & 0 deletions users/drashna/bootmagic_better.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
// Copyright 2020 Christopher Courtney, aka Drashna Jael're (@drashna) <[email protected]>
// SPDX-License-Identifier: GPL-2.0-or-later

#include "drashna.h"
#include "bootmagic_lite.h"

void bootmagic_lite(void) {
bool perform_reset = false;
// 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();

// 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, col = BOOTMAGIC_LITE_COLUMN;
#if defined(BOOTMAGIC_LITE_EEPROM_ROW) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN)
uint8_t row_e = BOOTMAGIC_LITE_EEPROM_ROW, col_e = BOOTMAGIC_LITE_EEPROM_COLUMN;
#endif

#if defined(SPLIT_KEYBOARD) && defined(BOOTMAGIC_LITE_ROW_RIGHT) && defined(BOOTMAGIC_LITE_COLUMN_RIGHT)
if (!is_keyboard_left()) {
row = BOOTMAGIC_LITE_ROW_RIGHT;
col = BOOTMAGIC_LITE_COLUMN_RIGHT;
#if defined(BOOTMAGIC_LITE_EEPROM_ROW) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN) && defined(BOOTMAGIC_LITE_EEPROM_ROW_RIGHT) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN_RIGHT)
row_e = BOOTMAGIC_LITE_EEPROM_ROW_RIGHT;
col_e = BOOTMAGIC_LITE_EEPROM_COLUMN_RIGHT;
# endif
}
#endif

#if defined(BOOTMAGIC_LITE_EEPROM_ROW) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN)
if (matrix_get_row(row_e) & (1 << col_e)) {
eeconfig_disable();
perform_reset = true;
}
#endif
if (matrix_get_row(row) & (1 << col)) {
perform_reset = true;
}
#ifdef STM32F411xE
if (!readPin(A0)) {
perform_reset = true;
}
#endif

if (perform_reset) {
bootloader_jump();
}
}
54 changes: 0 additions & 54 deletions users/drashna/drashna.c
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,6 @@
// SPDX-License-Identifier: GPL-2.0-or-later

#include "drashna.h"
#ifdef __AVR__
# include <avr/wdt.h>
#endif

userspace_config_t userspace_config;

Expand Down Expand Up @@ -132,54 +129,3 @@ void keyboard_post_init_i2c(void) {
scan_timer = timer_read();
}
#endif

void bootmagic_lite(void) {
bool perform_reset = false;
// 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();

// 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, col = BOOTMAGIC_LITE_COLUMN;
#if defined(BOOTMAGIC_LITE_EEPROM_ROW) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN)
uint8_t row_e = BOOTMAGIC_LITE_EEPROM_ROW, col_e = BOOTMAGIC_LITE_EEPROM_COLUMN;
#endif

#if defined(SPLIT_KEYBOARD) && defined(BOOTMAGIC_LITE_ROW_RIGHT) && defined(BOOTMAGIC_LITE_COLUMN_RIGHT)
if (!is_keyboard_left()) {
row = BOOTMAGIC_LITE_ROW_RIGHT;
col = BOOTMAGIC_LITE_COLUMN_RIGHT;
#if defined(BOOTMAGIC_LITE_EEPROM_ROW) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN) && defined(BOOTMAGIC_LITE_EEPROM_ROW_RIGHT) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN_RIGHT)
row_e = BOOTMAGIC_LITE_EEPROM_ROW_RIGHT;
col_e = BOOTMAGIC_LITE_EEPROM_COLUMN_RIGHT;
# endif
}
#endif

#if defined(BOOTMAGIC_LITE_EEPROM_ROW) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN)
if (matrix_get_row(row_e) & (1 << col_e)) {
eeconfig_disable();
perform_reset = true;
}
#endif
if (matrix_get_row(row) & (1 << col)) {
perform_reset = true;
}
#ifdef STM32F411xE
if (!readPin(A0)) {
perform_reset = true;
}
#endif

if (perform_reset) {
bootloader_jump();
}
}
4 changes: 4 additions & 0 deletions users/drashna/rules.mk
Original file line number Diff line number Diff line change
Expand Up @@ -133,3 +133,7 @@ ifeq ($(strip $(AUTOCORRECTION_ENABLE)), yes)
$(shell touch $(USER_PATH)/keyrecords/autocorrection/autocorrection.c)
OPT_DEFS += -DAUTOCORRECTION_ENABLE
endif

ifeq ($(strip $(BOOTMAGIC_ENABLE)), yes)
SRC += bootmagic_better.c
endif

0 comments on commit 90418b3

Please sign in to comment.