forked from mirrors/qmk_firmware
Backlight - Carve out a better location for private driver functionality (#8329)
* 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
This commit is contained in:
parent
d7ba0ad684
commit
3a303bd2ae
8 changed files with 73 additions and 69 deletions
|
@ -297,24 +297,27 @@ VALID_BACKLIGHT_TYPES := pwm software custom
|
||||||
BACKLIGHT_ENABLE ?= no
|
BACKLIGHT_ENABLE ?= no
|
||||||
BACKLIGHT_DRIVER ?= pwm
|
BACKLIGHT_DRIVER ?= pwm
|
||||||
ifeq ($(strip $(BACKLIGHT_ENABLE)), yes)
|
ifeq ($(strip $(BACKLIGHT_ENABLE)), yes)
|
||||||
SRC += $(QUANTUM_DIR)/process_keycode/process_backlight.c
|
|
||||||
ifeq ($(filter $(BACKLIGHT_DRIVER),$(VALID_BACKLIGHT_TYPES)),)
|
ifeq ($(filter $(BACKLIGHT_DRIVER),$(VALID_BACKLIGHT_TYPES)),)
|
||||||
$(error BACKLIGHT_DRIVER="$(BACKLIGHT_DRIVER)" is not a valid backlight type)
|
$(error BACKLIGHT_DRIVER="$(BACKLIGHT_DRIVER)" is not a valid backlight type)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
COMMON_VPATH += $(QUANTUM_DIR)/backlight
|
COMMON_VPATH += $(QUANTUM_DIR)/backlight
|
||||||
SRC += $(QUANTUM_DIR)/backlight/backlight.c
|
SRC += $(QUANTUM_DIR)/backlight/backlight.c
|
||||||
|
SRC += $(QUANTUM_DIR)/process_keycode/process_backlight.c
|
||||||
OPT_DEFS += -DBACKLIGHT_ENABLE
|
OPT_DEFS += -DBACKLIGHT_ENABLE
|
||||||
|
|
||||||
ifeq ($(strip $(BACKLIGHT_DRIVER)), custom)
|
ifeq ($(strip $(BACKLIGHT_DRIVER)), custom)
|
||||||
OPT_DEFS += -DBACKLIGHT_CUSTOM_DRIVER
|
OPT_DEFS += -DBACKLIGHT_CUSTOM_DRIVER
|
||||||
else ifeq ($(strip $(BACKLIGHT_DRIVER)), software)
|
|
||||||
SRC += $(QUANTUM_DIR)/backlight/backlight_soft.c
|
|
||||||
else
|
else
|
||||||
ifeq ($(PLATFORM),AVR)
|
SRC += $(QUANTUM_DIR)/backlight/backlight_driver_common.c
|
||||||
SRC += $(QUANTUM_DIR)/backlight/backlight_avr.c
|
ifeq ($(strip $(BACKLIGHT_DRIVER)), pwm)
|
||||||
|
ifeq ($(PLATFORM),AVR)
|
||||||
|
SRC += $(QUANTUM_DIR)/backlight/backlight_avr.c
|
||||||
|
else
|
||||||
|
SRC += $(QUANTUM_DIR)/backlight/backlight_arm.c
|
||||||
|
endif
|
||||||
else
|
else
|
||||||
SRC += $(QUANTUM_DIR)/backlight/backlight_arm.c
|
SRC += $(QUANTUM_DIR)/backlight/backlight_$(strip $(BACKLIGHT_DRIVER)).c
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
|
@ -20,6 +20,10 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#include "eeconfig.h"
|
#include "eeconfig.h"
|
||||||
#include "debug.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;
|
backlight_config_t backlight_config;
|
||||||
|
|
||||||
#ifdef BACKLIGHT_BREATHING
|
#ifdef BACKLIGHT_BREATHING
|
||||||
|
@ -27,51 +31,6 @@ backlight_config_t backlight_config;
|
||||||
static uint8_t breathing_period = BREATHING_PERIOD;
|
static uint8_t breathing_period = BREATHING_PERIOD;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef BACKLIGHT_CUSTOM_DRIVER
|
|
||||||
# if defined(BACKLIGHT_PINS)
|
|
||||||
static const pin_t backlight_pins[] = BACKLIGHT_PINS;
|
|
||||||
# ifndef BACKLIGHT_LED_COUNT
|
|
||||||
# define BACKLIGHT_LED_COUNT (sizeof(backlight_pins) / sizeof(pin_t))
|
|
||||||
# endif
|
|
||||||
|
|
||||||
# define FOR_EACH_LED(x) \
|
|
||||||
for (uint8_t i = 0; i < BACKLIGHT_LED_COUNT; i++) { \
|
|
||||||
pin_t backlight_pin = backlight_pins[i]; \
|
|
||||||
{ x } \
|
|
||||||
}
|
|
||||||
# else
|
|
||||||
// we support only one backlight pin
|
|
||||||
static const pin_t backlight_pin = BACKLIGHT_PIN;
|
|
||||||
# define FOR_EACH_LED(x) x
|
|
||||||
# endif
|
|
||||||
|
|
||||||
static inline void backlight_on(pin_t backlight_pin) {
|
|
||||||
# if BACKLIGHT_ON_STATE == 0
|
|
||||||
writePinLow(backlight_pin);
|
|
||||||
# else
|
|
||||||
writePinHigh(backlight_pin);
|
|
||||||
# endif
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void backlight_off(pin_t backlight_pin) {
|
|
||||||
# if BACKLIGHT_ON_STATE == 0
|
|
||||||
writePinHigh(backlight_pin);
|
|
||||||
# else
|
|
||||||
writePinLow(backlight_pin);
|
|
||||||
# endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void backlight_pins_init(void) {
|
|
||||||
// Setup backlight pin as output and output to off state.
|
|
||||||
FOR_EACH_LED(setPinOutput(backlight_pin); backlight_off(backlight_pin);)
|
|
||||||
}
|
|
||||||
|
|
||||||
void backlight_pins_on(void) { FOR_EACH_LED(backlight_on(backlight_pin);) }
|
|
||||||
|
|
||||||
void backlight_pins_off(void) { FOR_EACH_LED(backlight_off(backlight_pin);) }
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/** \brief Backlight initialization
|
/** \brief Backlight initialization
|
||||||
*
|
*
|
||||||
* FIXME: needs doc
|
* FIXME: needs doc
|
||||||
|
|
|
@ -44,10 +44,6 @@ typedef union {
|
||||||
};
|
};
|
||||||
} backlight_config_t;
|
} backlight_config_t;
|
||||||
|
|
||||||
void backlight_pins_init(void);
|
|
||||||
void backlight_pins_on(void);
|
|
||||||
void backlight_pins_off(void);
|
|
||||||
|
|
||||||
void backlight_init(void);
|
void backlight_init(void);
|
||||||
void backlight_toggle(void);
|
void backlight_toggle(void);
|
||||||
void backlight_enable(void);
|
void backlight_enable(void);
|
||||||
|
@ -79,11 +75,11 @@ void breathing_period_default(void);
|
||||||
void breathing_period_inc(void);
|
void breathing_period_inc(void);
|
||||||
void breathing_period_dec(void);
|
void breathing_period_dec(void);
|
||||||
|
|
||||||
|
void breathing_toggle(void);
|
||||||
|
|
||||||
// implementation specific
|
// implementation specific
|
||||||
void breathing_enable(void);
|
void breathing_enable(void);
|
||||||
void breathing_disable(void);
|
void breathing_disable(void);
|
||||||
void breathing_toggle(void);
|
|
||||||
bool is_breathing(void);
|
bool is_breathing(void);
|
||||||
void breathing_pulse(void);
|
void breathing_pulse(void);
|
||||||
void breathing_task(void);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -6,10 +6,6 @@
|
||||||
// TODO: remove short term bodge when refactoring BACKLIGHT_CUSTOM_DRIVER out
|
// TODO: remove short term bodge when refactoring BACKLIGHT_CUSTOM_DRIVER out
|
||||||
#ifdef BACKLIGHT_PIN
|
#ifdef BACKLIGHT_PIN
|
||||||
|
|
||||||
# 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
|
|
||||||
|
|
||||||
// GPIOV2 && GPIOV3
|
// GPIOV2 && GPIOV3
|
||||||
# ifndef BACKLIGHT_PAL_MODE
|
# ifndef BACKLIGHT_PAL_MODE
|
||||||
# define BACKLIGHT_PAL_MODE 2
|
# define BACKLIGHT_PAL_MODE 2
|
||||||
|
|
|
@ -1,11 +1,8 @@
|
||||||
#include "quantum.h"
|
#include "quantum.h"
|
||||||
#include "backlight.h"
|
#include "backlight.h"
|
||||||
|
#include "backlight_driver_common.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
#if !defined(BACKLIGHT_PIN) && !defined(BACKLIGHT_PINS)
|
|
||||||
# error "Backlight pin/pins not defined. Please configure."
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// This logic is a bit complex, we support 3 setups:
|
// This logic is a bit complex, we support 3 setups:
|
||||||
//
|
//
|
||||||
// 1. Hardware PWM when backlight is wired to a PWM pin.
|
// 1. Hardware PWM when backlight is wired to a PWM pin.
|
||||||
|
|
49
quantum/backlight/backlight_driver_common.c
Normal file
49
quantum/backlight/backlight_driver_common.c
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
#include "quantum.h"
|
||||||
|
#include "backlight.h"
|
||||||
|
#include "backlight_driver_common.h"
|
||||||
|
|
||||||
|
#if !defined(BACKLIGHT_PIN) && !defined(BACKLIGHT_PINS)
|
||||||
|
# error "Backlight pin/pins not defined. Please configure."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(BACKLIGHT_PINS)
|
||||||
|
static const pin_t backlight_pins[] = BACKLIGHT_PINS;
|
||||||
|
# ifndef BACKLIGHT_LED_COUNT
|
||||||
|
# define BACKLIGHT_LED_COUNT (sizeof(backlight_pins) / sizeof(pin_t))
|
||||||
|
# endif
|
||||||
|
|
||||||
|
# define FOR_EACH_LED(x) \
|
||||||
|
for (uint8_t i = 0; i < BACKLIGHT_LED_COUNT; i++) { \
|
||||||
|
pin_t backlight_pin = backlight_pins[i]; \
|
||||||
|
{ x } \
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
// we support only one backlight pin
|
||||||
|
static const pin_t backlight_pin = BACKLIGHT_PIN;
|
||||||
|
# define FOR_EACH_LED(x) x
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static inline void backlight_on(pin_t backlight_pin) {
|
||||||
|
#if BACKLIGHT_ON_STATE == 0
|
||||||
|
writePinLow(backlight_pin);
|
||||||
|
#else
|
||||||
|
writePinHigh(backlight_pin);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void backlight_off(pin_t backlight_pin) {
|
||||||
|
#if BACKLIGHT_ON_STATE == 0
|
||||||
|
writePinHigh(backlight_pin);
|
||||||
|
#else
|
||||||
|
writePinLow(backlight_pin);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void backlight_pins_init(void) {
|
||||||
|
// Setup backlight pin as output and output to off state.
|
||||||
|
FOR_EACH_LED(setPinOutput(backlight_pin); backlight_off(backlight_pin);)
|
||||||
|
}
|
||||||
|
|
||||||
|
void backlight_pins_on(void) { FOR_EACH_LED(backlight_on(backlight_pin);) }
|
||||||
|
|
||||||
|
void backlight_pins_off(void) { FOR_EACH_LED(backlight_off(backlight_pin);) }
|
7
quantum/backlight/backlight_driver_common.h
Normal file
7
quantum/backlight/backlight_driver_common.h
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
void backlight_pins_init(void);
|
||||||
|
void backlight_pins_on(void);
|
||||||
|
void backlight_pins_off(void);
|
||||||
|
|
||||||
|
void breathing_task(void);
|
|
@ -1,9 +1,6 @@
|
||||||
#include "quantum.h"
|
#include "quantum.h"
|
||||||
#include "backlight.h"
|
#include "backlight.h"
|
||||||
|
#include "backlight_driver_common.h"
|
||||||
#if !defined(BACKLIGHT_PIN) && !defined(BACKLIGHT_PINS)
|
|
||||||
# error "Backlight pin/pins not defined. Please configure."
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef BACKLIGHT_BREATHING
|
#ifdef BACKLIGHT_BREATHING
|
||||||
# error "Backlight breathing is not available for software PWM. Please disable."
|
# error "Backlight breathing is not available for software PWM. Please disable."
|
Loading…
Reference in a new issue