Browse Source

Improve ledmap feature

- Change date type of ledmap from byte to word
- New reverse bit, reversing binding stats
- Fix minor bugs
ledmap
Kai Ryu 9 years ago
parent
commit
f6643a082c

+ 33
- 33
common/ledmap.c View File

static led_binding_t default_layer_binding = 0; static led_binding_t default_layer_binding = 0;
static led_binding_t layer_binding = 0; static led_binding_t layer_binding = 0;
static led_binding_t backlight_binding = 0; static led_binding_t backlight_binding = 0;
static led_binding_t reverse_binding = 0;


static void update_led_state(led_state_t state);
static void update_led_state(led_state_t state, uint8_t force);


void ledmap_init(void) void ledmap_init(void)
{ {
for (uint8_t i = 0; i < LED_COUNT; i++) { for (uint8_t i = 0; i < LED_COUNT; i++) {
uint8_t code = ledmap_get_code(i);
if (code & LEDMAP_BACKLIGHT) {
LED_BIT_SET(backlight_binding, i);
}
code &= LEDMAP_MASK;
if (code >= LEDMAP_DEFAULT_LAYER_0 && code <= LEDMAP_DEFAULT_LAYER_31) {
LED_BIT_SET(default_layer_binding, i);
ledmap_t ledmap = ledmap_get_code(i);
if (ledmap.reverse) {
LED_BIT_SET(reverse_binding, i);
} }
else if (code >= LEDMAP_LAYER_0 && code <= LEDMAP_LAYER_31) {
LED_BIT_SET(layer_binding, i);
if (ledmap.backlight) {
LED_BIT_SET(backlight_binding, i);
} }
else if (code >= LEDMAP_NUM_LOCK && code <= LEDMAP_KANA) {
LED_BIT_SET(usb_led_binding, i);
switch (ledmap.binding) {
case LEDMAP_BINDING_DEFAULT_LAYER:
LED_BIT_SET(default_layer_binding, i);
break;
case LEDMAP_BINDING_LAYER:
LED_BIT_SET(layer_binding, i);
break;
case LEDMAP_BINDING_USB_LED:
LED_BIT_SET(usb_led_binding, i);
break;
} }
} }
ledmap_led_init(); ledmap_led_init();
update_led_state(0, 1);
} }


void led_set(uint8_t usb_led) void led_set(uint8_t usb_led)
led_state_t led_state = led_state_last; led_state_t led_state = led_state_last;
for (uint8_t i = 0; i < LED_COUNT; i++) { for (uint8_t i = 0; i < LED_COUNT; i++) {
if (usb_led_binding & LED_BIT(i)) { if (usb_led_binding & LED_BIT(i)) {
uint8_t code = ledmap_get_code(i) & LEDMAP_MASK;
for (uint8_t j = USB_LED_NUM_LOCK; j <= USB_LED_KANA; j++) {
if (code - LEDMAP_NUM_LOCK == j) {
(usb_led & (1 << j)) ? LED_BIT_SET(led_state, i) : LED_BIT_CLEAR(led_state, i);
}
}
uint8_t param = ledmap_get_code(i).param;
(usb_led & (1 << param)) ? LED_BIT_SET(led_state, i) : LED_BIT_CLEAR(led_state, i);
} }
} }
update_led_state(led_state);
update_led_state(led_state, 0);
} }
} }


led_state_t led_state = led_state_last; led_state_t led_state = led_state_last;
for (uint8_t i = 0; i < LED_COUNT; i++) { for (uint8_t i = 0; i < LED_COUNT; i++) {
if (default_layer_binding & LED_BIT(i)) { if (default_layer_binding & LED_BIT(i)) {
uint8_t code = ledmap_get_code(i) & LEDMAP_MASK;
(state & (1UL << (code - LEDMAP_DEFAULT_LAYER_0))) ? LED_BIT_SET(led_state, i) : LED_BIT_CLEAR(led_state, i);
uint8_t param = ledmap_get_code(i).param;
(state & (1UL << param)) ? LED_BIT_SET(led_state, i) : LED_BIT_CLEAR(led_state, i);
} }
} }
update_led_state(led_state);
update_led_state(led_state, 0);
} }
} }


