c1c5922aae
* Draft commit of typing speed RGB control * More information in the readme * Support all RGB animation modes (Fixes #1) * Added support for all RGB light modes to use typing speed Except christmas lights because that is seizure-inducing at high speeds! * Introduced a value range specific to each RGB mode Because some modes are a little too much when running at full speed! * Update readme.md * Update readme.md * Re-arrange typing_speed definitions (Fixes #5) (#6) * Re-arrange variable definitions to avoid including quantum.h from rgblight.c * Fix a compilation error when trying to run make test:all * Tweaks to the typing speed decay rate * Renamed to momentum; moved implementation into dedicated files * Groundwork for toggling momentum on/off (currently always on) * Add EEPROM toggle for momentum-matching * Moved momentum out of RGBLIGHT_ENABLE toggles so it's more generic * Move momentum decay task out of rgblight_task() * Fix missing momentum.h in lufa.c * Experimental LED support (untested) * Draft commit of typing speed RGB control * More information in the readme * Support all RGB animation modes (Fixes #1) * Added support for all RGB light modes to use typing speed Except christmas lights because that is seizure-inducing at high speeds! * Introduced a value range specific to each RGB mode Because some modes are a little too much when running at full speed! * Update readme.md * Update readme.md * Re-arrange typing_speed definitions (Fixes #5) (#6) * Re-arrange variable definitions to avoid including quantum.h from rgblight.c * Fix a compilation error when trying to run make test:all * Tweaks to the typing speed decay rate * Renamed to momentum; moved implementation into dedicated files * Groundwork for toggling momentum on/off (currently always on) * Add EEPROM toggle for momentum-matching * Moved momentum out of RGBLIGHT_ENABLE toggles so it's more generic * Move momentum decay task out of rgblight_task() * Fix missing momentum.h in lufa.c * Added documentation * Renamed feature to velocikey * Reverted readme to original state * Correct the readme title * Updated feature name in the docs * Update EECONFIG name * Add compile-time toggles for velocikey * Update feature documentation * Revert "Merge branch 'led-support' into master" This reverts commit e123ff5febf61639b9a9020748e1c2e2313460ff, reversing changes made to df111a55b9d4929182e16108b1c0ead15b16df97. * Move velocikey EECONFIG definition to depend on VELOCIKEY_ENABLE * Rename decay_task function to decelerate * Apply suggestions from code review Co-Authored-By: chrislewisdev <chris@chrislewisdev.com> * Re-order eeconfig definitions * Apply coding conventions * Apply #ifdef check in lufa.c * Refactored interval time checks into one functionc * Small rename * Fix unused function error for layouts not using all rgb effects * Only update EEPROM if Velocikey is enabled * Incorporate code review feedback * Small adjustment to top-end decay rate * Add Velocikey documentation to table of contents * Bring tetris:default keymap size down by disabling audio
190 lines
4.4 KiB
C
190 lines
4.4 KiB
C
#include <stdint.h>
|
|
#include <stdbool.h>
|
|
#include "eeprom.h"
|
|
#include "eeconfig.h"
|
|
|
|
#ifdef STM32_EEPROM_ENABLE
|
|
#include "hal.h"
|
|
#include "eeprom_stm32.h"
|
|
#endif
|
|
|
|
extern uint32_t default_layer_state;
|
|
/** \brief eeconfig enable
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
__attribute__ ((weak))
|
|
void eeconfig_init_user(void) {
|
|
// Reset user EEPROM value to blank, rather than to a set value
|
|
eeconfig_update_user(0);
|
|
}
|
|
|
|
__attribute__ ((weak))
|
|
void eeconfig_init_kb(void) {
|
|
// Reset Keyboard EEPROM value to blank, rather than to a set value
|
|
eeconfig_update_kb(0);
|
|
|
|
eeconfig_init_user();
|
|
}
|
|
|
|
|
|
/*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_init_quantum(void) {
|
|
#ifdef STM32_EEPROM_ENABLE
|
|
EEPROM_Erase();
|
|
#endif
|
|
eeprom_update_word(EECONFIG_MAGIC, EECONFIG_MAGIC_NUMBER);
|
|
eeprom_update_byte(EECONFIG_DEBUG, 0);
|
|
eeprom_update_byte(EECONFIG_DEFAULT_LAYER, 0);
|
|
default_layer_state = 0;
|
|
eeprom_update_byte(EECONFIG_KEYMAP, 0);
|
|
eeprom_update_byte(EECONFIG_MOUSEKEY_ACCEL, 0);
|
|
eeprom_update_byte(EECONFIG_BACKLIGHT, 0);
|
|
eeprom_update_byte(EECONFIG_AUDIO, 0xFF); // On by default
|
|
eeprom_update_dword(EECONFIG_RGBLIGHT, 0);
|
|
eeprom_update_byte(EECONFIG_STENOMODE, 0);
|
|
eeprom_update_dword(EECONFIG_HAPTIC, 0);
|
|
eeprom_update_byte(EECONFIG_VELOCIKEY, 0);
|
|
|
|
eeconfig_init_kb();
|
|
}
|
|
|
|
/** \brief eeconfig initialization
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_init(void) {
|
|
|
|
eeconfig_init_quantum();
|
|
}
|
|
|
|
/** \brief eeconfig enable
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_enable(void)
|
|
{
|
|
eeprom_update_word(EECONFIG_MAGIC, EECONFIG_MAGIC_NUMBER);
|
|
}
|
|
|
|
/** \brief eeconfig disable
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_disable(void)
|
|
{
|
|
#ifdef STM32_EEPROM_ENABLE
|
|
EEPROM_Erase();
|
|
#endif
|
|
eeprom_update_word(EECONFIG_MAGIC, EECONFIG_MAGIC_NUMBER_OFF);
|
|
}
|
|
|
|
/** \brief eeconfig is enabled
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
bool eeconfig_is_enabled(void)
|
|
{
|
|
return (eeprom_read_word(EECONFIG_MAGIC) == EECONFIG_MAGIC_NUMBER);
|
|
}
|
|
|
|
/** \brief eeconfig is disabled
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
bool eeconfig_is_disabled(void)
|
|
{
|
|
return (eeprom_read_word(EECONFIG_MAGIC) == EECONFIG_MAGIC_NUMBER_OFF);
|
|
}
|
|
|
|
/** \brief eeconfig read debug
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
uint8_t eeconfig_read_debug(void) { return eeprom_read_byte(EECONFIG_DEBUG); }
|
|
/** \brief eeconfig update debug
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_update_debug(uint8_t val) { eeprom_update_byte(EECONFIG_DEBUG, val); }
|
|
|
|
/** \brief eeconfig read default layer
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
uint8_t eeconfig_read_default_layer(void) { return eeprom_read_byte(EECONFIG_DEFAULT_LAYER); }
|
|
/** \brief eeconfig update default layer
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_update_default_layer(uint8_t val) { eeprom_update_byte(EECONFIG_DEFAULT_LAYER, val); }
|
|
|
|
/** \brief eeconfig read keymap
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
uint8_t eeconfig_read_keymap(void) { return eeprom_read_byte(EECONFIG_KEYMAP); }
|
|
/** \brief eeconfig update keymap
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_update_keymap(uint8_t val) { eeprom_update_byte(EECONFIG_KEYMAP, val); }
|
|
|
|
/** \brief eeconfig read backlight
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
uint8_t eeconfig_read_backlight(void) { return eeprom_read_byte(EECONFIG_BACKLIGHT); }
|
|
/** \brief eeconfig update backlight
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_update_backlight(uint8_t val) { eeprom_update_byte(EECONFIG_BACKLIGHT, val); }
|
|
|
|
|
|
/** \brief eeconfig read audio
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
uint8_t eeconfig_read_audio(void) { return eeprom_read_byte(EECONFIG_AUDIO); }
|
|
/** \brief eeconfig update audio
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_update_audio(uint8_t val) { eeprom_update_byte(EECONFIG_AUDIO, val); }
|
|
|
|
|
|
/** \brief eeconfig read kb
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
uint32_t eeconfig_read_kb(void) { return eeprom_read_dword(EECONFIG_KEYBOARD); }
|
|
/** \brief eeconfig update kb
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
|
|
void eeconfig_update_kb(uint32_t val) { eeprom_update_dword(EECONFIG_KEYBOARD, val); }
|
|
/** \brief eeconfig read user
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
uint32_t eeconfig_read_user(void) { return eeprom_read_dword(EECONFIG_USER); }
|
|
/** \brief eeconfig update user
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_update_user(uint32_t val) { eeprom_update_dword(EECONFIG_USER, val); }
|
|
|
|
|
|
uint32_t eeconfig_read_haptic(void) { return eeprom_read_dword(EECONFIG_HAPTIC); }
|
|
/** \brief eeconfig update user
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void eeconfig_update_haptic(uint32_t val) { eeprom_update_dword(EECONFIG_HAPTIC, val); }
|
|
|
|
|