summaryrefslogtreecommitdiffstats
path: root/keyboards/keychron/bluetooth
diff options
context:
space:
mode:
Diffstat (limited to 'keyboards/keychron/bluetooth')
-rw-r--r--keyboards/keychron/bluetooth/bat_level_animation.c12
-rw-r--r--keyboards/keychron/bluetooth/bluetooth.c4
-rw-r--r--keyboards/keychron/bluetooth/bluetooth.h3
-rw-r--r--keyboards/keychron/bluetooth/indicator.c268
-rw-r--r--keyboards/keychron/bluetooth/indicator.h2
-rw-r--r--keyboards/keychron/bluetooth/lpm.c4
-rw-r--r--keyboards/keychron/bluetooth/lpm_stm32l432.c20
7 files changed, 189 insertions, 124 deletions
diff --git a/keyboards/keychron/bluetooth/bat_level_animation.c b/keyboards/keychron/bluetooth/bat_level_animation.c
index 83a4f91cae..2e726e17b8 100644
--- a/keyboards/keychron/bluetooth/bat_level_animation.c
+++ b/keyboards/keychron/bluetooth/bat_level_animation.c
@@ -8,6 +8,7 @@
#elif if defined(PROTOCOL_LUFA)
# include "lufa.h"
#endif
+#include "eeprom.h"
#ifndef BAT_LEVEL_GROWING_INTERVAL
# define BAT_LEVEL_GROWING_INTERVAL 150
@@ -17,6 +18,14 @@
# define BAT_LEVEL_ON_INTERVAL 3000
#endif
+#ifdef LED_MATRIX_ENABLE
+# define LED_DRIVER_IS_ENABLED led_matrix_is_enabled
+#endif
+
+#ifdef RGB_MATRIX_ENABLE
+# define LED_DRIVER_IS_ENABLED rgb_matrix_is_enabled
+#endif
+
enum {
BAT_LVL_ANI_NONE,
BAT_LVL_ANI_GROWING,
@@ -113,7 +122,8 @@ void bat_level_animiation_update(void) {
case BAT_LVL_ANI_BLINK_ON:
animation_state = BAT_LVL_ANI_NONE;
- if (indicator_config.value == 0 && !indicator_is_backlit_enabled_eeprom()) {
+ indicator_eeconfig_reload();
+ if (indicator_config.value == 0 && !LED_DRIVER_IS_ENABLED()) {
indicator_disable();
}
break;
diff --git a/keyboards/keychron/bluetooth/bluetooth.c b/keyboards/keychron/bluetooth/bluetooth.c
index 10c79257a9..e93fd8d4ac 100644
--- a/keyboards/keychron/bluetooth/bluetooth.c
+++ b/keyboards/keychron/bluetooth/bluetooth.c
@@ -432,10 +432,12 @@ bluetooth_state_t bluetooth_get_state(void) {
return bt_state;
};
+__attribute__((weak)) bool process_record_kb_bt(uint16_t keycode, keyrecord_t *record) { return true;};
+
bool process_record_kb(uint16_t keycode, keyrecord_t *record) {
if (get_transport() == TRANSPORT_BLUETOOTH) {
lpm_timer_reset();
}
-
+ process_record_kb_bt(keycode, record);
return process_record_user(keycode, record);
}
diff --git a/keyboards/keychron/bluetooth/bluetooth.h b/keyboards/keychron/bluetooth/bluetooth.h
index b24df48845..bfbc838000 100644
--- a/keyboards/keychron/bluetooth/bluetooth.h
+++ b/keyboards/keychron/bluetooth/bluetooth.h
@@ -83,3 +83,6 @@ bluetooth_state_t bluetooth_get_state(void);
void bluetooth_low_battery_shutdown(void);
+bool process_record_kb_bt(uint16_t keycode, keyrecord_t *record);
+
+
diff --git a/keyboards/keychron/bluetooth/indicator.c b/keyboards/keychron/bluetooth/indicator.c
index fa9c9fc6e4..de7023e2fb 100644
--- a/keyboards/keychron/bluetooth/indicator.c
+++ b/keyboards/keychron/bluetooth/indicator.c
@@ -30,6 +30,7 @@
# endif
# include "i2c_master.h"
# include "bat_level_animation.h"
+# include "eeprom.h"
#endif
#ifdef LED_MATRIX_ENABLE
@@ -40,19 +41,7 @@
#endif
#define LED_ON 0x80
-
-#define INDICATOR_SET(s) \
- indicator_config.type = s##_config.type; \
- indicator_config.on_time = s##_config.on_time; \
- indicator_config.off_time = s##_config.off_time; \
- indicator_config.duration = s##_config.duration; \
- indicator_config.highlight = s##_config.highlight; \
- indicator_config.elapsed = 0;
-
-indicator_config_t pairing_config = INDICATOR_CONFIG_PARING;
-indicator_config_t connected_config = INDICATOR_CONFIG_CONNECTD;
-indicator_config_t reconnecting_config = INDICATOR_CONFIG_RECONNECTING;
-indicator_config_t disconnected_config = INDICATOR_CONFIG_DISCONNECTED;
+#define INDICATOR_SET(s) memcpy(&indicator_config, &s##_config, sizeof(indicator_config_t));
enum {
BACKLIGHT_OFF = 0x00,
@@ -60,8 +49,11 @@ enum {
BACKLIGHT_ON_UNCONNECTED = 0x02,
};
+static indicator_config_t pairing_config = INDICATOR_CONFIG_PARING;
+static indicator_config_t connected_config = INDICATOR_CONFIG_CONNECTD;
+static indicator_config_t reconnecting_config = INDICATOR_CONFIG_RECONNECTING;
+static indicator_config_t disconnected_config = INDICATOR_CONFIG_DISCONNECTED;
indicator_config_t indicator_config;
-
static bluetooth_state_t indicator_state;
static uint16_t next_period;
static indicator_type_t type;
@@ -78,6 +70,51 @@ static uint8_t host_led_matrix_list[HOST_DEVICES_COUNT] = HOST_LED_MATRIX_LIST;
static pin_t host_led_pin_list[HOST_DEVICES_COUNT] = HOST_LED_PIN_LIST;
#endif
+#ifndef BACKLIGHT_TURN_OFF_VALUE
+# define BACKLIGHT_TURN_OFF_VALUE 32
+#endif
+
+#ifdef LED_MATRIX_ENABLE
+# define LED_DRIVER led_matrix_driver
+# define LED_INDICATORS_KB led_matrix_indicators_kb
+# define LED_NONE_INDICATORS_KB led_matrix_none_indicators_kb
+# define SET_ALL_LED_OFF() led_matrix_set_value_all(0)
+# define SET_LED_OFF(idx) led_matrix_set_value(idx, 0)
+# define SET_LED_ON(idx) led_matrix_set_value(idx, 255)
+# define SET_LED_BT(idx) led_matrix_set_value(idx, 255)
+# define LED_DRIVER_IS_ENABLED led_matrix_is_enabled
+# define LED_DRIVER_EECONFIG_RELOAD() \
+ eeprom_read_block(&led_matrix_eeconfig, EECONFIG_LED_MATRIX, sizeof(led_matrix_eeconfig)); \
+ if (!led_matrix_eeconfig.mode) { \
+ eeconfig_update_led_matrix_default(); \
+ }
+# define LED_DRIVER_ALLOW_SHUTDOWN led_matrix_driver_allow_shutdown
+# define LED_DRIVER_ENABLE_NOEEPROM led_matrix_enable_noeeprom
+# define LED_DRIVER_DISABLE_NOEEPROM led_matrix_disable_noeeprom
+# define LED_DRIVER_DISABLE_TIMEOUT_SET led_matrix_disable_timeout_set
+# define LED_DRIVER_DISABLE_TIME_RESET led_matrix_disable_time_reset
+#endif
+
+#ifdef RGB_MATRIX_ENABLE
+# define LED_DRIVER rgb_matrix_driver
+# define LED_INDICATORS_KB rgb_matrix_indicators_kb
+# define LED_NONE_INDICATORS_KB rgb_matrix_none_indicators_kb
+# define SET_ALL_LED_OFF() rgb_matrix_set_color_all(0, 0, 0)
+# define SET_LED_OFF(idx) rgb_matrix_set_color(idx, 0, 0, 0)
+# define SET_LED_ON(idx) rgb_matrix_set_color(idx, 255, 255, 255)
+# define SET_LED_BT(idx) rgb_matrix_set_color(idx, 0, 0, 255)
+# define LED_DRIVER_IS_ENABLED rgb_matrix_is_enabled
+# define LED_DRIVER_EECONFIG_RELOAD() \
+ eeprom_read_block(&rgb_matrix_config, EECONFIG_RGB_MATRIX, sizeof(rgb_matrix_config)); \
+ if (!rgb_matrix_config.mode) { \
+ eeconfig_update_rgb_matrix_default(); \
+ }
+# define LED_DRIVER_ALLOW_SHUTDOWN rgb_matrix_driver_allow_shutdown
+# define LED_DRIVER_ENABLE_NOEEPROM rgb_matrix_enable_noeeprom
+# define LED_DRIVER_DISABLE_NOEEPROM rgb_matrix_disable_noeeprom
+# define LED_DRIVER_DISABLE_TIMEOUT_SET rgb_matrix_disable_timeout_set
+# define LED_DRIVER_DISABLE_TIME_RESET rgb_matrix_disable_time_reset
+#endif
void indicator_init(void) {
memset(&indicator_config, 0, sizeof(indicator_config));
@@ -96,69 +133,39 @@ void indicator_init(void) {
#if defined(LED_MATRIX_ENABLE) || defined(RGB_MATRIX_ENABLE)
void indicator_enable(void) {
-# ifdef LED_MATRIX_ENABLE
- if (!led_matrix_is_enabled()) {
- led_matrix_enable_noeeprom();
- }
-# endif
-# ifdef RGB_MATRIX_ENABLE
- if (!rgb_matrix_is_enabled()) {
- rgb_matrix_enable_noeeprom();
+ if (!LED_DRIVER_IS_ENABLED()) {
+ LED_DRIVER_ENABLE_NOEEPROM();
}
-# endif
}
-void indicator_disable(void) {
-# ifdef LED_MATRIX_ENABLE
- led_matrix_disable_noeeprom();
-# endif
-# ifdef RGB_MATRIX_ENABLE
- rgb_matrix_disable_noeeprom();
-# endif
+inline void indicator_disable(void) {
+ LED_DRIVER_DISABLE_NOEEPROM();
}
void indicator_set_backlit_timeout(uint32_t time) {
-# ifdef LED_MATRIX_ENABLE
- led_matrix_disable_timeout_set(time);
-# endif
-# ifdef RGB_MATRIX_ENABLE
- rgb_matrix_disable_timeout_set(time);
-# endif
+ LED_DRIVER_DISABLE_TIMEOUT_SET(time);
}
static inline void indicator_reset_backlit_time(void) {
-# ifdef LED_MATRIX_ENABLE
- led_matrix_disable_time_reset();
-# endif
-# ifdef RGB_MATRIX_ENABLE
- rgb_matrix_disable_time_reset();
-# endif
+ LED_DRIVER_DISABLE_TIME_RESET();
}
bool indicator_is_enabled(void) {
-# ifdef LED_MATRIX_ENABLE
- return led_matrix_is_enabled();
-# endif
-# ifdef RGB_MATRIX_ENABLE
- return rgb_matrix_is_enabled();
-# endif
+ return LED_DRIVER_IS_ENABLED();
}
-bool indicator_is_backlit_enabled_eeprom(void) {
-# ifdef LED_MATRIX_ENABLE
- return led_matrix_is_enabled_eeprom();
-# endif
-# ifdef RGB_MATRIX_ENABLE
- return rgb_matrix_is_enabled_eeprom();
-# endif
- return false;
+void indicator_eeconfig_reload(void) {
+ LED_DRIVER_EECONFIG_RELOAD();
}
#endif
-bool indicator_is_running(void) { return !!indicator_config.value; }
+bool indicator_is_running(void) {
+ return !!indicator_config.value;
+}
static void indicator_timer_cb(void *arg) {
+uprintf("indicator_timer_cb: %02x\n", (uint8_t)(*(indicator_type_t *)arg));
if (*(indicator_type_t *)arg != INDICATOR_LAST) type = *(indicator_type_t *)arg;
bool time_up = false;
@@ -226,8 +233,7 @@ static void indicator_timer_cb(void *arg) {
}
#ifdef HOST_LED_PIN_LIST
- if (indicator_config.value)
- {
+ if (indicator_config.value) {
uint8_t idx = (indicator_config.value & 0x0F) - 1;
if (idx < HOST_DEVICES_COUNT) {
@@ -243,17 +249,15 @@ static void indicator_timer_cb(void *arg) {
if (time_up) {
/* Set indicator to off on timeup, avoid keeping light up until next update in raindrop effect */
indicator_config.value = indicator_config.value & 0x0F;
-#ifdef LED_MATRIX_ENABLE
- led_matrix_indicators_kb();
-#endif
-#ifdef RGB_MATRIX_ENABLE
- rgb_matrix_indicators_kb();
+#if defined(LED_MATRIX_ENABLE) || defined(RGB_MATRIX_ENABLE)
+ LED_INDICATORS_KB();
#endif
indicator_config.value = 0;
}
- if (indicator_config.value == 0 && !indicator_is_backlit_enabled_eeprom()) {
- indicator_disable();
+ if (indicator_config.value == 0) {
+ indicator_eeconfig_reload();
+ if (!LED_DRIVER_IS_ENABLED()) indicator_disable();
}
}
@@ -335,8 +339,9 @@ void indicator_set(bluetooth_state_t state, uint8_t host_index) {
void indicator_stop(void) {
indicator_config.value = 0;
+ indicator_eeconfig_reload();
- if (indicator_is_backlit_enabled_eeprom()) {
+ if (indicator_is_enabled()) {
indicator_enable();
} else {
indicator_disable();
@@ -366,50 +371,44 @@ void indicator_task(void) {
}
}
-#ifdef LED_MATRIX_ENABLE
-void led_matrix_indicators_kb(void) {
- if (get_transport() == TRANSPORT_BLUETOOTH) {
- if (battery_is_critical_low()) {
- /* Prevent backlight flash caused by key activities */
- led_matrix_set_value_all(0);
- return;
- }
-
- if (bat_level_animiation_actived()) {
- bat_level_animiation_indicate();
- }
-
- static uint8_t last_host_index = 0xFF;
- if (indicator_config.value) {
- uint8_t host_index = indicator_config.value & 0x0F;
-
- if (indicator_config.highlight) {
- led_matrix_set_value_all(0);
- } else if (last_host_index != host_index) {
- led_matrix_set_value(host_led_matrix_list[last_host_index - 1], 0);
- last_host_index = host_index;
- }
-
- if (indicator_config.value & 0x80)
- led_matrix_set_value(host_led_matrix_list[host_index - 1], 255);
- else
- led_matrix_set_value(host_led_matrix_list[host_index - 1], 0);
- }
-# if defined(DIM_CAPS_LOCK) && defined(CAPS_LOCK_INDEX)
- else if (host_keyboard_led_state().caps_lock) {
- led_matrix_set_value(CAPS_LOCK_INDEX, 0);
- }
+#if defined(LED_MATRIX_ENABLE) || defined(RGB_MATRIX_ENABLE)
+static void os_state_indicate(void) {
+# if defined(NUM_LOCK_INDEX)
+ if (host_keyboard_led_state().num_lock) {
+ SET_LED_ON(NUM_LOCK_INDEX);
+ }
# endif
+# if defined(CAPS_LOCK_INDEX)
+ if (host_keyboard_led_state().caps_lock) {
+# if defined(DIM_CAPS_LOCK)
+ SET_LED_OFF(CAPS_LOCK_INDEX);
+# else
+ SET_LED_ON(CAPS_LOCK_INDEX);
+# endif
}
+# endif
+# if defined(SCROLL_LOCK_INDEX)
+ if (host_keyboard_led_state().scroll_lock) {
+ SET_LED_ON(SCROLL_LOCK_INDEX);
+ }
+# endif
+# if defined(COMPOSE_LOCK_INDEX)
+ if (host_keyboard_led_state().compose) {
+ SET_LED_ON(COMPOSE_LOCK_INDEX);
+ }
+# endif
+# if defined(KANA_LOCK_INDEX)
+ if (host_keyboard_led_state().kana) {
+ SET_LED_ON(KANA_LOCK_INDEX);
+ }
+# endif
}
-#endif
-#ifdef RGB_MATRIX_ENABLE
-void rgb_matrix_indicators_kb(void) {
- {
+void LED_INDICATORS_KB(void) {
+ if (get_transport() == TRANSPORT_BLUETOOTH) {
+ /* Prevent backlight flash caused by key activities */
if (battery_is_critical_low()) {
- /* Prevent backlight flash caused by key activities */
- rgb_matrix_set_color_all(0, 0, 0);
+ SET_ALL_LED_OFF();
return;
}
@@ -422,23 +421,62 @@ void rgb_matrix_indicators_kb(void) {
uint8_t host_index = indicator_config.value & 0x0F;
if (indicator_config.highlight) {
- rgb_matrix_set_color_all(0, 0, 0);
+ SET_ALL_LED_OFF();
} else if (last_host_index != host_index) {
- rgb_matrix_set_color(host_led_matrix_list[last_host_index - 1], 0, 0, 0);
+ SET_LED_OFF(host_led_matrix_list[last_host_index - 1]);
last_host_index = host_index;
}
if (indicator_config.value & 0x80) {
- rgb_matrix_set_color(host_led_matrix_list[host_index - 1], 0, 0, 255);
+ SET_LED_BT(host_led_matrix_list[host_index - 1]);
} else {
- rgb_matrix_set_color(host_led_matrix_list[host_index - 1], 0, 0, 0);
+ SET_LED_OFF(host_led_matrix_list[host_index - 1]);
}
- }
-# if defined(DIM_CAPS_LOCK) && defined(CAPS_LOCK_INDEX)
- else if (host_keyboard_led_state().caps_lock) {
- rgb_matrix_set_color(CAPS_LOCK_INDEX, 0, 0, 0);
- }
+ } else
+ os_state_indicate();
+
+ } else
+ os_state_indicate();
+}
+
+bool led_update_user(led_t led_state) {
+ if (!LED_DRIVER_IS_ENABLED()) {
+# ifdef RGB_MATRIX_DRIVER_SHUTDOWN_ENABLE
+ LED_DRIVER.exit_shutdown();
+# endif
+ SET_ALL_LED_OFF();
+ os_state_indicate();
+ LED_DRIVER.flush();
+# ifdef RGB_MATRIX_DRIVER_SHUTDOWN_ENABLE
+ if (LED_DRIVER_ALLOW_SHUTDOWN()) LED_DRIVER.shutdown();
# endif
}
+ return true;
}
+
+void LED_NONE_INDICATORS_KB(void) {
+ os_state_indicate();
+}
+
+# ifdef RGB_MATRIX_DRIVER_SHUTDOWN_ENABLE
+bool LED_DRIVER_ALLOW_SHUTDOWN(void) {
+# if defined(NUM_LOCK_INDEX)
+ if (host_keyboard_led_state().num_lock) return false;
+# endif
+# if defined(CAPS_LOCK_INDEX) && !defined(DIM_CAPS_LOCK)
+ if (host_keyboard_led_state().caps_lock) return false;
+# endif
+# if defined(SCROLL_LOCK_INDEX)
+ if (host_keyboard_led_state().scroll_lock) return false;
+# endif
+# if defined(COMPOSE_LOCK_INDEX)
+ if (host_keyboard_led_state().compose) return false;
+# endif
+# if defined(KANA_LOCK_INDEX)
+ if (host_keyboard_led_state().kana) return false;
+# endif
+ return true;
+}
+# endif
+
#endif
diff --git a/keyboards/keychron/bluetooth/indicator.h b/keyboards/keychron/bluetooth/indicator.h
index d09cf3c7cf..17bda1e65a 100644
--- a/keyboards/keychron/bluetooth/indicator.h
+++ b/keyboards/keychron/bluetooth/indicator.h
@@ -81,7 +81,7 @@ bool indicator_hook_key(uint16_t keycode);
void indicator_enable(void);
void indicator_disable(void);
void indicator_stop(void);
-bool indicator_is_backlit_enabled_eeprom(void);
+void indicator_eeconfig_reload(void);
bool indicator_is_running(void);
void indicator_battery_low_enable(bool enable);
diff --git a/keyboards/keychron/bluetooth/lpm.c b/keyboards/keychron/bluetooth/lpm.c
index 84f629a672..62e78d03b1 100644
--- a/keyboards/keychron/bluetooth/lpm.c
+++ b/keyboards/keychron/bluetooth/lpm.c
@@ -41,7 +41,11 @@ static matrix_row_t empty_matrix[MATRIX_ROWS] = {0};
void lpm_init(void) {
#ifdef USB_POWER_SENSE_PIN
+# if (USB_POWER_CONNECTED_LEVEL == 0)
setPinInputHigh(USB_POWER_SENSE_PIN);
+# else
+ setPinInputLow(USB_POWER_SENSE_PIN);
+# endif
#endif
lpm_timer_reset();
}
diff --git a/keyboards/keychron/bluetooth/lpm_stm32l432.c b/keyboards/keychron/bluetooth/lpm_stm32l432.c
index a871a1b53c..10fe9f5ceb 100644
--- a/keyboards/keychron/bluetooth/lpm_stm32l432.c
+++ b/keyboards/keychron/bluetooth/lpm_stm32l432.c
@@ -192,12 +192,6 @@ static inline void lpm_wakeup(void) {
PWR->SCR |= PWR_SCR_CWUF;
PWR->SCR |= PWR_SCR_CSBF;
-#if defined(KEEP_USB_CONNECTION_IN_BLUETOOTH_MODE)
- /* Remove USB isolation.*/
- PWR->CR2 |= PWR_CR2_USV; /* PWR_CR2_USV is available on STM32L4x2xx and STM32L4x3xx devices only. */
- usb_start(&USBD1);
-#endif
-
/* TIMx is disable during stop/standby/sleep mode, init after wakeup */
stInit();
timer_init();
@@ -211,8 +205,21 @@ static inline void lpm_wakeup(void) {
}
}
palDisableLineEvent(BLUETOOTH_INT_INPUT_PIN);
+
+#ifdef USB_POWER_SENSE_PIN
palDisableLineEvent(USB_POWER_SENSE_PIN);
+#if defined(KEEP_USB_CONNECTION_IN_BLUETOOTH_MODE)
+ if (usb_power_connected()) {
+ /* Remove USB isolation.*/
+ //PWR->CR2 |= PWR_CR2_USV; /* PWR_CR2_USV is available on STM32L4x2xx and STM32L4x3xx devices only. */
+ usb_power_connect();
+ usb_start(&USBD1);
+ }
+#endif
+
+#endif
+
#if defined(DIP_SWITCH_PINS)
dip_switch_init();
dip_switch_read(true);
@@ -222,6 +229,7 @@ static inline void lpm_wakeup(void) {
rtcSTM32SetPeriodicWakeup(&RTCD1, NULL);
nvicDisableVector(STM32_EXTI20_NUMBER);
#endif
+
}
/*