diff --git a/tmk_core/common/eeconfig.c b/tmk_core/common/eeconfig.c index e2eb4a38..0b98a027 100644 --- a/tmk_core/common/eeconfig.c +++ b/tmk_core/common/eeconfig.c @@ -5,7 +5,7 @@ void eeconfig_init(void) { - eeprom_update_word(EECONFIG_MAGIC, EECONFIG_MAGIC_NUMBER); + eeprom_update_word(EEPROM_SIGNATURE_ADDR, EEPROM_SIGNATURE); eeprom_update_byte(EECONFIG_DEBUG, 0); eeprom_update_byte(EECONFIG_DEFAULT_LAYER, 0); eeprom_update_byte(EECONFIG_KEYMAP, 0); @@ -24,19 +24,59 @@ void eeconfig_init(void) #endif } +uint8_t eeprom_feature_location(eeprom_feature_t feature) { + uint8_t location = EEPROM_HEADER_SIZE; + if (feature == eeprom_debug) + return location; + location += sizeof(typeof(eeprom_debug)); + if (feature == eeprom_default_layer) + return location; + location += sizeof(typeof(eeprom_default_layer)); + if (feature == eeprom_keymap) + return location; + location += sizeof(typeof(eeprom_keymap)); + if (feature == eeprom_mousekey_accel) + return location; + location += sizeof(typeof(eeprom_mousekey_accel)); + #ifdef BACKLIGHT_ENABLE + if (feature == eeprom_backlight) + return location; + location += sizeof(typeof(eeprom_backlight)); + #endif + #ifdef AUDIO_ENABLE + if (feature == eeprom_audio) + return location; + location += sizeof(typeof(eeprom_audio)); + #endif + #ifdef RGBLIGHT_ENABLE + if (feature == eeprom_rgblight) + return location; + location += sizeof(typeof(eeprom_rgblight)); + #endif + if (feature == eeprom_unicodemode) + return location; + location += sizeof(typeof(eeprom_unicodemode)); + #ifdef STENO_ENABLE + if (feature == eeprom_stenomode) + return location; + location += sizeof(typeof(eeprom_stenomode)); + #endif + return location; +} + void eeconfig_enable(void) { - eeprom_update_word(EECONFIG_MAGIC, EECONFIG_MAGIC_NUMBER); + eeprom_update_word(EEPROM_SIGNATURE_ADDR, EEPROM_SIGNATURE); } void eeconfig_disable(void) { - eeprom_update_word(EECONFIG_MAGIC, 0xFFFF); + eeprom_update_word(EEPROM_SIGNATURE_ADDR, 0xFFFF); } bool eeconfig_is_enabled(void) { - return (eeprom_read_word(EECONFIG_MAGIC) == EECONFIG_MAGIC_NUMBER); + return (eeprom_read_word(EEPROM_SIGNATURE_ADDR) == EEPROM_SIGNATURE); } uint8_t eeconfig_read_debug(void) { return eeprom_read_byte(EECONFIG_DEBUG); } diff --git a/tmk_core/common/eeconfig.h b/tmk_core/common/eeconfig.h index ce60ca86..ac81e7f0 100644 --- a/tmk_core/common/eeconfig.h +++ b/tmk_core/common/eeconfig.h @@ -21,8 +21,62 @@ along with this program. If not, see . #include #include - -#define EECONFIG_MAGIC_NUMBER (uint16_t)0xFEED +#define EEPROM_CONFIG_VERSION 1 +#define EEPROM_HEADER_SIZE 4 + +#define EEPROM_SIGNATURE (0xFEED - EEPROM_CONFIG_VERSION) +#define EEPROM_SIGNATURE_ADDR (uint16_t *)0 + +#define EEPROM_ENABLED_FEATURES eeprom_enabled_features +#define EEPROM_ENABLED_FEATURES_ADDR (uint16_t *)2 + +enum eeprom_optional_features { + eeprom_backlight_option, + eeprom_audio_option, + eeprom_rgblight_option, + eeprom_stenomode_option, + eeprom_free_range_option +}; + +static const uint16_t eeprom_enabled_features = + #ifdef BACKLIGHT_ENABLE + (1 << eeprom_backlight_option) | + #endif + #ifdef AUDIO_ENABLE + (1 << eeprom_audio_option) | + #endif + #ifdef RGBLIGHT_ENABLE + (1 << eeprom_rgblight_option) | + #endif + #ifdef STENO_ENABLE + (1 << eeprom_stenomode_option) | + #endif + 0; + +typedef enum eeprom_features { + eeprom_debug, + eeprom_default_layer, + eeprom_keymap, + eeprom_mousekey_accel, + eeprom_backlight, + eeprom_audio, + eeprom_rgblight, + eeprom_unicodemode, + eeprom_stenomode, + eeprom_free_range +} eeprom_feature_t; + +typedef uint8_t eeprom_debug_t; +typedef uint8_t eeprom_default_layer_t; +typedef uint8_t eeprom_keymap_t; +typedef uint8_t eeprom_mousekey_accel_t; +typedef uint8_t eeprom_backlight_t; +typedef uint8_t eeprom_audio_t; +typedef uint32_t eeprom_rgblight_t; +typedef uint8_t eeprom_unicodemode_t; +typedef uint8_t eeprom_stenomode_t; + +#define typeof(n) n ## _t /* eeprom parameteter address */ #define EECONFIG_MAGIC (uint16_t *)0