Move LED strip initialization (#397)

example_keyboards
Eric Tang 9 years ago committed by Jack Humbert
parent 92759be322
commit 6955719075

@ -11,10 +11,6 @@ void matrix_scan_user(void) {
} }
void matrix_init_kb(void) { void matrix_init_kb(void) {
#ifdef RGBLIGHT_ENABLE
rgblight_init();
#endif
matrix_init_user(); matrix_init_user();
} }

@ -26,10 +26,6 @@ void matrix_init_kb(void) {
init_backlight_pin(); init_backlight_pin();
#endif #endif
#ifdef RGBLIGHT_ENABLE
rgblight_init();
#endif
// JTAG disable for PORT F. write JTD bit twice within four cycles. // JTAG disable for PORT F. write JTD bit twice within four cycles.
MCUCR |= (1<<JTD); MCUCR |= (1<<JTD);
MCUCR |= (1<<JTD); MCUCR |= (1<<JTD);

@ -21,10 +21,6 @@ void matrix_init_kb(void) {
init_backlight_pin(); init_backlight_pin();
#endif #endif
#ifdef RGBLIGHT_ENABLE
rgblight_init();
#endif
// JTAG disable for PORT F. write JTD bit twice within four cycles. // JTAG disable for PORT F. write JTD bit twice within four cycles.
MCUCR |= (1<<JTD); MCUCR |= (1<<JTD);
MCUCR |= (1<<JTD); MCUCR |= (1<<JTD);

@ -19,10 +19,6 @@ void matrix_init_kb(void) {
backlight_init_ports(); backlight_init_ports();
#endif #endif
#ifdef RGBLIGHT_ENABLE
rgblight_init();
#endif
// Turn status LED on // Turn status LED on
DDRE |= (1<<6); DDRE |= (1<<6);
PORTE |= (1<<6); PORTE |= (1<<6);
@ -61,20 +57,20 @@ void backlight_init_ports()
// Setup PB7 as output and output low. // Setup PB7 as output and output low.
DDRB |= (1<<7); DDRB |= (1<<7);
PORTB &= ~(1<<7); PORTB &= ~(1<<7);
// Use full 16-bit resolution. // Use full 16-bit resolution.
ICR1 = 0xFFFF; ICR1 = 0xFFFF;
// I could write a wall of text here to explain... but TL;DW // I could write a wall of text here to explain... but TL;DW
// Go read the ATmega32u4 datasheet. // Go read the ATmega32u4 datasheet.
// And this: http://blog.saikoled.com/post/43165849837/secret-konami-cheat-code-to-high-resolution-pwm-on // And this: http://blog.saikoled.com/post/43165849837/secret-konami-cheat-code-to-high-resolution-pwm-on
// Pin PB7 = OCR1C (Timer 1, Channel C) // Pin PB7 = OCR1C (Timer 1, Channel C)
// Compare Output Mode = Clear on compare match, Channel C = COM1C1=1 COM1C0=0 // Compare Output Mode = Clear on compare match, Channel C = COM1C1=1 COM1C0=0
// (i.e. start high, go low when counter matches.) // (i.e. start high, go low when counter matches.)
// WGM Mode 14 (Fast PWM) = WGM13=1 WGM12=1 WGM11=1 WGM10=0 // 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 // Clock Select = clk/1 (no prescaling) = CS12=0 CS11=0 CS10=1
TCCR1A = _BV(COM1C1) | _BV(WGM11); // = 0b00001010; TCCR1A = _BV(COM1C1) | _BV(WGM11); // = 0b00001010;
TCCR1B = _BV(WGM13) | _BV(WGM12) | _BV(CS10); // = 0b00011001; TCCR1B = _BV(WGM13) | _BV(WGM12) | _BV(CS10); // = 0b00011001;
@ -100,7 +96,7 @@ void backlight_set(uint8_t level)
// Set the brightness // Set the brightness
CHANNEL = 0xFFFF; CHANNEL = 0xFFFF;
} }
else else
{ {
// Turn on PWM control of PB7 // Turn on PWM control of PB7
TCCR1A |= _BV(COM1C1); TCCR1A |= _BV(COM1C1);
@ -303,4 +299,4 @@ ISR(TIMER1_COMPA_vect)
#endif #endif

@ -20,11 +20,6 @@ void matrix_init_kb(void) {
backlight_init_ports(); backlight_init_ports();
#endif #endif
#ifdef RGBLIGHT_ENABLE
rgblight_init();
#endif
// Turn status LED on // Turn status LED on
DDRE |= (1<<6); DDRE |= (1<<6);
PORTE |= (1<<6); PORTE |= (1<<6);
@ -49,20 +44,20 @@ void backlight_init_ports()
// Setup PB7 as output and output low. // Setup PB7 as output and output low.
DDRB |= (1<<7); DDRB |= (1<<7);
PORTB &= ~(1<<7); PORTB &= ~(1<<7);
// Use full 16-bit resolution. // Use full 16-bit resolution.
ICR1 = 0xFFFF; ICR1 = 0xFFFF;
// I could write a wall of text here to explain... but TL;DW // I could write a wall of text here to explain... but TL;DW
// Go read the ATmega32u4 datasheet. // Go read the ATmega32u4 datasheet.
// And this: http://blog.saikoled.com/post/43165849837/secret-konami-cheat-code-to-high-resolution-pwm-on // And this: http://blog.saikoled.com/post/43165849837/secret-konami-cheat-code-to-high-resolution-pwm-on
// Pin PB7 = OCR1C (Timer 1, Channel C) // Pin PB7 = OCR1C (Timer 1, Channel C)
// Compare Output Mode = Clear on compare match, Channel C = COM1C1=1 COM1C0=0 // Compare Output Mode = Clear on compare match, Channel C = COM1C1=1 COM1C0=0
// (i.e. start high, go low when counter matches.) // (i.e. start high, go low when counter matches.)
// WGM Mode 14 (Fast PWM) = WGM13=1 WGM12=1 WGM11=1 WGM10=0 // 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 // Clock Select = clk/1 (no prescaling) = CS12=0 CS11=0 CS10=1
TCCR1A = _BV(COM1C1) | _BV(WGM11); // = 0b00001010; TCCR1A = _BV(COM1C1) | _BV(WGM11); // = 0b00001010;
TCCR1B = _BV(WGM13) | _BV(WGM12) | _BV(CS10); // = 0b00011001; TCCR1B = _BV(WGM13) | _BV(WGM12) | _BV(CS10); // = 0b00011001;
@ -88,7 +83,7 @@ void backlight_set(uint8_t level)
// Set the brightness // Set the brightness
CHANNEL = 0xFFFF; CHANNEL = 0xFFFF;
} }
else else
{ {
// Prevent backlight blink on lowest level // Prevent backlight blink on lowest level
PORTB &= ~(_BV(PORTB7)); PORTB &= ~(_BV(PORTB7));
@ -99,4 +94,4 @@ void backlight_set(uint8_t level)
} }
} }
#endif #endif

@ -46,6 +46,9 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#ifdef ADB_MOUSE_ENABLE #ifdef ADB_MOUSE_ENABLE
# include "adb.h" # include "adb.h"
#endif #endif
#ifdef RGBLIGHT_ENABLE
# include "rgblight.h"
#endif
#ifdef MATRIX_HAS_GHOST #ifdef MATRIX_HAS_GHOST
static bool is_row_ghosting(uint8_t row){ static bool is_row_ghosting(uint8_t row){
@ -89,6 +92,9 @@ void keyboard_init(void) {
#ifdef BACKLIGHT_ENABLE #ifdef BACKLIGHT_ENABLE
backlight_init(); backlight_init();
#endif #endif
#ifdef RGBLIGHT_ENABLE
rgblight_init();
#endif
#if defined(NKRO_ENABLE) && defined(FORCE_NKRO) #if defined(NKRO_ENABLE) && defined(FORCE_NKRO)
keyboard_nkro = true; keyboard_nkro = true;
#endif #endif

Loading…
Cancel
Save