led_state_t led_state = led_state_last; led_state_t led_state = led_state_last;
for (uint8_t i = 0; i < LED_COUNT; i++) { for (uint8_t i = 0; i < LED_COUNT; i++) {
if (layer_binding & LED_BIT(i)) { if (layer_binding & LED_BIT(i)) {
uint8_t code = ledmap_get_code(i) & LEDMAP_MASK;
(state & (1UL << (code - LEDMAP_LAYER_0))) ? LED_BIT_SET(led_state, i) : LED_BIT_CLEAR(led_state, i);
uint8_t param = ledmap_get_code(i).param;
(state & (1UL << param)) ? LED_BIT_SET(led_state, i) : LED_BIT_CLEAR(led_state, i);
} }
} }
update_led_state(led_state);
update_led_state(led_state, 0);
} }
} }
#endif #endif
if (state) { if (state) {
} }
else { else {
led_state_t led_state = led_state_last;
led_state_last &= ~(backlight_binding);
update_led_state(led_state);
update_led_state(led_state_last, 1);
} }
} }
#endif #endif


void update_led_state(led_state_t state)
void update_led_state(led_state_t state, uint8_t force)
{ {
uint8_t diff = led_state_last ^ state;
if (diff) {
led_state_t diff = led_state_last ^ state;
if (force || diff) {
for (uint8_t i = 0; i < LED_COUNT; i++) { for (uint8_t i = 0; i < LED_COUNT; i++) {
if (softpwm_led_get_state() && (backlight_binding & LED_BIT(i))) { if (softpwm_led_get_state() && (backlight_binding & LED_BIT(i))) {
continue; continue;
} }
if (diff & LED_BIT(i)) {
if (state & LED_BIT(i)) {
if (force || diff & LED_BIT(i)) {
if ((state ^ reverse_binding) & LED_BIT(i)) {
ledmap_led_on(i); ledmap_led_on(i);
} }
else { else {

+ 29
- 23
common/ledmap.h View File

typedef led_pack_t led_state_t; typedef led_pack_t led_state_t;
typedef led_pack_t led_binding_t; typedef led_pack_t led_binding_t;


typedef enum {
LEDMAP_NO = 0,
LEDMAP_DEFAULT_LAYER_0,
LEDMAP_DEFAULT_LAYER_31 = LEDMAP_DEFAULT_LAYER_0 + 31,
LEDMAP_LAYER_0,
LEDMAP_LAYER_31 = LEDMAP_LAYER_0 + 31,
LEDMAP_NUM_LOCK,
LEDMAP_CAPS_LOCK,
LEDMAP_SCROLL_LOCK,
LEDMAP_COMPOSE,
LEDMAP_KANA,
LEDMAP_BACKLIGHT = 0x80
} ledmap_code_t;

#define LEDMAP_MASK 0x7F
enum ledmap_binding {
LEDMAP_BINDING_NO = 0,
LEDMAP_BINDING_DEFAULT_LAYER,
LEDMAP_BINDING_LAYER,
LEDMAP_BINDING_USB_LED
};

enum ledmap_usb_led {
LEDMAP_USB_LED_NUM_LOCK = 0,
LEDMAP_USB_LED_CAPS_LOCK,
LEDMAP_USB_LED_SCROLL_LOCK,
LEDMAP_USB_LED_COMPOSE,
LEDMAP_USB_LED_KANA,
};


typedef union { typedef union {
uint8_t raw;
uint16_t code;
struct { struct {
uint8_t binding : 7;
bool backlight : 1;
uint8_t param: 8;
uint8_t binding: 4;
bool reverse: 1;
bool backlight: 1;
uint8_t reserved: 2;
}; };
} ledmap_t; } ledmap_t;


#define LEDMAP_DEFAULT_LAYER(x) (LEDMAP_DEFAULT_LAYER_0 + x)
#define LEDMAP_LAYER(x) (LEDMAP_LAYER_0 + x)
#define LEDMAP_DEFAULT_LAYER(layer) (LEDMAP_BINDING_DEFAULT_LAYER<<8 | layer)
#define LEDMAP_LAYER(layer) (LEDMAP_BINDING_LAYER<<8 | layer )
#define LEDMAP_NUM_LOCK (LEDMAP_BINDING_USB_LED<<8 | LEDMAP_USB_LED_NUM_LOCK)
#define LEDMAP_CAPS_LOCK (LEDMAP_BINDING_USB_LED<<8 | LEDMAP_USB_LED_CAPS_LOCK)
#define LEDMAP_SCROLL_LOCK (LEDMAP_BINDING_USB_LED<<8 | LEDMAP_USB_LED_SCROLL_LOCK)
#define LEDMAP_REVERSE (1<<12)
#define LEDMAP_BACKLIGHT (1<<13)


void ledmap_init(void); void ledmap_init(void);


#ifdef LEDMAP_ENABLE #ifdef LEDMAP_ENABLE
uint8_t ledmap_get_code(uint8_t index);
ledmap_t ledmap_get_code(uint8_t index);
void ledmap_led_init(void); void ledmap_led_init(void);
void ledmap_led_on(uint8_t index); void ledmap_led_on(uint8_t index);
void ledmap_led_off(uint8_t index); void ledmap_led_off(uint8_t index);
#else #else
#define ledmaps
#define ledmap_get()
#define ledmap_get_code()
#define ledmap_led_init() #define ledmap_led_init()
#define ledmap_led_on() #define ledmap_led_on()
#define ledmap_led_off() #define ledmap_led_off()

+ 7
- 8
common/ledmap_in_eeprom.c View File

#include <avr/pgmspace.h> #include <avr/pgmspace.h>
#include <avr/eeprom.h> #include <avr/eeprom.h>
#include "ledmap.h"
#include "ledmap_in_eeprom.h" #include "ledmap_in_eeprom.h"


#ifdef LEDMAP_IN_EEPROM_ENABLE #ifdef LEDMAP_IN_EEPROM_ENABLE


#undef ledmap_get_code #undef ledmap_get_code


static uint8_t ledmap[LED_COUNT];
static ledmap_t ledmap[LED_COUNT];


void ledmap_in_eeprom_init(void) void ledmap_in_eeprom_init(void)
{ {
for (uint8_t i = 0; i < LED_COUNT; i++) { for (uint8_t i = 0; i < LED_COUNT; i++) {
ledmap[i] = eeprom_read_byte(EECONFIG_LEDMAP + i);
//ledmap[i] = LEDMAP_UNCONFIGURED;
if (ledmap[i] == LEDMAP_UNCONFIGURED) {
ledmap[i].code = eeprom_read_word(EECONFIG_LEDMAP + i);
/* ledmap[i].code = LEDMAP_UNCONFIGURED; */
if (ledmap[i].code == LEDMAP_UNCONFIGURED) {
ledmap[i] = ledmap_get_code(i); ledmap[i] = ledmap_get_code(i);
eeprom_write_byte(EECONFIG_LEDMAP + i, ledmap[i]);
eeprom_write_word(EECONFIG_LEDMAP + i, ledmap[i].code);
} }
} }
} }
void write_ledmap_to_eeprom(void) void write_ledmap_to_eeprom(void)
{ {
for (uint8_t i = 0; i < LED_COUNT; i++) { for (uint8_t i = 0; i < LED_COUNT; i++) {
eeprom_write_byte(EECONFIG_LEDMAP + i, ledmap_get_code(i));
eeprom_write_word(EECONFIG_LEDMAP + i, ledmap_get_code(i).code);
} }
} }


uint8_t ledmap_in_eeprom_get_code(uint8_t i)
ledmap_t ledmap_in_eeprom_get_code(uint8_t i)
{ {
return ledmap[i]; return ledmap[i];
} }

+ 6
- 4
common/ledmap_in_eeprom.h View File

#ifndef LEDMAP_IN_EEPROM_H #ifndef LEDMAP_IN_EEPROM_H
#define LEDMAP_IN_EEPROM_H #define LEDMAP_IN_EEPROM_H


#include "ledmap.h"

#ifndef EECONFIG_LEDMAP_IN_EEPROM #ifndef EECONFIG_LEDMAP_IN_EEPROM
#define EECONFIG_LEDMAP_IN_EEPROM 7 #define EECONFIG_LEDMAP_IN_EEPROM 7
#endif #endif


#define EECONFIG_LEDMAP (uint8_t*)EECONFIG_LEDMAP_IN_EEPROM
#define LEDMAP_SIZE (sizeof(uint8_t) * LED_COUNT)
#define EECONFIG_LEDMAP (uint16_t*)EECONFIG_LEDMAP_IN_EEPROM
#define LEDMAP_SIZE (sizeof(uint16_t) * LED_COUNT)


#define LEDMAP_UNCONFIGURED 0xFF
#define LEDMAP_UNCONFIGURED 0xFFFF


#ifdef LEDMAP_IN_EEPROM_ENABLE #ifdef LEDMAP_IN_EEPROM_ENABLE
#define ledmap_get_code ledmap_in_eeprom_get_code #define ledmap_get_code ledmap_in_eeprom_get_code
void ledmap_in_eeprom_init(void); void ledmap_in_eeprom_init(void);
void write_ledmap_to_eeprom(void); void write_ledmap_to_eeprom(void);
uint8_t ledmap_in_eeprom_get_code(uint8_t index);
ledmap_t ledmap_in_eeprom_get_code(uint8_t index);
#else #else
#define ledmap_in_eeprom_init() #define ledmap_in_eeprom_init()
#define write_ledmap_to_eeprom() #define write_ledmap_to_eeprom()

+ 2
- 2
keyboard/gh60/Makefile View File

# project specific files # project specific files
SRC = keymap_common.c \ SRC = keymap_common.c \
matrix.c \ matrix.c \
led.c \
backlight.c \ backlight.c \
ledmap.c \
led_matrix.c
ledmap.c


ifdef KEYMAP ifdef KEYMAP
SRC := keymap_$(KEYMAP).c $(SRC) SRC := keymap_$(KEYMAP).c $(SRC)

+ 10
- 2
keyboard/gh60/Makefile.pjrc View File

SRC = keymap_common.c \ SRC = keymap_common.c \
matrix.c \ matrix.c \
led.c \ led.c \
backlight.c
backlight.c \
ledmap.c


ifdef KEYMAP ifdef KEYMAP
SRC := keymap_$(KEYMAP).c $(SRC) SRC := keymap_$(KEYMAP).c $(SRC)
COMMAND_ENABLE = yes # Commands for debug and configuration COMMAND_ENABLE = yes # Commands for debug and configuration
#SLEEP_LED_ENABLE = yes # Breathing sleep LED during USB suspend #SLEEP_LED_ENABLE = yes # Breathing sleep LED during USB suspend
NKRO_ENABLE = yes # USB Nkey Rollover - not yet supported in LUFA NKRO_ENABLE = yes # USB Nkey Rollover - not yet supported in LUFA
USB_6KRO_ENABLE = yes # USB 6key Rollover
#PS2_MOUSE_ENABLE = yes # PS/2 mouse(TrackPoint) support #PS2_MOUSE_ENABLE = yes # PS/2 mouse(TrackPoint) support
#PS2_USE_BUSYWAIT = yes
BACKLIGHT_ENABLE = yes # Enable keyboard backlight functionality BACKLIGHT_ENABLE = yes # Enable keyboard backlight functionality
KEYMAP_SECTION_ENABLE = yes # Fixed address keymap for keymap editor
KEYMAP_IN_EEPROM_ENABLE = yes # Read keymap from eeprom KEYMAP_IN_EEPROM_ENABLE = yes # Read keymap from eeprom
#KEYMAP_SECTION_ENABLE = yes # Fixed address keymap for keymap editor
SOFTPWM_LED_ENABLE = yes # Enable SoftPWM to drive backlight
FADING_LED_ENABLE = yes # Enable fading backlight
BREATHING_LED_ENABLE = yes # Enable breathing backlight
LEDMAP_ENABLE = yes # Enable LED mapping
LEDMAP_IN_EEPROM_ENABLE = yes # Read LED mapping from eeprom




# Search Path # Search Path

+ 3
- 3
keyboard/gh60/ledmap.c View File



#ifdef LEDMAP_ENABLE #ifdef LEDMAP_ENABLE


static const uint8_t ledmaps[LED_COUNT] PROGMEM = {
static const uint16_t ledmaps[LED_COUNT] PROGMEM = {
#if defined(GH60_REV_CHN) #if defined(GH60_REV_CHN)
[0] = LEDMAP_CAPS_LOCK | LEDMAP_BACKLIGHT, // CapsLock - PB2 [0] = LEDMAP_CAPS_LOCK | LEDMAP_BACKLIGHT, // CapsLock - PB2
[1] = LEDMAP_BACKLIGHT, // PWM - PB6 [1] = LEDMAP_BACKLIGHT, // PWM - PB6
#endif #endif
}; };


uint8_t ledmap_get_code(uint8_t index)
ledmap_t ledmap_get_code(uint8_t index)
{ {
return pgm_read_byte(&ledmaps[index]);
return (ledmap_t) { .code = pgm_read_word(&ledmaps[index]) };
} }


void ledmap_led_init(void) void ledmap_led_init(void)