summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Tang <e_l_tang@outlook.com>2016-06-13 00:01:55 +0200
committerJack Humbert <jack.humb@gmail.com>2016-06-13 00:01:55 +0200
commit6955719075a9a07524814e4183f3f90f83db1c6a (patch)
tree4992f68783514c307c327a8fe88fc41d29550a56
parent92759be3226c83087959015be097b66d8c7e2f21 (diff)
downloadqmk_firmware-6955719075a9a07524814e4183f3f90f83db1c6a.tar.gz
qmk_firmware-6955719075a9a07524814e4183f3f90f83db1c6a.tar.xz
Move LED strip initialization (#397)
-rw-r--r--keyboard/clueboard1/clueboard1.c4
-rw-r--r--keyboard/clueboard2/clueboard2.c4
-rw-r--r--keyboard/cluepad/cluepad.c4
-rw-r--r--keyboard/planck/planck.c16
-rw-r--r--keyboard/preonic/preonic.c17
-rw-r--r--tmk_core/common/keyboard.c6
6 files changed, 18 insertions, 33 deletions
diff --git a/keyboard/clueboard1/clueboard1.c b/keyboard/clueboard1/clueboard1.c
index 289e4644d..136ddf15b 100644
--- a/keyboard/clueboard1/clueboard1.c
+++ b/keyboard/clueboard1/clueboard1.c
@@ -11,10 +11,6 @@ void matrix_scan_user(void) {
}
void matrix_init_kb(void) {
- #ifdef RGBLIGHT_ENABLE
- rgblight_init();
- #endif
-
matrix_init_user();
}
diff --git a/keyboard/clueboard2/clueboard2.c b/keyboard/clueboard2/clueboard2.c
index 437f8d1e4..8493c564c 100644
--- a/keyboard/clueboard2/clueboard2.c
+++ b/keyboard/clueboard2/clueboard2.c
@@ -26,10 +26,6 @@ void matrix_init_kb(void) {
init_backlight_pin();
#endif
- #ifdef RGBLIGHT_ENABLE
- rgblight_init();
- #endif
-
// JTAG disable for PORT F. write JTD bit twice within four cycles.
MCUCR |= (1<<JTD);
MCUCR |= (1<<JTD);
diff --git a/keyboard/cluepad/cluepad.c b/keyboard/cluepad/cluepad.c
index d55b99960..a4dbd6fdc 100644
--- a/keyboard/cluepad/cluepad.c
+++ b/keyboard/cluepad/cluepad.c
@@ -21,10 +21,6 @@ void matrix_init_kb(void) {
init_backlight_pin();
#endif
- #ifdef RGBLIGHT_ENABLE
- rgblight_init();
- #endif
-
// JTAG disable for PORT F. write JTD bit twice within four cycles.
MCUCR |= (1<<JTD);
MCUCR |= (1<<JTD);
diff --git a/keyboard/planck/planck.c b/keyboard/planck/planck.c
index da7b3a170..f1a76266e 100644
--- a/keyboard/planck/planck.c
+++ b/keyboard/planck/planck.c
@@ -19,10 +19,6 @@ void matrix_init_kb(void) {
backlight_init_ports();
#endif
-#ifdef RGBLIGHT_ENABLE
- rgblight_init();
-#endif
-
// Turn status LED on
DDRE |= (1<<6);
PORTE |= (1<<6);
@@ -61,20 +57,20 @@ void backlight_init_ports()
// Setup PB7 as output and output low.
DDRB |= (1<<7);
PORTB &= ~(1<<7);
-
- // Use full 16-bit resolution.
+
+ // Use full 16-bit resolution.
ICR1 = 0xFFFF;
// I could write a wall of text here to explain... but TL;DW
// Go read the ATmega32u4 datasheet.
// And this: http://blog.saikoled.com/post/43165849837/secret-konami-cheat-code-to-high-resolution-pwm-on
-
+
// Pin PB7 = OCR1C (Timer 1, Channel C)
// Compare Output Mode = Clear on compare match, Channel C = COM1C1=1 COM1C0=0
// (i.e. start high, go low when counter matches.)
// WGM Mode 14 (Fast PWM) = WGM13=1 WGM12=1 WGM11=1 WGM10=0
// Clock Select = clk/1 (no prescaling) = CS12=0 CS11=0 CS10=1
-
+
TCCR1A = _BV(COM1C1) | _BV(WGM11); // = 0b00001010;
TCCR1B = _BV(WGM13) | _BV(WGM12) | _BV(CS10); // = 0b00011001;
@@ -100,7 +96,7 @@ void backlight_set(uint8_t level)
// Set the brightness
CHANNEL = 0xFFFF;
}
- else
+ else
{
// Turn on PWM control of PB7
TCCR1A |= _BV(COM1C1);
@@ -303,4 +299,4 @@ ISR(TIMER1_COMPA_vect)
-#endif \ No newline at end of file
+#endif
diff --git a/keyboard/preonic/preonic.c b/keyboard/preonic/preonic.c
index 13e05c65a..773451bf0 100644
--- a/keyboard/preonic/preonic.c
+++ b/keyboard/preonic/preonic.c
@@ -20,11 +20,6 @@ void matrix_init_kb(void) {
backlight_init_ports();
#endif
- #ifdef RGBLIGHT_ENABLE
- rgblight_init();
- #endif
-
-
// Turn status LED on
DDRE |= (1<<6);
PORTE |= (1<<6);
@@ -49,20 +44,20 @@ void backlight_init_ports()
// Setup PB7 as output and output low.
DDRB |= (1<<7);
PORTB &= ~(1<<7);
-
- // Use full 16-bit resolution.
+
+ // Use full 16-bit resolution.
ICR1 = 0xFFFF;
// I could write a wall of text here to explain... but TL;DW
// Go read the ATmega32u4 datasheet.
// And this: http://blog.saikoled.com/post/43165849837/secret-konami-cheat-code-to-high-resolution-pwm-on
-
+
// Pin PB7 = OCR1C (Timer 1, Channel C)
// Compare Output Mode = Clear on compare match, Channel C = COM1C1=1 COM1C0=0
// (i.e. start high, go low when counter matches.)
// WGM Mode 14 (Fast PWM) = WGM13=1 WGM12=1 WGM11=1 WGM10=0
// Clock Select = clk/1 (no prescaling) = CS12=0 CS11=0 CS10=1
-
+
TCCR1A = _BV(COM1C1) | _BV(WGM11); // = 0b00001010;
TCCR1B = _BV(WGM13) | _BV(WGM12) | _BV(CS10); // = 0b00011001;
@@ -88,7 +83,7 @@ void backlight_set(uint8_t level)
// Set the brightness
CHANNEL = 0xFFFF;
}
- else
+ else
{
// Prevent backlight blink on lowest level
PORTB &= ~(_BV(PORTB7));
@@ -99,4 +94,4 @@ void backlight_set(uint8_t level)
}
}
-#endif \ No newline at end of file
+#endif
diff --git a/tmk_core/common/keyboard.c b/tmk_core/common/keyboard.c
index bd543c45e..34e1ceeca 100644
--- a/tmk_core/common/keyboard.c
+++ b/tmk_core/common/keyboard.c
@@ -46,6 +46,9 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#ifdef ADB_MOUSE_ENABLE
# include "adb.h"
#endif
+#ifdef RGBLIGHT_ENABLE
+# include "rgblight.h"
+#endif
#ifdef MATRIX_HAS_GHOST
static bool is_row_ghosting(uint8_t row){
@@ -89,6 +92,9 @@ void keyboard_init(void) {
#ifdef BACKLIGHT_ENABLE
backlight_init();
#endif
+#ifdef RGBLIGHT_ENABLE
+ rgblight_init();
+#endif
#if defined(NKRO_ENABLE) && defined(FORCE_NKRO)
keyboard_nkro = true;
#endif