diff options
| -rw-r--r-- | keyboards/org60/Makefile | 3 | ||||
| -rw-r--r-- | keyboards/org60/config.h | 82 | ||||
| -rw-r--r-- | keyboards/org60/keymaps/base/keymap.c (renamed from keyboards/xd60/keymaps/BASE/keymap.c) | 0 | ||||
| -rw-r--r-- | keyboards/org60/keymaps/base/readme.md (renamed from keyboards/xd60/keymaps/BASE/readme.md) | 0 | ||||
| -rw-r--r-- | keyboards/org60/org60.c | 19 | ||||
| -rw-r--r-- | keyboards/org60/org60.h | 37 | ||||
| -rw-r--r-- | keyboards/org60/readme.md | 21 | ||||
| -rw-r--r-- | keyboards/org60/rules.mk | 64 | ||||
| -rw-r--r-- | keyboards/xd60/keymaps/base/keymap.c | 46 | ||||
| -rw-r--r-- | keyboards/xd60/keymaps/base/readme.md | 5 |
10 files changed, 226 insertions, 51 deletions
diff --git a/keyboards/org60/Makefile b/keyboards/org60/Makefile new file mode 100644 index 000000000..57b2ef62e --- /dev/null +++ b/keyboards/org60/Makefile | |||
| @@ -0,0 +1,3 @@ | |||
| 1 | ifndef MAKEFILE_INCLUDED | ||
| 2 | include ../../Makefile | ||
| 3 | endif | ||
diff --git a/keyboards/org60/config.h b/keyboards/org60/config.h new file mode 100644 index 000000000..62b3b69a0 --- /dev/null +++ b/keyboards/org60/config.h | |||
| @@ -0,0 +1,82 @@ | |||
| 1 | /* | ||
| 2 | Copyright 2012 Jun Wako <wakojun@gmail.com> | ||
| 3 | |||
| 4 | This program is free software: you can redistribute it and/or modify | ||
| 5 | it under the terms of the GNU General Public License as published by | ||
| 6 | the Free Software Foundation, either version 2 of the License, or | ||
| 7 | (at your option) any later version. | ||
| 8 | |||
| 9 | This program is distributed in the hope that it will be useful, | ||
| 10 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 11 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 12 | GNU General Public License for more details. | ||
| 13 | |||
| 14 | You should have received a copy of the GNU General Public License | ||
| 15 | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
| 16 | */ | ||
| 17 | |||
| 18 | #ifndef CONFIG_H | ||
| 19 | #define CONFIG_H | ||
| 20 | |||
| 21 | #include "config_common.h" | ||
| 22 | |||
| 23 | /* USB Device descriptor parameter */ | ||
| 24 | #define VENDOR_ID 0xFEED | ||
| 25 | #define PRODUCT_ID 0x6060 | ||
| 26 | #define DEVICE_VER 0x0001 | ||
| 27 | #define MANUFACTURER 大橘子外设 (Large orange peripherals) | ||
| 28 | #define PRODUCT Org60 | ||
| 29 | #define DESCRIPTION Org60 Keyboard PCB by 大橘子外设 (Large orange peripherals) | ||
| 30 | |||
| 31 | /* key matrix size */ | ||
| 32 | #define MATRIX_ROWS 5 | ||
| 33 | #define MATRIX_COLS 14 | ||
| 34 | |||
| 35 | /* | ||
| 36 | * Keyboard Matrix Assignments | ||
| 37 | * | ||
| 38 | * Change this to how you wired your keyboard | ||
| 39 | * COLS: AVR pins used for columns, left to right | ||
| 40 | * ROWS: AVR pins used for rows, top to bottom | ||
| 41 | * DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode) | ||
| 42 | * ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode) | ||
| 43 | * | ||
| 44 | */ | ||
| 45 | #define MATRIX_ROW_PINS { D0, D1, D2, D3, D5 } | ||
| 46 | #define MATRIX_COL_PINS { F0, F1, E6, C7, C6, B6, D4, B1, B7, B5, B4, D7, D6, B3 } | ||
| 47 | #define UNUSED_PINS | ||
| 48 | |||
| 49 | /* Backlight Setup */ | ||
| 50 | #define BACKLIGHT_PIN F5 | ||
| 51 | #define BACKLIGHT_LEVELS 6 | ||
| 52 | //#define BACKLIGHT_BREATHING | ||
| 53 | |||
| 54 | /* COL2ROW or ROW2COL */ | ||
| 55 | #define DIODE_DIRECTION COL2ROW | ||
| 56 | |||
| 57 | /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ | ||
| 58 | #define DEBOUNCING_DELAY 5 | ||
| 59 | |||
| 60 | /* RGB Underglow | ||
| 61 | * F6 PIN for Org60 that has pre-soldered WS2812 LEDs | ||
| 62 | */ | ||
| 63 | #define RGB_DI_PIN F6 | ||
| 64 | #define RGBLIGHT_ANIMATIONS | ||
| 65 | #define RGBLED_NUM 20 // Number of LEDs | ||
| 66 | #define RGBLIGHT_HUE_STEP 10 | ||
| 67 | #define RGBLIGHT_SAT_STEP 17 | ||
| 68 | #define RGBLIGHT_VAL_STEP 17 | ||
| 69 | |||
| 70 | /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ | ||
| 71 | #define LOCKING_SUPPORT_ENABLE | ||
| 72 | /* Locking resynchronize hack */ | ||
| 73 | #define LOCKING_RESYNC_ENABLE | ||
| 74 | |||
| 75 | /* key combination for magic key command */ | ||
| 76 | #define IS_COMMAND() ( \ | ||
| 77 | keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \ | ||
| 78 | ) | ||
| 79 | |||
| 80 | #define TAPPING_TERM 200 | ||
| 81 | |||
| 82 | #endif | ||
diff --git a/keyboards/xd60/keymaps/BASE/keymap.c b/keyboards/org60/keymaps/base/keymap.c index b3ccd5e58..b3ccd5e58 100644 --- a/keyboards/xd60/keymaps/BASE/keymap.c +++ b/keyboards/org60/keymaps/base/keymap.c | |||
diff --git a/keyboards/xd60/keymaps/BASE/readme.md b/keyboards/org60/keymaps/base/readme.md index 89f9acaa9..89f9acaa9 100644 --- a/keyboards/xd60/keymaps/BASE/readme.md +++ b/keyboards/org60/keymaps/base/readme.md | |||
diff --git a/keyboards/org60/org60.c b/keyboards/org60/org60.c new file mode 100644 index 000000000..77a5e7c18 --- /dev/null +++ b/keyboards/org60/org60.c | |||
| @@ -0,0 +1,19 @@ | |||
| 1 | #include "org60.h" | ||
| 2 | |||
| 3 | |||
| 4 | extern inline void org60_caps_led_on(void); | ||
| 5 | extern inline void org60_bl_led_on(void); | ||
| 6 | |||
| 7 | extern inline void org60_caps_led_off(void); | ||
| 8 | extern inline void org60_bl_led_off(void); | ||
| 9 | |||
| 10 | |||
| 11 | void led_set_kb(uint8_t usb_led) { | ||
| 12 | if (usb_led & (1<<USB_LED_CAPS_LOCK)) { | ||
| 13 | org60_caps_led_on(); | ||
| 14 | } else { | ||
| 15 | org60_caps_led_off(); | ||
| 16 | } | ||
| 17 | |||
| 18 | led_set_user(usb_led); | ||
| 19 | } | ||
diff --git a/keyboards/org60/org60.h b/keyboards/org60/org60.h new file mode 100644 index 000000000..7c1004342 --- /dev/null +++ b/keyboards/org60/org60.h | |||
| @@ -0,0 +1,37 @@ | |||
| 1 | #ifndef Org60_H | ||
| 2 | #define Org60_H | ||
| 3 | |||
| 4 | #include "quantum.h" | ||
| 5 | #include "led.h" | ||
| 6 | |||
| 7 | /* Org60 LEDs | ||
| 8 | * GPIO pads | ||
| 9 | * 0 F7 not connected | ||
| 10 | * 1 F6 RGB PWM Underglow | ||
| 11 | * 2 F5 Backlight LED | ||
| 12 | * 3 F4 not connected | ||
| 13 | * B2 Capslock LED | ||
| 14 | * B0 not connected | ||
| 15 | */ | ||
| 16 | inline void org60_caps_led_on(void) { DDRB |= (1<<2); PORTB &= ~(1<<2); } | ||
| 17 | inline void org60_bl_led_on(void) { DDRF |= (1<<5); PORTF &= ~(1<<5); } | ||
| 18 | |||
| 19 | inline void org60_caps_led_off(void) { DDRB &= ~(1<<2); PORTB &= ~(1<<2); } | ||
| 20 | inline void org60_bl_led_off(void) { DDRF &= ~(1<<5); PORTF &= ~(1<<5); } | ||
| 21 | |||
| 22 | /* Org60 Keymap Definition Macro */ | ||
| 23 | #define KEYMAP( \ | ||
| 24 | K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K49, \ | ||
| 25 | K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, \ | ||
| 26 | K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K2D, \ | ||
| 27 | K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K47, K3D, K3C, \ | ||
| 28 | K40, K41, K42, K45, K4A, K4B, K48, K4C, K4D \ | ||
| 29 | ) { \ | ||
| 30 | { K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D }, \ | ||
| 31 | { K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D }, \ | ||
| 32 | { K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, K2D }, \ | ||
| 33 | { K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3C, K3D }, \ | ||
| 34 | { K40, K41, K42, KC_NO,KC_NO,K45, KC_NO,K47, K48, K49, K4A, K4B, K4C, K4D } \ | ||
| 35 | } | ||
| 36 | |||
| 37 | #endif | ||
diff --git a/keyboards/org60/readme.md b/keyboards/org60/readme.md new file mode 100644 index 000000000..8e02a4021 --- /dev/null +++ b/keyboards/org60/readme.md | |||
| @@ -0,0 +1,21 @@ | |||
| 1 | # QMK Firmware for 大橘子外设 (Large Orange Peripheral)'s 60% Org60 PCB | ||
| 2 | |||
| 3 |  | ||
| 4 | |||
| 5 | |||
| 6 | ## Quantum MK Firmware | ||
| 7 | For the full Quantum feature list, see [the parent readme.md](/readme.md). | ||
| 8 | |||
| 9 | |||
| 10 | ## Additional Notes | ||
| 11 | The Org60 seems to be a variant of the XD60 (which is essentially a GH60 rev. C, with support for a right-hand arrow cluster), which has USB-C and built-in RGB underlighting. | ||
| 12 | |||
| 13 | Compatibility with GH60 expansion boards is unknown. | ||
| 14 | |||
| 15 | Board also supports in-switch LEDs (two-pin, single colour), as well as WS2182 LED strips for underglow lighting. | ||
| 16 | |||
| 17 | Default keymap included, matching configuration on sale page. | ||
| 18 | |||
| 19 | |||
| 20 | ## Build | ||
| 21 | To build the default keymap, simply run `make org60-default`. \ No newline at end of file | ||
diff --git a/keyboards/org60/rules.mk b/keyboards/org60/rules.mk new file mode 100644 index 000000000..566ac0cb8 --- /dev/null +++ b/keyboards/org60/rules.mk | |||
| @@ -0,0 +1,64 @@ | |||
| 1 | # MCU name | ||
| 2 | MCU = atmega32u4 | ||
| 3 | |||
| 4 | |||
| 5 | # Processor frequency. | ||
| 6 | # This will define a symbol, F_CPU, in all source code files equal to the | ||
| 7 | # processor frequency in Hz. You can then use this symbol in your source code to | ||
| 8 | # calculate timings. Do NOT tack on a 'UL' at the end, this will be done | ||
| 9 | # automatically to create a 32-bit value in your source code. | ||
| 10 | # | ||
| 11 | # This will be an integer division of F_USB below, as it is sourced by | ||
| 12 | # F_USB after it has run through any CPU prescalers. Note that this value | ||
| 13 | # does not *change* the processor frequency - it should merely be updated to | ||
| 14 | # reflect the processor speed set externally so that the code can use accurate | ||
| 15 | # software delays. | ||
| 16 | F_CPU = 16000000 | ||
| 17 | |||
| 18 | |||
| 19 | # LUFA specific | ||
| 20 | # Target architecture (see library "Board Types" documentation). | ||
| 21 | ARCH = AVR8 | ||
| 22 | |||
| 23 | |||
| 24 | # Input clock frequency. | ||
| 25 | # This will define a symbol, F_USB, in all source code files equal to the | ||
| 26 | # input clock frequency (before any prescaling is performed) in Hz. This value may | ||
| 27 | # differ from F_CPU if prescaling is used on the latter, and is required as the | ||
| 28 | # raw input clock is fed directly to the PLL sections of the AVR for high speed | ||
| 29 | # clock generation for the USB and other AVR subsections. Do NOT tack on a 'UL' | ||
| 30 | # at the end, this will be done automatically to create a 32-bit value in your | ||
| 31 | # source code. | ||
| 32 | # | ||
| 33 | # If no clock division is performed on the input clock inside the AVR (via the | ||
| 34 | # CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU. | ||
| 35 | F_USB = $(F_CPU) | ||
| 36 | |||
| 37 | |||
| 38 | # Interrupt driven control endpoint task(+60) | ||
| 39 | OPT_DEFS += -DINTERRUPT_CONTROL_ENDPOINT | ||
| 40 | |||
| 41 | |||
| 42 | # Boot Section Size in *bytes* | ||
| 43 | # Teensy halfKay 512 | ||
| 44 | # Teensy++ halfKay 1024 | ||
| 45 | # Atmel DFU loader 4096 | ||
| 46 | # LUFA bootloader 4096 | ||
| 47 | # USBaspLoader 2048 | ||
| 48 | OPT_DEFS += -DBOOTLOADER_SIZE=4096 | ||
| 49 | |||
| 50 | |||
| 51 | # Build Options | ||
| 52 | AUDIO_ENABLE = no # Audio output on port C6 | ||
| 53 | BACKLIGHT_ENABLE = yes # Enable keyboard backlight functionality | ||
| 54 | BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID | ||
| 55 | BOOTMAGIC_ENABLE = yes # Virtual DIP switch configuration(+1000) | ||
| 56 | COMMAND_ENABLE = no # Commands for debug and configuration | ||
| 57 | CONSOLE_ENABLE = no # Console for debug(+400) | ||
| 58 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) | ||
| 59 | MIDI_ENABLE = no # MIDI controls | ||
| 60 | MOUSEKEY_ENABLE = yes # Mouse keys(+4700) | ||
| 61 | NKRO_ENABLE = yes # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | ||
| 62 | RGBLIGHT_ENABLE = yes # Enable WS2812 RGB underlight. Do not enable this with audio at the same time. | ||
| 63 | SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend | ||
| 64 | UNICODE_ENABLE = no # Unicode | ||
diff --git a/keyboards/xd60/keymaps/base/keymap.c b/keyboards/xd60/keymaps/base/keymap.c deleted file mode 100644 index b3ccd5e58..000000000 --- a/keyboards/xd60/keymaps/base/keymap.c +++ /dev/null | |||
| @@ -1,46 +0,0 @@ | |||
| 1 | #include "xd60.h" | ||
| 2 | #include "action_layer.h" | ||
| 3 | |||
| 4 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 5 | |||
| 6 | // 0: Base Layer | ||
| 7 | KEYMAP( | ||
| 8 | KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC , KC_NO, \ | ||
| 9 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, \ | ||
| 10 | KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_NO, KC_ENT, \ | ||
| 11 | KC_LSFT, KC_NO, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_NO, KC_RSFT ,KC_UP, KC_DEL, \ | ||
| 12 | KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RGUI, F(0), KC_LEFT, KC_DOWN, KC_RIGHT), | ||
| 13 | |||
| 14 | // 1: Function Layer | ||
| 15 | KEYMAP( | ||
| 16 | RESET, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_NO, KC_NO, \ | ||
| 17 | KC_NO, KC_WH_U, KC_UP, KC_WH_D, KC_BSPC,KC_HOME,KC_CALC,KC_NO, KC_INS, KC_NO, KC_PSCR, KC_SLCK, KC_PAUS, KC_DEL, \ | ||
| 18 | KC_NO, KC_LEFT, KC_DOWN, KC_RIGHT,KC_DEL, KC_END, KC_PGDN,KC_NO, KC_NO, KC_NO, KC_HOME, KC_PGUP, KC_NO, KC_ENT, \ | ||
| 19 | KC_LSFT, KC_NO, KC_NO, KC_APP, BL_STEP,KC_NO, KC_NO, KC_VOLD,KC_VOLU,KC_MUTE, KC_END, KC_RSFT, KC_NO ,KC_PGUP, KC_INS, \ | ||
| 20 | KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RGUI, F(0), KC_HOME, KC_PGDOWN,KC_END), | ||
| 21 | |||
| 22 | }; | ||
| 23 | |||
| 24 | // Custom Actions | ||
| 25 | const uint16_t PROGMEM fn_actions[] = { | ||
| 26 | [0] = ACTION_LAYER_MOMENTARY(1), // to Fn overlay | ||
| 27 | }; | ||
| 28 | |||
| 29 | // Macros | ||
| 30 | const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
| 31 | |||
| 32 | // MACRODOWN only works in this function | ||
| 33 | switch(id) { | ||
| 34 | case 0: | ||
| 35 | if (record->event.pressed) { register_code(KC_RSFT); } | ||
| 36 | else { unregister_code(KC_RSFT); } | ||
| 37 | break; | ||
| 38 | } | ||
| 39 | |||
| 40 | return MACRO_NONE; | ||
| 41 | }; | ||
| 42 | |||
| 43 | // Loop | ||
| 44 | void matrix_scan_user(void) { | ||
| 45 | // Empty | ||
| 46 | }; | ||
diff --git a/keyboards/xd60/keymaps/base/readme.md b/keyboards/xd60/keymaps/base/readme.md deleted file mode 100644 index 89f9acaa9..000000000 --- a/keyboards/xd60/keymaps/base/readme.md +++ /dev/null | |||
| @@ -1,5 +0,0 @@ | |||
| 1 |  | ||
| 2 | |||
| 3 | All of the keys which CAN have a function should be assigned one. | ||
| 4 | |||
| 5 | The keys with KC_NO cannot be assigned a value | ||
