summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjpetermans <tibcmhhm@gmail.com>2017-04-13 17:51:37 -0700
committerjpetermans <tibcmhhm@gmail.com>2017-04-13 17:51:37 -0700
commitec1e936dfbb3b346ce74394c0ed92b5e279480d4 (patch)
tree2f71040c4f45b190964e874ac0fb136d6de80d79
parent1b1adf35bb746a875c2b846e1b1b405075c94847 (diff)
fixed bit shift in led_set_bit
-rw-r--r--keyboards/infinity60/led_controller.c26
1 files changed, 21 insertions, 5 deletions
diff --git a/keyboards/infinity60/led_controller.c b/keyboards/infinity60/led_controller.c
index eb3ccafc11..e98d8de505 100644
--- a/keyboards/infinity60/led_controller.c
+++ b/keyboards/infinity60/led_controller.c
@@ -376,26 +376,40 @@ void set_led_bit (uint8_t page, uint8_t *led_control_reg, uint8_t led_addr, uint
uint8_t control_reg_addr, column_bit, column_byte, temp;
//first byte is led control register address 0x00
//msg_led tens column is pin#, ones column is bit position in 8-bit mask
+ chThdSleepMilliseconds(10);
+ xprintf("led_addr: %d ", led_addr);
control_reg_addr = ((led_addr / 10) % 10 - 1 ) * 0x02;// A-register is every other byte
column_bit = 1<<(led_addr % 10 - 1);
is31_read_register(page,control_reg_addr,&temp);//need to maintain status of leds in this row (1 byte)
+ chThdSleepMilliseconds(10);
+ xprintf("col_bit: %X ", column_bit);
column_byte = temp;
+ chThdSleepMilliseconds(10);
+ xprintf("action: %X ", action);
switch(action) {
case 0:
- column_byte &= ~1<<(column_bit);
+ xprintf("off-");
+ chThdSleepMilliseconds(10);
+ column_byte &= ~column_bit;
break;
case 1:
- column_byte |= 1<<(column_bit);
+ xprintf("on-");
+ chThdSleepMilliseconds(10);
+ column_byte |= column_bit;
break;
case 2:
- column_byte ^= 1<<(column_bit);
+ xprintf("toggle-");
+ chThdSleepMilliseconds(10);
+ column_byte ^= column_bit;
break;
}
led_control_reg[0] = control_reg_addr;
led_control_reg[1] = column_byte;
+ chThdSleepMilliseconds(10);
+ xprintf("set_bit row: %X set_bit col: %X\n", led_control_reg[0], led_control_reg[1]);
}
void set_lock_leds(uint8_t lock_type, uint8_t led_on) {
@@ -427,11 +441,13 @@ void set_lock_leds(uint8_t lock_type, uint8_t led_on) {
#endif
}
- for(page=BACKLIGHT_OFF_LOCK_LED_OFF; page<8; page++) { //set in led_controller.h
+ for(page=0; page<8; page++) { //set in led_controller.h
//TODO: check if frame2 (or frame1, first byte all on), and ignore if true
//also if BACKLIGHT_OFF_LOCK_LED_OFF set
set_led_bit(page,led_control_write,led_addr,led_on);
- is31_write_data (page, led_control_write, 0x02);
+ xprintf("lock_led row: %X lock_led col%X\n", led_control_write[0], led_control_write[1]);
+ is31_write_data(page, led_control_write, 0x02);
+ chThdSleepMilliseconds(10);
}
}