new build method for macway
This commit is contained in:
parent
461e0d3d8c
commit
2f80e790c6
17 changed files with 432 additions and 227 deletions
|
@ -56,7 +56,8 @@ SRC = tmk.c \
|
||||||
usb_debug.c \
|
usb_debug.c \
|
||||||
usb.c \
|
usb.c \
|
||||||
jump_bootloader.c \
|
jump_bootloader.c \
|
||||||
print.c
|
print.c \
|
||||||
|
util.c
|
||||||
SRC += $(TARGET_SRC)
|
SRC += $(TARGET_SRC)
|
||||||
|
|
||||||
# C source file search path
|
# C source file search path
|
||||||
|
@ -116,17 +117,41 @@ CSTANDARD = -std=gnu99
|
||||||
|
|
||||||
|
|
||||||
# Place -D or -U options here for C sources
|
# Place -D or -U options here for C sources
|
||||||
CDEFS = -DF_CPU=$(F_CPU)UL -DDESCRIPTION=$(DESCRIPTION)
|
CDEFS = -DF_CPU=$(F_CPU)UL
|
||||||
|
CDEFS += -DDESCRIPTION=$(DESCRIPTION)
|
||||||
|
CDEFS += -DVENDOR_ID=$(VENDOR_ID)
|
||||||
|
CDEFS += -DPRODUCT_ID=$(PRODUCT_ID)
|
||||||
|
CDEFS += -DMANUFACTURER=$(MANUFACTURER)
|
||||||
|
CDEFS += -DPRODUCT=$(PRODUCT)
|
||||||
|
ifdef MOUSE_DELAY_TIME
|
||||||
|
CDEFS += -DMOUSE_DELAY_TIME=$(MOUSE_DELAY_TIME)
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
# Place -D or -U options here for ASM sources
|
# Place -D or -U options here for ASM sources
|
||||||
ADEFS = -DF_CPU=$(F_CPU) -DDESCRIPTION=$(DESCRIPTION)
|
ADEFS = -DF_CPU=$(F_CPU)
|
||||||
|
ADEFS += -DDESCRIPTION=$(DESCRIPTION)
|
||||||
|
ADEFS += -DVENDOR_ID=$(VENDOR_ID)
|
||||||
|
ADEFS += -DPRODUCT_ID=$(PRODUCT_ID)
|
||||||
|
ADEFS += -DMANUFACTURER=$(MANUFACTURER)
|
||||||
|
ADEFS += -DPRODUCT=$(PRODUCT)
|
||||||
|
ifdef MOUSE_DELAY_TIME
|
||||||
|
ADEFS += -DMOUSE_DELAY_TIME=$(MOUSE_DELAY_TIME)
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
# Place -D or -U options here for C++ sources
|
# Place -D or -U options here for C++ sources
|
||||||
CPPDEFS = -DF_CPU=$(F_CPU)UL -DDESCRIPTION=$(DESCRIPTION)
|
CPPDEFS = -DF_CPU=$(F_CPU)UL -DDESCRIPTION=$(DESCRIPTION) -DVENDOR_ID=$(VENDOR_ID) -DPRODUCT_ID=$(PRODUCT_ID)
|
||||||
#CPPDEFS += -D__STDC_LIMIT_MACROS
|
#CPPDEFS += -D__STDC_LIMIT_MACROS
|
||||||
#CPPDEFS += -D__STDC_CONSTANT_MACROS
|
#CPPDEFS += -D__STDC_CONSTANT_MACROS
|
||||||
|
CPPDEFS += -DDESCRIPTION=$(DESCRIPTION)
|
||||||
|
CPPDEFS += -DVENDOR_ID=$(VENDOR_ID)
|
||||||
|
CPPDEFS += -DPRODUCT_ID=$(PRODUCT_ID)
|
||||||
|
CPPDEFS += -DMANUFACTURER=$(MANUFACTURER)
|
||||||
|
CPPDEFS += -DPRODUCT=$(PRODUCT)
|
||||||
|
ifdef MOUSE_DELAY_TIME
|
||||||
|
CPPDEFS += -DMOUSE_DELAY_TIME=$(MOUSE_DELAY_TIME)
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
20
README
20
README
|
@ -93,21 +93,12 @@ debouncing logic
|
||||||
layer switching
|
layer switching
|
||||||
time before switching
|
time before switching
|
||||||
timeout when not used during specific time
|
timeout when not used during specific time
|
||||||
debug on/off
|
|
||||||
Fn key conbination during normal operation
|
|
||||||
matrix print on/off
|
|
||||||
key print on/off
|
|
||||||
mouse print on/off
|
|
||||||
|
|
||||||
Trackpoint(PS/2)
|
Trackpoint(PS/2)
|
||||||
receive PS/2 signal from TrackPoint
|
receive PS/2 signal from TrackPoint
|
||||||
send USB HID report
|
send USB HID report
|
||||||
Thinkpad keyboard support
|
Thinkpad keyboard support
|
||||||
turn keyboard to USB keyboard/mouse composite device
|
turn keyboard to USB keyboard/mouse composite device
|
||||||
mouse horizontal wheel
|
|
||||||
http://www.microchip.com/forums/tm.aspx?high=&m=391435&mpage=1#391521
|
|
||||||
http://www.keil.com/forum/15671/
|
|
||||||
http://www.microsoft.com/whdc/device/input/wheel.mspx
|
|
||||||
setting menu(configure without changing firmware)
|
setting menu(configure without changing firmware)
|
||||||
console for display
|
console for display
|
||||||
keymap/layer setting
|
keymap/layer setting
|
||||||
|
@ -131,6 +122,17 @@ debug on/off
|
||||||
debug off by default
|
debug off by default
|
||||||
pressing keys during booting
|
pressing keys during booting
|
||||||
2010/10/23
|
2010/10/23
|
||||||
|
mouse horizontal wheel
|
||||||
|
http://www.microchip.com/forums/tm.aspx?high=&m=391435&mpage=1#391521
|
||||||
|
http://www.keil.com/forum/15671/
|
||||||
|
http://www.microsoft.com/whdc/device/input/wheel.mspx
|
||||||
|
2010/10/13
|
||||||
|
debug on/off
|
||||||
|
Fn key conbination during normal operation
|
||||||
|
matrix print on/off
|
||||||
|
key print on/off
|
||||||
|
mouse print on/off
|
||||||
|
2010/10/26
|
||||||
|
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
|
@ -39,7 +39,13 @@
|
||||||
# To rebuild project do "make clean" then "make all".
|
# To rebuild project do "make clean" then "make all".
|
||||||
#----------------------------------------------------------------------------
|
#----------------------------------------------------------------------------
|
||||||
|
|
||||||
DESCRIPTION = 't.m.k. firmware for HHKB pro\n'
|
VENDOR_ID = 0xFEED
|
||||||
|
PRODUCT_ID = 0xCAFE
|
||||||
|
MANUFACTURER = 't.m.k.'
|
||||||
|
PRODUCT = 't.m.k. HHKB pro'
|
||||||
|
DESCRIPTION = 't.m.k. firmware for HHKB pro'
|
||||||
|
|
||||||
|
MOUSE_DELAY_TIME = 127
|
||||||
|
|
||||||
# Target file name (without extension).
|
# Target file name (without extension).
|
||||||
TARGET = tmk_hhkb
|
TARGET = tmk_hhkb
|
||||||
|
|
|
@ -1,14 +1,16 @@
|
||||||
/*
|
/*
|
||||||
* Keymap for PFU HHKB Pro
|
* Keymap for PFU HHKB Pro
|
||||||
*/
|
*/
|
||||||
|
#include <stdint.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <avr/pgmspace.h>
|
#include <avr/pgmspace.h>
|
||||||
#include "usb_keyboard.h"
|
#include "usb_keyboard.h"
|
||||||
#include "usb_keycodes.h"
|
#include "usb_keycodes.h"
|
||||||
#include "matrix.h"
|
#include "matrix.h"
|
||||||
#include "keymap.h"
|
|
||||||
#include "print.h"
|
#include "print.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
#include "util.h"
|
||||||
|
#include "keymap.h"
|
||||||
|
|
||||||
|
|
||||||
#define FN_KEYCODE(fn) (pgm_read_byte(&fn_keycode[(fn)]))
|
#define FN_KEYCODE(fn) (pgm_read_byte(&fn_keycode[(fn)]))
|
||||||
|
@ -33,9 +35,6 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int onbit(uint8_t bits);
|
|
||||||
|
|
||||||
|
|
||||||
static int current_layer = 0;
|
static int current_layer = 0;
|
||||||
static bool layer_used = false;
|
static bool layer_used = false;
|
||||||
|
|
||||||
|
@ -104,7 +103,7 @@ static const uint8_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
* |-----------------------------------------------------------|
|
* |-----------------------------------------------------------|
|
||||||
* |Shift | | | | | | | | | | |Shift | |
|
* |Shift | | | | | | | | | | |Shift | |
|
||||||
* `-----------------------------------------------------------'
|
* `-----------------------------------------------------------'
|
||||||
* |Gui|Alt |Sapce |Alt |Gui|
|
* |Gui|Alt |Space |Alt |Gui|
|
||||||
* `-------------------------------------------'
|
* `-------------------------------------------'
|
||||||
*/
|
*/
|
||||||
KEYMAP(KB_ESC, KB_F1, KB_F2, KB_F3, KB_F4, KB_F5, KB_F6, KB_F7, KB_F8, KB_F9, KB_F10, KB_F11, KB_F12, KB_INS, KB_DEL, \
|
KEYMAP(KB_ESC, KB_F1, KB_F2, KB_F3, KB_F4, KB_F5, KB_F6, KB_F7, KB_F8, KB_F9, KB_F10, KB_F11, KB_F12, KB_INS, KB_DEL, \
|
||||||
|
@ -199,7 +198,7 @@ void keymap_fn_proc(int fn_bits)
|
||||||
} else if (fn_bits == 0) {
|
} else if (fn_bits == 0) {
|
||||||
// send key when Fn key is released without using the layer
|
// send key when Fn key is released without using the layer
|
||||||
if (!layer_used) {
|
if (!layer_used) {
|
||||||
uint8_t code = FN_KEYCODE(onbit(last_bits));
|
uint8_t code = FN_KEYCODE(biton(last_bits));
|
||||||
if (code != KB_NO) {
|
if (code != KB_NO) {
|
||||||
if (IS_MOD(code)) {
|
if (IS_MOD(code)) {
|
||||||
keyboard_modifier_keys = last_mod | 1<<(code & 0x07);
|
keyboard_modifier_keys = last_mod | 1<<(code & 0x07);
|
||||||
|
@ -221,18 +220,9 @@ void keymap_fn_proc(int fn_bits)
|
||||||
last_bits = fn_bits;
|
last_bits = fn_bits;
|
||||||
last_mod = keyboard_modifier_keys;
|
last_mod = keyboard_modifier_keys;
|
||||||
layer_used = false;
|
layer_used = false;
|
||||||
keymap_set_layer(FN_LAYER(onbit(fn_bits)));
|
keymap_set_layer(FN_LAYER(biton(fn_bits)));
|
||||||
debug("layer: "); phex(current_layer); debug("(");
|
debug("layer: "); phex(current_layer); debug("(");
|
||||||
debug_bin(last_bits); debug(")\n");
|
debug_bin(last_bits); debug(")\n");
|
||||||
debug("last_mod: "); debug_hex(last_mod); debug("\n");
|
debug("last_mod: "); debug_hex(last_mod); debug("\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int onbit(uint8_t bits)
|
|
||||||
{
|
|
||||||
int n = 0;
|
|
||||||
if (bits >> 4) { bits >>= 4; n += 4;}
|
|
||||||
if (bits >> 2) { bits >>= 2; n += 2;}
|
|
||||||
if (bits >> 1) { bits >>= 1; n += 1;}
|
|
||||||
return n;
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
#ifndef KEYMAP_H
|
#ifndef KEYMAP_H
|
||||||
#define KEYMAP_H 1
|
#define KEYMAP_H 1
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <stdbool.h>
|
|
||||||
#include "usb_keycodes.h"
|
#include "usb_keycodes.h"
|
||||||
#include "keymap_skel.h"
|
#include "keymap_skel.h"
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,13 @@
|
||||||
/*
|
/*
|
||||||
* scan matrix
|
* scan matrix
|
||||||
*/
|
*/
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
#include <avr/io.h>
|
#include <avr/io.h>
|
||||||
#include <util/delay.h>
|
#include <util/delay.h>
|
||||||
#include "matrix.h"
|
#include "matrix.h"
|
||||||
#include "print.h"
|
#include "print.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
// matrix is active low. (key on: 0/key off: 1)
|
// matrix is active low. (key on: 0/key off: 1)
|
||||||
//
|
//
|
||||||
|
@ -30,10 +33,6 @@ static uint8_t _matrix0[MATRIX_ROWS];
|
||||||
static uint8_t _matrix1[MATRIX_ROWS];
|
static uint8_t _matrix1[MATRIX_ROWS];
|
||||||
|
|
||||||
|
|
||||||
static bool matrix_has_ghost_in_row(int row);
|
|
||||||
static int bit_pop(uint8_t bits);
|
|
||||||
|
|
||||||
|
|
||||||
inline
|
inline
|
||||||
int matrix_rows(void)
|
int matrix_rows(void)
|
||||||
{
|
{
|
||||||
|
@ -122,9 +121,6 @@ void matrix_print(void)
|
||||||
for (int row = 0; row < matrix_rows(); row++) {
|
for (int row = 0; row < matrix_rows(); row++) {
|
||||||
phex(row); print(": ");
|
phex(row); print(": ");
|
||||||
pbin_reverse(matrix_get_row(row));
|
pbin_reverse(matrix_get_row(row));
|
||||||
if (matrix_has_ghost_in_row(row)) {
|
|
||||||
print(" <ghost");
|
|
||||||
}
|
|
||||||
print("\n");
|
print("\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -133,22 +129,7 @@ int matrix_key_count(void)
|
||||||
{
|
{
|
||||||
int count = 0;
|
int count = 0;
|
||||||
for (int i = 0; i < MATRIX_ROWS; i++) {
|
for (int i = 0; i < MATRIX_ROWS; i++) {
|
||||||
count += bit_pop(matrix[i]);
|
count += bitpop(matrix[i]);
|
||||||
}
|
}
|
||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline
|
|
||||||
static bool matrix_has_ghost_in_row(int row)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
static int bit_pop(uint8_t bits)
|
|
||||||
{
|
|
||||||
int c;
|
|
||||||
for (c = 0; bits; c++)
|
|
||||||
bits &= bits -1;
|
|
||||||
return c;
|
|
||||||
}
|
|
||||||
|
|
|
@ -17,8 +17,11 @@
|
||||||
|
|
||||||
#define MOUSE_MOVE_UNIT 10
|
#define MOUSE_MOVE_UNIT 10
|
||||||
#define MOUSE_MOVE_ACCEL (mouse_repeat < 50 ? mouse_repeat/5 : 10)
|
#define MOUSE_MOVE_ACCEL (mouse_repeat < 50 ? mouse_repeat/5 : 10)
|
||||||
|
|
||||||
|
#ifndef MOUSE_DELAY_TIME
|
||||||
# define MOUSE_DELAY_TIME 255
|
# define MOUSE_DELAY_TIME 255
|
||||||
#define MOUSE_DELAY_MS (MOUSE_DELAY_TIME >> (mouse_repeat < 5 ? mouse_repeat : 5))
|
#endif
|
||||||
|
#define MOUSE_DELAY_MS (MOUSE_DELAY_TIME >> (mouse_repeat < 5 ? mouse_repeat : 4))
|
||||||
|
|
||||||
|
|
||||||
// TODO: refactoring
|
// TODO: refactoring
|
||||||
|
@ -157,7 +160,7 @@ void proc_matrix(void) {
|
||||||
case KB_V: // print version & information
|
case KB_V: // print version & information
|
||||||
usb_keyboard_clear();
|
usb_keyboard_clear();
|
||||||
usb_keyboard_send();
|
usb_keyboard_send();
|
||||||
print(XSTR(DESCRIPTION));
|
print(STR(DESCRIPTION) "\n");
|
||||||
_delay_ms(1000);
|
_delay_ms(1000);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,14 +39,24 @@
|
||||||
# To rebuild project do "make clean" then "make all".
|
# To rebuild project do "make clean" then "make all".
|
||||||
#----------------------------------------------------------------------------
|
#----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
VENDOR_ID = 0xFEED
|
||||||
|
PRODUCT_ID = 0xBEEF
|
||||||
|
MANUFACTURER = 't.m.k.'
|
||||||
|
PRODUCT = 't.m.k. Macway mod'
|
||||||
|
DESCRIPTION = 't.m.k. firmware for Macway mod'
|
||||||
|
|
||||||
# Target file name (without extension).
|
# Target file name (without extension).
|
||||||
TARGET = tmk_macway
|
TARGET = tmk_macway
|
||||||
|
|
||||||
|
# Directory common source filess exist
|
||||||
COMMON_DIR = ..
|
COMMON_DIR = ..
|
||||||
|
|
||||||
|
# Directory keyboard dependent files exist
|
||||||
TARGET_DIR = .
|
TARGET_DIR = .
|
||||||
TARGET_SRC = $(TARGET_DIR)/keymap.c \
|
|
||||||
$(TARGET_DIR)/matrix.c
|
# keyboard dependent files
|
||||||
|
TARGET_SRC = keymap.c \
|
||||||
|
matrix.c
|
||||||
|
|
||||||
|
|
||||||
# MCU name, you MUST set this to match the board you are using
|
# MCU name, you MUST set this to match the board you are using
|
||||||
|
|
6
macway/controller.h
Normal file
6
macway/controller.h
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
#ifndef CONTROLLER_H
|
||||||
|
#define CONTROLLER_H 1
|
||||||
|
|
||||||
|
#include "controller_teensy.h"
|
||||||
|
|
||||||
|
#endif
|
317
macway/keymap.c
317
macway/keymap.c
|
@ -1,140 +1,227 @@
|
||||||
/*
|
/*
|
||||||
* keymap for modified Macway
|
* Keymap for Macway mod
|
||||||
*/
|
*/
|
||||||
|
#include <stdint.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <avr/pgmspace.h>
|
#include <avr/pgmspace.h>
|
||||||
#include "matrix.h"
|
|
||||||
#include "keymap.h"
|
|
||||||
#include "usb_keyboard.h"
|
#include "usb_keyboard.h"
|
||||||
|
#include "usb_keycodes.h"
|
||||||
|
#include "matrix.h"
|
||||||
|
#include "print.h"
|
||||||
|
#include "debug.h"
|
||||||
|
#include "util.h"
|
||||||
|
#include "keymap.h"
|
||||||
|
|
||||||
int current_layer = 0;
|
|
||||||
bool key_sent = false;
|
|
||||||
|
|
||||||
/*
|
#define FN_KEYCODE(fn) (pgm_read_byte(&fn_keycode[(fn)]))
|
||||||
* Layer0(Default Layer)
|
#define FN_LAYER(fn) (pgm_read_byte(&fn_layer[(fn)]))
|
||||||
* ,----------------------------------------------------------.
|
#define KEYCODE(layer, row, col) (pgm_read_byte(&keymaps[(layer)][(row)][(col)]))
|
||||||
|
#define KEYMAP( \
|
||||||
|
R1C1, R1C0, R2C0, R3C0, R4C0, R4C1, R5C1, R5C0, R6C0, R7C0, R8C0, R8C1, R6C1, R0C2, \
|
||||||
|
R1C2, R1C3, R2C3, R3C3, R4C3, R4C2, R5C2, R5C3, R6C3, R7C3, R8C3, R8C2, R6C2, \
|
||||||
|
R1C5, R1C4, R2C4, R3C4, R4C4, R4C5, R5C5, R5C4, R6C4, R7C4, R8C4, R8C5, R0C6, \
|
||||||
|
R6C7, R1C6, R2C6, R3C6, R4C6, R4C7, R5C7, R5C6, R6C6, R7C6, R8C7, R3C2, R3C5, \
|
||||||
|
R7C5, R2C2, R0C0, R0C7, R2C1, R0C4, R3C7, R2C7, R1C7 \
|
||||||
|
) { \
|
||||||
|
{ R0C0, KB_NO, R0C2, KB_NO, R0C4, KB_NO, R0C6, R0C7 }, \
|
||||||
|
{ R1C0, R1C1, R1C2, R1C3, R1C4, R1C5, R1C6, R1C7 }, \
|
||||||
|
{ R2C0, R2C1, R2C2, R2C3, R2C4, KB_NO, R2C6, R2C7 }, \
|
||||||
|
{ R3C0, KB_NO, R3C2, R3C3, R3C4, R3C5, R3C6, R3C7 }, \
|
||||||
|
{ R4C0, R4C1, R4C2, R4C3, R4C4, R4C5, R4C6, R4C7 }, \
|
||||||
|
{ R5C0, R5C1, R5C2, R5C3, R5C4, R5C5, R5C6, R5C7 }, \
|
||||||
|
{ R6C0, R6C1, R6C2, R6C3, R6C4, KB_NO, R6C6, R6C7 }, \
|
||||||
|
{ R7C0, KB_NO, KB_NO, R7C3, R7C4, R7C5, R7C6, KB_NO }, \
|
||||||
|
{ R8C0, R8C1, R8C2, R8C3, R8C4, R8C5, KB_NO, R8C7 } \
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int current_layer = 0;
|
||||||
|
static bool layer_used = false;
|
||||||
|
|
||||||
|
/* layer to change into while Fn key pressed */
|
||||||
|
static const int PROGMEM fn_layer[] = { 0, 1, 2, 3, 4, 0, 2, 3 };
|
||||||
|
|
||||||
|
/* keycode to sent when Fn key released without using layer keys. */
|
||||||
|
static const uint8_t PROGMEM fn_keycode[] = {
|
||||||
|
KB_NO, // FN_0 [NOT USED]
|
||||||
|
KB_NO, // FN_1 layer 1
|
||||||
|
KB_QUOTE, // FN_2 layer 2
|
||||||
|
KB_SCOLON, // FN_3 layer 3
|
||||||
|
KB_SPACE, // FN_4 layer 4 [NOT USED]
|
||||||
|
KB_NO, // FN_5 [NOT USED]
|
||||||
|
KB_NO, // FN_6 layer 2
|
||||||
|
KB_NO // FN_7 layer 3
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
|
/* Layer 0: Default Layer
|
||||||
|
* ,-----------------------------------------------------------.
|
||||||
* |Esc| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =|Backsp |
|
* |Esc| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| =|Backsp |
|
||||||
* |----------------------------------------------------------|
|
* |-----------------------------------------------------------|
|
||||||
* |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| |
|
* |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| |
|
||||||
* |----------------------------------------------------' |
|
* |-----------------------------------------------------' |
|
||||||
* |Contr| A| S| D| F| G| H| J| K| L| ;| '|Return |
|
* |Contro| A| S| D| F| G| H| J| K| L|Fn3|Fn2|Return |
|
||||||
* |----------------------------------------------------------|
|
* |-----------------------------------------------------------|
|
||||||
* |Shift | Z| X| C| V| B| N| M| ,| .| /|Shift |Fn2|
|
* |Shift | Z| X| C| V| B| N| M| ,| .| /|Shift |Fn1|
|
||||||
* |----------------------------------------------------------|
|
* |-----------------------------------------------------------|
|
||||||
* |Fn3|Gui |Alt |Space |Fn1 |Lef|Dow|Up |Rig|
|
* |Fn7|Gui |Alt |Space |Fn6 |\ |` | | |
|
||||||
* `----------------------------------------------------------'
|
* `-----------------------------------------------------------'
|
||||||
*
|
*/
|
||||||
* Layer1(with Fn1)
|
KEYMAP(KB_ESC, KB_1, KB_2, KB_3, KB_4, KB_5, KB_6, KB_7, KB_8, KB_9, KB_0, KB_MINS,KB_EQL, KB_BSPC, \
|
||||||
* ,----------------------------------------------------------.
|
KB_TAB, KB_Q, KB_W, KB_E, KB_R, KB_T, KB_Y, KB_U, KB_I, KB_O, KB_P, KB_LBRC,KB_RBRC, \
|
||||||
* | `| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delete|
|
KB_LCTL,KB_A, KB_S, KB_D, KB_F, KB_G, KB_H, KB_J, KB_K, KB_L, FN_3, FN_2, KB_ENT, \
|
||||||
* |----------------------------------------------------------|
|
KB_LSFT,KB_Z, KB_X, KB_C, KB_V, KB_B, KB_N, KB_M, KB_COMM,KB_DOT, KB_SLSH,KB_RSFT,FN_1, \
|
||||||
* | \ | | | | | | | | | | | | | |
|
FN_7, KB_LGUI,KB_LALT,KB_SPC, FN_6, KB_BSLS,KB_GRV, KB_NO, KB_NO),
|
||||||
* |----------------------------------------------------' |
|
|
||||||
* |Contr| | | | | |Lef|Dow|Up |Rig| | | \ |
|
/* Layer 1: HHKB mode (HHKB Fn)
|
||||||
* |----------------------------------------------------------|
|
* ,-----------------------------------------------------------.
|
||||||
|
* |Pow| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delete |
|
||||||
|
* |-----------------------------------------------------------|
|
||||||
|
* |Caps | | | | | | | |Psc|Slk|Pus|Up | | |
|
||||||
|
* |-----------------------------------------------------' |
|
||||||
|
* |Contro| | | | | | *| /|Hom|PgU|Lef|Rig|Enter |
|
||||||
|
* |-----------------------------------------------------------|
|
||||||
|
* |Shift | | | | | | +| -|End|PgD|Dow|Shift |xxx|
|
||||||
|
* |-----------------------------------------------------------|
|
||||||
|
* | |Gui |Alt | |Alt | | | | |
|
||||||
|
* `-----------------------------------------------------------'
|
||||||
|
*/
|
||||||
|
KEYMAP(KB_PWR, KB_F1, KB_F2, KB_F3, KB_F4, KB_F5, KB_F6, KB_F7, KB_F8, KB_F9, KB_F10, KB_F11, KB_F12, KB_DEL, \
|
||||||
|
KB_CAPS,KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_PSCR,KB_SLCK,KB_BRK, KB_UP, KB_NO, \
|
||||||
|
KB_LCTL,KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KP_ASTR,KP_SLSH,KB_HOME,KB_PGUP,KB_LEFT,KB_RGHT,KB_ENT, \
|
||||||
|
KB_LSFT,KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KP_PLUS,KP_MINS,KB_END, KB_PGDN,KB_DOWN,KB_RSFT,FN_1, \
|
||||||
|
KB_NO, KB_LGUI,KB_LALT,KB_SPC, KB_RALT,KB_NO, KB_NO, KB_NO, KB_NO),
|
||||||
|
|
||||||
|
/* Layer 2: Vi mode (Quote/Rmeta)
|
||||||
|
* ,-----------------------------------------------------------.
|
||||||
|
* | `| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12| ` |
|
||||||
|
* |-----------------------------------------------------------|
|
||||||
|
* | \ |Hom|PgD|Up |PgU|End|Hom|PgD|PgU|End| | | | |
|
||||||
|
* |-----------------------------------------------------' |
|
||||||
|
* |Contro| |Lef|Dow|Rig| |Lef|Dow|Up |Rig| |xxx| \ |
|
||||||
|
* |-----------------------------------------------------------|
|
||||||
* |Shift | | | | | |Hom|PgD|PgU|End| |Shift | |
|
* |Shift | | | | | |Hom|PgD|PgU|End| |Shift | |
|
||||||
* |----------------------------------------------------------|
|
* |-----------------------------------------------------------|
|
||||||
* | |Gui |Alt | |Fn1 |Lef|Dow|Up |Rig|
|
* | |Gui |Alt |Space |xxxxx| | | | |
|
||||||
* `----------------------------------------------------------'
|
* `-----------------------------------------------------------'
|
||||||
*
|
*/
|
||||||
* Layer2(with Fn2)
|
KEYMAP(KB_GRV, KB_F1, KB_F2, KB_F3, KB_F4, KB_F5, KB_F6, KB_F7, KB_F8, KB_F9, KB_F10, KB_F11, KB_F12, KB_GRV, \
|
||||||
|
KB_BSLS,KB_HOME,KB_PGDN,KB_UP, KB_PGUP,KB_END, KB_HOME,KB_PGDN,KB_PGUP,KB_END, KB_NO, KB_NO, KB_NO, \
|
||||||
|
KB_LCTL,KB_NO, KB_LEFT,KB_DOWN,KB_RGHT,KB_NO, KB_LEFT,KB_DOWN,KB_UP, KB_RGHT,KB_NO, FN_2, KB_BSLS, \
|
||||||
|
KB_LSFT,KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_RSFT,KB_NO, \
|
||||||
|
KB_NO, KB_LGUI,KB_LALT,KB_SPC, FN_6, KB_NO, KB_NO, KB_NO, KB_NO),
|
||||||
|
|
||||||
|
/* Layer 3: Mouse mode (Semicolon)
|
||||||
* ,-------------------------------------------------------- --.
|
* ,-------------------------------------------------------- --.
|
||||||
* | `| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delete|
|
* |Esc| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delete |
|
||||||
* |----------------------------------------------------------|
|
* |-----------------------------------------------------------|
|
||||||
* | \ | | | | | | | | | | |Up | | |
|
* |Tab |MwL|MwU|McU|MwD|MwR|MwL|MwD|MwU|MwR| | | | |
|
||||||
* |----------------------------------------------------' |
|
* |-----------------------------------------------------' |
|
||||||
* |Contr|VoD|VoU|Mut|F20| | *| /|Hom|PgU|Lef|Rig| \ |
|
* |Contro|Mb1|Mb2|Mb3| | |McL|McD|McU|McR|xxx| |Return |
|
||||||
* |----------------------------------------------------------|
|
* |-----------------------------------------------------------|
|
||||||
* |Shift | | | | | | +| -|End|PgD|Dow|Shift |Fn2|
|
|
||||||
* |----------------------------------------------------------|
|
|
||||||
* | |Gui |Alt | | |Lef|Dow|Up |Rig|
|
|
||||||
* `----------------------------------------------------------'
|
|
||||||
*
|
|
||||||
* Layer3(with Fn3)
|
|
||||||
* ,----------------------------------------------------------.
|
|
||||||
* | `| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delete|
|
|
||||||
* |----------------------------------------------------------|
|
|
||||||
* | \ | | | | | | | | | | | | | |
|
|
||||||
* |----------------------------------------------------' |
|
|
||||||
* |Contr|Mb1|Mb2|Mb3| | |McL|McD|McU|McR| | | \ |
|
|
||||||
* |----------------------------------------------------------|
|
|
||||||
* |Shift | | | | | |MwL|MwD|MwU|MwR| |Shift | |
|
* |Shift | | | | | |MwL|MwD|MwU|MwR| |Shift | |
|
||||||
* |----------------------------------------------------------|
|
* |-----------------------------------------------------------|
|
||||||
* | |Gui |Alt |Mb1 |Mb2 |MsL|MsD|MsU|MsR|
|
* |xxx|Gui |Alt |Mb1 |Alt | | | | |
|
||||||
* `----------------------------------------------------------'
|
* `-----------------------------------------------------------'
|
||||||
* Mc: Mouse Cursor / Mb: Mouse Button / Mw: Mouse Wheel
|
* Mc: Mouse Cursor / Mb: Mouse Button / Mw: Mouse Wheel
|
||||||
*/
|
*/
|
||||||
static const uint8_t PROGMEM Keymap[][MATRIX_ROWS][MATRIX_COLS] = {
|
KEYMAP(KB_ESC, KB_F1, KB_F2, KB_F3, KB_F4, KB_F5, KB_F6, KB_F7, KB_F8, KB_F9, KB_F10, KB_F11, KB_F12, KB_DEL, \
|
||||||
// 0: default
|
KB_TAB, MS_WH_L,MS_WH_U,MS_UP, MS_WH_D,MS_WH_R,MS_WH_L,MS_WH_D,MS_WH_U,MS_WH_R,KB_NO, KB_NO, KB_NO, \
|
||||||
{
|
KB_LCTL,KB_NO, MS_LEFT,MS_DOWN,MS_RGHT,KB_NO, MS_LEFT,MS_DOWN,MS_UP, MS_RGHT,FN_3, KB_NO, KB_ENT, \
|
||||||
{ KB_LALT, KB_NO, KB_BSPACE, KB_NO, KB_LEFT, KB_NO, KB_ENTER, KB_SPACE },
|
KB_LSFT,KB_NO, MS_DOWN,KB_NO, KB_NO, KB_NO, MS_BTN2,MS_BTN1,MS_BTN2,MS_BTN3,KB_NO, KB_RSFT,KB_NO, \
|
||||||
{ KB_1, KB_ESCAPE, KB_TAB, KB_Q, KB_A, KB_LCTRL, KB_Z, KB_RIGHT },
|
FN_7, KB_LGUI,KB_LALT,MS_BTN1,KB_RALT,KB_NO, KB_NO, KB_NO, KB_NO),
|
||||||
{ KB_2, FN_1, KB_LGUI, KB_W, KB_S, KB_NO, KB_X, KB_UP },
|
|
||||||
{ KB_3, KB_NO, KB_RSHIFT, KB_E, KB_D, FN_2, KB_C, KB_DOWN },
|
/* Layer 4: Matias half keyboard style (Space)
|
||||||
{ KB_4, KB_5, KB_T, KB_R, KB_F, KB_G, KB_V, KB_B },
|
* ,-----------------------------------------------------------.
|
||||||
{ KB_7, KB_6, KB_Y, KB_U, KB_J, KB_H, KB_M, KB_N },
|
* |Esc| F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11|F12|Delete |
|
||||||
{ KB_8, KB_EQUAL, KB_RBRACKET,KB_I, KB_K, KB_NO, KB_COMMA, KB_LSHIFT },
|
* |-----------------------------------------------------------|
|
||||||
{ KB_9, KB_NO, KB_NO, KB_O, KB_L, FN_3, KB_DOT, KB_NO },
|
* |Backs| P| O| I| U| Y| T| R| E| W| Q|Tab|Tab| |
|
||||||
{ KB_0, KB_MINUS, KB_LBRACKET,KB_P, KB_SCOLON, KB_QUOTE, KB_NO, KB_SLASH }
|
* |-----------------------------------------------------' |
|
||||||
},
|
* |Contro| ;| L| K| J| H| G| F| D| S| A|Con|Control |
|
||||||
// 1: FN_1(RIGHT ALT)
|
* |-----------------------------------------------------------|
|
||||||
{
|
* |Shift | /| .| ,| M| N| B| V| C| X| Z|Shift | |
|
||||||
{ KB_LALT, KB_NO, KB_DELETE, KB_NO, KB_NO, KB_NO, KB_BSLASH,KB_NO },
|
* |-----------------------------------------------------------|
|
||||||
{ KB_F1, KB_GRAVE, KB_BSLASH, KB_NO, KB_NO, KB_LCTRL, KB_NO, KB_NO },
|
* | |Gui |Alt |xxxxxxxxxxxxxxxxxxxxxx|Alt | | | | |
|
||||||
{ KB_F2, KB_NO, KB_LGUI, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO },
|
* `-----------------------------------------------------------'
|
||||||
{ KB_F3, KB_NO, KB_RSHIFT, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO },
|
*/
|
||||||
{ KB_F4, KB_F5, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO },
|
KEYMAP(KB_MINS,KB_0, KB_9, KB_8, KB_7, KB_6, KB_5, KB_4, KB_3, KB_2, KB_1, KB_NO, KB_NO, KB_ESC, \
|
||||||
{ KB_F7, KB_F6, KB_NO, KB_NO, KB_DOWN, KB_LEFT, KB_PGDOWN,KB_HOME },
|
KB_BSPC,KB_P, KB_O, KB_I, KB_U, KB_Y, KB_T, KB_R, KB_E, KB_W, KB_Q, KB_TAB, KB_TAB, \
|
||||||
{ KB_F8, KB_F12, KB_NO, KB_NO, KB_UP, KB_NO, KB_PGUP, KB_LSHIFT },
|
KB_LCTL,KB_SCLN,KB_L, KB_K, KB_J, KB_H, KB_G, KB_F, KB_D, KB_S, KB_A, KB_RCTL,KB_RCTL, \
|
||||||
{ KB_F9, KB_NO, KB_NO, KB_NO, KB_RIGHT, KB_NO, KB_END, KB_NO },
|
KB_LSFT,KB_SLSH,KB_DOT, KB_COMM,KB_M, KB_N, KB_B, KB_V, KB_C, KB_X, KB_Z, KB_RSFT,KB_NO, \
|
||||||
{ KB_F10, KB_F11, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO }
|
KB_NO, KB_LGUI,KB_LALT,FN_4, KB_RALT,KB_NO, KB_NO, KB_NO, KB_NO),
|
||||||
},
|
|
||||||
// 2: FN_2(HHKB Fn)
|
|
||||||
{
|
|
||||||
{ KB_LALT, KB_NO, KB_DELETE, KB_NO, KB_NO, KB_NO, KB_BSLASH,KB_NO },
|
|
||||||
{ KB_F1, KB_GRAVE, KB_BSLASH, KB_NO, KB_VOLDOWN,KB_LCTRL, KB_NO, KB_NO },
|
|
||||||
{ KB_F2, KB_NO, KB_LGUI, KB_NO, KB_VOLUP, KB_NO, KB_NO, KB_NO },
|
|
||||||
{ KB_F3, KB_NO, KB_RSHIFT, KB_NO, KB_MUTE, KB_NO, KB_NO, KB_NO },
|
|
||||||
{ KB_F4, KB_F5, KB_NO, KB_NO, KB_F20, KB_NO, KB_NO, KB_NO },
|
|
||||||
{ KB_F7, KB_F6, KB_NO, KB_NO, KP_SLASH, KP_ASTERISK,KP_MINUS, KP_PLUS },
|
|
||||||
{ KB_F8, KB_F12, KB_NO, KB_NO, KB_HOME, KB_NO, KB_END, KB_LSHIFT },
|
|
||||||
{ KB_F9, KB_NO, KB_NO, KB_NO, KB_PGUP, KB_NO, KB_PGDOWN,KB_NO },
|
|
||||||
{ KB_F10, KB_F11, KB_UP, KB_NO, KB_LEFT, KB_RIGHT, KB_NO, KB_DOWN }
|
|
||||||
},
|
|
||||||
// 3: FN_3(LEFT Bottom)
|
|
||||||
{
|
|
||||||
{ KB_LALT, KB_NO, KB_DELETE, KB_NO, MS_LEFT, KB_NO, KB_BSLASH, MS_BTN1 },
|
|
||||||
{ KB_F1, KB_GRAVE, KB_BSLASH, KB_NO, MS_BTN1, KB_LCTRL, KB_NO, MS_RIGHT },
|
|
||||||
{ KB_F2, MS_BTN2, KB_LGUI, KB_NO, MS_BTN2, KB_NO, KB_NO, MS_UP },
|
|
||||||
{ KB_F3, KB_NO, KB_RSHIFT, KB_NO, MS_BTN3, KB_NO, KB_NO, MS_DOWN },
|
|
||||||
{ KB_F4, KB_F5, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO },
|
|
||||||
{ KB_F7, KB_F6, KB_NO, KB_NO, MS_DOWN, MS_LEFT, MS_WH_UP, MS_WH_LEFT },
|
|
||||||
{ KB_F8, KB_F12, MS_BTN5, KB_NO, MS_UP, KB_NO, MS_WH_DOWN, KB_LSHIFT },
|
|
||||||
{ KB_F9, KB_NO, KB_NO, KB_NO, MS_RIGHT, KB_NO, MS_WH_RIGHT,KB_NO },
|
|
||||||
{ KB_F10, KB_F11, MS_BTN4, KB_NO, KB_NO, KB_NO, KB_NO, KB_NO }
|
|
||||||
},
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
uint8_t get_keycode(int layer, int row, int col)
|
uint8_t keymap_get_keycode(int row, int col)
|
||||||
{
|
{
|
||||||
if (row >= MATRIX_ROWS)
|
return keymap_get_keycodel(current_layer, row, col);
|
||||||
return KB_NO;
|
|
||||||
if (col >= MATRIX_COLS)
|
|
||||||
return KB_NO;
|
|
||||||
return pgm_read_byte(&Keymap[layer][row][col]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int get_layer(void) {
|
uint8_t keymap_get_keycodel(int layer, int row, int col)
|
||||||
int layer = 0;
|
{
|
||||||
for (int row = 0; row < MATRIX_ROWS; row++) {
|
uint8_t code = KEYCODE(layer, row, col);
|
||||||
for (int col = 0; col < MATRIX_ROWS; col++) {
|
// normal key or mouse key
|
||||||
if (matrix[row] & 1<<col) continue;
|
if (IS_KEY(code) || IS_MOUSE(code))
|
||||||
if (get_keycode(0, row, col) == FN_1) layer = 1;
|
layer_used = true;
|
||||||
if (get_keycode(0, row, col) == FN_2) layer = 2;
|
return code;
|
||||||
if (get_keycode(0, row, col) == FN_3) layer = 3;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
int keymap_get_layer(void)
|
||||||
|
{
|
||||||
|
return current_layer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
int keymap_set_layer(int layer)
|
||||||
|
{
|
||||||
current_layer = layer;
|
current_layer = layer;
|
||||||
return current_layer;
|
return current_layer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
bool keymap_is_special_mode(int fn_bits)
|
||||||
|
{
|
||||||
|
return (keyboard_modifier_keys == (BIT_LCTRL | BIT_LSHIFT | BIT_LALT | BIT_LGUI));
|
||||||
|
}
|
||||||
|
|
||||||
|
void keymap_fn_proc(int fn_bits)
|
||||||
|
{
|
||||||
|
// layer switching
|
||||||
|
static int last_bits = 0;
|
||||||
|
static uint8_t last_mod = 0;
|
||||||
|
|
||||||
|
if (usb_keyboard_has_key() || fn_bits == last_bits) {
|
||||||
|
// do nothing during press other than Fn key
|
||||||
|
return;
|
||||||
|
} else if (fn_bits == 0) {
|
||||||
|
// send key when Fn key is released without using the layer
|
||||||
|
if (!layer_used) {
|
||||||
|
uint8_t code = FN_KEYCODE(biton(last_bits));
|
||||||
|
if (code != KB_NO) {
|
||||||
|
if (IS_MOD(code)) {
|
||||||
|
keyboard_modifier_keys = last_mod | 1<<(code & 0x07);
|
||||||
|
} else {
|
||||||
|
keyboard_keys[0] = code;
|
||||||
|
keyboard_modifier_keys = last_mod;
|
||||||
|
}
|
||||||
|
usb_keyboard_send();
|
||||||
|
usb_keyboard_print();
|
||||||
|
usb_keyboard_clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
last_bits = 0;
|
||||||
|
last_mod = 0;
|
||||||
|
layer_used = false;
|
||||||
|
keymap_set_layer(0); // default layer
|
||||||
|
} else if ((fn_bits & (fn_bits - 1)) == 0) {
|
||||||
|
// switch layer when just one Fn Key is pressed
|
||||||
|
last_bits = fn_bits;
|
||||||
|
last_mod = keyboard_modifier_keys;
|
||||||
|
layer_used = false;
|
||||||
|
keymap_set_layer(FN_LAYER(biton(fn_bits)));
|
||||||
|
debug("layer: "); phex(current_layer); debug("(");
|
||||||
|
debug_bin(last_bits); debug(")\n");
|
||||||
|
debug("last_mod: "); debug_hex(last_mod); debug("\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -1,20 +1,7 @@
|
||||||
#ifndef KEYMAP_H
|
#ifndef KEYMAP_H
|
||||||
#define KEYMAP_H 1
|
#define KEYMAP_H 1
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <stdbool.h>
|
|
||||||
#include "usb_keycodes.h"
|
#include "usb_keycodes.h"
|
||||||
|
#include "keymap_skel.h"
|
||||||
|
|
||||||
#define MATRIX_ROWS 9
|
|
||||||
#define MATRIX_COLS 8
|
|
||||||
|
|
||||||
|
|
||||||
extern int current_layer;
|
|
||||||
extern bool key_sent;
|
|
||||||
|
|
||||||
|
|
||||||
int get_layer(void);
|
|
||||||
uint8_t get_keycode(int layer, int row, int col);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,10 +1,13 @@
|
||||||
/*
|
/*
|
||||||
* scan matrix
|
* scan matrix
|
||||||
*/
|
*/
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
#include <avr/io.h>
|
#include <avr/io.h>
|
||||||
#include <util/delay.h>
|
#include <util/delay.h>
|
||||||
#include "keymap.h"
|
|
||||||
#include "matrix.h"
|
#include "matrix.h"
|
||||||
|
#include "print.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
// matrix is active low. (key on: 0/key off: 1)
|
// matrix is active low. (key on: 0/key off: 1)
|
||||||
// row: Hi-Z(unselected)/low output(selected)
|
// row: Hi-Z(unselected)/low output(selected)
|
||||||
|
@ -18,11 +21,24 @@ uint8_t *matrix_prev;
|
||||||
static uint8_t _matrix0[MATRIX_ROWS];
|
static uint8_t _matrix0[MATRIX_ROWS];
|
||||||
static uint8_t _matrix1[MATRIX_ROWS];
|
static uint8_t _matrix1[MATRIX_ROWS];
|
||||||
|
|
||||||
|
static bool matrix_has_ghost_in_row(uint8_t row);
|
||||||
static uint8_t read_col(void);
|
static uint8_t read_col(void);
|
||||||
static void unselect_rows(void);
|
static void unselect_rows(void);
|
||||||
static void select_row(uint8_t row);
|
static void select_row(uint8_t row);
|
||||||
|
|
||||||
|
|
||||||
|
inline
|
||||||
|
int matrix_rows(void)
|
||||||
|
{
|
||||||
|
return MATRIX_ROWS;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
int matrix_cols(void)
|
||||||
|
{
|
||||||
|
return MATRIX_COLS;
|
||||||
|
}
|
||||||
|
|
||||||
// this must be called once before matrix_scan.
|
// this must be called once before matrix_scan.
|
||||||
void matrix_init(void)
|
void matrix_init(void)
|
||||||
{
|
{
|
||||||
|
@ -32,33 +48,31 @@ void matrix_init(void)
|
||||||
PORTB = 0xFF;
|
PORTB = 0xFF;
|
||||||
|
|
||||||
// initialize matrix state: all keys off
|
// initialize matrix state: all keys off
|
||||||
for (int i=0; i < MATRIX_ROWS; i++) _matrix0[i] = 0xFF;
|
for (int i=0; i < MATRIX_ROWS; i++) _matrix0[i] = 0x00;
|
||||||
for (int i=0; i < MATRIX_ROWS; i++) _matrix1[i] = 0xFF;
|
for (int i=0; i < MATRIX_ROWS; i++) _matrix1[i] = 0x00;
|
||||||
matrix = _matrix0;
|
matrix = _matrix0;
|
||||||
matrix_prev = _matrix1;
|
matrix_prev = _matrix1;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t matrix_scan(void)
|
int matrix_scan(void)
|
||||||
{
|
{
|
||||||
uint8_t row, state;
|
|
||||||
uint8_t *tmp;
|
uint8_t *tmp;
|
||||||
|
|
||||||
tmp = matrix_prev;
|
tmp = matrix_prev;
|
||||||
matrix_prev = matrix;
|
matrix_prev = matrix;
|
||||||
matrix = tmp;
|
matrix = tmp;
|
||||||
|
|
||||||
for (row = 0; row < MATRIX_ROWS; row++) {
|
for (int i = 0; i < MATRIX_ROWS; i++) {
|
||||||
select_row(row);
|
select_row(i);
|
||||||
_delay_us(30); // without this wait read unstable value.
|
_delay_us(30); // without this wait read unstable value.
|
||||||
state = read_col();
|
matrix[i] = ~read_col();
|
||||||
unselect_rows();
|
unselect_rows();
|
||||||
|
|
||||||
matrix[row] = state;
|
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool matrix_is_modified(void) {
|
bool matrix_is_modified(void)
|
||||||
|
{
|
||||||
for (int i = 0; i < MATRIX_ROWS; i++) {
|
for (int i = 0; i < MATRIX_ROWS; i++) {
|
||||||
if (matrix[i] != matrix_prev[i])
|
if (matrix[i] != matrix_prev[i])
|
||||||
return true;
|
return true;
|
||||||
|
@ -66,7 +80,8 @@ bool matrix_is_modified(void) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool matrix_has_ghost(void) {
|
bool matrix_has_ghost(void)
|
||||||
|
{
|
||||||
for (int i = 0; i < MATRIX_ROWS; i++) {
|
for (int i = 0; i < MATRIX_ROWS; i++) {
|
||||||
if (matrix_has_ghost_in_row(i))
|
if (matrix_has_ghost_in_row(i))
|
||||||
return true;
|
return true;
|
||||||
|
@ -74,16 +89,50 @@ bool matrix_has_ghost(void) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool matrix_has_ghost_in_row(uint8_t row) {
|
inline
|
||||||
uint8_t state = ~matrix[row];
|
bool matrix_is_on(int row, int col)
|
||||||
|
{
|
||||||
|
return (matrix[row] & (1<<col));
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
uint16_t matrix_get_row(int row)
|
||||||
|
{
|
||||||
|
return matrix[row];
|
||||||
|
}
|
||||||
|
|
||||||
|
void matrix_print(void)
|
||||||
|
{
|
||||||
|
print("\nr/c 01234567\n");
|
||||||
|
for (int row = 0; row < matrix_rows(); row++) {
|
||||||
|
phex(row); print(": ");
|
||||||
|
pbin_reverse(matrix_get_row(row));
|
||||||
|
if (matrix_has_ghost_in_row(row)) {
|
||||||
|
print(" <ghost");
|
||||||
|
}
|
||||||
|
print("\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int matrix_key_count(void)
|
||||||
|
{
|
||||||
|
int count = 0;
|
||||||
|
for (int i = 0; i < MATRIX_ROWS; i++) {
|
||||||
|
count += bitpop(matrix[i]);
|
||||||
|
}
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool matrix_has_ghost_in_row(uint8_t row)
|
||||||
|
{
|
||||||
// no ghost exists in case less than 2 keys on
|
// no ghost exists in case less than 2 keys on
|
||||||
if (((state - 1) & state) == 0)
|
if (((matrix[row] - 1) & matrix[row]) == 0)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// ghost exists in case same state as other row
|
// ghost exists in case same state as other row
|
||||||
for (int i=0; i < MATRIX_ROWS; i++) {
|
for (int i=0; i < MATRIX_ROWS; i++) {
|
||||||
if (i == row) continue;
|
if (i != row && (matrix[i] & matrix[row]) == matrix[row])
|
||||||
if ((~matrix[i] & state) == state) return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -93,7 +142,8 @@ static uint8_t read_col(void)
|
||||||
return PINB;
|
return PINB;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void unselect_rows(void) {
|
static void unselect_rows(void)
|
||||||
|
{
|
||||||
DDRD = 0x00;
|
DDRD = 0x00;
|
||||||
PORTD = 0x00;
|
PORTD = 0x00;
|
||||||
DDRC = 0x00;
|
DDRC = 0x00;
|
||||||
|
|
15
macway/matrix.h
Normal file
15
macway/matrix.h
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
#ifndef MATRIX_H
|
||||||
|
#define MATRIX_H 1
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include "matrix_skel.h"
|
||||||
|
|
||||||
|
|
||||||
|
#define MATRIX_ROWS 9
|
||||||
|
#define MATRIX_COLS 8
|
||||||
|
|
||||||
|
|
||||||
|
extern uint8_t *matrix;
|
||||||
|
extern uint8_t *matrix_prev;
|
||||||
|
|
||||||
|
#endif
|
9
tmk.c
9
tmk.c
|
@ -69,8 +69,11 @@ int main(void)
|
||||||
|
|
||||||
matrix_init();
|
matrix_init();
|
||||||
matrix_scan();
|
matrix_scan();
|
||||||
// debug on by pressing down any 4 keys during boot time.
|
// debug on by pressing down any 4 or more keys during boot time.
|
||||||
if (matrix_key_count() == 4) print_enable = true;
|
if (matrix_key_count() >= 4) {
|
||||||
|
print_enable = true;
|
||||||
|
debug_enable = true;
|
||||||
|
}
|
||||||
|
|
||||||
/* wait for debug pipe ready */
|
/* wait for debug pipe ready */
|
||||||
if (print_enable) {
|
if (print_enable) {
|
||||||
|
@ -87,7 +90,7 @@ int main(void)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
// print description
|
// print description
|
||||||
print(XSTR(DESCRIPTION));
|
print(STR(DESCRIPTION) "\n");
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
proc_matrix();
|
proc_matrix();
|
||||||
|
|
16
usb.c
16
usb.c
|
@ -29,6 +29,7 @@
|
||||||
#include "usb_mouse.h"
|
#include "usb_mouse.h"
|
||||||
#include "usb_debug.h"
|
#include "usb_debug.h"
|
||||||
#include "print.h"
|
#include "print.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
|
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
|
@ -38,16 +39,29 @@
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
// You can change these to give your code its own name.
|
// You can change these to give your code its own name.
|
||||||
|
#ifndef MANUFACTURER
|
||||||
# define STR_MANUFACTURER L"t.m.k."
|
# define STR_MANUFACTURER L"t.m.k."
|
||||||
|
#else
|
||||||
|
# define STR_MANUFACTURER LSTR(MANUFACTURER)
|
||||||
|
#endif
|
||||||
|
#ifndef PRODUCT
|
||||||
# define STR_PRODUCT L"t.m.k. keyboard"
|
# define STR_PRODUCT L"t.m.k. keyboard"
|
||||||
|
#else
|
||||||
|
# define STR_PRODUCT LSTR(PRODUCT)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
// Mac OS-X and Linux automatically load the correct drivers. On
|
// Mac OS-X and Linux automatically load the correct drivers. On
|
||||||
// Windows, even though the driver is supplied by Microsoft, an
|
// Windows, even though the driver is supplied by Microsoft, an
|
||||||
// INF file is needed to load the driver. These numbers need to
|
// INF file is needed to load the driver. These numbers need to
|
||||||
// match the INF file.
|
// match the INF file.
|
||||||
|
#ifndef VENDOR_ID
|
||||||
# define VENDOR_ID 0xFEED
|
# define VENDOR_ID 0xFEED
|
||||||
#define PRODUCT_ID 0xCAFE
|
#endif
|
||||||
|
|
||||||
|
#ifndef PRODUCT_ID
|
||||||
|
# define PRODUCT_ID 0xBABE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
// USB devices are supposed to implment a halt feature, which is
|
// USB devices are supposed to implment a halt feature, which is
|
||||||
|
|
18
util.c
Normal file
18
util.c
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
|
int bitpop(uint8_t bits)
|
||||||
|
{
|
||||||
|
int c;
|
||||||
|
for (c = 0; bits; c++)
|
||||||
|
bits &= bits -1;
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
|
int biton(uint8_t bits)
|
||||||
|
{
|
||||||
|
int n = 0;
|
||||||
|
if (bits >> 4) { bits >>= 4; n += 4;}
|
||||||
|
if (bits >> 2) { bits >>= 2; n += 2;}
|
||||||
|
if (bits >> 1) { bits >>= 1; n += 1;}
|
||||||
|
return n;
|
||||||
|
}
|
14
util.h
14
util.h
|
@ -1,7 +1,17 @@
|
||||||
#ifndef UTIL_H
|
#ifndef UTIL_H
|
||||||
#define UTIL_H 1
|
#define UTIL_H 1
|
||||||
|
|
||||||
#define XSTR(s) STR(s)
|
#include <stdint.h>
|
||||||
#define STR(s) #s
|
|
||||||
|
// convert to L string
|
||||||
|
#define LSTR(s) XLSTR(s)
|
||||||
|
#define XLSTR(s) L ## #s
|
||||||
|
// convert to string
|
||||||
|
#define STR(s) XSTR(s)
|
||||||
|
#define XSTR(s) #s
|
||||||
|
|
||||||
|
|
||||||
|
int bitpop(uint8_t bits);
|
||||||
|
int biton(uint8_t bits);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue