Use keymap folder hash to reset dynamic keymap eeprom

This commit is contained in:
zvecr 2022-06-27 20:22:10 +01:00
parent 2273c5b4e0
commit 2592402627
5 changed files with 62 additions and 7 deletions

View file

@ -344,7 +344,12 @@ $(KEYBOARD_OUTPUT)/src/layouts.h: $(INFO_JSON_FILES)
$(eval CMD=$(QMK_BIN) generate-layouts --quiet --keyboard $(KEYBOARD) --output $(KEYBOARD_OUTPUT)/src/layouts.h)
@$(BUILD_CMD)
generated-files: $(KEYBOARD_OUTPUT)/src/info_config.h $(KEYBOARD_OUTPUT)/src/default_keyboard.c $(KEYBOARD_OUTPUT)/src/default_keyboard.h $(KEYBOARD_OUTPUT)/src/layouts.h
$(KEYBOARD_OUTPUT)/src/keymap_hash.h:
@$(SILENT) || printf "$(MSG_GENERATING) $@" | $(AWK_CMD)
$(eval CMD=$(QMK_BIN) generate-keymap-hash -q -o "$(KEYMAP_OUTPUT)/src/keymap_hash.h" -kb $(KEYBOARD) -km $(KEYMAP))
@$(BUILD_CMD)
generated-files: $(KEYBOARD_OUTPUT)/src/keymap_hash.h $(KEYBOARD_OUTPUT)/src/info_config.h $(KEYBOARD_OUTPUT)/src/default_keyboard.c $(KEYBOARD_OUTPUT)/src/default_keyboard.h $(KEYBOARD_OUTPUT)/src/layouts.h
.INTERMEDIATE : generated-files

View file

@ -55,6 +55,7 @@ subcommands = [
'qmk.cli.generate.info_json',
'qmk.cli.generate.keyboard_c',
'qmk.cli.generate.keyboard_h',
'qmk.cli.generate.keymap_hash',
'qmk.cli.generate.layouts',
'qmk.cli.generate.rgb_breathe_table',
'qmk.cli.generate.rules_mk',

View file

@ -0,0 +1,36 @@
"""Used by the make system to generate header.
"""
from fnvhash import fnv1a_32
from milc import cli
from qmk.commands import dump_lines
from qmk.keymap import locate_keymap
from qmk.keyboard import keyboard_completer, keyboard_folder
from qmk.path import normpath
from qmk.constants import GPL2_HEADER_C_LIKE, GENERATED_HEADER_C_LIKE
@cli.argument('-o', '--output', arg_only=True, type=normpath, help='File to write to')
@cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages")
@cli.argument('-kb', '--keyboard', arg_only=True, type=keyboard_folder, completer=keyboard_completer, required=True, help='Keyboard to generate header for.')
@cli.argument('-km', '--keymap', arg_only=True, required=True, help='Keymap to generate header for.')
@cli.subcommand('Used by the make system to generate header', hidden=True)
def generate_keymap_hash(cli):
# Build the header file.
header_lines = [GPL2_HEADER_C_LIKE, GENERATED_HEADER_C_LIKE, '#pragma once']
keymap_folder = locate_keymap(cli.args.keyboard, cli.args.keymap).parent
keymap_files = list(keymap_folder.glob('**/*'))
keymap_files.sort()
content = ""
for file in keymap_files:
content += file.read_text(encoding='utf-8')
val = fnv1a_32(bytes(content, 'utf-8'))
header_lines.append(f'#define KEYMAP_HASH 0x{val:08X}ul')
# Show the results
dump_lines(cli.args.output, header_lines, cli.args.quiet)

View file

@ -16,6 +16,9 @@
bool via_eeprom_is_valid(void);
void via_eeprom_set_valid(bool valid);
void eeconfig_init_via(void);
#elif defined(DYNAMIC_KEYMAP_ENABLE)
# include "keymap_hash.h"
void dynamic_keymap_reset(void);
#endif
/** \brief eeconfig enable
@ -81,10 +84,9 @@ void eeconfig_init_quantum(void) {
// properly re-initialized.
via_eeprom_set_valid(false);
eeconfig_init_via();
#elif defined(XAP_ENABLE)
// TODO: define XAP reset behaviour
void dynamic_keymap_reset(void);
#elif defined(DYNAMIC_KEYMAP_ENABLE)
dynamic_keymap_reset();
eeprom_update_dword(EECONFIG_KEYMAP_HASH, KEYMAP_HASH);
#endif
eeconfig_init_kb();
@ -123,10 +125,14 @@ void eeconfig_disable(void) {
*/
bool eeconfig_is_enabled(void) {
bool is_eeprom_enabled = (eeprom_read_word(EECONFIG_MAGIC) == EECONFIG_MAGIC_NUMBER);
#ifdef VIA_ENABLE
#if defined(VIA_ENABLE)
if (is_eeprom_enabled) {
is_eeprom_enabled = via_eeprom_is_valid();
}
#elif defined(DYNAMIC_KEYMAP_ENABLE)
if (is_eeprom_enabled) {
is_eeprom_enabled = (eeprom_read_dword(EECONFIG_KEYMAP_HASH) == KEYMAP_HASH);
}
#endif
return is_eeprom_enabled;
}
@ -137,10 +143,14 @@ bool eeconfig_is_enabled(void) {
*/
bool eeconfig_is_disabled(void) {
bool is_eeprom_disabled = (eeprom_read_word(EECONFIG_MAGIC) == EECONFIG_MAGIC_NUMBER_OFF);
#ifdef VIA_ENABLE
#if defined(VIA_ENABLE)
if (!is_eeprom_disabled) {
is_eeprom_disabled = !via_eeprom_is_valid();
}
#elif defined(DYNAMIC_KEYMAP_ENABLE)
if (!is_eeprom_disabled) {
is_eeprom_disabled = (eeprom_read_dword(EECONFIG_KEYMAP_HASH) != KEYMAP_HASH);
}
#endif
return is_eeprom_disabled;
}

View file

@ -53,8 +53,11 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// TODO: Combine these into a single word and single block of EEPROM
#define EECONFIG_KEYMAP_UPPER_BYTE (uint8_t *)34
#define EECONFIG_KEYMAP_HASH (uint32_t *)35
// Size of EEPROM being used, other code can refer to this for available EEPROM
#define EECONFIG_SIZE 35
#define EECONFIG_SIZE 39
/* debug bit */
#define EECONFIG_DEBUG_ENABLE (1 << 0)
#define EECONFIG_DEBUG_MATRIX (1 << 1)