Merge remote-tracking branch 'tmk/master' into cub_layout
This commit is contained in:
commit
3be39e436d
21 changed files with 524 additions and 165 deletions
|
|
@ -68,6 +68,14 @@ ifdef BACKLIGHT_ENABLE
|
||||||
OPT_DEFS += -DBACKLIGHT_ENABLE
|
OPT_DEFS += -DBACKLIGHT_ENABLE
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifdef KEYMAP_SECTION_ENABLE
|
||||||
|
OPT_DEFS += -DKEYMAP_SECTION_ENABLE
|
||||||
|
EXTRALDFLAGS = -Wl,-L$(TOP_DIR),-Tldscript_keymap_avr5.x
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Version string
|
||||||
|
OPT_DEFS += -DVERSION=$(shell (git describe --dirty || echo 'unknown') 2> /dev/null)
|
||||||
|
|
||||||
|
|
||||||
# Search Path
|
# Search Path
|
||||||
VPATH += $(TOP_DIR)/common
|
VPATH += $(TOP_DIR)/common
|
||||||
|
|
|
||||||
|
|
@ -207,10 +207,10 @@ enum mods_codes {
|
||||||
MODS_ONESHOT = 0x00,
|
MODS_ONESHOT = 0x00,
|
||||||
};
|
};
|
||||||
#define ACTION_KEY(key) ACTION(ACT_MODS, (key))
|
#define ACTION_KEY(key) ACTION(ACT_MODS, (key))
|
||||||
#define ACTION_MODS(mods) ACTION(ACT_MODS, (mods)<<8 | 0)
|
#define ACTION_MODS(mods) ACTION(ACT_MODS, (mods&0x1f)<<8 | 0)
|
||||||
#define ACTION_MODS_KEY(mods, key) ACTION(ACT_MODS, (mods)<<8 | (key))
|
#define ACTION_MODS_KEY(mods, key) ACTION(ACT_MODS, (mods&0x1f)<<8 | (key))
|
||||||
#define ACTION_MODS_TAP_KEY(mods, key) ACTION(ACT_MODS_TAP, (mods)<<8 | (key))
|
#define ACTION_MODS_TAP_KEY(mods, key) ACTION(ACT_MODS_TAP, (mods&0x1f)<<8 | (key))
|
||||||
#define ACTION_MODS_ONESHOT(mods) ACTION(ACT_MODS_TAP, (mods)<<8 | MODS_ONESHOT)
|
#define ACTION_MODS_ONESHOT(mods) ACTION(ACT_MODS_TAP, (mods&0x1f)<<8 | MODS_ONESHOT)
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
||||||
|
|
@ -27,9 +27,7 @@ static uint8_t waiting_buffer_tail = 0;
|
||||||
static bool process_tapping(keyrecord_t *record);
|
static bool process_tapping(keyrecord_t *record);
|
||||||
static bool waiting_buffer_enq(keyrecord_t record);
|
static bool waiting_buffer_enq(keyrecord_t record);
|
||||||
static void waiting_buffer_clear(void);
|
static void waiting_buffer_clear(void);
|
||||||
#if TAPPING_TERM >= 500
|
|
||||||
static bool waiting_buffer_typed(keyevent_t event);
|
static bool waiting_buffer_typed(keyevent_t event);
|
||||||
#endif
|
|
||||||
static bool waiting_buffer_has_anykey_pressed(void);
|
static bool waiting_buffer_has_anykey_pressed(void);
|
||||||
static void waiting_buffer_scan_tap(void);
|
static void waiting_buffer_scan_tap(void);
|
||||||
static void debug_tapping_key(void);
|
static void debug_tapping_key(void);
|
||||||
|
|
@ -109,6 +107,13 @@ bool process_tapping(keyrecord_t *keyp)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
/* release a key pressed before tapping */
|
||||||
|
else if (!event.pressed && !waiting_buffer_typed(event)) {
|
||||||
|
/* Unexpected repeating occurs unless this event is processed immedately. */
|
||||||
|
debug("Tapping: release a key pressed before tapping\n");
|
||||||
|
process_action(keyp);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
// set interrupted flag when other key preesed during tapping
|
// set interrupted flag when other key preesed during tapping
|
||||||
if (event.pressed) {
|
if (event.pressed) {
|
||||||
|
|
@ -289,7 +294,6 @@ void waiting_buffer_clear(void)
|
||||||
waiting_buffer_tail = 0;
|
waiting_buffer_tail = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if TAPPING_TERM >= 500
|
|
||||||
bool waiting_buffer_typed(keyevent_t event)
|
bool waiting_buffer_typed(keyevent_t event)
|
||||||
{
|
{
|
||||||
for (uint8_t i = waiting_buffer_tail; i != waiting_buffer_head; i = (i + 1) % WAITING_BUFFER_SIZE) {
|
for (uint8_t i = waiting_buffer_tail; i != waiting_buffer_head; i = (i + 1) % WAITING_BUFFER_SIZE) {
|
||||||
|
|
@ -299,7 +303,6 @@ bool waiting_buffer_typed(keyevent_t event)
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
bool waiting_buffer_has_anykey_pressed(void)
|
bool waiting_buffer_has_anykey_pressed(void)
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -71,7 +71,8 @@ void bootloader_jump_after_watchdog_reset(void)
|
||||||
MCUSR &= ~(1<<WDRF);
|
MCUSR &= ~(1<<WDRF);
|
||||||
wdt_disable();
|
wdt_disable();
|
||||||
|
|
||||||
((void (*)(void))BOOTLOADER_START)();
|
// This is compled into 'icall', address should be in word unit, not byte.
|
||||||
|
((void (*)(void))(BOOTLOADER_START/2))();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -141,7 +142,7 @@ void bootloader_jump(void) {
|
||||||
ADCSRA = 0; TWCR = 0; UCSR0B = 0;
|
ADCSRA = 0; TWCR = 0; UCSR0B = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// start Bootloader
|
// This is compled into 'icall', address should be in word unit, not byte.
|
||||||
((void (*)(void))BOOTLOADER_START)();
|
((void (*)(void))(BOOTLOADER_START/2))();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -18,8 +18,10 @@ void bootmagic(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* do scans in case of bounce */
|
/* do scans in case of bounce */
|
||||||
|
print("boogmagic scan: ... ");
|
||||||
uint8_t scan = 100;
|
uint8_t scan = 100;
|
||||||
while (scan--) { matrix_scan(); _delay_ms(10); }
|
while (scan--) { matrix_scan(); _delay_ms(10); }
|
||||||
|
print("done.\n");
|
||||||
|
|
||||||
/* bootmagic skip */
|
/* bootmagic skip */
|
||||||
if (bootmagic_scan_keycode(BOOTMAGIC_KEY_SKIP)) {
|
if (bootmagic_scan_keycode(BOOTMAGIC_KEY_SKIP)) {
|
||||||
|
|
@ -53,7 +55,7 @@ void bootmagic(void)
|
||||||
|
|
||||||
/* keymap config */
|
/* keymap config */
|
||||||
keymap_config.raw = eeconfig_read_keymap();
|
keymap_config.raw = eeconfig_read_keymap();
|
||||||
if (bootmagic_scan_keycode(BOOTMAGIC_KEY_SWAP_CONTROL_CPASLOCK)) {
|
if (bootmagic_scan_keycode(BOOTMAGIC_KEY_SWAP_CONTROL_CAPSLOCK)) {
|
||||||
keymap_config.swap_control_capslock = !keymap_config.swap_control_capslock;
|
keymap_config.swap_control_capslock = !keymap_config.swap_control_capslock;
|
||||||
}
|
}
|
||||||
if (bootmagic_scan_keycode(BOOTMAGIC_KEY_CAPSLOCK_TO_CONTROL)) {
|
if (bootmagic_scan_keycode(BOOTMAGIC_KEY_CAPSLOCK_TO_CONTROL)) {
|
||||||
|
|
|
||||||
|
|
@ -23,34 +23,72 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* debug enable */
|
/* debug enable */
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEBUG_ENABLE
|
||||||
#define BOOTMAGIC_KEY_DEBUG_ENABLE KC_D
|
#define BOOTMAGIC_KEY_DEBUG_ENABLE KC_D
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEBUG_MATRIX
|
||||||
#define BOOTMAGIC_KEY_DEBUG_MATRIX KC_X
|
#define BOOTMAGIC_KEY_DEBUG_MATRIX KC_X
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEBUG_KEYBOARD
|
||||||
#define BOOTMAGIC_KEY_DEBUG_KEYBOARD KC_K
|
#define BOOTMAGIC_KEY_DEBUG_KEYBOARD KC_K
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEBUG_MOUSE
|
||||||
#define BOOTMAGIC_KEY_DEBUG_MOUSE KC_M
|
#define BOOTMAGIC_KEY_DEBUG_MOUSE KC_M
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* keymap config
|
* keymap config
|
||||||
*/
|
*/
|
||||||
#define BOOTMAGIC_KEY_SWAP_CONTROL_CPASLOCK KC_LCTRL
|
#ifndef BOOTMAGIC_KEY_SWAP_CONTROL_CAPSLOCK
|
||||||
|
#define BOOTMAGIC_KEY_SWAP_CONTROL_CAPSLOCK KC_LCTRL
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_CAPSLOCK_TO_CONTROL
|
||||||
#define BOOTMAGIC_KEY_CAPSLOCK_TO_CONTROL KC_CAPSLOCK
|
#define BOOTMAGIC_KEY_CAPSLOCK_TO_CONTROL KC_CAPSLOCK
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_SWAP_LALT_LGUI
|
||||||
#define BOOTMAGIC_KEY_SWAP_LALT_LGUI KC_LALT
|
#define BOOTMAGIC_KEY_SWAP_LALT_LGUI KC_LALT
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_SWAP_RALT_RGUI
|
||||||
#define BOOTMAGIC_KEY_SWAP_RALT_RGUI KC_RALT
|
#define BOOTMAGIC_KEY_SWAP_RALT_RGUI KC_RALT
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_NO_GUI
|
||||||
#define BOOTMAGIC_KEY_NO_GUI KC_LGUI
|
#define BOOTMAGIC_KEY_NO_GUI KC_LGUI
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_SWAP_GRAVE_ESC
|
||||||
#define BOOTMAGIC_KEY_SWAP_GRAVE_ESC KC_GRAVE
|
#define BOOTMAGIC_KEY_SWAP_GRAVE_ESC KC_GRAVE
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_SWAP_BACKSLASH_BACKSPACE
|
||||||
#define BOOTMAGIC_KEY_SWAP_BACKSLASH_BACKSPACE KC_BSLASH
|
#define BOOTMAGIC_KEY_SWAP_BACKSLASH_BACKSPACE KC_BSLASH
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* change default layer
|
* change default layer
|
||||||
*/
|
*/
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEFAULT_LAYER_0
|
||||||
#define BOOTMAGIC_KEY_DEFAULT_LAYER_0 KC_0
|
#define BOOTMAGIC_KEY_DEFAULT_LAYER_0 KC_0
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEFAULT_LAYER_1
|
||||||
#define BOOTMAGIC_KEY_DEFAULT_LAYER_1 KC_1
|
#define BOOTMAGIC_KEY_DEFAULT_LAYER_1 KC_1
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEFAULT_LAYER_2
|
||||||
#define BOOTMAGIC_KEY_DEFAULT_LAYER_2 KC_2
|
#define BOOTMAGIC_KEY_DEFAULT_LAYER_2 KC_2
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEFAULT_LAYER_3
|
||||||
#define BOOTMAGIC_KEY_DEFAULT_LAYER_3 KC_3
|
#define BOOTMAGIC_KEY_DEFAULT_LAYER_3 KC_3
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEFAULT_LAYER_4
|
||||||
#define BOOTMAGIC_KEY_DEFAULT_LAYER_4 KC_4
|
#define BOOTMAGIC_KEY_DEFAULT_LAYER_4 KC_4
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEFAULT_LAYER_5
|
||||||
#define BOOTMAGIC_KEY_DEFAULT_LAYER_5 KC_5
|
#define BOOTMAGIC_KEY_DEFAULT_LAYER_5 KC_5
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEFAULT_LAYER_6
|
||||||
#define BOOTMAGIC_KEY_DEFAULT_LAYER_6 KC_6
|
#define BOOTMAGIC_KEY_DEFAULT_LAYER_6 KC_6
|
||||||
|
#endif
|
||||||
|
#ifndef BOOTMAGIC_KEY_DEFAULT_LAYER_7
|
||||||
#define BOOTMAGIC_KEY_DEFAULT_LAYER_7 KC_7
|
#define BOOTMAGIC_KEY_DEFAULT_LAYER_7 KC_7
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
void bootmagic(void);
|
void bootmagic(void);
|
||||||
|
|
|
||||||
|
|
@ -251,10 +251,48 @@ static bool command_common(uint8_t code)
|
||||||
break;
|
break;
|
||||||
case KC_V: // print version & information
|
case KC_V: // print version & information
|
||||||
print("\n\n----- Version -----\n");
|
print("\n\n----- Version -----\n");
|
||||||
print(STR(DESCRIPTION) "\n");
|
print("DESC: " STR(DESCRIPTION) "\n");
|
||||||
print(STR(MANUFACTURER) "(" STR(VENDOR_ID) ")/");
|
print("VID: " STR(VENDOR_ID) "(" STR(MANUFACTURER) ") "
|
||||||
print(STR(PRODUCT) "(" STR(PRODUCT_ID) ") ");
|
"PID: " STR(PRODUCT_ID) "(" STR(PRODUCT) ") "
|
||||||
print("VERSION: " STR(DEVICE_VER) "\n");
|
"VER: " STR(DEVICE_VER) "\n");
|
||||||
|
print("BUILD: " STR(VERSION) " (" __TIME__ " " __DATE__ ")\n");
|
||||||
|
/* build options */
|
||||||
|
print("OPTIONS:"
|
||||||
|
#ifdef PROTOCOL_PJRC
|
||||||
|
" PJRC"
|
||||||
|
#endif
|
||||||
|
#ifdef PROTOCOL_LUFA
|
||||||
|
" LUFA"
|
||||||
|
#endif
|
||||||
|
#ifdef PROTOCOL_VUSB
|
||||||
|
" VUSB"
|
||||||
|
#endif
|
||||||
|
#ifdef BOOTMAGIC_ENABLE
|
||||||
|
" BOOTMAGIC"
|
||||||
|
#endif
|
||||||
|
#ifdef MOUSEKEY_ENABLE
|
||||||
|
" MOUSEKEY"
|
||||||
|
#endif
|
||||||
|
#ifdef EXTRAKEY_ENABLE
|
||||||
|
" EXTRAKEY"
|
||||||
|
#endif
|
||||||
|
#ifdef CONSOLE_ENABLE
|
||||||
|
" CONSOLE"
|
||||||
|
#endif
|
||||||
|
#ifdef COMMAND_ENABLE
|
||||||
|
" COMMAND"
|
||||||
|
#endif
|
||||||
|
#ifdef NKRO_ENABLE
|
||||||
|
" NKRO"
|
||||||
|
#endif
|
||||||
|
#ifdef KEYMAP_SECTION_ENABLE
|
||||||
|
" KEYMAP_SECTION"
|
||||||
|
#endif
|
||||||
|
" " STR(BOOTLOADER_SIZE) "\n");
|
||||||
|
|
||||||
|
print("GCC: " STR(__GNUC__) "." STR(__GNUC_MINOR__) "." STR(__GNUC_PATCHLEVEL__)
|
||||||
|
" AVR-LIBC: " __AVR_LIBC_VERSION_STRING__
|
||||||
|
" AVR_ARCH: avr" STR(__AVR_ARCH__) "\n");
|
||||||
break;
|
break;
|
||||||
case KC_T: // print timer
|
case KC_T: // print timer
|
||||||
print_val_hex32(timer_count);
|
print_val_hex32(timer_count);
|
||||||
|
|
|
||||||
|
|
@ -54,9 +54,6 @@ static bool has_ghost_in_row(uint8_t row)
|
||||||
|
|
||||||
void keyboard_init(void)
|
void keyboard_init(void)
|
||||||
{
|
{
|
||||||
// TODO: configuration of sendchar impl
|
|
||||||
print_set_sendchar(sendchar);
|
|
||||||
|
|
||||||
timer_init();
|
timer_init();
|
||||||
matrix_init();
|
matrix_init();
|
||||||
#ifdef PS2_MOUSE_ENABLE
|
#ifdef PS2_MOUSE_ENABLE
|
||||||
|
|
|
||||||
|
|
@ -36,10 +36,11 @@ action_t action_for_key(uint8_t layer, key_t key)
|
||||||
return keymap_fn_to_action(keycode);
|
return keymap_fn_to_action(keycode);
|
||||||
#ifdef BOOTMAGIC_ENABLE
|
#ifdef BOOTMAGIC_ENABLE
|
||||||
case KC_CAPSLOCK:
|
case KC_CAPSLOCK:
|
||||||
|
case KC_LOCKING_CAPS:
|
||||||
if (keymap_config.swap_control_capslock || keymap_config.capslock_to_control) {
|
if (keymap_config.swap_control_capslock || keymap_config.capslock_to_control) {
|
||||||
return keycode_to_action(KC_LCTL);
|
return keycode_to_action(KC_LCTL);
|
||||||
}
|
}
|
||||||
return keycode_to_action(KC_CAPS);
|
return keycode_to_action(keycode);
|
||||||
case KC_LCTL:
|
case KC_LCTL:
|
||||||
if (keymap_config.swap_control_capslock) {
|
if (keymap_config.swap_control_capslock) {
|
||||||
return keycode_to_action(KC_CAPSLOCK);
|
return keycode_to_action(KC_CAPSLOCK);
|
||||||
|
|
|
||||||
|
|
@ -51,8 +51,7 @@ bool suspend_wakeup_condition(void)
|
||||||
// run immediately after wakeup
|
// run immediately after wakeup
|
||||||
void suspend_wakeup_init(void)
|
void suspend_wakeup_init(void)
|
||||||
{
|
{
|
||||||
// clear matrix and keyboard state
|
// clear keyboard state
|
||||||
matrix_init();
|
|
||||||
clear_keyboard();
|
clear_keyboard();
|
||||||
#ifdef BACKLIGHT_ENABLE
|
#ifdef BACKLIGHT_ENABLE
|
||||||
backlight_init();
|
backlight_init();
|
||||||
|
|
|
||||||
|
|
@ -71,7 +71,7 @@ OPT_DEFS += -DBOOTLOADER_SIZE=4096
|
||||||
# Build Options
|
# Build Options
|
||||||
# *Comment out* to disable the options.
|
# *Comment out* to disable the options.
|
||||||
#
|
#
|
||||||
#BOOTMAGIC_ENABLE = yes # Virtual DIP switch configuration(+1000)
|
BOOTMAGIC_ENABLE = yes # Virtual DIP switch configuration(+1000)
|
||||||
MOUSEKEY_ENABLE = yes # Mouse keys(+4700)
|
MOUSEKEY_ENABLE = yes # Mouse keys(+4700)
|
||||||
EXTRAKEY_ENABLE = yes # Audio control and System control(+450)
|
EXTRAKEY_ENABLE = yes # Audio control and System control(+450)
|
||||||
CONSOLE_ENABLE = yes # Console for debug(+400)
|
CONSOLE_ENABLE = yes # Console for debug(+400)
|
||||||
|
|
|
||||||
|
|
@ -1,10 +1,12 @@
|
||||||
M0110/M0110A to USB keyboard converter
|
M0110/M0110A to USB keyboard converter
|
||||||
======================================
|
======================================
|
||||||
This firmware converts the protocol of Apple Macintosh keyboard M0110/M0110A into USB.
|
This firmware converts the protocol of Apple Macintosh keyboard **M0110**, **M0110A** and **M0120** into USB. Target of this project is USB AVR controller **ATmega32U4**. Using this converter you can revive these retro keyboards with modern computer.
|
||||||
Target board of this project is [PJRC Teensy](http://www.pjrc.com/teensy/), though,
|
|
||||||
you can use other board with USB AVR like `ATmega32U4` and `AT90USB`.
|
Pics of **M0110 + M0120** and **M0110A**.
|
||||||
|
|
||||||
|

|
||||||
|

|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
- M0110A support was contributed by [skagon@github](https://github.com/skagon).
|
- M0110A support was contributed by [skagon@github](https://github.com/skagon).
|
||||||
- M0120 also is supported. keys(+ * / and ,) on M0120 are recognized as cursor keys.
|
- M0120 also is supported. keys(+ * / and ,) on M0120 are recognized as cursor keys.
|
||||||
|
|
@ -13,49 +15,42 @@ you can use other board with USB AVR like `ATmega32U4` and `AT90USB`.
|
||||||
|
|
||||||
Update
|
Update
|
||||||
------
|
------
|
||||||
- 2013/08 Change port for signals PF to PD
|
- 2013/08: Change port for signals `PF` to `PD`
|
||||||
|
- 2013/09: Change port again, it uses inversely `PD0` for data and `PD1` for clock line now.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Connection
|
Building Hardware
|
||||||
----------
|
-----------------
|
||||||
You need 4P4C plug and cable to connect Teensy or other AVR dev board into the keyboard.
|
You need **4P4C** cable and **ATMega32U4** board like PJRC [Teensy]. Port of the MCU `PD1` is assigned to `CLOCK` line and `PD0` to `DATA` by default, you can change pin configuration with editing `config.h`.
|
||||||
Teensy port `PD0` is assigned for `CLOCK` line and `PD1` for `DATA` by default,
|
|
||||||
you can change pin configuration with editing *config.h*.
|
|
||||||
|
|
||||||
You can find 4P4C plugs on telephone handset cable. Note that it is *crossover* connection
|
[](http://i.imgur.com/4G2ZOeg.jpg)
|
||||||
while Macintosh keyboard cable is *straight*.
|
|
||||||
|
|
||||||
[]
|
### 4P4C phone handset cable
|
||||||
|
Note that original cable used with Mac is **straight** while phone handset cable is **crossover**.
|
||||||
|
|
||||||
In this pic:
|
<http://en.wikipedia.org/wiki/Modular_connector#4P4C>
|
||||||
|
|
||||||
1. `GND`(Black)
|
Close-up pic of handset cable. You can see one end of plug has reverse color codes against the other. Click to enlarge.
|
||||||
2. `CLOCK`(Red)
|
[](http://i.imgur.com/3S9P1mY.jpg?1)
|
||||||
3. `DATA`(Green)
|
|
||||||
4. `+5V`(Yellow)
|
|
||||||
|
|
||||||
Note that wire colors may vary in your cable.
|
[Teensy]: http://www.pjrc.com/teensy/
|
||||||
|
|
||||||
|
|
||||||
### Pinout
|
### Socket Pinout
|
||||||
- <http://pinouts.ru/Inputs/MacKeyboard_pinout.shtml>
|
- <http://pinouts.ru/Inputs/MacKeyboard_pinout.shtml>
|
||||||
- <http://en.wikipedia.org/wiki/Modular_connector#4P4C>
|
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
|
||||||
### Pull-up Registor
|
### Pull-up Registor
|
||||||
You may need pull-up registors on signal lines(`CLOCK`, `DATA`) in particular
|
You may need pull-up registors on signal lines(`CLOCK`, `DATA`) in particular when you have long or coiled cable. **1k-10k Ohm** will be OK for this purpose. In that case the converter may not read signal from keyboard correctly without pull-up resistors.
|
||||||
when you have long or coiled cable. 1k-10k Ohm will be OK for this purpose.
|
|
||||||
In some cases MCU can't read signal from keyboard correctly without pull-up resistors.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Building Frimware
|
Building Frimware
|
||||||
-----------------
|
-----------------
|
||||||
To compile firmware you need AVR GCC. You can use [WinAVR](http://winavr.sourceforge.net/) on Windows.
|
To compile firmware you need AVR GCC. You can edit *Makefile* and *config.h* to change compile options and pin configuration.
|
||||||
You can edit *Makefile* and *config.h* to change compile options and pin configuration.
|
|
||||||
|
|
||||||
$ git clone git://github.com/tmk/tmk_keyboard.git (or download source)
|
$ git clone git://github.com/tmk/tmk_keyboard.git (or download source)
|
||||||
$ cd m0110_usb
|
$ cd m0110_usb
|
||||||
|
|
@ -71,64 +66,69 @@ Keymap
|
||||||
You can change keymaps by editing *keymap.c*.
|
You can change keymaps by editing *keymap.c*.
|
||||||
|
|
||||||
### M0110 & M0120
|
### M0110 & M0120
|
||||||
#### *Default*
|
#### *Default Layer*
|
||||||
,---------------------------------------------------------. ,---------------.
|
,---------------------------------------------------------. ,---------------.
|
||||||
| `| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =|Backs| |Ctl| -|Lft|Rgt|
|
| `| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =|Backs| |Clr| -|Lft|Rgt|
|
||||||
|---------------------------------------------------------| |---------------|
|
|---------------------------------------------------------| |---------------|
|
||||||
|Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| \| | 7| 8| 9| Up|
|
|Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| \| | 7| 8| 9| Up|
|
||||||
|---------------------------------------------------------| |---------------|
|
|---------------------------------------------------------| |---------------|
|
||||||
|Fn0 | A| S| D| F| G| H| J| K| L| ;| '|Return| | 4| 5| 6| Dn|
|
|Caps | A| S| D| F| G| H| J| K| L| ;| '|Enter | | 4| 5| 6| Dn|
|
||||||
|---------------------------------------------------------| |---------------|
|
|---------------------------------------------------------| |---------------|
|
||||||
|Shift | Z| X| C| V| B| N| M| ,| ,| /|Shift | | 1| 2| 3| |
|
|Shift | Z| X| C| V| B| N| M| ,| ,| /|Shift | | 1| 2| 3| |
|
||||||
`---------------------------------------------------------' |-----------|Ent|
|
`---------------------------------------------------------' |-----------|Ent|
|
||||||
|Ctl|Alt | Space |Gui |Ctl| | 0| .| |
|
|Ctl|Gui | Space |Alt |Ctl| | 0| .| |
|
||||||
`-----------------------------------------------' `---------------'
|
`-----------------------------------------------' `---------------'
|
||||||
#### *HHKB/WASD Layer(WASD/IJKL)*
|
|
||||||
,---------------------------------------------------------. ,---------------.
|
- `Space` and `Enter` also work as `Fn` layer switch key when holding down.
|
||||||
|Esc| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delet| |Nlk| -|Lft|Rgt|
|
|
||||||
|---------------------------------------------------------| |---------------|
|
#### *Function Layer(WASD/HHKB)*
|
||||||
|Caps |Hom| Up|PgU| | | |PgU| Up|Hom|Psc|Slk|Pau|Ins| | 7| 8| 9| Up|
|
,---------------------------------------------------------. ,---------------.
|
||||||
|---------------------------------------------------------| |---------------|
|
|Esc| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delet| |Nlk| -|Lft|Rgt|
|
||||||
|Fn0 |Lef|Dow|Rig| | | |Lef|Dow|Rig| | |Return| | 4| 5| 6| Dn|
|
|---------------------------------------------------------| |---------------|
|
||||||
|---------------------------------------------------------| |---------------|
|
|Caps |Hom| Up|PgU| | | | |Psc|Slk|Pau|Up |Ins| \| | 7| 8| 9| Up|
|
||||||
|Shift |End| |PgD| | | |PgD| |End| |Shift | | 1| 2| 3| |
|
|---------------------------------------------------------| |---------------|
|
||||||
`---------------------------------------------------------' |-----------|Ent|
|
|Caps |Lef|Dow|Rig| | | | |Hom|PgU|Lef|Rig|Enter | | 4| 5| 6| Dn|
|
||||||
|Ctl|Alt | Space |Gui |Ctl| | 0| .| |
|
|---------------------------------------------------------| |---------------|
|
||||||
`-----------------------------------------------' `---------------'
|
|Shift |End| |PgD| | | | |End|PgD|Dow|Shift | | 1| 2| 3| |
|
||||||
|
`---------------------------------------------------------' |-----------|Ent|
|
||||||
|
|Ctl|Gui | Space |Alt |Ctl| | 0| .| |
|
||||||
|
`-----------------------------------------------' `---------------'
|
||||||
|
|
||||||
|
|
||||||
### M0110A
|
### M0110A
|
||||||
#### *Default*
|
#### *Default Layer*
|
||||||
,---------------------------------------------------------. ,---------------.
|
,---------------------------------------------------------. ,---------------.
|
||||||
| `| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =|Backs| |Ctl| =| /| *|
|
| `| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =|Backs| |Clr| =| /| *|
|
||||||
|---------------------------------------------------------| |---------------|
|
|---------------------------------------------------------| |---------------|
|
||||||
|Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| | | 7| 8| 9| -|
|
|Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| | | 7| 8| 9| -|
|
||||||
|-----------------------------------------------------' | |---------------|
|
|-----------------------------------------------------' | |---------------|
|
||||||
|Fn0 | A| S| D| F| G| H| J| K| L| ;| '|Return| | 4| 5| 6| +|
|
|Caps | A| S| D| F| G| H| J| K| L| ;| '|Enter | | 4| 5| 6| +|
|
||||||
|---------------------------------------------------------| |---------------|
|
|---------------------------------------------------------| |---------------|
|
||||||
|Shift | Z| X| C| V| B| N| M| ,| ,| /|Shft| Up| | 1| 2| 3| |
|
|Shift | Z| X| C| V| B| N| M| ,| ,| /|Shft| Up| | 1| 2| 3| |
|
||||||
|---------------------------------------------------------| |-----------|Ent|
|
|---------------------------------------------------------| |-----------|Ent|
|
||||||
|Alt |Gui | Space | \|Lft|Rgt| Dn| | 0| .| |
|
|Ctrl |Gui | Space | \|Lft|Rgt|Dwn| | 0| .| |
|
||||||
`---------------------------------------------------------' `---------------'
|
`---------------------------------------------------------' `---------------'
|
||||||
#### *Cursor Layer(WASD/IJKL)*
|
|
||||||
|
- `Space` and `Enter` also work as `Fn` layer switch key when holding down.
|
||||||
|
- `Backslash(\)` also works as `Alt` when holding down.
|
||||||
|
|
||||||
|
#### *Function Layer(WASD/HHKB)*
|
||||||
,---------------------------------------------------------. ,---------------.
|
,---------------------------------------------------------. ,---------------.
|
||||||
|Esc| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delet| |Nlk| =| /| *|
|
|Esc| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delet| |Nlk| =| /| *|
|
||||||
|---------------------------------------------------------| |---------------|
|
|---------------------------------------------------------| |---------------|
|
||||||
|Caps |Hom| Up|PgU| | | |PgU| Up|Hom|Psc|Slk|Pau| | | 7| 8| 9| -|
|
|Caps |Hom| Up|PgU| | | | |Psc|Slk|Pau|Up |Ins| | | 7| 8| 9| -|
|
||||||
|-----------------------------------------------------' | |---------------|
|
|-----------------------------------------------------' | |---------------|
|
||||||
|Fn0 |Lef|Dow|Rig| | | |Lef|Dow|Rig| | |Return| | 4| 5| 6| +|
|
|Caps |Lef|Dow|Rig| | | | |Hom|PgU|Lef|Rig|Enter | | 4| 5| 6| +|
|
||||||
|---------------------------------------------------------| |---------------|
|
|---------------------------------------------------------| |---------------|
|
||||||
|Shift |End| |PgD| | | |PgD| |End| |Shif|PgU| | 1| 2| 3| |
|
|Shift |End| |PgD| | | | |End|PgD|Dow|Shif|PgU| | 1| 2| 3| |
|
||||||
|---------------------------------------------------------| |-----------|Ent|
|
|---------------------------------------------------------| |-----------|Ent|
|
||||||
|Alt |Gui | Space |Ins|Hom|End|PgD| | 0| .| |
|
|Ctrl |Gui | Space | \|Hom|End|PgD| | 0| .| |
|
||||||
`---------------------------------------------------------' `---------------'
|
`---------------------------------------------------------' `---------------'
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Debug
|
Debug
|
||||||
-----
|
-----
|
||||||
You can use [PJRC HID listen](http://www.pjrc.com/teensy/hid_listen.html) to see debug output.
|
You can use [PJRC HID listen](http://www.pjrc.com/teensy/hid_listen.html) to see debug output. The converter has some functions for debug, press `<Command>+H` simultaneously to get help.
|
||||||
|
|
||||||
The converter has some functions for debug, press `<magickey>+H` simultaneously to get help.
|
- Command: `Shift+Option+Command`(`Shift+Alt+Gui` or `Shift+Alt+Control`)
|
||||||
These function is totally undocumented, tentative, inconsistent and buggy.
|
|
||||||
|
|
||||||
magickey: Shift+Option+Command(Shift+Alt+Gui or Shift+Alt+Control)
|
|
||||||
|
|
|
||||||
|
|
@ -32,10 +32,6 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#define MATRIX_COLS 8
|
#define MATRIX_COLS 8
|
||||||
|
|
||||||
|
|
||||||
/* legacy keymap support */
|
|
||||||
#define USE_LEGACY_KEYMAP
|
|
||||||
|
|
||||||
|
|
||||||
/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
|
/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
|
||||||
#define LOCKING_SUPPORT_ENABLE
|
#define LOCKING_SUPPORT_ENABLE
|
||||||
/* Locking resynchronize hack */
|
/* Locking resynchronize hack */
|
||||||
|
|
@ -48,15 +44,19 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_LALT) | MOD_BIT(KC_LCTL)) \
|
keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_LALT) | MOD_BIT(KC_LCTL)) \
|
||||||
)
|
)
|
||||||
|
|
||||||
|
/* boot magic key */
|
||||||
|
#define BOOTMAGIC_KEY_SALT KC_FN0
|
||||||
|
#define BOOTMAGIC_KEY_CAPSLOCK_TO_CONTROL KC_LCAP
|
||||||
|
|
||||||
|
|
||||||
/* ports */
|
/* ports */
|
||||||
#define M0110_CLOCK_PORT PORTD
|
#define M0110_CLOCK_PORT PORTD
|
||||||
#define M0110_CLOCK_PIN PIND
|
#define M0110_CLOCK_PIN PIND
|
||||||
#define M0110_CLOCK_DDR DDRD
|
#define M0110_CLOCK_DDR DDRD
|
||||||
#define M0110_CLOCK_BIT 0
|
#define M0110_CLOCK_BIT 1
|
||||||
#define M0110_DATA_PORT PORTD
|
#define M0110_DATA_PORT PORTD
|
||||||
#define M0110_DATA_PIN PIND
|
#define M0110_DATA_PIN PIND
|
||||||
#define M0110_DATA_DDR DDRD
|
#define M0110_DATA_DDR DDRD
|
||||||
#define M0110_DATA_BIT 1
|
#define M0110_DATA_BIT 0
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 48 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 49 KiB |
|
|
@ -44,7 +44,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| | | 7| 8| 9| -|
|
* |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| | | 7| 8| 9| -|
|
||||||
* |-----------------------------------------------------' | |---------------|
|
* |-----------------------------------------------------' | |---------------|
|
||||||
* |Caps | A| S| D| F| G| H| J| K| L| ;| '|Return| | 4| 5| 6| +|
|
* |Caps | A| S| D| F| G| H| J| K| L| ;| '|Enter | | 4| 5| 6| +|
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Shift | Z| X| C| V| B| N| M| ,| ,| /|Shft|Up | | 1| 2| 3| |
|
* |Shift | Z| X| C| V| B| N| M| ,| ,| /|Shft|Up | | 1| 2| 3| |
|
||||||
* |---------------------------------------------------------' |-----------|Ent|
|
* |---------------------------------------------------------' |-----------|Ent|
|
||||||
|
|
@ -57,7 +57,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| \| | 7| 8| 9| /|
|
* |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| \| | 7| 8| 9| /|
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Caps | A| S| D| F| G| H| J| K| L| ;| '|Return| | 4| 5| 6| ,|
|
* |Caps | A| S| D| F| G| H| J| K| L| ;| '|Enter | | 4| 5| 6| ,|
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Shift | Z| X| C| V| B| N| M| ,| ,| /|Shift | | 1| 2| 3| |
|
* |Shift | Z| X| C| V| B| N| M| ,| ,| /|Shift | | 1| 2| 3| |
|
||||||
* `---------------------------------------------------------' |-----------|Ent|
|
* `---------------------------------------------------------' |-----------|Ent|
|
||||||
|
|
@ -77,7 +77,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| | | 7| 8| 9| -|
|
* |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| | | 7| 8| 9| -|
|
||||||
* |-----------------------------------------------------' | |---------------|
|
* |-----------------------------------------------------' | |---------------|
|
||||||
* |Caps | A| S| D| F| G| H| J| K| L| ;| '|Return| | 4| 5| 6| +|
|
* |Caps | A| S| D| F| G| H| J| K| L| ;| '|Enter | | 4| 5| 6| +|
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Shift | Z| X| C| V| B| N| M| ,| ,| /|Shft|Up | | 1| 2| 3| |
|
* |Shift | Z| X| C| V| B| N| M| ,| ,| /|Shft|Up | | 1| 2| 3| |
|
||||||
* |---------------------------------------------------------| |-----------|Ent|
|
* |---------------------------------------------------------| |-----------|Ent|
|
||||||
|
|
@ -108,89 +108,79 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
{ KC_##K68, KC_NO, KC_NO, KC_NO, KC_NO, KC_##K6D, KC_NO, KC_NO }, \
|
{ KC_##K68, KC_NO, KC_NO, KC_NO, KC_NO, KC_##K6D, KC_NO, KC_NO }, \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define KEYCODE(layer, row, col) (pgm_read_byte(&keymaps[(layer)][(row)][(col)]))
|
#ifdef KEYMAP_SECTION_ENABLE
|
||||||
|
const uint8_t keymaps[][MATRIX_ROWS][MATRIX_COLS] __attribute__ ((section (".keymap.keymaps"))) = {
|
||||||
|
#else
|
||||||
// Assign Fn key(0-7) to a layer to which switch with the Fn key pressed.
|
static const uint8_t keymaps[][MATRIX_ROWS][MATRIX_COLS] PROGMEM = {
|
||||||
static const uint8_t PROGMEM fn_layer[] = {
|
#endif
|
||||||
1, // Fn0
|
|
||||||
0, // Fn1
|
|
||||||
0, // Fn2
|
|
||||||
0, // Fn3
|
|
||||||
0, // Fn4
|
|
||||||
0, // Fn5
|
|
||||||
0, // Fn6
|
|
||||||
0 // Fn7
|
|
||||||
};
|
|
||||||
|
|
||||||
// Assign Fn key(0-7) to a keycode sent when release Fn key without use of the layer.
|
|
||||||
// See layer.c for details.
|
|
||||||
static const uint8_t PROGMEM fn_keycode[] = {
|
|
||||||
KC_NO, // Fn0
|
|
||||||
KC_NO, // Fn1
|
|
||||||
KC_NO, // Fn2
|
|
||||||
KC_NO, // Fn3
|
|
||||||
KC_NO, // Fn4
|
|
||||||
KC_NO, // Fn5
|
|
||||||
KC_NO, // Fn6
|
|
||||||
KC_NO // Fn7
|
|
||||||
};
|
|
||||||
|
|
||||||
static const uint8_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
|
||||||
/* Default:
|
/* Default:
|
||||||
* ,---------------------------------------------------------. ,---------------.
|
* ,---------------------------------------------------------. ,---------------.
|
||||||
* | `| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =|Backs| |Ctl| =| /| *|
|
* | `| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =|Backs| |Clr| =| /| *|
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| | | 7| 8| 9| -|
|
* |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| | | 7| 8| 9| -|
|
||||||
* |-----------------------------------------------------' | |---------------|
|
* |-----------------------------------------------------' | |---------------|
|
||||||
* |Fn0 | A| S| D| F| G| H| J| K| L| ;| '|Return| | 4| 5| 6| +|
|
* |Caps | A| S| D| F| G| H| J| K| L| ;| '|Enter | | 4| 5| 6| +|
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Shift | Z| X| C| V| B| N| M| ,| ,| /|Shft|Up | | 1| 2| 3| |
|
* |Shift | Z| X| C| V| B| N| M| ,| ,| /|Shft|Up | | 1| 2| 3| |
|
||||||
* |---------------------------------------------------------| |-----------|Ent|
|
* |---------------------------------------------------------| |-----------|Ent|
|
||||||
* |Ctl |Alt | Space |Gui| \|Lft|Rgt|Dn | | 0| .| |
|
* |Ctl |Gui | Space |Alt| \|Lft|Rgt|Dn | | 0| .| |
|
||||||
* `---------------------------------------------------------' `---------------'
|
* `---------------------------------------------------------' `---------------'
|
||||||
*/
|
*/
|
||||||
KEYMAP(
|
KEYMAP(
|
||||||
GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, MINS,EQL, BSPC, LCTL,EQL, PSLS,PAST,
|
GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, MINS,EQL, BSPC, CLR, EQL, PSLS,PAST,
|
||||||
TAB, Q, W, E, R, T, Y, U, I, O, P, LBRC,RBRC, P7, P8, P9, PMNS,
|
TAB, Q, W, E, R, T, Y, U, I, O, P, LBRC,RBRC, P7, P8, P9, PMNS,
|
||||||
FN0, A, S, D, F, G, H, J, K, L, SCLN,QUOT, ENT, P4, P5, P6, PPLS,
|
LCAP,A, S, D, F, G, H, J, K, L, SCLN,QUOT, FN1, P4, P5, P6, PPLS,
|
||||||
LSFT,Z, X, C, V, B, N, M, COMM,DOT, SLSH, UP, P1, P2, P3, PENT,
|
LSFT,Z, X, C, V, B, N, M, COMM,DOT, SLSH, UP, P1, P2, P3, PENT,
|
||||||
LCTL,LALT, SPC, LGUI,BSLS,LEFT,RGHT,DOWN, P0, PDOT
|
LCTL,LGUI, FN0, LALT,FN2, LEFT,RGHT,DOWN, P0, PDOT
|
||||||
),
|
),
|
||||||
/* Cursor Layer(WASD, IJKL)
|
/* Cursor Layer(WASD, IJKL)
|
||||||
* ,---------------------------------------------------------. ,---------------.
|
* ,---------------------------------------------------------. ,---------------.
|
||||||
* |Esc| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delet| |Nlk| =| /| *|
|
* |Esc| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delet| |Nlk| =| /| *|
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Caps |Hom| Up|PgU| | | |PgU| Up|Hom|Psc|Slk|Pau| | | 7| 8| 9| -|
|
* |Caps |Hom| Up|PgU| | | | |Psc|Slk|Pau|Up |Ins| | | 7| 8| 9| -|
|
||||||
* |-----------------------------------------------------' | |---------------|
|
* |-----------------------------------------------------' | |---------------|
|
||||||
* |Fn0 |Lef|Dow|Rig| | | |Lef|Dow|Rig| | |Return| | 4| 5| 6| +|
|
* |Caps |Lef|Dow|Rig| | | | |Hom|PgU|Lef|Rig|Enter | | 4| 5| 6| +|
|
||||||
* |---------------------------------------------------------| |---------------|
|
* |---------------------------------------------------------| |---------------|
|
||||||
* |Shift |End| |PgD| | | |PgD| |End| |Shif|PgU| | 1| 2| 3| |
|
* |Shift |End| |PgD| | | | |End|PgD|Dow|Shif|PgU| | 1| 2| 3| |
|
||||||
* |---------------------------------------------------------| |-----------|Ent|
|
* |---------------------------------------------------------| |-----------|Ent|
|
||||||
* |Ctl |Alt | Space |Gui |Ins|Hom|End|PgD| | 0| .| |
|
* |Ctl |Gui | Space |Alt | \|Hom|End|PgD| | 0| .| |
|
||||||
* `---------------------------------------------------------' `---------------'
|
* `---------------------------------------------------------' `---------------'
|
||||||
*/
|
*/
|
||||||
KEYMAP(
|
KEYMAP(
|
||||||
ESC, F1, F2, F3, F4, F5, F6, F7, F8, F9, F10, F11, F12, DEL, NLCK,EQL, PSLS,PAST,
|
ESC, F1, F2, F3, F4, F5, F6, F7, F8, F9, F10, F11, F12, DEL, NLCK,EQL, PSLS,PAST,
|
||||||
CAPS,HOME,UP, PGUP,NO, NO, NO, PGUP,UP, HOME,PSCR,SLCK,PAUS, P7, P8, P9, PMNS,
|
CAPS,HOME,UP, PGUP,NO, NO, NO, NO, PSCR,SLCK,PAUS,UP, INS, P7, P8, P9, PMNS,
|
||||||
FN0, LEFT,DOWN,RGHT,NO, NO, NO, LEFT,DOWN,RGHT,NO, NO, ENT, P4, P5, P6, PPLS,
|
LCAP,LEFT,DOWN,RGHT,NO, NO, NO, NO, HOME,PGUP,LEFT,RGHT, FN1, P4, P5, P6, PPLS,
|
||||||
LSFT,END, NO, PGDN,NO, NO, NO, PGDN,NO, END, NO, PGUP, P1, P2, P3, PENT,
|
LSFT,END, NO, PGDN,NO, NO, NO, NO, END, PGDN,DOWN, PGUP, P1, P2, P3, PENT,
|
||||||
LCTL,LALT, SPC, LGUI,INS, HOME,END, PGDN, P0, PDOT
|
LCTL,LGUI, FN0, LALT,FN2, HOME,END, PGDN, P0, PDOT
|
||||||
),
|
),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
uint8_t keymap_get_keycode(uint8_t layer, uint8_t row, uint8_t col)
|
/*
|
||||||
|
* Fn action definition
|
||||||
|
*/
|
||||||
|
#ifdef KEYMAP_SECTION_ENABLE
|
||||||
|
const uint16_t fn_actions[] __attribute__ ((section (".keymap.fn_actions"))) = {
|
||||||
|
#else
|
||||||
|
static const uint16_t fn_actions[] PROGMEM = {
|
||||||
|
#endif
|
||||||
|
[0] = ACTION_LAYER_TAP_KEY(1, KC_SPACE), // Layer switch with Tap key Space
|
||||||
|
[1] = ACTION_LAYER_TAP_KEY(1, KC_ENTER), // Layer switch with Tap key Enter
|
||||||
|
[2] = ACTION_MODS_TAP_KEY(MOD_LALT, KC_BSLS), // LALT with Tap key Backslash
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* translates key to keycode */
|
||||||
|
uint8_t keymap_key_to_keycode(uint8_t layer, key_t key)
|
||||||
{
|
{
|
||||||
return KEYCODE(layer, row, col);
|
return pgm_read_byte(&keymaps[(layer)][(key.row)][(key.col)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t keymap_fn_layer(uint8_t index)
|
/* translates Fn index to action */
|
||||||
|
action_t keymap_fn_to_action(uint8_t keycode)
|
||||||
{
|
{
|
||||||
return pgm_read_byte(&fn_layer[index]);
|
action_t action;
|
||||||
}
|
action.code = pgm_read_word(&fn_actions[FN_INDEX(keycode)]);
|
||||||
|
return action;
|
||||||
uint8_t keymap_fn_keycode(uint8_t index)
|
|
||||||
{
|
|
||||||
return pgm_read_byte(&fn_keycode[index]);
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -111,12 +111,13 @@ OPT_DEFS += -DBOOTLOADER_SIZE=4096
|
||||||
# Build Options
|
# Build Options
|
||||||
# comment out to disable the options.
|
# comment out to disable the options.
|
||||||
#
|
#
|
||||||
BOOTMAGIC_ENABLE = yes # Virtual DIP switch configuration
|
BOOTMAGIC_ENABLE = yes # Virtual DIP switch configuration
|
||||||
MOUSEKEY_ENABLE = yes # Mouse keys
|
MOUSEKEY_ENABLE = yes # Mouse keys
|
||||||
EXTRAKEY_ENABLE = yes # Audio control and System control
|
EXTRAKEY_ENABLE = yes # Audio control and System control
|
||||||
CONSOLE_ENABLE = yes # Console for debug
|
CONSOLE_ENABLE = yes # Console for debug
|
||||||
COMMAND_ENABLE = yes # Commands for debug and configuration
|
COMMAND_ENABLE = yes # Commands for debug and configuration
|
||||||
NKRO_ENABLE = yes # USB Nkey Rollover
|
NKRO_ENABLE = yes # USB Nkey Rollover
|
||||||
|
KEYMAP_SECTION_ENABLE = yes # fixed address keymap for keymap editor
|
||||||
|
|
||||||
|
|
||||||
# Search Path
|
# Search Path
|
||||||
|
|
@ -128,4 +129,5 @@ include $(TOP_DIR)/common.mk
|
||||||
include $(TOP_DIR)/rules.mk
|
include $(TOP_DIR)/rules.mk
|
||||||
|
|
||||||
debug-on: EXTRAFLAGS += -DDEBUG
|
debug-on: EXTRAFLAGS += -DDEBUG
|
||||||
|
#debug-on: EXTRAFLAGS += -DDEBUG -DDEBUG_ACTION
|
||||||
debug-on: all
|
debug-on: all
|
||||||
|
|
|
||||||
|
|
@ -48,8 +48,11 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
{ KC_##K70, KC_##K71, KC_##K72, KC_##K73, KC_##K74, KC_##K75, KC_##K76, KC_NO } \
|
{ KC_##K70, KC_##K71, KC_##K72, KC_##K73, KC_##K74, KC_##K75, KC_##K76, KC_NO } \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef KEYMAP_SECTION_ENABLE
|
||||||
static const uint8_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
const uint8_t keymaps[][MATRIX_ROWS][MATRIX_COLS] __attribute__ ((section (".keymap.keymaps"))) = {
|
||||||
|
#else
|
||||||
|
static const uint8_t keymaps[][MATRIX_ROWS][MATRIX_COLS] PROGMEM = {
|
||||||
|
#endif
|
||||||
/* Layer 0: Default Layer
|
/* Layer 0: Default Layer
|
||||||
* ,-----------------------------------------------------------.
|
* ,-----------------------------------------------------------.
|
||||||
* |Esc| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =| \| `|
|
* |Esc| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =| \| `|
|
||||||
|
|
@ -186,7 +189,11 @@ enum macro_id {
|
||||||
/*
|
/*
|
||||||
* Fn action definition
|
* Fn action definition
|
||||||
*/
|
*/
|
||||||
static const uint16_t PROGMEM fn_actions[] = {
|
#ifdef KEYMAP_SECTION_ENABLE
|
||||||
|
const uint16_t fn_actions[] __attribute__ ((section (".keymap.fn_actions"))) = {
|
||||||
|
#else
|
||||||
|
static const uint16_t fn_actions[] PROGMEM = {
|
||||||
|
#endif
|
||||||
[0] = ACTION_DEFAULT_LAYER_SET(0), // Default layer(not used)
|
[0] = ACTION_DEFAULT_LAYER_SET(0), // Default layer(not used)
|
||||||
[1] = ACTION_LAYER_TAP_TOGGLE(1), // HHKB layer(toggle with 5 taps)
|
[1] = ACTION_LAYER_TAP_TOGGLE(1), // HHKB layer(toggle with 5 taps)
|
||||||
[2] = ACTION_LAYER_TAP_KEY(2, KC_SLASH), // Cursor layer with Slash*
|
[2] = ACTION_LAYER_TAP_KEY(2, KC_SLASH), // Cursor layer with Slash*
|
||||||
|
|
@ -310,10 +317,6 @@ uint8_t keymap_key_to_keycode(uint8_t layer, key_t key)
|
||||||
action_t keymap_fn_to_action(uint8_t keycode)
|
action_t keymap_fn_to_action(uint8_t keycode)
|
||||||
{
|
{
|
||||||
action_t action;
|
action_t action;
|
||||||
if (FN_INDEX(keycode) < sizeof(fn_actions) / sizeof(fn_actions[0])) {
|
action.code = pgm_read_word(&fn_actions[FN_INDEX(keycode)]);
|
||||||
action.code = pgm_read_word(&fn_actions[FN_INDEX(keycode)]);
|
|
||||||
} else {
|
|
||||||
action.code = ACTION_NO;
|
|
||||||
}
|
|
||||||
return action;
|
return action;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
268
ldscript_keymap_avr5.x
Normal file
268
ldscript_keymap_avr5.x
Normal file
|
|
@ -0,0 +1,268 @@
|
||||||
|
/*
|
||||||
|
* linker script for configurable keymap
|
||||||
|
*
|
||||||
|
* This adds keymap section which places keymap at fixed address and
|
||||||
|
* is based on binutils-avr ldscripts(/usr/lib/ldscripts/avr5.x).
|
||||||
|
*/
|
||||||
|
OUTPUT_FORMAT("elf32-avr","elf32-avr","elf32-avr")
|
||||||
|
OUTPUT_ARCH(avr:5)
|
||||||
|
MEMORY
|
||||||
|
{
|
||||||
|
/* With keymap section
|
||||||
|
*
|
||||||
|
* Flash Map of ATMega32U4(32KB)
|
||||||
|
* +------------+ 0x0000
|
||||||
|
* | .vectors |
|
||||||
|
* | .progmem |
|
||||||
|
* | .init0-9 | > text region
|
||||||
|
* | .text |
|
||||||
|
* | .fini9-0 |
|
||||||
|
* | |
|
||||||
|
* |------------| _etext
|
||||||
|
* | .data |
|
||||||
|
* | .bss | > data region
|
||||||
|
* | .noinit |
|
||||||
|
* | |
|
||||||
|
* |------------| 0x6800
|
||||||
|
* | .keymap | > keymap region(2KB)
|
||||||
|
* |------------| 0x7000
|
||||||
|
* | bootloader | 4KB
|
||||||
|
* +------------+ 0x7FFF
|
||||||
|
*/
|
||||||
|
text (rx) : ORIGIN = 0, LENGTH = 128K
|
||||||
|
keymap (rw!x) : ORIGIN = 0x6800, LENGTH = 2K
|
||||||
|
data (rw!x) : ORIGIN = 0x800060, LENGTH = 0xffa0
|
||||||
|
eeprom (rw!x) : ORIGIN = 0x810000, LENGTH = 64K
|
||||||
|
fuse (rw!x) : ORIGIN = 0x820000, LENGTH = 1K
|
||||||
|
lock (rw!x) : ORIGIN = 0x830000, LENGTH = 1K
|
||||||
|
signature (rw!x) : ORIGIN = 0x840000, LENGTH = 1K
|
||||||
|
}
|
||||||
|
SECTIONS
|
||||||
|
{
|
||||||
|
/* Read-only sections, merged into text segment: */
|
||||||
|
.hash : { *(.hash) }
|
||||||
|
.dynsym : { *(.dynsym) }
|
||||||
|
.dynstr : { *(.dynstr) }
|
||||||
|
.gnu.version : { *(.gnu.version) }
|
||||||
|
.gnu.version_d : { *(.gnu.version_d) }
|
||||||
|
.gnu.version_r : { *(.gnu.version_r) }
|
||||||
|
.rel.init : { *(.rel.init) }
|
||||||
|
.rela.init : { *(.rela.init) }
|
||||||
|
.rel.text :
|
||||||
|
{
|
||||||
|
*(.rel.text)
|
||||||
|
*(.rel.text.*)
|
||||||
|
*(.rel.gnu.linkonce.t*)
|
||||||
|
}
|
||||||
|
.rela.text :
|
||||||
|
{
|
||||||
|
*(.rela.text)
|
||||||
|
*(.rela.text.*)
|
||||||
|
*(.rela.gnu.linkonce.t*)
|
||||||
|
}
|
||||||
|
.rel.fini : { *(.rel.fini) }
|
||||||
|
.rela.fini : { *(.rela.fini) }
|
||||||
|
.rel.rodata :
|
||||||
|
{
|
||||||
|
*(.rel.rodata)
|
||||||
|
*(.rel.rodata.*)
|
||||||
|
*(.rel.gnu.linkonce.r*)
|
||||||
|
}
|
||||||
|
.rela.rodata :
|
||||||
|
{
|
||||||
|
*(.rela.rodata)
|
||||||
|
*(.rela.rodata.*)
|
||||||
|
*(.rela.gnu.linkonce.r*)
|
||||||
|
}
|
||||||
|
.rel.data :
|
||||||
|
{
|
||||||
|
*(.rel.data)
|
||||||
|
*(.rel.data.*)
|
||||||
|
*(.rel.gnu.linkonce.d*)
|
||||||
|
}
|
||||||
|
.rela.data :
|
||||||
|
{
|
||||||
|
*(.rela.data)
|
||||||
|
*(.rela.data.*)
|
||||||
|
*(.rela.gnu.linkonce.d*)
|
||||||
|
}
|
||||||
|
.rel.ctors : { *(.rel.ctors) }
|
||||||
|
.rela.ctors : { *(.rela.ctors) }
|
||||||
|
.rel.dtors : { *(.rel.dtors) }
|
||||||
|
.rela.dtors : { *(.rela.dtors) }
|
||||||
|
.rel.got : { *(.rel.got) }
|
||||||
|
.rela.got : { *(.rela.got) }
|
||||||
|
.rel.bss : { *(.rel.bss) }
|
||||||
|
.rela.bss : { *(.rela.bss) }
|
||||||
|
.rel.plt : { *(.rel.plt) }
|
||||||
|
.rela.plt : { *(.rela.plt) }
|
||||||
|
/* Internal text space or external memory. */
|
||||||
|
.text :
|
||||||
|
{
|
||||||
|
*(.vectors)
|
||||||
|
KEEP(*(.vectors))
|
||||||
|
/* For data that needs to reside in the lower 64k of progmem. */
|
||||||
|
*(.progmem.gcc*)
|
||||||
|
*(.progmem*)
|
||||||
|
. = ALIGN(2);
|
||||||
|
__trampolines_start = . ;
|
||||||
|
/* The jump trampolines for the 16-bit limited relocs will reside here. */
|
||||||
|
*(.trampolines)
|
||||||
|
*(.trampolines*)
|
||||||
|
__trampolines_end = . ;
|
||||||
|
/* For future tablejump instruction arrays for 3 byte pc devices.
|
||||||
|
We don't relax jump/call instructions within these sections. */
|
||||||
|
*(.jumptables)
|
||||||
|
*(.jumptables*)
|
||||||
|
/* For code that needs to reside in the lower 128k progmem. */
|
||||||
|
*(.lowtext)
|
||||||
|
*(.lowtext*)
|
||||||
|
__ctors_start = . ;
|
||||||
|
*(.ctors)
|
||||||
|
__ctors_end = . ;
|
||||||
|
__dtors_start = . ;
|
||||||
|
*(.dtors)
|
||||||
|
__dtors_end = . ;
|
||||||
|
KEEP(SORT(*)(.ctors))
|
||||||
|
KEEP(SORT(*)(.dtors))
|
||||||
|
/* From this point on, we don't bother about wether the insns are
|
||||||
|
below or above the 16 bits boundary. */
|
||||||
|
*(.init0) /* Start here after reset. */
|
||||||
|
KEEP (*(.init0))
|
||||||
|
*(.init1)
|
||||||
|
KEEP (*(.init1))
|
||||||
|
*(.init2) /* Clear __zero_reg__, set up stack pointer. */
|
||||||
|
KEEP (*(.init2))
|
||||||
|
*(.init3)
|
||||||
|
KEEP (*(.init3))
|
||||||
|
*(.init4) /* Initialize data and BSS. */
|
||||||
|
KEEP (*(.init4))
|
||||||
|
*(.init5)
|
||||||
|
KEEP (*(.init5))
|
||||||
|
*(.init6) /* C++ constructors. */
|
||||||
|
KEEP (*(.init6))
|
||||||
|
*(.init7)
|
||||||
|
KEEP (*(.init7))
|
||||||
|
*(.init8)
|
||||||
|
KEEP (*(.init8))
|
||||||
|
*(.init9) /* Call main(). */
|
||||||
|
KEEP (*(.init9))
|
||||||
|
*(.text)
|
||||||
|
. = ALIGN(2);
|
||||||
|
*(.text.*)
|
||||||
|
. = ALIGN(2);
|
||||||
|
*(.fini9) /* _exit() starts here. */
|
||||||
|
KEEP (*(.fini9))
|
||||||
|
*(.fini8)
|
||||||
|
KEEP (*(.fini8))
|
||||||
|
*(.fini7)
|
||||||
|
KEEP (*(.fini7))
|
||||||
|
*(.fini6) /* C++ destructors. */
|
||||||
|
KEEP (*(.fini6))
|
||||||
|
*(.fini5)
|
||||||
|
KEEP (*(.fini5))
|
||||||
|
*(.fini4)
|
||||||
|
KEEP (*(.fini4))
|
||||||
|
*(.fini3)
|
||||||
|
KEEP (*(.fini3))
|
||||||
|
*(.fini2)
|
||||||
|
KEEP (*(.fini2))
|
||||||
|
*(.fini1)
|
||||||
|
KEEP (*(.fini1))
|
||||||
|
*(.fini0) /* Infinite loop after program termination. */
|
||||||
|
KEEP (*(.fini0))
|
||||||
|
_etext = . ;
|
||||||
|
} > text
|
||||||
|
.data : AT (ADDR (.text) + SIZEOF (.text))
|
||||||
|
{
|
||||||
|
PROVIDE (__data_start = .) ;
|
||||||
|
*(.data)
|
||||||
|
*(.data*)
|
||||||
|
*(.rodata) /* We need to include .rodata here if gcc is used */
|
||||||
|
*(.rodata*) /* with -fdata-sections. */
|
||||||
|
*(.gnu.linkonce.d*)
|
||||||
|
. = ALIGN(2);
|
||||||
|
_edata = . ;
|
||||||
|
PROVIDE (__data_end = .) ;
|
||||||
|
} > data
|
||||||
|
.bss : AT (ADDR (.bss))
|
||||||
|
{
|
||||||
|
PROVIDE (__bss_start = .) ;
|
||||||
|
*(.bss)
|
||||||
|
*(.bss*)
|
||||||
|
*(COMMON)
|
||||||
|
PROVIDE (__bss_end = .) ;
|
||||||
|
} > data
|
||||||
|
__data_load_start = LOADADDR(.data);
|
||||||
|
__data_load_end = __data_load_start + SIZEOF(.data);
|
||||||
|
/* Global data not cleared after reset. */
|
||||||
|
.noinit :
|
||||||
|
{
|
||||||
|
PROVIDE (__noinit_start = .) ;
|
||||||
|
*(.noinit*)
|
||||||
|
PROVIDE (__noinit_end = .) ;
|
||||||
|
_end = . ;
|
||||||
|
PROVIDE (__heap_start = .) ;
|
||||||
|
} > data
|
||||||
|
/* keymap region is located at end of flash
|
||||||
|
* .fn_actions Fn actions definitions
|
||||||
|
* .keymaps Mapping layers
|
||||||
|
*/
|
||||||
|
.keymap :
|
||||||
|
{
|
||||||
|
PROVIDE(__keymap_start = .) ;
|
||||||
|
*(.keymap.fn_actions) /* 32*actions = 64bytes */
|
||||||
|
. = ALIGN(0x40);
|
||||||
|
*(.keymap.keymaps) /* rest of .keymap section */
|
||||||
|
*(.keymap*)
|
||||||
|
/* . = ALIGN(0x800); */ /* keymap section takes 2KB- */
|
||||||
|
} > keymap = 0x00 /* zero fill */
|
||||||
|
.eeprom :
|
||||||
|
{
|
||||||
|
*(.eeprom*)
|
||||||
|
__eeprom_end = . ;
|
||||||
|
} > eeprom
|
||||||
|
.fuse :
|
||||||
|
{
|
||||||
|
KEEP(*(.fuse))
|
||||||
|
KEEP(*(.lfuse))
|
||||||
|
KEEP(*(.hfuse))
|
||||||
|
KEEP(*(.efuse))
|
||||||
|
} > fuse
|
||||||
|
.lock :
|
||||||
|
{
|
||||||
|
KEEP(*(.lock*))
|
||||||
|
} > lock
|
||||||
|
.signature :
|
||||||
|
{
|
||||||
|
KEEP(*(.signature*))
|
||||||
|
} > signature
|
||||||
|
/* Stabs debugging sections. */
|
||||||
|
.stab 0 : { *(.stab) }
|
||||||
|
.stabstr 0 : { *(.stabstr) }
|
||||||
|
.stab.excl 0 : { *(.stab.excl) }
|
||||||
|
.stab.exclstr 0 : { *(.stab.exclstr) }
|
||||||
|
.stab.index 0 : { *(.stab.index) }
|
||||||
|
.stab.indexstr 0 : { *(.stab.indexstr) }
|
||||||
|
.comment 0 : { *(.comment) }
|
||||||
|
/* DWARF debug sections.
|
||||||
|
Symbols in the DWARF debugging sections are relative to the beginning
|
||||||
|
of the section so we begin them at 0. */
|
||||||
|
/* DWARF 1 */
|
||||||
|
.debug 0 : { *(.debug) }
|
||||||
|
.line 0 : { *(.line) }
|
||||||
|
/* GNU DWARF 1 extensions */
|
||||||
|
.debug_srcinfo 0 : { *(.debug_srcinfo) }
|
||||||
|
.debug_sfnames 0 : { *(.debug_sfnames) }
|
||||||
|
/* DWARF 1.1 and DWARF 2 */
|
||||||
|
.debug_aranges 0 : { *(.debug_aranges) }
|
||||||
|
.debug_pubnames 0 : { *(.debug_pubnames) }
|
||||||
|
/* DWARF 2 */
|
||||||
|
.debug_info 0 : { *(.debug_info) *(.gnu.linkonce.wi.*) }
|
||||||
|
.debug_abbrev 0 : { *(.debug_abbrev) }
|
||||||
|
.debug_line 0 : { *(.debug_line) }
|
||||||
|
.debug_frame 0 : { *(.debug_frame) }
|
||||||
|
.debug_str 0 : { *(.debug_str) }
|
||||||
|
.debug_loc 0 : { *(.debug_loc) }
|
||||||
|
.debug_macinfo 0 : { *(.debug_macinfo) }
|
||||||
|
}
|
||||||
|
|
@ -531,19 +531,26 @@ static void SetupHardware(void)
|
||||||
|
|
||||||
// for Console_Task
|
// for Console_Task
|
||||||
USB_Device_EnableSOFEvents();
|
USB_Device_EnableSOFEvents();
|
||||||
|
print_set_sendchar(sendchar);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void) __attribute__ ((weak));
|
int main(void) __attribute__ ((weak));
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
SetupHardware();
|
SetupHardware();
|
||||||
|
sei();
|
||||||
|
#if defined(INTERRUPT_CONTROL_ENDPOINT)
|
||||||
|
while (USB_DeviceState != DEVICE_STATE_Configured) ;
|
||||||
|
#endif
|
||||||
|
print("USB configured.\n");
|
||||||
|
|
||||||
keyboard_init();
|
keyboard_init();
|
||||||
host_set_driver(&lufa_driver);
|
host_set_driver(&lufa_driver);
|
||||||
#ifdef SLEEP_LED_ENABLE
|
#ifdef SLEEP_LED_ENABLE
|
||||||
sleep_led_init();
|
sleep_led_init();
|
||||||
#endif
|
#endif
|
||||||
sei();
|
|
||||||
|
|
||||||
|
print("Keyboard start.\n");
|
||||||
while (1) {
|
while (1) {
|
||||||
while (USB_DeviceState == DEVICE_STATE_Suspended) {
|
while (USB_DeviceState == DEVICE_STATE_Suspended) {
|
||||||
suspend_power_down();
|
suspend_power_down();
|
||||||
|
|
|
||||||
|
|
@ -91,10 +91,11 @@ uint8_t m0110_error = 0;
|
||||||
|
|
||||||
void m0110_init(void)
|
void m0110_init(void)
|
||||||
{
|
{
|
||||||
uint8_t data;
|
|
||||||
idle();
|
idle();
|
||||||
_delay_ms(1000);
|
_delay_ms(1000);
|
||||||
|
|
||||||
|
/* Not needed to initialize in fact.
|
||||||
|
uint8_t data;
|
||||||
m0110_send(M0110_MODEL);
|
m0110_send(M0110_MODEL);
|
||||||
data = m0110_recv();
|
data = m0110_recv();
|
||||||
print("m0110_init model: "); phex(data); print("\n");
|
print("m0110_init model: "); phex(data); print("\n");
|
||||||
|
|
@ -102,6 +103,7 @@ void m0110_init(void)
|
||||||
m0110_send(M0110_TEST);
|
m0110_send(M0110_TEST);
|
||||||
data = m0110_recv();
|
data = m0110_recv();
|
||||||
print("m0110_init test: "); phex(data); print("\n");
|
print("m0110_init test: "); phex(data); print("\n");
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t m0110_send(uint8_t data)
|
uint8_t m0110_send(uint8_t data)
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue