mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-10-25 03:29:59 +02:00 
			
		
		
		
	 3a303bd2ae
			
		
	
	
		3a303bd2ae
		
			
		
	
	
	
	
		
			
			* 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) {}
 |