Fix indicator issue
This commit is contained in:
parent
6829fbd074
commit
652e6f3db8
1 changed files with 17 additions and 15 deletions
|
|
@ -213,8 +213,9 @@ static void indicator_timer_cb(void *arg) {
|
||||||
|
|
||||||
if ((indicator_config.duration == 0 || indicator_config.elapsed <= indicator_config.duration) && next_period != 0) {
|
if ((indicator_config.duration == 0 || indicator_config.elapsed <= indicator_config.duration) && next_period != 0) {
|
||||||
indicator_config.elapsed += next_period;
|
indicator_config.elapsed += next_period;
|
||||||
} else
|
} else {
|
||||||
time_up = true;
|
time_up = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
|
@ -224,6 +225,21 @@ static void indicator_timer_cb(void *arg) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef HOST_LED_PIN_LIST
|
||||||
|
if (indicator_config.value)
|
||||||
|
{
|
||||||
|
uint8_t idx = (indicator_config.value & 0x0F) - 1;
|
||||||
|
|
||||||
|
if (idx < HOST_DEVICES_COUNT) {
|
||||||
|
if ((indicator_config.value & 0x80) && !time_up) {
|
||||||
|
writePin(host_led_pin_list[idx], HOST_LED_PIN_ON_STATE);
|
||||||
|
} else {
|
||||||
|
writePin(host_led_pin_list[idx], !HOST_LED_PIN_ON_STATE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (time_up) {
|
if (time_up) {
|
||||||
/* Set indicator to off on timeup, avoid keeping light up until next update in raindrop effect */
|
/* Set indicator to off on timeup, avoid keeping light up until next update in raindrop effect */
|
||||||
indicator_config.value = indicator_config.value & 0x0F;
|
indicator_config.value = indicator_config.value & 0x0F;
|
||||||
|
|
@ -236,20 +252,6 @@ static void indicator_timer_cb(void *arg) {
|
||||||
indicator_config.value = 0;
|
indicator_config.value = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef HOST_LED_PIN_LIST
|
|
||||||
if (indicator_config.value)
|
|
||||||
{
|
|
||||||
uint8_t idx = (indicator_config.value & 0x0F) - 1;
|
|
||||||
chDbgAssert(idx < HOST_DEVICES_COUNT, "array out of bounds");
|
|
||||||
|
|
||||||
if (indicator_config.value & 0x80) {
|
|
||||||
writePin(host_led_pin_list[idx], HOST_LED_PIN_ON_STATE);
|
|
||||||
} else {
|
|
||||||
writePin(host_led_pin_list[idx], !HOST_LED_PIN_ON_STATE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (indicator_config.value == 0 && !indicator_is_backlit_enabled_eeprom()) {
|
if (indicator_config.value == 0 && !indicator_is_backlit_enabled_eeprom()) {
|
||||||
indicator_disable();
|
indicator_disable();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue