c93249f1b2
Enable KEYCHRON_RGB_ENABLE for the Q5 Max, wiring up PER_KEY_RGB and MIXED_RGB effects, and fix a cascade of EEPROM bugs that caused the Launcher-configured RGB mode to revert to the default heatmap on every power cycle and wireless transport change. Keychron RGB enablement: - Add KEYCHRON_RGB_ENABLE = yes to rules.mk - Define default_per_key_led[] and default_region[] for the ANSI Encoder layout in ansi_encoder.c (extern'd by keychron_rgb.c) - Fix missing #include "eeconfig_custom_rgb.h" in mixed_rgb.c and rgb_matrix_kb.inc so EECONFIG_SIZE_CUSTOM_RGB is in scope for the compile guards that gate the custom effects - Add #undef EECONFIG_KB_DATA_SIZE before the Keychron redefinition in eeconfig_kb.h to suppress redefinition of QMK's default-zero value EEPROM persistence fixes (keychron_rgb.c): - Fix retail_demo_enable never being written to EEPROM in eeconfig_reset_custom_rgb(): original code used eeprom_read_block instead of eeprom_update_block, leaving 0xFF on freshly-flashed boards; retail_demo_task() treats any non-zero value as "demo active" and forces the mode to CUSTOM_MIXED_RGB every scan - Clamp retail_demo_enable > 1 to 0 on load to recover boards already affected by the above bug - Move EECONFIG_KEYBOARD version stamp from eeconfig_init_custom_rgb() (load path) to eeconfig_reset_custom_rgb() (reset/write path) so the version is only stamped when valid defaults are actually written - Call eeconfig_update_rgb_matrix() in kc_rgb_save() so the current QMK RGB mode is persisted alongside Keychron data; without this, rgb_matrix_init() (called on every transport change) reloads the compile-time default RGB_MATRIX_TYPING_HEATMAP from EEPROM Transport-change persistence (q5_max.c): - Call eeconfig_init_custom_rgb() in keyboard_post_init_kb() so Keychron RGB arrays are loaded from EEPROM on every boot instead of being zero-initialised - Add wireless_enter_connected_kb() hook: re-applies the EEPROM-saved QMK RGB mode after BT/2.4G reconnect in case the reconnect sequence resets the in-RAM mode before the display settles DIP switch Win-side override (keymap.c): - Replace rgb_matrix_mode() / rgb_matrix_sethsv() calls (which write to EEPROM and permanently overwrite the Launcher mode) with a dip_win_active flag; rgb_matrix_indicators_advanced_user() paints all LEDs white each frame when the flag is set, leaving the active effect and EEPROM untouched VIA keymap address pinning (config.h): - Define VIA_EEPROM_MAGIC_ADDR 544 to anchor VIA keymap storage at a fixed EEPROM offset; without this, growth in EECONFIG_KB_DATA_SIZE silently shifts the keymap block, corrupting stored layouts (observed as layer-0 keys reverting to KC_TRNS / KC_NONE on boot)
97 lines
3.1 KiB
C
97 lines
3.1 KiB
C
/* Copyright 2024 @ Keychron (https://www.keychron.com)
|
|
*
|
|
* This program is free software : you can redistribute it and /or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program.If not, see < http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "quantum.h"
|
|
#include "keychron_task.h"
|
|
#ifdef FACTORY_TEST_ENABLE
|
|
# include "factory_test.h"
|
|
# include "keychron_common.h"
|
|
#endif
|
|
#ifdef LK_WIRELESS_ENABLE
|
|
# include "lkbt51.h"
|
|
# include "wireless.h"
|
|
# include "keychron_wireless_common.h"
|
|
# include "battery.h"
|
|
#endif
|
|
|
|
|
|
#ifdef DIP_SWITCH_ENABLE
|
|
// Weak hook — override in keymap.c to handle dip-switch events
|
|
// without conflicting with factory_test.c's dip_switch_update_user.
|
|
__attribute__((weak)) void dip_switch_update_keymap(uint8_t index, bool active) {}
|
|
|
|
bool dip_switch_update_kb(uint8_t index, bool active) {
|
|
// if (index == 0) {
|
|
// default_layer_set(1UL << (active ? 2 : 0));
|
|
// }
|
|
dip_switch_update_user(index, active);
|
|
dip_switch_update_keymap(index, active);
|
|
|
|
return true;
|
|
}
|
|
#endif
|
|
|
|
#ifdef LK_WIRELESS_ENABLE
|
|
// Re-apply the saved QMK RGB mode every time wireless connects.
|
|
// During transport changes, rgb_matrix_init() reads the correct mode from
|
|
// EEPROM, but something in the BT/2.4G reconnect sequence can reset it
|
|
// before the display settles. This hook fires after connection is fully
|
|
// established, ensuring the Launcher-configured mode persists.
|
|
void wireless_enter_connected_kb(uint8_t host_idx) {
|
|
# if defined(RGB_MATRIX_ENABLE) && defined(KEYCHRON_RGB_ENABLE)
|
|
extern void eeconfig_init_custom_rgb(void);
|
|
eeconfig_init_custom_rgb();
|
|
|
|
// Re-read the QMK RGB mode from EEPROM and apply if it drifted.
|
|
rgb_config_t saved_rgb;
|
|
eeprom_read_block(&saved_rgb, EECONFIG_RGB_MATRIX, sizeof(saved_rgb));
|
|
if (saved_rgb.mode && saved_rgb.mode != rgb_matrix_get_mode()) {
|
|
rgb_matrix_mode_noeeprom(saved_rgb.mode);
|
|
}
|
|
# endif
|
|
}
|
|
#endif
|
|
|
|
void keyboard_post_init_kb(void) {
|
|
#ifdef LK_WIRELESS_ENABLE
|
|
palSetLineMode(P2P4_MODE_SELECT_PIN, PAL_MODE_INPUT);
|
|
palSetLineMode(BT_MODE_SELECT_PIN, PAL_MODE_INPUT);
|
|
|
|
lkbt51_init(false);
|
|
wireless_init();
|
|
#endif
|
|
|
|
#ifdef ENCODER_ENABLE
|
|
encoder_cb_init();
|
|
#endif
|
|
|
|
#if defined(RGB_MATRIX_ENABLE) && defined(KEYCHRON_RGB_ENABLE)
|
|
// Load Keychron custom RGB data (effect list, regions, per-key colours)
|
|
// from EEPROM into RAM. Without this call the arrays are zero-initialised
|
|
// and Launcher settings are lost on every power cycle or transport change.
|
|
extern void eeconfig_init_custom_rgb(void);
|
|
eeconfig_init_custom_rgb();
|
|
#endif
|
|
|
|
keyboard_post_init_user();
|
|
}
|
|
|
|
#ifdef LK_WIRELESS_ENABLE
|
|
bool lpm_is_kb_idle(void) {
|
|
return !factory_reset_indicating();
|
|
}
|
|
#endif
|