mirror of
https://github.com/qmk/qmk_firmware.git
synced 2024-12-13 05:11:01 +00:00
93 lines
3.4 KiB
C
93 lines
3.4 KiB
C
// Copyright 2024 Nick Brassel (@tzarc)
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
#include "eeprom.h"
|
|
#include "via.h"
|
|
#include "nvm_via.h"
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Keyboard level code can change where VIA stores the magic.
|
|
// The magic is the build date YYMMDD encoded as BCD in 3 bytes,
|
|
// thus installing firmware built on a different date to the one
|
|
// already installed can be detected and the EEPROM data is reset.
|
|
// The only reason this is important is in case EEPROM usage changes
|
|
// and the EEPROM was not explicitly reset by bootmagic lite.
|
|
#ifndef VIA_EEPROM_MAGIC_ADDR
|
|
# define VIA_EEPROM_MAGIC_ADDR (EECONFIG_SIZE)
|
|
#endif
|
|
|
|
#define VIA_EEPROM_LAYOUT_OPTIONS_ADDR (VIA_EEPROM_MAGIC_ADDR + 3)
|
|
|
|
// The end of the EEPROM memory used by VIA
|
|
// By default, dynamic keymaps will start at this if there is no
|
|
// custom config
|
|
#define VIA_EEPROM_CUSTOM_CONFIG_ADDR (VIA_EEPROM_LAYOUT_OPTIONS_ADDR + VIA_EEPROM_LAYOUT_OPTIONS_SIZE)
|
|
|
|
#define VIA_EEPROM_CONFIG_END (VIA_EEPROM_CUSTOM_CONFIG_ADDR + VIA_EEPROM_CUSTOM_CONFIG_SIZE)
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
void nvm_via_read_magic(uint8_t *magic0, uint8_t *magic1, uint8_t *magic2) {
|
|
if (magic0) {
|
|
*magic0 = eeprom_read_byte((void *)VIA_EEPROM_MAGIC_ADDR + 0);
|
|
}
|
|
|
|
if (magic1) {
|
|
*magic1 = eeprom_read_byte((void *)VIA_EEPROM_MAGIC_ADDR + 1);
|
|
}
|
|
|
|
if (magic2) {
|
|
*magic2 = eeprom_read_byte((void *)VIA_EEPROM_MAGIC_ADDR + 2);
|
|
}
|
|
}
|
|
|
|
void nvm_via_update_magic(uint8_t magic0, uint8_t magic1, uint8_t magic2) {
|
|
eeprom_update_byte((void *)VIA_EEPROM_MAGIC_ADDR + 0, magic0);
|
|
eeprom_update_byte((void *)VIA_EEPROM_MAGIC_ADDR + 1, magic1);
|
|
eeprom_update_byte((void *)VIA_EEPROM_MAGIC_ADDR + 2, magic2);
|
|
}
|
|
|
|
uint32_t nvm_via_read_layout_options(void) {
|
|
uint32_t value = 0;
|
|
// Start at the most significant byte
|
|
void *source = (void *)(VIA_EEPROM_LAYOUT_OPTIONS_ADDR);
|
|
for (uint8_t i = 0; i < VIA_EEPROM_LAYOUT_OPTIONS_SIZE; i++) {
|
|
value = value << 8;
|
|
value |= eeprom_read_byte(source);
|
|
source++;
|
|
}
|
|
return value;
|
|
}
|
|
|
|
void nvm_via_update_layout_options(uint32_t val) {
|
|
// Start at the least significant byte
|
|
void *target = (void *)(VIA_EEPROM_LAYOUT_OPTIONS_ADDR + VIA_EEPROM_LAYOUT_OPTIONS_SIZE - 1);
|
|
for (uint8_t i = 0; i < VIA_EEPROM_LAYOUT_OPTIONS_SIZE; i++) {
|
|
eeprom_update_byte(target, val & 0xFF);
|
|
val = val >> 8;
|
|
target--;
|
|
}
|
|
}
|
|
|
|
uint32_t nvm_via_read_custom_config(void *buf, uint32_t offset, uint32_t length) {
|
|
#if VIA_EEPROM_CUSTOM_CONFIG_SIZE > 0
|
|
void *ee_start = (void *)(uintptr_t)(VIA_EEPROM_CUSTOM_CONFIG_ADDR + offset);
|
|
void *ee_end = (void *)(uintptr_t)(VIA_EEPROM_CUSTOM_CONFIG_ADDR + MIN(VIA_EEPROM_CUSTOM_CONFIG_SIZE, offset + length));
|
|
eeprom_read_block(buf, ee_start, ee_end - ee_start);
|
|
return ee_end - ee - start;
|
|
#else
|
|
return 0;
|
|
#endif
|
|
}
|
|
|
|
uint32_t nvm_via_update_custom_config(const void *buf, uint32_t offset, uint32_t length) {
|
|
#if VIA_EEPROM_CUSTOM_CONFIG_SIZE > 0
|
|
void *ee_start = (void *)(uintptr_t)(VIA_EEPROM_CUSTOM_CONFIG_ADDR + offset);
|
|
void *ee_end = (void *)(uintptr_t)(VIA_EEPROM_CUSTOM_CONFIG_ADDR + MIN(VIA_EEPROM_CUSTOM_CONFIG_SIZE, offset + length));
|
|
eeprom_update_block(buf, ee_start, ee_end - ee_start);
|
|
return ee_end - ee_start;
|
|
#else
|
|
return 0;
|
|
#endif
|
|
} |