mirror of
https://github.com/qmk/qmk_firmware.git
synced 2025-07-25 02:21:17 +00:00
Compare commits
No commits in common. "2f7be506de354bb4ace73f3cd27cf365a9e48fd8" and "14a138f48ecdc2c4bb2b15d53acde1fe06da80f8" have entirely different histories.
2f7be506de
...
14a138f48e
@ -3,8 +3,6 @@
|
|||||||
"manufacturer": "ryanbaekr",
|
"manufacturer": "ryanbaekr",
|
||||||
"url": "",
|
"url": "",
|
||||||
"maintainer": "ryanbaekr",
|
"maintainer": "ryanbaekr",
|
||||||
"processor": "atmega32u4",
|
|
||||||
"bootloader": "caterina",
|
|
||||||
"usb": {
|
"usb": {
|
||||||
"vid": "0x7262",
|
"vid": "0x7262",
|
||||||
"pid": "0x0001",
|
"pid": "0x0001",
|
||||||
|
1
keyboards/ryanbaekr/rb1/keymaps/default/readme.md
Normal file
1
keyboards/ryanbaekr/rb1/keymaps/default/readme.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
# The default keymap for rb1
|
@ -10,10 +10,6 @@ Make example for this keyboard (after setting up your build environment):
|
|||||||
|
|
||||||
make ryanbaekr/rb1:default
|
make ryanbaekr/rb1:default
|
||||||
|
|
||||||
Flashing example for this keyboard:
|
|
||||||
|
|
||||||
make ryanbaekr/rb1:default:flash
|
|
||||||
|
|
||||||
To boot into the bootloader, hold the reset button on the SparkFun Qwiic Pro Micro - USB-C on plug in
|
To boot into the bootloader, hold the reset button on the SparkFun Qwiic Pro Micro - USB-C on plug in
|
||||||
|
|
||||||
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
# MCU name
|
||||||
|
MCU = atmega32u4
|
||||||
|
|
||||||
|
# Bootloader selection
|
||||||
|
BOOTLOADER = caterina
|
||||||
|
|
||||||
# Build Options
|
# Build Options
|
||||||
# change yes to no to disable
|
# change yes to no to disable
|
||||||
#
|
#
|
||||||
|
@ -19,6 +19,10 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|||||||
|
|
||||||
#include "config_common.h"
|
#include "config_common.h"
|
||||||
|
|
||||||
|
/* key matrix size */
|
||||||
|
#define MATRIX_ROWS 5
|
||||||
|
#define MATRIX_COLS 4
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Keyboard Matrix Assignments
|
* Keyboard Matrix Assignments
|
||||||
*
|
*
|
||||||
|
@ -3,8 +3,6 @@
|
|||||||
"manufacturer": "ryanbaekr",
|
"manufacturer": "ryanbaekr",
|
||||||
"url": "",
|
"url": "",
|
||||||
"maintainer": "ryanbaekr",
|
"maintainer": "ryanbaekr",
|
||||||
"processor": "atmega32u4",
|
|
||||||
"bootloader": "caterina",
|
|
||||||
"usb": {
|
"usb": {
|
||||||
"vid": "0x7262",
|
"vid": "0x7262",
|
||||||
"pid": "0x0018",
|
"pid": "0x0018",
|
||||||
|
1
keyboards/ryanbaekr/rb18/keymaps/default/readme.md
Normal file
1
keyboards/ryanbaekr/rb18/keymaps/default/readme.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
# The default keymap for rb18
|
@ -10,10 +10,6 @@ Make example for this keyboard (after setting up your build environment):
|
|||||||
|
|
||||||
make ryanbaekr/rb18:default
|
make ryanbaekr/rb18:default
|
||||||
|
|
||||||
Flashing example for this keyboard:
|
|
||||||
|
|
||||||
make ryanbaekr/rb18:default:flash
|
|
||||||
|
|
||||||
To boot into the bootloader, hold the reset button on the Elite-C on plug in
|
To boot into the bootloader, hold the reset button on the Elite-C on plug in
|
||||||
|
|
||||||
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
# MCU name
|
||||||
|
MCU = atmega32u4
|
||||||
|
|
||||||
|
# Bootloader selection
|
||||||
|
BOOTLOADER = caterina
|
||||||
|
|
||||||
# Build Options
|
# Build Options
|
||||||
# change yes to no to disable
|
# change yes to no to disable
|
||||||
#
|
#
|
||||||
|
@ -19,6 +19,10 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|||||||
|
|
||||||
#include "config_common.h"
|
#include "config_common.h"
|
||||||
|
|
||||||
|
/* key matrix size */
|
||||||
|
#define MATRIX_ROWS 5
|
||||||
|
#define MATRIX_COLS 16
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Keyboard Matrix Assignments
|
* Keyboard Matrix Assignments
|
||||||
*
|
*
|
||||||
|
@ -3,8 +3,6 @@
|
|||||||
"manufacturer": "ryanbaekr",
|
"manufacturer": "ryanbaekr",
|
||||||
"url": "",
|
"url": "",
|
||||||
"maintainer": "ryanbaekr",
|
"maintainer": "ryanbaekr",
|
||||||
"processor": "atmega32u4",
|
|
||||||
"bootloader": "caterina",
|
|
||||||
"usb": {
|
"usb": {
|
||||||
"vid": "0x7262",
|
"vid": "0x7262",
|
||||||
"pid": "0x0069",
|
"pid": "0x0069",
|
||||||
|
1
keyboards/ryanbaekr/rb69/keymaps/default/readme.md
Normal file
1
keyboards/ryanbaekr/rb69/keymaps/default/readme.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
# The default keymap for rb69
|
@ -10,10 +10,6 @@ Make example for this keyboard (after setting up your build environment):
|
|||||||
|
|
||||||
make ryanbaekr/rb69:default
|
make ryanbaekr/rb69:default
|
||||||
|
|
||||||
Flashing example for this keyboard:
|
|
||||||
|
|
||||||
make ryanbaekr/rb69:default:flash
|
|
||||||
|
|
||||||
To boot into the bootloader, hold the reset button on the Elite-C on plug in
|
To boot into the bootloader, hold the reset button on the Elite-C on plug in
|
||||||
|
|
||||||
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
# MCU name
|
||||||
|
MCU = atmega32u4
|
||||||
|
|
||||||
|
# Bootloader selection
|
||||||
|
BOOTLOADER = caterina
|
||||||
|
|
||||||
# Build Options
|
# Build Options
|
||||||
# change yes to no to disable
|
# change yes to no to disable
|
||||||
#
|
#
|
||||||
|
@ -19,6 +19,10 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|||||||
|
|
||||||
#include "config_common.h"
|
#include "config_common.h"
|
||||||
|
|
||||||
|
/* key matrix size */
|
||||||
|
#define MATRIX_ROWS 6
|
||||||
|
#define MATRIX_COLS 17
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Keyboard Matrix Assignments
|
* Keyboard Matrix Assignments
|
||||||
*
|
*
|
||||||
|
@ -3,8 +3,6 @@
|
|||||||
"manufacturer": "ryanbaekr",
|
"manufacturer": "ryanbaekr",
|
||||||
"url": "",
|
"url": "",
|
||||||
"maintainer": "ryanbaekr",
|
"maintainer": "ryanbaekr",
|
||||||
"processor": "atmega32u4",
|
|
||||||
"bootloader": "caterina",
|
|
||||||
"usb": {
|
"usb": {
|
||||||
"vid": "0x7262",
|
"vid": "0x7262",
|
||||||
"pid": "0x0086",
|
"pid": "0x0086",
|
||||||
|
1
keyboards/ryanbaekr/rb86/keymaps/default/readme.md
Normal file
1
keyboards/ryanbaekr/rb86/keymaps/default/readme.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
# The default keymap for rb86
|
@ -10,10 +10,6 @@ Make example for this keyboard (after setting up your build environment):
|
|||||||
|
|
||||||
make ryanbaekr/rb86:default
|
make ryanbaekr/rb86:default
|
||||||
|
|
||||||
Flashing example for this keyboard:
|
|
||||||
|
|
||||||
make ryanbaekr/rb86:default:flash
|
|
||||||
|
|
||||||
To boot into the bootloader, hold the reset button on the Elite-C on plug in
|
To boot into the bootloader, hold the reset button on the Elite-C on plug in
|
||||||
|
|
||||||
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
# MCU name
|
||||||
|
MCU = atmega32u4
|
||||||
|
|
||||||
|
# Bootloader selection
|
||||||
|
BOOTLOADER = caterina
|
||||||
|
|
||||||
# Build Options
|
# Build Options
|
||||||
# change yes to no to disable
|
# change yes to no to disable
|
||||||
#
|
#
|
||||||
|
@ -1,102 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2022 ryanbaekr
|
|
||||||
|
|
||||||
This program is free software: you can redistribute it and/or modify
|
|
||||||
it under the terms of the GNU General Public License as published by
|
|
||||||
the Free Software Foundation, either version 2 of the License, or
|
|
||||||
(at your option) any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
GNU General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License
|
|
||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include "config_common.h"
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Keyboard Matrix Assignments
|
|
||||||
*
|
|
||||||
* Change this to how you wired your keyboard
|
|
||||||
* COLS: AVR pins used for columns, left to right
|
|
||||||
* ROWS: AVR pins used for rows, top to bottom
|
|
||||||
* DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode)
|
|
||||||
* ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode)
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
#define MATRIX_ROW_PINS { D2, D7, C6, D4, D0, D1 }
|
|
||||||
#define MATRIX_COL_PINS { F4, F5, F6, F7, B1, B3, B2, B6, F0, F1, C7, E6, B4, B5, B7, D5, D3 }
|
|
||||||
|
|
||||||
/* COL2ROW, ROW2COL*/
|
|
||||||
#define DIODE_DIRECTION COL2ROW
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Split Keyboard specific options, make sure you have 'SPLIT_KEYBOARD = yes' in your rules.mk, and define SOFT_SERIAL_PIN.
|
|
||||||
*/
|
|
||||||
//#define SOFT_SERIAL_PIN D0 // or D1, D2, D3, E6
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */
|
|
||||||
#define DEBOUNCE 5
|
|
||||||
|
|
||||||
/* define if matrix has ghost (lacks anti-ghosting diodes) */
|
|
||||||
//#define MATRIX_HAS_GHOST
|
|
||||||
|
|
||||||
/* number of backlight levels */
|
|
||||||
#define BACKLIGHT_LEVELS 10
|
|
||||||
|
|
||||||
/* Underglow options */
|
|
||||||
#define RGB_DI_PIN B0
|
|
||||||
#ifdef RGB_DI_PIN
|
|
||||||
#define RGBLIGHT_EFFECT_BREATHING
|
|
||||||
#define RGBLIGHT_EFFECT_RAINBOW_MOOD
|
|
||||||
#define RGBLIGHT_EFFECT_RAINBOW_SWIRL
|
|
||||||
#define RGBLIGHT_EFFECT_SNAKE
|
|
||||||
#define RGBLIGHT_EFFECT_KNIGHT
|
|
||||||
#define RGBLIGHT_EFFECT_CHRISTMAS
|
|
||||||
#define RGBLIGHT_EFFECT_STATIC_GRADIENT
|
|
||||||
#define RGBLIGHT_EFFECT_RGB_TEST
|
|
||||||
#define RGBLIGHT_EFFECT_ALTERNATING
|
|
||||||
#define RGBLIGHT_EFFECT_TWINKLE
|
|
||||||
#define RGBLED_NUM 15
|
|
||||||
#define RGBLED_HUE_STEP 8
|
|
||||||
#define RGBLED_SAT_STEP 8
|
|
||||||
#define RGBLED_VAL_STEP 8
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
|
|
||||||
#define LOCKING_SUPPORT_ENABLE
|
|
||||||
/* Locking resynchronize hack */
|
|
||||||
#define LOCKING_RESYNC_ENABLE
|
|
||||||
|
|
||||||
/* If defined, GRAVE_ESC will always act as ESC when CTRL is held.
|
|
||||||
* This is userful for the Windows task manager shortcut (ctrl+shift+esc).
|
|
||||||
*/
|
|
||||||
// #define GRAVE_ESC_CTRL_OVERRIDE
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Force NKRO
|
|
||||||
*
|
|
||||||
* Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved
|
|
||||||
* state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the
|
|
||||||
* makefile for this to work.)
|
|
||||||
*
|
|
||||||
* If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N)
|
|
||||||
* until the next keyboard reset.
|
|
||||||
*
|
|
||||||
* NKRO may prevent your keystrokes from being detected in the BIOS, but it is
|
|
||||||
* fully operational during normal computer usage.
|
|
||||||
*
|
|
||||||
* For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N)
|
|
||||||
* or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by
|
|
||||||
* bootmagic, NKRO mode will always be enabled until it is toggled again during a
|
|
||||||
* power-up.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
//#define FORCE_NKRO
|
|
@ -1,18 +0,0 @@
|
|||||||
{
|
|
||||||
"keyboard_name": "rb87",
|
|
||||||
"manufacturer": "ryanbaekr",
|
|
||||||
"url": "",
|
|
||||||
"maintainer": "ryanbaekr",
|
|
||||||
"processor": "atmega32u4",
|
|
||||||
"bootloader": "caterina",
|
|
||||||
"usb": {
|
|
||||||
"vid": "0x7262",
|
|
||||||
"pid": "0x0087",
|
|
||||||
"device_version": "0.0.3"
|
|
||||||
},
|
|
||||||
"layouts": {
|
|
||||||
"LAYOUT": {
|
|
||||||
"layout": [{"x":0, "y":0}, {"x":1.5, "y":0}, {"x":2.5, "y":0}, {"x":3.5, "y":0}, {"x":4.5, "y":0}, {"x":5.75, "y":0}, {"x":6.75, "y":0}, {"x":7.75, "y":0}, {"x":8.75, "y":0}, {"x":10, "y":0}, {"x":11, "y":0}, {"x":12, "y":0}, {"x":13, "y":0}, {"x":14.25, "y":0}, {"x":15.25, "y":0}, {"x":16.25, "y":0}, {"x":0, "y":1.25}, {"x":1, "y":1.25}, {"x":2, "y":1.25}, {"x":3, "y":1.25}, {"x":4, "y":1.25}, {"x":5, "y":1.25}, {"x":6, "y":1.25}, {"x":7, "y":1.25}, {"x":8, "y":1.25}, {"x":9, "y":1.25}, {"x":10, "y":1.25}, {"x":11, "y":1.25}, {"x":12, "y":1.25}, {"x":13, "y":1.25, "w":2}, {"x":15.25, "y":1.25}, {"x":16.25, "y":1.25}, {"x":0, "y":2.25, "w":1.5}, {"x":1.5, "y":2.25}, {"x":2.5, "y":2.25}, {"x":3.5, "y":2.25}, {"x":4.5, "y":2.25}, {"x":5.5, "y":2.25}, {"x":6.5, "y":2.25}, {"x":7.5, "y":2.25}, {"x":8.5, "y":2.25}, {"x":9.5, "y":2.25}, {"x":10.5, "y":2.25}, {"x":11.5, "y":2.25}, {"x":12.5, "y":2.25}, {"x":13.5, "y":2.25, "w":1.5}, {"x":15.25, "y":2.25}, {"x":16.25, "y":2.25}, {"x":0, "y":3.25, "w":1.75}, {"x":1.75, "y":3.25}, {"x":2.75, "y":3.25}, {"x":3.75, "y":3.25}, {"x":4.75, "y":3.25}, {"x":5.75, "y":3.25}, {"x":6.75, "y":3.25}, {"x":7.75, "y":3.25}, {"x":8.75, "y":3.25}, {"x":9.75, "y":3.25}, {"x":10.75, "y":3.25}, {"x":11.75, "y":3.25}, {"x":12.75, "y":3.25, "w":2.25}, {"x":15.25, "y":3.25}, {"x":16.25, "y":3.25}, {"x":0, "y":4.25, "w":2.25}, {"x":2.25, "y":4.25}, {"x":3.25, "y":4.25}, {"x":4.25, "y":4.25}, {"x":5.25, "y":4.25}, {"x":6.25, "y":4.25}, {"x":7.25, "y":4.25}, {"x":8.25, "y":4.25}, {"x":9.25, "y":4.25}, {"x":10.25, "y":4.25}, {"x":11.25, "y":4.25}, {"x":12.25, "y":4.25, "w":2.75}, {"x":15.25, "y":4.5}, {"x":0, "y":5.25, "w":1.5}, {"x":1.5, "y":5.25, "w":1.25}, {"x":2.75, "y":5.25, "w":1.25}, {"x":4, "y":5.25, "w":6.25}, {"x":10.25, "y":5.25, "w":1.25}, {"x":11.5, "y":5.25, "w":1.25}, {"x":12.75, "y":5.25, "w":1.25}, {"x":14.25, "y":5.5}, {"x":15.25, "y":5.5}, {"x":16.25, "y":5.5}]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,36 +0,0 @@
|
|||||||
/* Copyright 2022 ryanbaekr
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
#include QMK_KEYBOARD_H
|
|
||||||
|
|
||||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
|
||||||
[0] = LAYOUT(
|
|
||||||
KC_ESC, 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_PSCR, KC_SCRL, KC_PAUS,
|
|
||||||
KC_GRV, 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_INS, KC_HOME,
|
|
||||||
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, KC_DEL, KC_END,
|
|
||||||
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_ENT, KC_PGUP, KC_PGDN,
|
|
||||||
KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
|
|
||||||
KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, TG(1), KC_RCTL, KC_LEFT, KC_DOWN, KC_RGHT
|
|
||||||
),
|
|
||||||
|
|
||||||
[1] = LAYOUT(
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_F13, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______
|
|
||||||
)
|
|
||||||
};
|
|
@ -1,54 +0,0 @@
|
|||||||
/* Copyright 2022 ryanbaekr
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
#include QMK_KEYBOARD_H
|
|
||||||
|
|
||||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
|
||||||
[0] = LAYOUT(
|
|
||||||
KC_ESC, 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_PSCR, KC_SCRL, KC_PAUS,
|
|
||||||
KC_GRV, 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_INS, KC_HOME,
|
|
||||||
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, KC_DEL, KC_END,
|
|
||||||
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_ENT, KC_PGUP, KC_PGDN,
|
|
||||||
KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
|
|
||||||
KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, TG(1), KC_RCTL, KC_LEFT, KC_DOWN, KC_RGHT
|
|
||||||
),
|
|
||||||
|
|
||||||
[1] = LAYOUT(
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_F13, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______
|
|
||||||
),
|
|
||||||
|
|
||||||
[2] = LAYOUT(
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______
|
|
||||||
),
|
|
||||||
|
|
||||||
[3] = LAYOUT(
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______
|
|
||||||
)
|
|
||||||
};
|
|
@ -1,2 +0,0 @@
|
|||||||
VIA_ENABLE = yes
|
|
||||||
LTO_ENABLE = yes
|
|
@ -1,17 +0,0 @@
|
|||||||
/* Copyright 2022 ryanbaekr
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "rb87.h"
|
|
@ -1,37 +0,0 @@
|
|||||||
/* Copyright 2022 ryanbaekr
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include "quantum.h"
|
|
||||||
|
|
||||||
#define ___ KC_NO
|
|
||||||
|
|
||||||
#define LAYOUT( \
|
|
||||||
k00, k02, k03, k04, k05, k06, k07, k08, k09, k0a, k0b, k0c, k0d, k0e, k0f, k0g, \
|
|
||||||
k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, k1c, k1e, k1f, k1g, \
|
|
||||||
k20, k22, k23, k24, k25, k26, k27, k28, k29, k2a, k2b, k2c, k2d, k2e, k2f, k2g, \
|
|
||||||
k30, k32, k33, k34, k35, k36, k37, k38, k39, k3a, k3b, k3c, k3d, k3f, k3g, \
|
|
||||||
k41, k42, k43, k44, k45, k46, k47, k48, k49, k4a, k4b, k4d, k4f, \
|
|
||||||
k50, k52, k53, k57, k5a, k5c, k5d, k5e, k5f, k5g \
|
|
||||||
){ \
|
|
||||||
{ k00, ___, k02, k03, k04, k05, k06, k07, k08, k09, k0a, k0b, k0c, k0d, k0e, k0f, k0g }, \
|
|
||||||
{ k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, k1c, ___, k1e, k1f, k1g }, \
|
|
||||||
{ k20, ___, k22, k23, k24, k25, k26, k27, k28, k29, k2a, k2b, k2c, k2d, k2e, k2f, k2g }, \
|
|
||||||
{ k30, ___, k32, k33, k34, k35, k36, k37, k38, k39, k3a, k3b, k3c, k3d, ___, k3f, k3g }, \
|
|
||||||
{ ___, k41, k42, k43, k44, k45, k46, k47, k48, k49, k4a, k4b, ___, k4d, ___, k4f, ___ }, \
|
|
||||||
{ k50, ___, k52, k53, ___, ___, ___, k57, ___, ___, k5a, ___, k5c, k5d, k5e, k5f, k5g } \
|
|
||||||
}
|
|
@ -1,19 +0,0 @@
|
|||||||
# rb87
|
|
||||||
|
|
||||||
A diy stacked acrylic 80% keyboard.
|
|
||||||
|
|
||||||
* Keyboard Maintainer: [ryanbaekr](https://github.com/ryanbaekr)
|
|
||||||
* Hardware Supported: rb87 with Elite-C
|
|
||||||
* Hardware Availability: 2022/12/30
|
|
||||||
|
|
||||||
Make example for this keyboard (after setting up your build environment):
|
|
||||||
|
|
||||||
make ryanbaekr/rb87:default
|
|
||||||
|
|
||||||
Flashing example for this keyboard:
|
|
||||||
|
|
||||||
make ryanbaekr/rb87:default:flash
|
|
||||||
|
|
||||||
To boot into the bootloader, hold the reset button on the Elite-C on plug in
|
|
||||||
|
|
||||||
See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
|
|
@ -1,12 +0,0 @@
|
|||||||
# Build Options
|
|
||||||
# change yes to no to disable
|
|
||||||
#
|
|
||||||
BOOTMAGIC_ENABLE = yes # Enable Bootmagic Lite
|
|
||||||
MOUSEKEY_ENABLE = yes # Mouse keys
|
|
||||||
EXTRAKEY_ENABLE = yes # Audio control and System control
|
|
||||||
CONSOLE_ENABLE = no # Console for debug
|
|
||||||
COMMAND_ENABLE = no # Commands for debug and configuration
|
|
||||||
NKRO_ENABLE = no # Enable N-Key Rollover
|
|
||||||
BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality
|
|
||||||
RGBLIGHT_ENABLE = yes # Enable keyboard RGB underglow
|
|
||||||
AUDIO_ENABLE = no # Audio output
|
|
@ -91,7 +91,7 @@ union {
|
|||||||
report_digitizer_t digitizer;
|
report_digitizer_t digitizer;
|
||||||
#endif
|
#endif
|
||||||
#ifdef JOYSTICK_ENABLE
|
#ifdef JOYSTICK_ENABLE
|
||||||
report_joystick_t joystick;
|
joystick_report_t joystick;
|
||||||
#endif
|
#endif
|
||||||
} universal_report_blank = {0};
|
} universal_report_blank = {0};
|
||||||
|
|
||||||
@ -368,14 +368,14 @@ typedef struct {
|
|||||||
#ifdef RAW_ENABLE
|
#ifdef RAW_ENABLE
|
||||||
usb_driver_config_t raw_driver;
|
usb_driver_config_t raw_driver;
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef XAP_ENABLE
|
||||||
|
usb_driver_config_t xap_driver;
|
||||||
|
#endif
|
||||||
#ifdef MIDI_ENABLE
|
#ifdef MIDI_ENABLE
|
||||||
usb_driver_config_t midi_driver;
|
usb_driver_config_t midi_driver;
|
||||||
#endif
|
#endif
|
||||||
#ifdef VIRTSER_ENABLE
|
#ifdef VIRTSER_ENABLE
|
||||||
usb_driver_config_t serial_driver;
|
usb_driver_config_t serial_driver;
|
||||||
#endif
|
|
||||||
#ifdef XAP_ENABLE
|
|
||||||
usb_driver_config_t xap_driver;
|
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
usb_driver_config_t array[0];
|
usb_driver_config_t array[0];
|
||||||
@ -402,6 +402,14 @@ static usb_driver_configs_t drivers = {
|
|||||||
.raw_driver = QMK_USB_DRIVER_CONFIG(RAW, 0, false),
|
.raw_driver = QMK_USB_DRIVER_CONFIG(RAW, 0, false),
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XAP_ENABLE
|
||||||
|
# define XAP_IN_CAPACITY 4
|
||||||
|
# define XAP_OUT_CAPACITY 4
|
||||||
|
# define XAP_IN_MODE USB_EP_MODE_TYPE_INTR
|
||||||
|
# define XAP_OUT_MODE USB_EP_MODE_TYPE_INTR
|
||||||
|
.xap_driver = QMK_USB_DRIVER_CONFIG(XAP, 0, false),
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef MIDI_ENABLE
|
#ifdef MIDI_ENABLE
|
||||||
# define MIDI_STREAM_IN_CAPACITY 4
|
# define MIDI_STREAM_IN_CAPACITY 4
|
||||||
# define MIDI_STREAM_OUT_CAPACITY 4
|
# define MIDI_STREAM_OUT_CAPACITY 4
|
||||||
@ -417,14 +425,6 @@ static usb_driver_configs_t drivers = {
|
|||||||
# define CDC_OUT_MODE USB_EP_MODE_TYPE_BULK
|
# define CDC_OUT_MODE USB_EP_MODE_TYPE_BULK
|
||||||
.serial_driver = QMK_USB_DRIVER_CONFIG(CDC, CDC_NOTIFICATION_EPNUM, false),
|
.serial_driver = QMK_USB_DRIVER_CONFIG(CDC, CDC_NOTIFICATION_EPNUM, false),
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
|
||||||
# define XAP_IN_CAPACITY 4
|
|
||||||
# define XAP_OUT_CAPACITY 4
|
|
||||||
# define XAP_IN_MODE USB_EP_MODE_TYPE_INTR
|
|
||||||
# define XAP_OUT_MODE USB_EP_MODE_TYPE_INTR
|
|
||||||
.xap_driver = QMK_USB_DRIVER_CONFIG(XAP, 0, false),
|
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#define NUM_USB_DRIVERS (sizeof(drivers) / sizeof(usb_driver_config_t))
|
#define NUM_USB_DRIVERS (sizeof(drivers) / sizeof(usb_driver_config_t))
|
||||||
|
@ -486,6 +486,12 @@ void EVENT_USB_Device_ConfigurationChanged(void) {
|
|||||||
ConfigSuccess &= Endpoint_ConfigureEndpoint((RAW_OUT_EPNUM | ENDPOINT_DIR_OUT), EP_TYPE_INTERRUPT, RAW_EPSIZE, 1);
|
ConfigSuccess &= Endpoint_ConfigureEndpoint((RAW_OUT_EPNUM | ENDPOINT_DIR_OUT), EP_TYPE_INTERRUPT, RAW_EPSIZE, 1);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XAP_ENABLE
|
||||||
|
/* Setup XAP endpoints */
|
||||||
|
ConfigSuccess &= Endpoint_ConfigureEndpoint((XAP_IN_EPNUM | ENDPOINT_DIR_IN), EP_TYPE_INTERRUPT, XAP_EPSIZE, 1);
|
||||||
|
ConfigSuccess &= Endpoint_ConfigureEndpoint((XAP_OUT_EPNUM | ENDPOINT_DIR_OUT), EP_TYPE_INTERRUPT, XAP_EPSIZE, 1);
|
||||||
|
#endif // XAP_ENABLE
|
||||||
|
|
||||||
#ifdef CONSOLE_ENABLE
|
#ifdef CONSOLE_ENABLE
|
||||||
/* Setup console endpoint */
|
/* Setup console endpoint */
|
||||||
ConfigSuccess &= Endpoint_ConfigureEndpoint((CONSOLE_IN_EPNUM | ENDPOINT_DIR_IN), EP_TYPE_INTERRUPT, CONSOLE_EPSIZE, 1);
|
ConfigSuccess &= Endpoint_ConfigureEndpoint((CONSOLE_IN_EPNUM | ENDPOINT_DIR_IN), EP_TYPE_INTERRUPT, CONSOLE_EPSIZE, 1);
|
||||||
@ -517,12 +523,6 @@ void EVENT_USB_Device_ConfigurationChanged(void) {
|
|||||||
ConfigSuccess &= Endpoint_ConfigureEndpoint((DIGITIZER_IN_EPNUM | ENDPOINT_DIR_IN), EP_TYPE_INTERRUPT, DIGITIZER_EPSIZE, 1);
|
ConfigSuccess &= Endpoint_ConfigureEndpoint((DIGITIZER_IN_EPNUM | ENDPOINT_DIR_IN), EP_TYPE_INTERRUPT, DIGITIZER_EPSIZE, 1);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
|
||||||
/* Setup XAP endpoints */
|
|
||||||
ConfigSuccess &= Endpoint_ConfigureEndpoint((XAP_IN_EPNUM | ENDPOINT_DIR_IN), EP_TYPE_INTERRUPT, XAP_EPSIZE, 1);
|
|
||||||
ConfigSuccess &= Endpoint_ConfigureEndpoint((XAP_OUT_EPNUM | ENDPOINT_DIR_OUT), EP_TYPE_INTERRUPT, XAP_EPSIZE, 1);
|
|
||||||
#endif // XAP_ENABLE
|
|
||||||
|
|
||||||
usb_device_state_set_configuration(USB_DeviceState == DEVICE_STATE_Configured, USB_Device_ConfigurationNumber);
|
usb_device_state_set_configuration(USB_DeviceState == DEVICE_STATE_Configured, USB_Device_ConfigurationNumber);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -406,30 +406,6 @@ const USB_Descriptor_HIDReport_Datatype_t PROGMEM RawReport[] = {
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONSOLE_ENABLE
|
|
||||||
const USB_Descriptor_HIDReport_Datatype_t PROGMEM ConsoleReport[] = {
|
|
||||||
HID_RI_USAGE_PAGE(16, 0xFF31), // Vendor Defined (PJRC Teensy compatible)
|
|
||||||
HID_RI_USAGE(8, 0x74), // Vendor Defined (PJRC Teensy compatible)
|
|
||||||
HID_RI_COLLECTION(8, 0x01), // Application
|
|
||||||
// Data to host
|
|
||||||
HID_RI_USAGE(8, 0x75), // Vendor Defined
|
|
||||||
HID_RI_LOGICAL_MINIMUM(8, 0x00),
|
|
||||||
HID_RI_LOGICAL_MAXIMUM(16, 0x00FF),
|
|
||||||
HID_RI_REPORT_COUNT(8, CONSOLE_EPSIZE),
|
|
||||||
HID_RI_REPORT_SIZE(8, 0x08),
|
|
||||||
HID_RI_INPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE),
|
|
||||||
|
|
||||||
// Data from host
|
|
||||||
HID_RI_USAGE(8, 0x76), // Vendor Defined
|
|
||||||
HID_RI_LOGICAL_MINIMUM(8, 0x00),
|
|
||||||
HID_RI_LOGICAL_MAXIMUM(16, 0x00FF),
|
|
||||||
HID_RI_REPORT_COUNT(8, CONSOLE_EPSIZE),
|
|
||||||
HID_RI_REPORT_SIZE(8, 0x08),
|
|
||||||
HID_RI_OUTPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE | HID_IOF_NON_VOLATILE),
|
|
||||||
HID_RI_END_COLLECTION(0),
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
#ifdef XAP_ENABLE
|
||||||
const USB_Descriptor_HIDReport_Datatype_t PROGMEM XapReport[] = {
|
const USB_Descriptor_HIDReport_Datatype_t PROGMEM XapReport[] = {
|
||||||
HID_RI_USAGE_PAGE(16, 0xFF51), // Vendor Defined ('Q')
|
HID_RI_USAGE_PAGE(16, 0xFF51), // Vendor Defined ('Q')
|
||||||
@ -454,6 +430,30 @@ const USB_Descriptor_HIDReport_Datatype_t PROGMEM XapReport[] = {
|
|||||||
};
|
};
|
||||||
#endif // XAP_ENABLE
|
#endif // XAP_ENABLE
|
||||||
|
|
||||||
|
#ifdef CONSOLE_ENABLE
|
||||||
|
const USB_Descriptor_HIDReport_Datatype_t PROGMEM ConsoleReport[] = {
|
||||||
|
HID_RI_USAGE_PAGE(16, 0xFF31), // Vendor Defined (PJRC Teensy compatible)
|
||||||
|
HID_RI_USAGE(8, 0x74), // Vendor Defined (PJRC Teensy compatible)
|
||||||
|
HID_RI_COLLECTION(8, 0x01), // Application
|
||||||
|
// Data to host
|
||||||
|
HID_RI_USAGE(8, 0x75), // Vendor Defined
|
||||||
|
HID_RI_LOGICAL_MINIMUM(8, 0x00),
|
||||||
|
HID_RI_LOGICAL_MAXIMUM(16, 0x00FF),
|
||||||
|
HID_RI_REPORT_COUNT(8, CONSOLE_EPSIZE),
|
||||||
|
HID_RI_REPORT_SIZE(8, 0x08),
|
||||||
|
HID_RI_INPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE),
|
||||||
|
|
||||||
|
// Data from host
|
||||||
|
HID_RI_USAGE(8, 0x76), // Vendor Defined
|
||||||
|
HID_RI_LOGICAL_MINIMUM(8, 0x00),
|
||||||
|
HID_RI_LOGICAL_MAXIMUM(16, 0x00FF),
|
||||||
|
HID_RI_REPORT_COUNT(8, CONSOLE_EPSIZE),
|
||||||
|
HID_RI_REPORT_SIZE(8, 0x08),
|
||||||
|
HID_RI_OUTPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE | HID_IOF_NON_VOLATILE),
|
||||||
|
HID_RI_END_COLLECTION(0),
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Device descriptor
|
* Device descriptor
|
||||||
*/
|
*/
|
||||||
@ -603,6 +603,56 @@ const USB_Descriptor_Configuration_t PROGMEM ConfigurationDescriptor = {
|
|||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XAP_ENABLE
|
||||||
|
/*
|
||||||
|
* QMK XAP
|
||||||
|
*/
|
||||||
|
.Xap_Interface = {
|
||||||
|
.Header = {
|
||||||
|
.Size = sizeof(USB_Descriptor_Interface_t),
|
||||||
|
.Type = DTYPE_Interface
|
||||||
|
},
|
||||||
|
.InterfaceNumber = XAP_INTERFACE,
|
||||||
|
.AlternateSetting = 0x00,
|
||||||
|
.TotalEndpoints = 2,
|
||||||
|
.Class = HID_CSCP_HIDClass,
|
||||||
|
.SubClass = HID_CSCP_NonBootSubclass,
|
||||||
|
.Protocol = HID_CSCP_NonBootProtocol,
|
||||||
|
.InterfaceStrIndex = NO_DESCRIPTOR
|
||||||
|
},
|
||||||
|
.Xap_HID = {
|
||||||
|
.Header = {
|
||||||
|
.Size = sizeof(USB_HID_Descriptor_HID_t),
|
||||||
|
.Type = HID_DTYPE_HID
|
||||||
|
},
|
||||||
|
.HIDSpec = VERSION_BCD(1, 1, 1),
|
||||||
|
.CountryCode = 0x00,
|
||||||
|
.TotalReportDescriptors = 1,
|
||||||
|
.HIDReportType = HID_DTYPE_Report,
|
||||||
|
.HIDReportLength = sizeof(XapReport)
|
||||||
|
},
|
||||||
|
.Xap_INEndpoint = {
|
||||||
|
.Header = {
|
||||||
|
.Size = sizeof(USB_Descriptor_Endpoint_t),
|
||||||
|
.Type = DTYPE_Endpoint
|
||||||
|
},
|
||||||
|
.EndpointAddress = (ENDPOINT_DIR_IN | XAP_IN_EPNUM),
|
||||||
|
.Attributes = (EP_TYPE_INTERRUPT | ENDPOINT_ATTR_NO_SYNC | ENDPOINT_USAGE_DATA),
|
||||||
|
.EndpointSize = XAP_EPSIZE,
|
||||||
|
.PollingIntervalMS = 0x01
|
||||||
|
},
|
||||||
|
.Xap_OUTEndpoint = {
|
||||||
|
.Header = {
|
||||||
|
.Size = sizeof(USB_Descriptor_Endpoint_t),
|
||||||
|
.Type = DTYPE_Endpoint
|
||||||
|
},
|
||||||
|
.EndpointAddress = (ENDPOINT_DIR_OUT | XAP_OUT_EPNUM),
|
||||||
|
.Attributes = (EP_TYPE_INTERRUPT | ENDPOINT_ATTR_NO_SYNC | ENDPOINT_USAGE_DATA),
|
||||||
|
.EndpointSize = XAP_EPSIZE,
|
||||||
|
.PollingIntervalMS = 0x01
|
||||||
|
},
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(MOUSE_ENABLE) && !defined(MOUSE_SHARED_EP)
|
#if defined(MOUSE_ENABLE) && !defined(MOUSE_SHARED_EP)
|
||||||
/*
|
/*
|
||||||
* Mouse
|
* Mouse
|
||||||
@ -1072,56 +1122,6 @@ const USB_Descriptor_Configuration_t PROGMEM ConfigurationDescriptor = {
|
|||||||
.PollingIntervalMS = USB_POLLING_INTERVAL_MS
|
.PollingIntervalMS = USB_POLLING_INTERVAL_MS
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
|
||||||
/*
|
|
||||||
* QMK XAP
|
|
||||||
*/
|
|
||||||
.Xap_Interface = {
|
|
||||||
.Header = {
|
|
||||||
.Size = sizeof(USB_Descriptor_Interface_t),
|
|
||||||
.Type = DTYPE_Interface
|
|
||||||
},
|
|
||||||
.InterfaceNumber = XAP_INTERFACE,
|
|
||||||
.AlternateSetting = 0x00,
|
|
||||||
.TotalEndpoints = 2,
|
|
||||||
.Class = HID_CSCP_HIDClass,
|
|
||||||
.SubClass = HID_CSCP_NonBootSubclass,
|
|
||||||
.Protocol = HID_CSCP_NonBootProtocol,
|
|
||||||
.InterfaceStrIndex = NO_DESCRIPTOR
|
|
||||||
},
|
|
||||||
.Xap_HID = {
|
|
||||||
.Header = {
|
|
||||||
.Size = sizeof(USB_HID_Descriptor_HID_t),
|
|
||||||
.Type = HID_DTYPE_HID
|
|
||||||
},
|
|
||||||
.HIDSpec = VERSION_BCD(1, 1, 1),
|
|
||||||
.CountryCode = 0x00,
|
|
||||||
.TotalReportDescriptors = 1,
|
|
||||||
.HIDReportType = HID_DTYPE_Report,
|
|
||||||
.HIDReportLength = sizeof(XapReport)
|
|
||||||
},
|
|
||||||
.Xap_INEndpoint = {
|
|
||||||
.Header = {
|
|
||||||
.Size = sizeof(USB_Descriptor_Endpoint_t),
|
|
||||||
.Type = DTYPE_Endpoint
|
|
||||||
},
|
|
||||||
.EndpointAddress = (ENDPOINT_DIR_IN | XAP_IN_EPNUM),
|
|
||||||
.Attributes = (EP_TYPE_INTERRUPT | ENDPOINT_ATTR_NO_SYNC | ENDPOINT_USAGE_DATA),
|
|
||||||
.EndpointSize = XAP_EPSIZE,
|
|
||||||
.PollingIntervalMS = 0x01
|
|
||||||
},
|
|
||||||
.Xap_OUTEndpoint = {
|
|
||||||
.Header = {
|
|
||||||
.Size = sizeof(USB_Descriptor_Endpoint_t),
|
|
||||||
.Type = DTYPE_Endpoint
|
|
||||||
},
|
|
||||||
.EndpointAddress = (ENDPOINT_DIR_OUT | XAP_OUT_EPNUM),
|
|
||||||
.Attributes = (EP_TYPE_INTERRUPT | ENDPOINT_ATTR_NO_SYNC | ENDPOINT_USAGE_DATA),
|
|
||||||
.EndpointSize = XAP_EPSIZE,
|
|
||||||
.PollingIntervalMS = 0x01
|
|
||||||
},
|
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1250,6 +1250,14 @@ uint16_t get_usb_descriptor(const uint16_t wValue, const uint16_t wIndex, const
|
|||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XAP_ENABLE
|
||||||
|
case XAP_INTERFACE:
|
||||||
|
Address = &ConfigurationDescriptor.Xap_HID;
|
||||||
|
Size = sizeof(USB_HID_Descriptor_HID_t);
|
||||||
|
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef CONSOLE_ENABLE
|
#ifdef CONSOLE_ENABLE
|
||||||
case CONSOLE_INTERFACE:
|
case CONSOLE_INTERFACE:
|
||||||
Address = &ConfigurationDescriptor.Console_HID;
|
Address = &ConfigurationDescriptor.Console_HID;
|
||||||
@ -1257,14 +1265,12 @@ uint16_t get_usb_descriptor(const uint16_t wValue, const uint16_t wIndex, const
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(JOYSTICK_ENABLE) && !defined(JOYSTICK_SHARED_EP)
|
#if defined(JOYSTICK_ENABLE) && !defined(JOYSTICK_SHARED_EP)
|
||||||
case JOYSTICK_INTERFACE:
|
case JOYSTICK_INTERFACE:
|
||||||
Address = &ConfigurationDescriptor.Joystick_HID;
|
Address = &ConfigurationDescriptor.Joystick_HID;
|
||||||
Size = sizeof(USB_HID_Descriptor_HID_t);
|
Size = sizeof(USB_HID_Descriptor_HID_t);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(DIGITIZER_ENABLE) && !defined(DIGITIZER_SHARED_EP)
|
#if defined(DIGITIZER_ENABLE) && !defined(DIGITIZER_SHARED_EP)
|
||||||
case DIGITIZER_INTERFACE:
|
case DIGITIZER_INTERFACE:
|
||||||
Address = &ConfigurationDescriptor.Digitizer_HID;
|
Address = &ConfigurationDescriptor.Digitizer_HID;
|
||||||
@ -1272,14 +1278,6 @@ uint16_t get_usb_descriptor(const uint16_t wValue, const uint16_t wIndex, const
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
|
||||||
case XAP_INTERFACE:
|
|
||||||
Address = &ConfigurationDescriptor.Xap_HID;
|
|
||||||
Size = sizeof(USB_HID_Descriptor_HID_t);
|
|
||||||
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
@ -1317,6 +1315,14 @@ uint16_t get_usb_descriptor(const uint16_t wValue, const uint16_t wIndex, const
|
|||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XAP_ENABLE
|
||||||
|
case XAP_INTERFACE:
|
||||||
|
Address = &XapReport;
|
||||||
|
Size = sizeof(XapReport);
|
||||||
|
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef CONSOLE_ENABLE
|
#ifdef CONSOLE_ENABLE
|
||||||
case CONSOLE_INTERFACE:
|
case CONSOLE_INTERFACE:
|
||||||
Address = &ConsoleReport;
|
Address = &ConsoleReport;
|
||||||
@ -1336,14 +1342,6 @@ uint16_t get_usb_descriptor(const uint16_t wValue, const uint16_t wIndex, const
|
|||||||
Size = sizeof(DigitizerReport);
|
Size = sizeof(DigitizerReport);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
|
||||||
case XAP_INTERFACE:
|
|
||||||
Address = &XapReport;
|
|
||||||
Size = sizeof(XapReport);
|
|
||||||
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
@ -78,6 +78,14 @@ typedef struct {
|
|||||||
USB_Descriptor_Endpoint_t Raw_OUTEndpoint;
|
USB_Descriptor_Endpoint_t Raw_OUTEndpoint;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XAP_ENABLE
|
||||||
|
// Mouse HID Interface
|
||||||
|
USB_Descriptor_Interface_t Xap_Interface;
|
||||||
|
USB_HID_Descriptor_HID_t Xap_HID;
|
||||||
|
USB_Descriptor_Endpoint_t Xap_INEndpoint;
|
||||||
|
USB_Descriptor_Endpoint_t Xap_OUTEndpoint;
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(MOUSE_ENABLE) && !defined(MOUSE_SHARED_EP)
|
#if defined(MOUSE_ENABLE) && !defined(MOUSE_SHARED_EP)
|
||||||
// Mouse HID Interface
|
// Mouse HID Interface
|
||||||
USB_Descriptor_Interface_t Mouse_Interface;
|
USB_Descriptor_Interface_t Mouse_Interface;
|
||||||
@ -145,14 +153,6 @@ typedef struct {
|
|||||||
USB_HID_Descriptor_HID_t Digitizer_HID;
|
USB_HID_Descriptor_HID_t Digitizer_HID;
|
||||||
USB_Descriptor_Endpoint_t Digitizer_INEndpoint;
|
USB_Descriptor_Endpoint_t Digitizer_INEndpoint;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
|
||||||
// XAP HID Interface
|
|
||||||
USB_Descriptor_Interface_t Xap_Interface;
|
|
||||||
USB_HID_Descriptor_HID_t Xap_HID;
|
|
||||||
USB_Descriptor_Endpoint_t Xap_INEndpoint;
|
|
||||||
USB_Descriptor_Endpoint_t Xap_OUTEndpoint;
|
|
||||||
#endif
|
|
||||||
} USB_Descriptor_Configuration_t;
|
} USB_Descriptor_Configuration_t;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -173,6 +173,10 @@ enum usb_interfaces {
|
|||||||
RAW_INTERFACE,
|
RAW_INTERFACE,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XAP_ENABLE
|
||||||
|
XAP_INTERFACE,
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(MOUSE_ENABLE) && !defined(MOUSE_SHARED_EP)
|
#if defined(MOUSE_ENABLE) && !defined(MOUSE_SHARED_EP)
|
||||||
MOUSE_INTERFACE,
|
MOUSE_INTERFACE,
|
||||||
#endif
|
#endif
|
||||||
@ -202,10 +206,6 @@ enum usb_interfaces {
|
|||||||
#if defined(DIGITIZER_ENABLE) && !defined(DIGITIZER_SHARED_EP)
|
#if defined(DIGITIZER_ENABLE) && !defined(DIGITIZER_SHARED_EP)
|
||||||
DIGITIZER_INTERFACE,
|
DIGITIZER_INTERFACE,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
|
||||||
XAP_INTERFACE,
|
|
||||||
#endif
|
|
||||||
TOTAL_INTERFACES
|
TOTAL_INTERFACES
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -238,6 +238,15 @@ enum usb_endpoints {
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XAP_ENABLE
|
||||||
|
XAP_IN_EPNUM = NEXT_EPNUM,
|
||||||
|
# if STM32_USB_USE_OTG1
|
||||||
|
# define XAP_OUT_EPNUM XAP_IN_EPNUM
|
||||||
|
# else
|
||||||
|
XAP_OUT_EPNUM = NEXT_EPNUM,
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef SHARED_EP_ENABLE
|
#ifdef SHARED_EP_ENABLE
|
||||||
SHARED_IN_EPNUM = NEXT_EPNUM,
|
SHARED_IN_EPNUM = NEXT_EPNUM,
|
||||||
#endif
|
#endif
|
||||||
@ -293,15 +302,6 @@ enum usb_endpoints {
|
|||||||
# define DIGITIZER_IN_EPNUM SHARED_IN_EPNUM
|
# define DIGITIZER_IN_EPNUM SHARED_IN_EPNUM
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
|
||||||
XAP_IN_EPNUM = NEXT_EPNUM,
|
|
||||||
# if STM32_USB_USE_OTG1
|
|
||||||
# define XAP_OUT_EPNUM XAP_IN_EPNUM
|
|
||||||
# else
|
|
||||||
XAP_OUT_EPNUM = NEXT_EPNUM,
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef PROTOCOL_LUFA
|
#ifdef PROTOCOL_LUFA
|
||||||
|
@ -73,6 +73,10 @@ enum usb_interfaces {
|
|||||||
RAW_INTERFACE = NEXT_INTERFACE,
|
RAW_INTERFACE = NEXT_INTERFACE,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XAP_ENABLE
|
||||||
|
XAP_INTERFACE = NEXT_INTERFACE,
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(SHARED_EP_ENABLE) && !defined(KEYBOARD_SHARED_EP)
|
#if defined(SHARED_EP_ENABLE) && !defined(KEYBOARD_SHARED_EP)
|
||||||
SHARED_INTERFACE = NEXT_INTERFACE,
|
SHARED_INTERFACE = NEXT_INTERFACE,
|
||||||
#endif
|
#endif
|
||||||
@ -81,10 +85,6 @@ enum usb_interfaces {
|
|||||||
CONSOLE_INTERFACE = NEXT_INTERFACE,
|
CONSOLE_INTERFACE = NEXT_INTERFACE,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
|
||||||
XAP_INTERFACE = NEXT_INTERFACE,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
TOTAL_INTERFACES = NEXT_INTERFACE
|
TOTAL_INTERFACES = NEXT_INTERFACE
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -789,29 +789,6 @@ const PROGMEM uchar raw_hid_report[] = {
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONSOLE_ENABLE)
|
|
||||||
const PROGMEM uchar console_hid_report[] = {
|
|
||||||
0x06, 0x31, 0xFF, // Usage Page (Vendor Defined - PJRC Teensy compatible)
|
|
||||||
0x09, 0x74, // Usage (Vendor Defined - PJRC Teensy compatible)
|
|
||||||
0xA1, 0x01, // Collection (Application)
|
|
||||||
// Data to host
|
|
||||||
0x09, 0x75, // Usage (Vendor Defined)
|
|
||||||
0x15, 0x00, // Logical Minimum (0x00)
|
|
||||||
0x26, 0xFF, 0x00, // Logical Maximum (0x00FF)
|
|
||||||
0x95, CONSOLE_BUFFER_SIZE, // Report Count
|
|
||||||
0x75, 0x08, // Report Size (8)
|
|
||||||
0x81, 0x02, // Input (Data, Variable, Absolute)
|
|
||||||
// Data from host
|
|
||||||
0x09, 0x76, // Usage (Vendor Defined)
|
|
||||||
0x15, 0x00, // Logical Minimum (0x00)
|
|
||||||
0x26, 0xFF, 0x00, // Logical Maximum (0x00FF)
|
|
||||||
0x95, CONSOLE_BUFFER_SIZE, // Report Count
|
|
||||||
0x75, 0x08, // Report Size (8)
|
|
||||||
0x91, 0x02, // Output (Data)
|
|
||||||
0xC0 // End Collection
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef XAP_ENABLE
|
#ifdef XAP_ENABLE
|
||||||
const PROGMEM uchar xap_report[] = {
|
const PROGMEM uchar xap_report[] = {
|
||||||
0x06, 0x51, 0xFF, // Usage Page (Vendor Defined)
|
0x06, 0x51, 0xFF, // Usage Page (Vendor Defined)
|
||||||
@ -835,6 +812,29 @@ const PROGMEM uchar xap_report[] = {
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONSOLE_ENABLE)
|
||||||
|
const PROGMEM uchar console_hid_report[] = {
|
||||||
|
0x06, 0x31, 0xFF, // Usage Page (Vendor Defined - PJRC Teensy compatible)
|
||||||
|
0x09, 0x74, // Usage (Vendor Defined - PJRC Teensy compatible)
|
||||||
|
0xA1, 0x01, // Collection (Application)
|
||||||
|
// Data to host
|
||||||
|
0x09, 0x75, // Usage (Vendor Defined)
|
||||||
|
0x15, 0x00, // Logical Minimum (0x00)
|
||||||
|
0x26, 0xFF, 0x00, // Logical Maximum (0x00FF)
|
||||||
|
0x95, CONSOLE_BUFFER_SIZE, // Report Count
|
||||||
|
0x75, 0x08, // Report Size (8)
|
||||||
|
0x81, 0x02, // Input (Data, Variable, Absolute)
|
||||||
|
// Data from host
|
||||||
|
0x09, 0x76, // Usage (Vendor Defined)
|
||||||
|
0x15, 0x00, // Logical Minimum (0x00)
|
||||||
|
0x26, 0xFF, 0x00, // Logical Maximum (0x00FF)
|
||||||
|
0x95, CONSOLE_BUFFER_SIZE, // Report Count
|
||||||
|
0x75, 0x08, // Report Size (8)
|
||||||
|
0x91, 0x02, // Output (Data)
|
||||||
|
0xC0 // End Collection
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef USB_MAX_POWER_CONSUMPTION
|
#ifndef USB_MAX_POWER_CONSUMPTION
|
||||||
# define USB_MAX_POWER_CONSUMPTION 500
|
# define USB_MAX_POWER_CONSUMPTION 500
|
||||||
#endif
|
#endif
|
||||||
@ -1011,6 +1011,56 @@ const PROGMEM usbConfigurationDescriptor_t usbConfigurationDescriptor = {
|
|||||||
},
|
},
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
|
# if defined(XAP_ENABLE)
|
||||||
|
/*
|
||||||
|
* XAP
|
||||||
|
*/
|
||||||
|
.xapInterface = {
|
||||||
|
.header = {
|
||||||
|
.bLength = sizeof(usbInterfaceDescriptor_t),
|
||||||
|
.bDescriptorType = USBDESCR_INTERFACE
|
||||||
|
},
|
||||||
|
.bInterfaceNumber = XAP_INTERFACE,
|
||||||
|
.bAlternateSetting = 0x00,
|
||||||
|
.bNumEndpoints = 2,
|
||||||
|
.bInterfaceClass = 0x03,
|
||||||
|
.bInterfaceSubClass = 0x00,
|
||||||
|
.bInterfaceProtocol = 0x00,
|
||||||
|
.iInterface = 0x00
|
||||||
|
},
|
||||||
|
.xapHID = {
|
||||||
|
.header = {
|
||||||
|
.bLength = sizeof(usbHIDDescriptor_t),
|
||||||
|
.bDescriptorType = USBDESCR_HID
|
||||||
|
},
|
||||||
|
.bcdHID = 0x0101,
|
||||||
|
.bCountryCode = 0x00,
|
||||||
|
.bNumDescriptors = 1,
|
||||||
|
.bDescriptorType = USBDESCR_HID_REPORT,
|
||||||
|
.wDescriptorLength = sizeof(xap_report)
|
||||||
|
},
|
||||||
|
.xapINEndpoint = {
|
||||||
|
.header = {
|
||||||
|
.bLength = sizeof(usbEndpointDescriptor_t),
|
||||||
|
.bDescriptorType = USBDESCR_ENDPOINT
|
||||||
|
},
|
||||||
|
.bEndpointAddress = (USBRQ_DIR_DEVICE_TO_HOST | USB_CFG_EP4_NUMBER),
|
||||||
|
.bmAttributes = 0x03,
|
||||||
|
.wMaxPacketSize = XAP_EPSIZE,
|
||||||
|
.bInterval = USB_POLLING_INTERVAL_MS
|
||||||
|
},
|
||||||
|
.xapOUTEndpoint = {
|
||||||
|
.header = {
|
||||||
|
.bLength = sizeof(usbEndpointDescriptor_t),
|
||||||
|
.bDescriptorType = USBDESCR_ENDPOINT
|
||||||
|
},
|
||||||
|
.bEndpointAddress = (USBRQ_DIR_HOST_TO_DEVICE | USB_CFG_EP4_NUMBER),
|
||||||
|
.bmAttributes = 0x03,
|
||||||
|
.wMaxPacketSize = XAP_EPSIZE,
|
||||||
|
.bInterval = USB_POLLING_INTERVAL_MS
|
||||||
|
},
|
||||||
|
# endif
|
||||||
|
|
||||||
# ifdef SHARED_EP_ENABLE
|
# ifdef SHARED_EP_ENABLE
|
||||||
/*
|
/*
|
||||||
* Shared
|
* Shared
|
||||||
@ -1107,57 +1157,7 @@ const PROGMEM usbConfigurationDescriptor_t usbConfigurationDescriptor = {
|
|||||||
.bmAttributes = 0x03,
|
.bmAttributes = 0x03,
|
||||||
.wMaxPacketSize = CONSOLE_EPSIZE,
|
.wMaxPacketSize = CONSOLE_EPSIZE,
|
||||||
.bInterval = 0x01
|
.bInterval = 0x01
|
||||||
},
|
}
|
||||||
# endif
|
|
||||||
|
|
||||||
# if defined(XAP_ENABLE)
|
|
||||||
/*
|
|
||||||
* XAP
|
|
||||||
*/
|
|
||||||
.xapInterface = {
|
|
||||||
.header = {
|
|
||||||
.bLength = sizeof(usbInterfaceDescriptor_t),
|
|
||||||
.bDescriptorType = USBDESCR_INTERFACE
|
|
||||||
},
|
|
||||||
.bInterfaceNumber = XAP_INTERFACE,
|
|
||||||
.bAlternateSetting = 0x00,
|
|
||||||
.bNumEndpoints = 2,
|
|
||||||
.bInterfaceClass = 0x03,
|
|
||||||
.bInterfaceSubClass = 0x00,
|
|
||||||
.bInterfaceProtocol = 0x00,
|
|
||||||
.iInterface = 0x00
|
|
||||||
},
|
|
||||||
.xapHID = {
|
|
||||||
.header = {
|
|
||||||
.bLength = sizeof(usbHIDDescriptor_t),
|
|
||||||
.bDescriptorType = USBDESCR_HID
|
|
||||||
},
|
|
||||||
.bcdHID = 0x0101,
|
|
||||||
.bCountryCode = 0x00,
|
|
||||||
.bNumDescriptors = 1,
|
|
||||||
.bDescriptorType = USBDESCR_HID_REPORT,
|
|
||||||
.wDescriptorLength = sizeof(xap_report)
|
|
||||||
},
|
|
||||||
.xapINEndpoint = {
|
|
||||||
.header = {
|
|
||||||
.bLength = sizeof(usbEndpointDescriptor_t),
|
|
||||||
.bDescriptorType = USBDESCR_ENDPOINT
|
|
||||||
},
|
|
||||||
.bEndpointAddress = (USBRQ_DIR_DEVICE_TO_HOST | USB_CFG_EP4_NUMBER),
|
|
||||||
.bmAttributes = 0x03,
|
|
||||||
.wMaxPacketSize = XAP_EPSIZE,
|
|
||||||
.bInterval = USB_POLLING_INTERVAL_MS
|
|
||||||
},
|
|
||||||
.xapOUTEndpoint = {
|
|
||||||
.header = {
|
|
||||||
.bLength = sizeof(usbEndpointDescriptor_t),
|
|
||||||
.bDescriptorType = USBDESCR_ENDPOINT
|
|
||||||
},
|
|
||||||
.bEndpointAddress = (USBRQ_DIR_HOST_TO_DEVICE | USB_CFG_EP4_NUMBER),
|
|
||||||
.bmAttributes = 0x03,
|
|
||||||
.wMaxPacketSize = XAP_EPSIZE,
|
|
||||||
.bInterval = USB_POLLING_INTERVAL_MS
|
|
||||||
},
|
|
||||||
# endif
|
# endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1216,6 +1216,13 @@ USB_PUBLIC usbMsgLen_t usbFunctionDescriptor(struct usbRequest *rq) {
|
|||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(XAP_ENABLE)
|
||||||
|
case XAP_INTERFACE:
|
||||||
|
usbMsgPtr = (usbMsgPtr_t)&usbConfigurationDescriptor.xapHID;
|
||||||
|
len = sizeof(usbHIDDescriptor_t);
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef SHARED_EP_ENABLE
|
#ifdef SHARED_EP_ENABLE
|
||||||
case SHARED_INTERFACE:
|
case SHARED_INTERFACE:
|
||||||
usbMsgPtr = (usbMsgPtr_t)&usbConfigurationDescriptor.sharedHID;
|
usbMsgPtr = (usbMsgPtr_t)&usbConfigurationDescriptor.sharedHID;
|
||||||
@ -1229,13 +1236,6 @@ USB_PUBLIC usbMsgLen_t usbFunctionDescriptor(struct usbRequest *rq) {
|
|||||||
len = sizeof(usbHIDDescriptor_t);
|
len = sizeof(usbHIDDescriptor_t);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(XAP_ENABLE)
|
|
||||||
case XAP_INTERFACE:
|
|
||||||
usbMsgPtr = (usbMsgPtr_t)&usbConfigurationDescriptor.xapHID;
|
|
||||||
len = sizeof(usbHIDDescriptor_t);
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case USBDESCR_HID_REPORT:
|
case USBDESCR_HID_REPORT:
|
||||||
@ -1255,6 +1255,13 @@ USB_PUBLIC usbMsgLen_t usbFunctionDescriptor(struct usbRequest *rq) {
|
|||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(XAP_ENABLE)
|
||||||
|
case XAP_INTERFACE:
|
||||||
|
usbMsgPtr = (usbMsgPtr_t)xap_report;
|
||||||
|
len = sizeof(xap_report);
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef SHARED_EP_ENABLE
|
#ifdef SHARED_EP_ENABLE
|
||||||
case SHARED_INTERFACE:
|
case SHARED_INTERFACE:
|
||||||
usbMsgPtr = (usbMsgPtr_t)shared_hid_report;
|
usbMsgPtr = (usbMsgPtr_t)shared_hid_report;
|
||||||
@ -1268,13 +1275,6 @@ USB_PUBLIC usbMsgLen_t usbFunctionDescriptor(struct usbRequest *rq) {
|
|||||||
len = sizeof(console_hid_report);
|
len = sizeof(console_hid_report);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(XAP_ENABLE)
|
|
||||||
case XAP_INTERFACE:
|
|
||||||
usbMsgPtr = (usbMsgPtr_t)xap_report;
|
|
||||||
len = sizeof(xap_report);
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -104,6 +104,13 @@ typedef struct usbConfigurationDescriptor {
|
|||||||
usbEndpointDescriptor_t rawOUTEndpoint;
|
usbEndpointDescriptor_t rawOUTEndpoint;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(XAP_ENABLE)
|
||||||
|
usbInterfaceDescriptor_t xapInterface;
|
||||||
|
usbHIDDescriptor_t xapHID;
|
||||||
|
usbEndpointDescriptor_t xapINEndpoint;
|
||||||
|
usbEndpointDescriptor_t xapOUTEndpoint;
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(SHARED_EP_ENABLE) && !defined(KEYBOARD_SHARED_EP)
|
#if defined(SHARED_EP_ENABLE) && !defined(KEYBOARD_SHARED_EP)
|
||||||
usbInterfaceDescriptor_t sharedInterface;
|
usbInterfaceDescriptor_t sharedInterface;
|
||||||
usbHIDDescriptor_t sharedHID;
|
usbHIDDescriptor_t sharedHID;
|
||||||
@ -116,13 +123,6 @@ typedef struct usbConfigurationDescriptor {
|
|||||||
usbEndpointDescriptor_t consoleINEndpoint;
|
usbEndpointDescriptor_t consoleINEndpoint;
|
||||||
usbEndpointDescriptor_t consoleOUTEndpoint;
|
usbEndpointDescriptor_t consoleOUTEndpoint;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(XAP_ENABLE)
|
|
||||||
usbInterfaceDescriptor_t xapInterface;
|
|
||||||
usbHIDDescriptor_t xapHID;
|
|
||||||
usbEndpointDescriptor_t xapINEndpoint;
|
|
||||||
usbEndpointDescriptor_t xapOUTEndpoint;
|
|
||||||
#endif
|
|
||||||
} __attribute__((packed)) usbConfigurationDescriptor_t;
|
} __attribute__((packed)) usbConfigurationDescriptor_t;
|
||||||
|
|
||||||
extern bool vusb_suspended;
|
extern bool vusb_suspended;
|
||||||
|
Loading…
Reference in New Issue
Block a user