aboutsummaryrefslogtreecommitdiff
path: root/common
diff options
context:
space:
mode:
authortmk <nobody@nowhere>2013-06-22 16:14:56 +0900
committertmk <nobody@nowhere>2013-06-22 16:24:56 +0900
commit9de9d719527c7a8cac71d0bc49ba1d2d4f63cf06 (patch)
tree5cfd02ffd53d5be7c40453644558319f75b48fa8 /common
parent2593ae132812414f02e7cf483bb141cd2c78595c (diff)
downloadqmk_firmware-9de9d719527c7a8cac71d0bc49ba1d2d4f63cf06.tar.gz
qmk_firmware-9de9d719527c7a8cac71d0bc49ba1d2d4f63cf06.zip
Add default layer config to bootmagic
Diffstat (limited to 'common')
-rw-r--r--common/action_layer.c4
-rw-r--r--common/action_layer.h2
-rw-r--r--common/bootmagic.c18
-rw-r--r--common/bootmagic.h4
-rw-r--r--common/command.c4
-rw-r--r--common/eeconfig.c4
-rw-r--r--common/eeconfig.h4
7 files changed, 31 insertions, 9 deletions
diff --git a/common/action_layer.c b/common/action_layer.c
index d24aa2e19..526e24d53 100644
--- a/common/action_layer.c
+++ b/common/action_layer.c
@@ -30,9 +30,9 @@ void default_layer_debug(void)
30 dprintf("%08lX(%u)", default_layer_state, biton32(default_layer_state)); 30 dprintf("%08lX(%u)", default_layer_state, biton32(default_layer_state));
31} 31}
32 32
33void default_layer_set(uint8_t layer) 33void default_layer_set(uint32_t state)
34{ 34{
35 default_layer_state_set(1UL<<layer); 35 default_layer_state_set(state);
36} 36}
37 37
38#ifndef NO_ACTION_LAYER 38#ifndef NO_ACTION_LAYER
diff --git a/common/action_layer.h b/common/action_layer.h
index 23f8a00bb..034e00027 100644
--- a/common/action_layer.h
+++ b/common/action_layer.h
@@ -27,7 +27,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
27 */ 27 */
28extern uint32_t default_layer_state; 28extern uint32_t default_layer_state;
29void default_layer_debug(void); 29void default_layer_debug(void);
30void default_layer_set(uint8_t layer); 30void default_layer_set(uint32_t state);
31 31
32#ifndef NO_ACTION_LAYER 32#ifndef NO_ACTION_LAYER
33/* bitwise operation */ 33/* bitwise operation */
diff --git a/common/bootmagic.c b/common/bootmagic.c
index 716f5d956..11eef3c3c 100644
--- a/common/bootmagic.c
+++ b/common/bootmagic.c
@@ -74,6 +74,24 @@ void bootmagic(void)
74 keymap_config.swap_backslash_backspace = !keymap_config.swap_backslash_backspace; 74 keymap_config.swap_backslash_backspace = !keymap_config.swap_backslash_backspace;
75 } 75 }
76 eeconfig_write_keymap(keymap_config.raw); 76 eeconfig_write_keymap(keymap_config.raw);
77
78 /* default layer */
79 uint8_t default_layer = 0;
80 if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_0)) { default_layer |= (1<<0); }
81 if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_1)) { default_layer |= (1<<1); }
82 if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_2)) { default_layer |= (1<<2); }
83 if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_3)) { default_layer |= (1<<3); }
84 if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_4)) { default_layer |= (1<<4); }
85 if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_5)) { default_layer |= (1<<5); }
86 if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_6)) { default_layer |= (1<<6); }
87 if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_7)) { default_layer |= (1<<7); }
88 if (default_layer) {
89 eeconfig_write_default_layer(default_layer);
90 default_layer_set((uint32_t)default_layer);
91 } else {
92 default_layer = eeconfig_read_default_layer();
93 default_layer_set((uint32_t)default_layer);
94 }
77} 95}
78 96
79bool bootmagic_scan_keycode(uint8_t keycode) 97bool bootmagic_scan_keycode(uint8_t keycode)
diff --git a/common/bootmagic.h b/common/bootmagic.h
index 2e7496ebc..68935e970 100644
--- a/common/bootmagic.h
+++ b/common/bootmagic.h
@@ -41,6 +41,10 @@
41#define BOOTMAGIC_KEY_DEFAULT_LAYER_1 KC_1 41#define BOOTMAGIC_KEY_DEFAULT_LAYER_1 KC_1
42#define BOOTMAGIC_KEY_DEFAULT_LAYER_2 KC_2 42#define BOOTMAGIC_KEY_DEFAULT_LAYER_2 KC_2
43#define BOOTMAGIC_KEY_DEFAULT_LAYER_3 KC_3 43#define BOOTMAGIC_KEY_DEFAULT_LAYER_3 KC_3
44#define BOOTMAGIC_KEY_DEFAULT_LAYER_4 KC_4
45#define BOOTMAGIC_KEY_DEFAULT_LAYER_5 KC_5
46#define BOOTMAGIC_KEY_DEFAULT_LAYER_6 KC_6
47#define BOOTMAGIC_KEY_DEFAULT_LAYER_7 KC_7
44 48
45 49
46void bootmagic(void); 50void bootmagic(void);
diff --git a/common/command.c b/common/command.c
index 74b7c5ebc..73a72b4a1 100644
--- a/common/command.c
+++ b/common/command.c
@@ -129,7 +129,7 @@ static void command_common_help(void)
129#ifdef BOOTMAGIC_ENABLE 129#ifdef BOOTMAGIC_ENABLE
130static void print_eeconfig(void) 130static void print_eeconfig(void)
131{ 131{
132 print("default_layer: "); print_dec(eeconfig_read_defalt_layer()); print("\n"); 132 print("default_layer: "); print_dec(eeconfig_read_default_layer()); print("\n");
133 133
134 debug_config_t dc; 134 debug_config_t dc;
135 dc.raw = eeconfig_read_debug(); 135 dc.raw = eeconfig_read_debug();
@@ -579,6 +579,6 @@ static void switch_default_layer(uint8_t layer)
579{ 579{
580 print("switch_default_layer: "); print_dec(biton32(default_layer_state)); 580 print("switch_default_layer: "); print_dec(biton32(default_layer_state));
581 print(" to "); print_dec(layer); print("\n"); 581 print(" to "); print_dec(layer); print("\n");
582 default_layer_set(layer); 582 default_layer_set(1UL<<layer);
583 clear_keyboard(); 583 clear_keyboard();
584} 584}
diff --git a/common/eeconfig.c b/common/eeconfig.c
index 0481d4b9c..a833f4db9 100644
--- a/common/eeconfig.c
+++ b/common/eeconfig.c
@@ -30,8 +30,8 @@ bool eeconfig_is_enabled(void)
30uint8_t eeconfig_read_debug(void) { return eeprom_read_byte(EECONFIG_DEBUG); } 30uint8_t eeconfig_read_debug(void) { return eeprom_read_byte(EECONFIG_DEBUG); }
31void eeconfig_write_debug(uint8_t val) { eeprom_write_byte(EECONFIG_DEBUG, val); } 31void eeconfig_write_debug(uint8_t val) { eeprom_write_byte(EECONFIG_DEBUG, val); }
32 32
33uint8_t eeconfig_read_defalt_layer(void) { return eeprom_read_byte(EECONFIG_DEFAULT_LAYER); } 33uint8_t eeconfig_read_default_layer(void) { return eeprom_read_byte(EECONFIG_DEFAULT_LAYER); }
34void eeconfig_write_defalt_layer(uint8_t val) { eeprom_write_byte(EECONFIG_DEFAULT_LAYER, val); } 34void eeconfig_write_default_layer(uint8_t val) { eeprom_write_byte(EECONFIG_DEFAULT_LAYER, val); }
35 35
36uint8_t eeconfig_read_keymap(void) { return eeprom_read_byte(EECONFIG_KEYMAP); } 36uint8_t eeconfig_read_keymap(void) { return eeprom_read_byte(EECONFIG_KEYMAP); }
37void eeconfig_write_keymap(uint8_t val) { eeprom_write_byte(EECONFIG_KEYMAP, val); } 37void eeconfig_write_keymap(uint8_t val) { eeprom_write_byte(EECONFIG_KEYMAP, val); }
diff --git a/common/eeconfig.h b/common/eeconfig.h
index 526cee783..0b605fc7b 100644
--- a/common/eeconfig.h
+++ b/common/eeconfig.h
@@ -58,8 +58,8 @@ void eeconfig_disable(void);
58uint8_t eeconfig_read_debug(void); 58uint8_t eeconfig_read_debug(void);
59void eeconfig_write_debug(uint8_t val); 59void eeconfig_write_debug(uint8_t val);
60 60
61uint8_t eeconfig_read_defalt_layer(void); 61uint8_t eeconfig_read_default_layer(void);
62void eeconfig_write_defalt_layer(uint8_t val); 62void eeconfig_write_default_layer(uint8_t val);
63 63
64uint8_t eeconfig_read_keymap(void); 64uint8_t eeconfig_read_keymap(void);
65void eeconfig_write_keymap(uint8_t val); 65void eeconfig_write_keymap(uint8_t val);