|
@@ -594,34 +594,45 @@ static const uint8_t backlight_pin = BACKLIGHT_PIN;
|
|
# define COM1x1 COM1A1
|
|
# define COM1x1 COM1A1
|
|
# define OCR1x OCR1A
|
|
# define OCR1x OCR1A
|
|
#else
|
|
#else
|
|
-# error "Backlight pin not supported - use B5, B6, or B7"
|
|
+# define NO_BACKLIGHT_CLOCK
|
|
|
|
+#endif
|
|
|
|
+
|
|
|
|
+#ifndef BACKLIGHT_ON_STATE
|
|
|
|
+#define BACKLIGHT_ON_STATE 0
|
|
#endif
|
|
#endif
|
|
|
|
|
|
__attribute__ ((weak))
|
|
__attribute__ ((weak))
|
|
void backlight_init_ports(void)
|
|
void backlight_init_ports(void)
|
|
{
|
|
{
|
|
|
|
|
|
-
|
|
+
|
|
|
|
|
|
_SFR_IO8((backlight_pin >> 4) + 1) |= _BV(backlight_pin & 0xF);
|
|
_SFR_IO8((backlight_pin >> 4) + 1) |= _BV(backlight_pin & 0xF);
|
|
-
|
|
+ #if BACKLIGHT_ON_STATE == 0
|
|
- _SFR_IO8((backlight_pin >> 4) + 2) &= ~_BV(backlight_pin & 0xF);
|
|
+
|
|
|
|
+ _SFR_IO8((backlight_pin >> 4) + 2) &= ~_BV(backlight_pin & 0xF);
|
|
|
|
+ #else
|
|
|
|
+
|
|
|
|
+ _SFR_IO8((backlight_pin >> 4) + 2) |= _BV(backlight_pin & 0xF);
|
|
|
|
+ #endif
|
|
|
|
|
|
-
|
|
+ #ifndef NO_BACKLIGHT_CLOCK
|
|
- ICR1 = 0xFFFF;
|
|
+
|
|
|
|
+ ICR1 = 0xFFFF;
|
|
|
|
|
|
-
|
|
+
|
|
-
|
|
+
|
|
-
|
|
+
|
|
|
|
|
|
-
|
|
+
|
|
-
|
|
+
|
|
-
|
|
+
|
|
-
|
|
+
|
|
-
|
|
+
|
|
|
|
|
|
- TCCR1A = _BV(COM1x1) | _BV(WGM11);
|
|
+ TCCR1A = _BV(COM1x1) | _BV(WGM11);
|
|
- TCCR1B = _BV(WGM13) | _BV(WGM12) | _BV(CS10);
|
|
+ TCCR1B = _BV(WGM13) | _BV(WGM12) | _BV(CS10);
|
|
|
|
+ #endif
|
|
|
|
|
|
backlight_init();
|
|
backlight_init();
|
|
#ifdef BACKLIGHT_BREATHING
|
|
#ifdef BACKLIGHT_BREATHING
|
|
@@ -633,24 +644,43 @@ __attribute__ ((weak))
|
|
void backlight_set(uint8_t level)
|
|
void backlight_set(uint8_t level)
|
|
{
|
|
{
|
|
|
|
|
|
-
|
|
+ #if BACKLIGHT_ON_STATE == 0
|
|
- _SFR_IO8((backlight_pin >> 4) + 2) &= ~_BV(backlight_pin & 0xF);
|
|
+
|
|
|
|
+ _SFR_IO8((backlight_pin >> 4) + 2) &= ~_BV(backlight_pin & 0xF);
|
|
|
|
+ #else
|
|
|
|
+
|
|
|
|
+ _SFR_IO8((backlight_pin >> 4) + 2) |= _BV(backlight_pin & 0xF);
|
|
|
|
+ #endif
|
|
|
|
|
|
if ( level == 0 ) {
|
|
if ( level == 0 ) {
|
|
-
|
|
+ #ifndef NO_BACKLIGHT_CLOCK
|
|
- TCCR1A &= ~(_BV(COM1x1));
|
|
+
|
|
- OCR1x = 0x0;
|
|
+ TCCR1A &= ~(_BV(COM1x1));
|
|
- } else if ( level == BACKLIGHT_LEVELS ) {
|
|
+ OCR1x = 0x0;
|
|
-
|
|
+ #else
|
|
- TCCR1A |= _BV(COM1x1);
|
|
+ #if BACKLIGHT_ON_STATE == 0
|
|
-
|
|
+
|
|
- OCR1x = 0xFFFF;
|
|
+ _SFR_IO8((backlight_pin >> 4) + 2) |= _BV(backlight_pin & 0xF);
|
|
- } else {
|
|
+ #else
|
|
-
|
|
+
|
|
- TCCR1A |= _BV(COM1x1);
|
|
+ _SFR_IO8((backlight_pin >> 4) + 2) &= ~_BV(backlight_pin & 0xF);
|
|
-
|
|
+ #endif
|
|
- OCR1x = 0xFFFF >> ((BACKLIGHT_LEVELS - level) * ((BACKLIGHT_LEVELS + 1) / 2));
|
|
+ #endif
|
|
- }
|
|
+ }
|
|
|
|
+ #ifndef NO_BACKLIGHT_CLOCK
|
|
|
|
+ else if ( level == BACKLIGHT_LEVELS ) {
|
|
|
|
+
|
|
|
|
+ TCCR1A |= _BV(COM1x1);
|
|
|
|
+
|
|
|
|
+ OCR1x = 0xFFFF;
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+
|
|
|
|
+ TCCR1A |= _BV(COM1x1);
|
|
|
|
+
|
|
|
|
+ OCR1x = 0xFFFF >> ((BACKLIGHT_LEVELS - level) * ((BACKLIGHT_LEVELS + 1) / 2));
|
|
|
|
+ }
|
|
|
|
+ #endif
|
|
|
|
|
|
#ifdef BACKLIGHT_BREATHING
|
|
#ifdef BACKLIGHT_BREATHING
|
|
breathing_intensity_default();
|
|
breathing_intensity_default();
|