mirror of
https://github.com/mfulz/qmk_firmware.git
synced 2025-10-24 02:59:57 +02:00

* rename backlight_soft to match rules.mk * rename backlight_soft to match rules.mk - update common_features * Carve out a better location for private driver backlight functionality
242 lines
6.7 KiB
C
242 lines
6.7 KiB
C
/*
|
|
Copyright 2013 Mathias Andersson <wraul@dbox.se>
|
|
|
|
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 "backlight.h"
|
|
#include "eeconfig.h"
|
|
#include "debug.h"
|
|
|
|
#if defined(STM32F0XX) || defined(STM32F0xx)
|
|
# pragma message("Backlight support for STMF072 has had limited testing, YMMV. If unsure, set 'BACKLIGHT_ENABLE = no' in your rules.mk")
|
|
#endif
|
|
|
|
backlight_config_t backlight_config;
|
|
|
|
#ifdef BACKLIGHT_BREATHING
|
|
// TODO: migrate to backlight_config_t
|
|
static uint8_t breathing_period = BREATHING_PERIOD;
|
|
#endif
|
|
|
|
/** \brief Backlight initialization
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_init(void) {
|
|
/* check signature */
|
|
if (!eeconfig_is_enabled()) {
|
|
eeconfig_init();
|
|
}
|
|
backlight_config.raw = eeconfig_read_backlight();
|
|
if (backlight_config.level > BACKLIGHT_LEVELS) {
|
|
backlight_config.level = BACKLIGHT_LEVELS;
|
|
}
|
|
backlight_set(backlight_config.enable ? backlight_config.level : 0);
|
|
}
|
|
|
|
/** \brief Backlight increase
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_increase(void) {
|
|
if (backlight_config.level < BACKLIGHT_LEVELS) {
|
|
backlight_config.level++;
|
|
}
|
|
backlight_config.enable = 1;
|
|
eeconfig_update_backlight(backlight_config.raw);
|
|
dprintf("backlight increase: %u\n", backlight_config.level);
|
|
backlight_set(backlight_config.level);
|
|
}
|
|
|
|
/** \brief Backlight decrease
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_decrease(void) {
|
|
if (backlight_config.level > 0) {
|
|
backlight_config.level--;
|
|
backlight_config.enable = !!backlight_config.level;
|
|
eeconfig_update_backlight(backlight_config.raw);
|
|
}
|
|
dprintf("backlight decrease: %u\n", backlight_config.level);
|
|
backlight_set(backlight_config.level);
|
|
}
|
|
|
|
/** \brief Backlight toggle
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_toggle(void) {
|
|
bool enabled = backlight_config.enable;
|
|
dprintf("backlight toggle: %u\n", enabled);
|
|
if (enabled)
|
|
backlight_disable();
|
|
else
|
|
backlight_enable();
|
|
}
|
|
|
|
/** \brief Enable backlight
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_enable(void) {
|
|
if (backlight_config.enable) return; // do nothing if backlight is already on
|
|
|
|
backlight_config.enable = true;
|
|
if (backlight_config.raw == 1) // enabled but level == 0
|
|
backlight_config.level = 1;
|
|
eeconfig_update_backlight(backlight_config.raw);
|
|
dprintf("backlight enable\n");
|
|
backlight_set(backlight_config.level);
|
|
}
|
|
|
|
/** \brief Disable backlight
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_disable(void) {
|
|
if (!backlight_config.enable) return; // do nothing if backlight is already off
|
|
|
|
backlight_config.enable = false;
|
|
eeconfig_update_backlight(backlight_config.raw);
|
|
dprintf("backlight disable\n");
|
|
backlight_set(0);
|
|
}
|
|
|
|
/** /brief Get the backlight status
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
bool is_backlight_enabled(void) { return backlight_config.enable; }
|
|
|
|
/** \brief Backlight step through levels
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_step(void) {
|
|
backlight_config.level++;
|
|
if (backlight_config.level > BACKLIGHT_LEVELS) {
|
|
backlight_config.level = 0;
|
|
}
|
|
backlight_config.enable = !!backlight_config.level;
|
|
eeconfig_update_backlight(backlight_config.raw);
|
|
dprintf("backlight step: %u\n", backlight_config.level);
|
|
backlight_set(backlight_config.level);
|
|
}
|
|
|
|
/** \brief Backlight set level without EEPROM update
|
|
*
|
|
*/
|
|
void backlight_level_noeeprom(uint8_t level) {
|
|
if (level > BACKLIGHT_LEVELS) level = BACKLIGHT_LEVELS;
|
|
backlight_config.level = level;
|
|
backlight_config.enable = !!backlight_config.level;
|
|
backlight_set(backlight_config.level);
|
|
}
|
|
|
|
/** \brief Backlight set level
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_level(uint8_t level) {
|
|
backlight_level_noeeprom(level);
|
|
eeconfig_update_backlight(backlight_config.raw);
|
|
}
|
|
|
|
/** \brief Update current backlight state to EEPROM
|
|
*
|
|
*/
|
|
void eeconfig_update_backlight_current(void) { eeconfig_update_backlight(backlight_config.raw); }
|
|
|
|
/** \brief Get backlight level
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
uint8_t get_backlight_level(void) { return backlight_config.level; }
|
|
|
|
#ifdef BACKLIGHT_BREATHING
|
|
/** \brief Backlight breathing toggle
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_toggle_breathing(void) {
|
|
bool breathing = backlight_config.breathing;
|
|
dprintf("backlight breathing toggle: %u\n", breathing);
|
|
if (breathing)
|
|
backlight_disable_breathing();
|
|
else
|
|
backlight_enable_breathing();
|
|
}
|
|
|
|
/** \brief Enable backlight breathing
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_enable_breathing(void) {
|
|
if (backlight_config.breathing) return; // do nothing if breathing is already on
|
|
|
|
backlight_config.breathing = true;
|
|
eeconfig_update_backlight(backlight_config.raw);
|
|
dprintf("backlight breathing enable\n");
|
|
breathing_enable();
|
|
}
|
|
|
|
/** \brief Disable backlight breathing
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
void backlight_disable_breathing(void) {
|
|
if (!backlight_config.breathing) return; // do nothing if breathing is already off
|
|
|
|
backlight_config.breathing = false;
|
|
eeconfig_update_backlight(backlight_config.raw);
|
|
dprintf("backlight breathing disable\n");
|
|
breathing_disable();
|
|
}
|
|
|
|
/** \brief Get the backlight breathing status
|
|
*
|
|
* FIXME: needs doc
|
|
*/
|
|
bool is_backlight_breathing(void) { return backlight_config.breathing; }
|
|
|
|
// following are marked as weak purely for backwards compatibility
|
|
__attribute__((weak)) void breathing_period_set(uint8_t value) { breathing_period = value ? value : 1; }
|
|
|
|
__attribute__((weak)) uint8_t get_breathing_period(void) { return breathing_period; }
|
|
|
|
__attribute__((weak)) void breathing_period_default(void) { breathing_period_set(BREATHING_PERIOD); }
|
|
|
|
__attribute__((weak)) void breathing_period_inc(void) { breathing_period_set(breathing_period + 1); }
|
|
|
|
__attribute__((weak)) void breathing_period_dec(void) { breathing_period_set(breathing_period - 1); }
|
|
|
|
__attribute__((weak)) void breathing_toggle(void) {
|
|
if (is_breathing())
|
|
breathing_disable();
|
|
else
|
|
breathing_enable();
|
|
}
|
|
|
|
#endif
|
|
|
|
// defaults for backlight api
|
|
__attribute__((weak)) void backlight_init_ports(void) {}
|
|
|
|
__attribute__((weak)) void backlight_set(uint8_t level) {}
|
|
|
|
__attribute__((weak)) void backlight_task(void) {}
|