Add JC65 ps2avrGB keyboard (#2351)
* Adds JC65 ps2avrGB keyboard * Adds default keymap * Adds personal keymap * Backlight On/off support Migrated code from the BFake. Functionality only on BL_ON, BL_OFF, BL_TOGG. * Backlighting config adjustment Only 1 level supported. * Personal keymap update BL toggle added and RGB layer updates. * Renamed jc65 ps2avrgb directory Renamed directory for more clarity. * Default keymap and default rules * Personal keymap and personal rules * Group JC65 QMK and PS2 versions Group JC65 QMK and PS2 versions, Split directories, Readme for parent folder. * Default keycaps and personal keymaps re-added Default and personal keymaps re-added. Keymaps, Readme, Rules.mk, and config.h * v32a default keymap rules Default to no. * RGB and Backlight default settings Set to yes. * Rules.mk defaults for personal keymap Rules.mk defaults for personal keymap * Revised keyboard readme make paths Revised. * Path correction * jc65 default folder set set default pcb to qmk version * default rules for v32a set to enable backlight and rgb by default.
This commit is contained in:
		
							parent
							
								
									8c2ae4a470
								
							
						
					
					
						commit
						a972b26274
					
				
					 40 changed files with 1164 additions and 134 deletions
				
			
		|  | @ -1,36 +1 @@ | ||||||
| #include "jc65.h" | #include "jc65.h" | ||||||
| 
 |  | ||||||
| void matrix_init_kb(void) { |  | ||||||
| 	// put your keyboard start-up code here
 |  | ||||||
| 	// runs once when the firmware starts up
 |  | ||||||
| 
 |  | ||||||
| 	matrix_init_user(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void matrix_scan_kb(void) { |  | ||||||
| 	// put your looping keyboard code here
 |  | ||||||
| 	// runs every cycle (a lot)
 |  | ||||||
| 
 |  | ||||||
| 	matrix_scan_user(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| bool process_record_kb(uint16_t keycode, keyrecord_t *record) { |  | ||||||
| 	// put your per-action keyboard code here
 |  | ||||||
| 	// runs for every action, just before processing by the firmware
 |  | ||||||
| 
 |  | ||||||
| 	return process_record_user(keycode, record); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void led_set_kb(uint8_t usb_led) { |  | ||||||
| 	// put your keyboard LED indicator (ex: Caps Lock LED) toggling code here
 |  | ||||||
|     if (usb_led & (1<<USB_LED_CAPS_LOCK)) { |  | ||||||
|         // output low
 |  | ||||||
|         DDRB |= (1<<2); |  | ||||||
|         PORTB &= ~(1<<2); |  | ||||||
|     } else { |  | ||||||
|         // Hi-Z
 |  | ||||||
|         DDRB &= ~(1<<2); |  | ||||||
|         PORTB &= ~(1<<2); |  | ||||||
|     } |  | ||||||
| 	led_set_user(usb_led); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  | @ -3,19 +3,12 @@ | ||||||
| 
 | 
 | ||||||
| #include "quantum.h" | #include "quantum.h" | ||||||
| 
 | 
 | ||||||
| #define KEYMAP( \ | #ifdef KEYBOARD_jc65_v32u4 | ||||||
|     K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, \ |     #include "v32u4.h" | ||||||
|      K10, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D,   K1E,   K1F, \ | #endif | ||||||
|       K20, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C,     K2D,     K2F, \ | 
 | ||||||
|      K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B,   K3D,   K3E, K3F, \ | #ifdef KEYBOARD_jc65_v32a | ||||||
|     K40,  K41,  K43,    K44,      K46,      K48,      K4A, K4B, K4C, K4D, K4E, K4F \ |     #include "v32a.h" | ||||||
| )\ | #endif | ||||||
| {\ |  | ||||||
|   {K00, K01,   K02,   K03, K04, K05,   K06, K07,   K08, K09,   K0A, K0B, K0C,   K0D, K0E,   K0F}, \ |  | ||||||
|   {K10, KC_NO, K12,   K13, K14, K15,   K16, K17,   K18, K19,   K1A, K1B, K1C,   K1D, K1E,   K1F}, \ |  | ||||||
|   {K20, KC_NO, K22,   K23, K24, K25,   K26, K27,   K28, K29,   K2A, K2B, K2C,   K2D, KC_NO, K2F}, \ |  | ||||||
|   {K30, K31,   K32,   K33, K34, K35,   K36, K37,   K38, K39,   K3A, K3B, KC_NO, K3D, K3E,   K3F}, \ |  | ||||||
|   {K40, K41,   KC_NO, K43, K44, KC_NO, K46, KC_NO, K48, KC_NO, K4A, K4B, K4C,   K4D, K4E,   K4F}, \ |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | @ -3,20 +3,12 @@ JC65 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
| 
 | 
 | ||||||
| The JC65 PCB actually has two revisions: A QMK native version, and a PS2AVRGB version. Jchan offered both PCBs as options during the M65-A Round 1 group buy, and were also available choices for the 65% acrylic case group buy. In the near future both PCB versions should be available from keyclack.com when the storefront part opens. | The JC65 PCB actually has two revisions: A QMK native version, and a PS2AVRGB version. Jchan offered both PCBs as options during the M65-A Round 1 group buy and are now currently available on [keyclack.com](https://keyclack.com/) | ||||||
| 
 | 
 | ||||||
| These docs are for the QMK version of the PCB. [More info on qmk.fm](http://qmk.fm/planck/) | Make example native QMK version (after setting up your build environment): | ||||||
| 
 | 
 | ||||||
| Keyboard Maintainer: [Ethan Madden](https://github.com/jetpacktuxedo) |     make jc65/v32u4:default | ||||||
| Hardware Supported: JC65 rev.qmk |  | ||||||
| Hardware Availability: [keyclack.com](https://keyclack.com/) |  | ||||||
| 
 | 
 | ||||||
| Make example for this keyboard (after setting up your build environment): | Make example ps2avrGB version (after setting up your build environment): | ||||||
| 
 | 
 | ||||||
|     make jc65:default |     make jc65/v32a:default | ||||||
| 
 |  | ||||||
| Or to make and flash: |  | ||||||
| 
 |  | ||||||
|     make jc65:default:dfu |  | ||||||
| 
 |  | ||||||
| See [build environment setup](https://docs.qmk.fm/build_environment_setup.html) then the [make instructions](https://docs.qmk.fm/make_instructions.html) for more information. |  | ||||||
|  | @ -1,68 +1 @@ | ||||||
| # MCU name
 | DEFAULT_FOLDER = jc65/v32u4 | ||||||
| #MCU = at90usb1287
 |  | ||||||
| MCU = atmega32u4 |  | ||||||
| 
 |  | ||||||
| # Processor frequency.
 |  | ||||||
| #     This will define a symbol, F_CPU, in all source code files equal to the
 |  | ||||||
| #     processor frequency in Hz. You can then use this symbol in your source code to
 |  | ||||||
| #     calculate timings. Do NOT tack on a 'UL' at the end, this will be done
 |  | ||||||
| #     automatically to create a 32-bit value in your source code.
 |  | ||||||
| #
 |  | ||||||
| #     This will be an integer division of F_USB below, as it is sourced by
 |  | ||||||
| #     F_USB after it has run through any CPU prescalers. Note that this value
 |  | ||||||
| #     does not *change* the processor frequency - it should merely be updated to
 |  | ||||||
| #     reflect the processor speed set externally so that the code can use accurate
 |  | ||||||
| #     software delays.
 |  | ||||||
| F_CPU = 16000000 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| #
 |  | ||||||
| # LUFA specific
 |  | ||||||
| #
 |  | ||||||
| # Target architecture (see library "Board Types" documentation).
 |  | ||||||
| ARCH = AVR8 |  | ||||||
| 
 |  | ||||||
| # Input clock frequency.
 |  | ||||||
| #     This will define a symbol, F_USB, in all source code files equal to the
 |  | ||||||
| #     input clock frequency (before any prescaling is performed) in Hz. This value may
 |  | ||||||
| #     differ from F_CPU if prescaling is used on the latter, and is required as the
 |  | ||||||
| #     raw input clock is fed directly to the PLL sections of the AVR for high speed
 |  | ||||||
| #     clock generation for the USB and other AVR subsections. Do NOT tack on a 'UL'
 |  | ||||||
| #     at the end, this will be done automatically to create a 32-bit value in your
 |  | ||||||
| #     source code.
 |  | ||||||
| #
 |  | ||||||
| #     If no clock division is performed on the input clock inside the AVR (via the
 |  | ||||||
| #     CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU.
 |  | ||||||
| F_USB = $(F_CPU) |  | ||||||
| 
 |  | ||||||
| # Interrupt driven control endpoint task(+60)
 |  | ||||||
| OPT_DEFS += -DINTERRUPT_CONTROL_ENDPOINT |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| # Boot Section Size in *bytes*
 |  | ||||||
| #   Teensy halfKay   512
 |  | ||||||
| #   Teensy++ halfKay 1024
 |  | ||||||
| #   Atmel DFU loader 4096
 |  | ||||||
| #   LUFA bootloader  4096
 |  | ||||||
| #   USBaspLoader     2048
 |  | ||||||
| OPT_DEFS += -DBOOTLOADER_SIZE=4096 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| # Build Options
 |  | ||||||
| #   change yes to no to disable
 |  | ||||||
| #
 |  | ||||||
| BOOTMAGIC_ENABLE = no      # Virtual DIP switch configuration(+1000) |  | ||||||
| MOUSEKEY_ENABLE = yes       # Mouse keys(+4700) |  | ||||||
| EXTRAKEY_ENABLE = yes       # Audio control and System control(+450) |  | ||||||
| CONSOLE_ENABLE = no        # Console for debug(+400) |  | ||||||
| COMMAND_ENABLE = no        # Commands for debug and configuration |  | ||||||
| # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE
 |  | ||||||
| SLEEP_LED_ENABLE = no       # Breathing sleep LED during USB suspend |  | ||||||
| # if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work
 |  | ||||||
| NKRO_ENABLE = yes           # USB Nkey Rollover |  | ||||||
| BACKLIGHT_ENABLE = yes       # Enable keyboard backlight functionality on B7 by default |  | ||||||
| RGBLIGHT_ENABLE = yes |  | ||||||
| MIDI_ENABLE = no            # MIDI controls |  | ||||||
| UNICODE_ENABLE = no         # Unicode |  | ||||||
| BLUETOOTH_ENABLE = no       # Enable Bluetooth with the Adafruit EZ-Key HID |  | ||||||
| AUDIO_ENABLE = no           # Audio output on port C6 |  | ||||||
							
								
								
									
										46
									
								
								keyboards/jc65/v32a/config.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								keyboards/jc65/v32a/config.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,46 @@ | ||||||
|  | /*
 | ||||||
|  | Copyright 2017 Luiz Ribeiro <luizribeiro@gmail.com> | ||||||
|  | 
 | ||||||
|  | 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/>.
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | #ifndef CONFIG_H | ||||||
|  | #define CONFIG_H | ||||||
|  | 
 | ||||||
|  | #include "config_common.h" | ||||||
|  | 
 | ||||||
|  | #define VENDOR_ID       0x1234 | ||||||
|  | #define PRODUCT_ID      0x5679 | ||||||
|  | #define MANUFACTURER    winkeyless.kr | ||||||
|  | #define PRODUCT         JC65 PS2AVRGB | ||||||
|  | 
 | ||||||
|  | /* matrix size */ | ||||||
|  | #define MATRIX_ROWS 8 | ||||||
|  | #define MATRIX_COLS 16 | ||||||
|  | 
 | ||||||
|  | #define NO_BACKLIGHT_CLOCK | ||||||
|  | #define BACKLIGHT_LEVELS 1 | ||||||
|  | #define RGBLED_NUM 16 | ||||||
|  | #define RGBLIGHT_ANIMATIONS | ||||||
|  | #define RGBLIGHT_HUE_STEP 8 | ||||||
|  | #define RGBLIGHT_SAT_STEP 8 | ||||||
|  | #define RGBLIGHT_VAL_STEP 8 | ||||||
|  | #define RGBLIGHT_EFFECT_KNIGHT_LED_NUM 8 | ||||||
|  | 
 | ||||||
|  | #define NO_UART 1 | ||||||
|  | 
 | ||||||
|  | /* key combination for command */ | ||||||
|  | #define IS_COMMAND() (keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT))) | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
							
								
								
									
										106
									
								
								keyboards/jc65/v32a/i2c.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								keyboards/jc65/v32a/i2c.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,106 @@ | ||||||
|  | /*
 | ||||||
|  | Copyright 2016 Luiz Ribeiro <luizribeiro@gmail.com> | ||||||
|  | 
 | ||||||
|  | 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/>.
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | // Please do not modify this file 
 | ||||||
|  | 
 | ||||||
|  | #include <avr/io.h> | ||||||
|  | #include <util/twi.h> | ||||||
|  | 
 | ||||||
|  | #include "i2c.h" | ||||||
|  | 
 | ||||||
|  | void i2c_set_bitrate(uint16_t bitrate_khz) { | ||||||
|  |     uint8_t bitrate_div = ((F_CPU / 1000l) / bitrate_khz); | ||||||
|  |     if (bitrate_div >= 16) { | ||||||
|  |         bitrate_div = (bitrate_div - 16) / 2; | ||||||
|  |     } | ||||||
|  |     TWBR = bitrate_div; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void i2c_init(void) { | ||||||
|  |     // set pull-up resistors on I2C bus pins
 | ||||||
|  |     PORTC |= 0b11; | ||||||
|  | 
 | ||||||
|  |     i2c_set_bitrate(400); | ||||||
|  | 
 | ||||||
|  |     // enable TWI (two-wire interface)
 | ||||||
|  |     TWCR |= (1 << TWEN); | ||||||
|  | 
 | ||||||
|  |     // enable TWI interrupt and slave address ACK
 | ||||||
|  |     TWCR |= (1 << TWIE); | ||||||
|  |     TWCR |= (1 << TWEA); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | uint8_t i2c_start(uint8_t address) { | ||||||
|  |     // reset TWI control register
 | ||||||
|  |     TWCR = 0; | ||||||
|  | 
 | ||||||
|  |     // begin transmission and wait for it to end
 | ||||||
|  |     TWCR = (1<<TWINT) | (1<<TWSTA) | (1<<TWEN); | ||||||
|  |     while (!(TWCR & (1<<TWINT))); | ||||||
|  | 
 | ||||||
|  |     // check if the start condition was successfully transmitted
 | ||||||
|  |     if ((TWSR & 0xF8) != TW_START) { | ||||||
|  |         return 1; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // transmit address and wait
 | ||||||
|  |     TWDR = address; | ||||||
|  |     TWCR = (1<<TWINT) | (1<<TWEN); | ||||||
|  |     while (!(TWCR & (1<<TWINT))); | ||||||
|  | 
 | ||||||
|  |     // check if the device has acknowledged the READ / WRITE mode
 | ||||||
|  |     uint8_t twst = TW_STATUS & 0xF8; | ||||||
|  |     if ((twst != TW_MT_SLA_ACK) && (twst != TW_MR_SLA_ACK)) { | ||||||
|  |         return 1; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void i2c_stop(void) { | ||||||
|  |     TWCR = (1<<TWINT) | (1<<TWEN) | (1<<TWSTO); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | uint8_t i2c_write(uint8_t data) { | ||||||
|  |     TWDR = data; | ||||||
|  | 
 | ||||||
|  |     // transmit data and wait
 | ||||||
|  |     TWCR = (1<<TWINT) | (1<<TWEN); | ||||||
|  |     while (!(TWCR & (1<<TWINT))); | ||||||
|  | 
 | ||||||
|  |     if ((TWSR & 0xF8) != TW_MT_DATA_ACK) { | ||||||
|  |         return 1; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | uint8_t i2c_send(uint8_t address, uint8_t *data, uint16_t length) { | ||||||
|  |     if (i2c_start(address)) { | ||||||
|  |         return 1; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     for (uint16_t i = 0; i < length; i++) { | ||||||
|  |         if (i2c_write(data[i])) { | ||||||
|  |             return 1; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     i2c_stop(); | ||||||
|  | 
 | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
							
								
								
									
										27
									
								
								keyboards/jc65/v32a/i2c.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								keyboards/jc65/v32a/i2c.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,27 @@ | ||||||
|  | /*
 | ||||||
|  | Copyright 2016 Luiz Ribeiro <luizribeiro@gmail.com> | ||||||
|  | 
 | ||||||
|  | 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/>.
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | // Please do not modify this file 
 | ||||||
|  | 
 | ||||||
|  | #ifndef __I2C_H__ | ||||||
|  | #define __I2C_H__ | ||||||
|  | 
 | ||||||
|  | void i2c_init(void); | ||||||
|  | void i2c_set_bitrate(uint16_t bitrate_khz); | ||||||
|  | uint8_t i2c_send(uint8_t address, uint8_t *data, uint16_t length); | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
							
								
								
									
										11
									
								
								keyboards/jc65/v32a/keymaps/default/keymap.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								keyboards/jc65/v32a/keymaps/default/keymap.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,11 @@ | ||||||
|  | #include "v32a.h" | ||||||
|  | 
 | ||||||
|  | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||||
|  |     [0] = KEYMAP(         | ||||||
|  |         KC_GESC,   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_BSLS,KC_BSPC, KC_INS, | ||||||
|  |          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_CAPS,   KC_A,   KC_S,   KC_D,   KC_F,   KC_G,   KC_H,   KC_J,   KC_K,   KC_L,KC_SCLN,KC_QUOT,KC_NUHS,         KC_ENT,KC_PGUP, | ||||||
|  |         KC_LSFT,KC_NUBS,   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_PGDN, | ||||||
|  |         KC_LCTL,KC_LGUI,KC_LALT,         KC_SPC, KC_SPC, KC_SPC,                        KC_RALT,KC_RGUI,KC_RCTL,KC_LEFT,KC_DOWN,KC_RGHT | ||||||
|  |     ), | ||||||
|  | }; | ||||||
							
								
								
									
										10
									
								
								keyboards/jc65/v32a/keymaps/default/readme.md
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								keyboards/jc65/v32a/keymaps/default/readme.md
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,10 @@ | ||||||
|  | Default Keymap | ||||||
|  | ======= | ||||||
|  | 
 | ||||||
|  | Default plain keymap with only a base layer. | ||||||
|  | 
 | ||||||
|  | Keymap Maintainer: [Jason Barnachea](https://github.com/nautxx) | ||||||
|  | 
 | ||||||
|  | Difference from base layout: None. | ||||||
|  | 
 | ||||||
|  | Intended usage: Reference layout. | ||||||
							
								
								
									
										2
									
								
								keyboards/jc65/v32a/keymaps/default/rules.mk
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								keyboards/jc65/v32a/keymaps/default/rules.mk
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,2 @@ | ||||||
|  | RGBLIGHT_ENABLE = yes | ||||||
|  | BACKLIGHT_ENABLE = yes | ||||||
							
								
								
									
										81
									
								
								keyboards/jc65/v32a/keymaps/naut/keymap.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								keyboards/jc65/v32a/keymaps/naut/keymap.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,81 @@ | ||||||
|  | #include "v32a.h" | ||||||
|  | 
 | ||||||
|  | // Define Layers
 | ||||||
|  | #define _BASE 0 | ||||||
|  | #define _FNX  1 | ||||||
|  | #define _MAC  2 | ||||||
|  | #define _RGB  3 | ||||||
|  | 
 | ||||||
|  | // Define Macros
 | ||||||
|  | #define M_PRTS  M(0) | ||||||
|  | #define M_PRTA  M(1) | ||||||
|  | #define M_MSSN  M(2) | ||||||
|  | #define M_APPS  M(3) | ||||||
|  | #define M_SPOT  M(4) | ||||||
|  | #define M_LEFT  M(5) | ||||||
|  | #define M_RGHT  M(6) | ||||||
|  | 
 | ||||||
|  | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||||
|  |     // Base Layer
 | ||||||
|  |     [_BASE] = KEYMAP( | ||||||
|  |          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_BSLS, KC_GRV, KC_INS, | ||||||
|  |          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_BSPC, KC_DEL, | ||||||
|  |         KC_LCTL,   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,KC_PGUP, | ||||||
|  |         KC_LSFT,  KC_NO,   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_PGDN, | ||||||
|  |           MO(1),KC_LALT,KC_LGUI,         KC_SPC, KC_SPC, KC_SPC,                        KC_RGUI,  KC_NO,KC_RALT,KC_LEFT,KC_DOWN,KC_RGHT | ||||||
|  |     ), | ||||||
|  |     // Fn Layer
 | ||||||
|  |     [_FNX] = KEYMAP( | ||||||
|  |         KC_TRNS,  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_TRNS,KC_TRNS,  TG(3), | ||||||
|  |         KC_CAPS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,        KC_TRNS,KC_TRNS, | ||||||
|  |         KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,        KC_TRNS,KC_TRNS, | ||||||
|  |         KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,          TG(2),KC_VOLU,KC_MPLY, | ||||||
|  |         KC_TRNS,KC_TRNS,KC_TRNS,        KC_TRNS,KC_TRNS,KC_TRNS,                        KC_TRNS,KC_TRNS,KC_TRNS,KC_MRWD,KC_VOLD,KC_MFFD | ||||||
|  |     ), | ||||||
|  |     // Mac Layer
 | ||||||
|  |     [_MAC] = KEYMAP( | ||||||
|  |           TO(0), KC_F14, KC_F15, M_APPS, M_MSSN, KC_F11, KC_F12,KC_MRWD,KC_MPLY,KC_MFFD,KC_MUTE,KC_VOLD,KC_VOLU,KC_EJCT,  KC_NO,  KC_NO, | ||||||
|  |         KC_TRNS, M_PRTS, M_PRTA,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,        KC_TRNS,KC_TRNS, | ||||||
|  |         KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,        KC_TRNS,KC_TRNS, | ||||||
|  |         KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,KC_TRNS,          TO(0), M_MSSN,KC_TRNS, | ||||||
|  |         KC_TRNS,KC_TRNS,KC_TRNS,         M_SPOT, M_SPOT, M_SPOT,                        KC_TRNS,KC_TRNS,KC_TRNS, M_LEFT, M_APPS, M_RGHT | ||||||
|  |     ), | ||||||
|  |     // RGB and BL Layer
 | ||||||
|  |     [_RGB] = KEYMAP( | ||||||
|  |           TO(0),  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  TO(0), | ||||||
|  |           KC_NO,RGB_HUD,RGB_HUI,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,          KC_NO,BL_TOGG, | ||||||
|  |           KC_NO,RGB_SAD,RGB_SAI,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,          KC_NO,RGB_TOG, | ||||||
|  |           KC_NO,  KC_NO,RGB_VAD,RGB_VAI,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,  KC_NO,RGB_MOD,RGB_RMOD,         KC_NO,RGB_M_P,RGB_M_R, | ||||||
|  |           KC_NO,  KC_NO,  KC_NO,          KC_NO,  KC_NO,  KC_NO,                          KC_NO,  KC_NO,  KC_NO,  KC_NO,RGB_M_G,RGB_M_SW | ||||||
|  |     ), | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | // The Macros
 | ||||||
|  | const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||||||
|  |     if (record->event.pressed) { | ||||||
|  |         switch(id) { | ||||||
|  |             case 0: | ||||||
|  |                 return MACRO(D(LGUI), D(LSFT), T(3), U(LSFT), U(LGUI), END); //Mac print screen
 | ||||||
|  |                 break; | ||||||
|  |             case 1: | ||||||
|  |                 return MACRO(D(LGUI), D(LSFT), T(4), U(LSFT), U(LGUI), END); //Mac print area
 | ||||||
|  |                 break; | ||||||
|  |             case 2: | ||||||
|  |                 return MACRO(D(LCTL), T(UP), U(LCTL), END);                  //Mac mission control
 | ||||||
|  |                 break; | ||||||
|  |             case 3: | ||||||
|  |                 return MACRO(D(LCTL), T(DOWN), U(LCTL), END);                //Mac applications
 | ||||||
|  |                 break; | ||||||
|  |             case 4: | ||||||
|  |                 return MACRO(D(LGUI), T(SPC), U(LGUI), END);                 //Mac spotlight search
 | ||||||
|  |                 break; | ||||||
|  |             case 5: | ||||||
|  |                 return MACRO(D(LCTL), T(LEFT), U(LCTL), END);                //Mac mission left
 | ||||||
|  |                 break; | ||||||
|  |             case 6: | ||||||
|  |                 return MACRO(D(LGUI), T(RGHT), U(LGUI), END);                //Mac mission right
 | ||||||
|  |                 break; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return MACRO_NONE; | ||||||
|  | }; | ||||||
							
								
								
									
										16
									
								
								keyboards/jc65/v32a/keymaps/naut/readme.md
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								keyboards/jc65/v32a/keymaps/naut/readme.md
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,16 @@ | ||||||
|  | Naut's Keymap | ||||||
|  | ======= | ||||||
|  |   | ||||||
|  | Layer 1: HHKB Split backspace, 6.25u space, control on caps, Fn on L-Ctl. | ||||||
|  | 
 | ||||||
|  | Layer 2: F Row on numrow, caps on tab, media shortcuts on arrows | ||||||
|  | 
 | ||||||
|  | Layer 3: Mac Media buttons on numrow | ||||||
|  | 
 | ||||||
|  | Layer 4: RGB control | ||||||
|  | 
 | ||||||
|  | Keymap Maintainer: [Jason Barnachea](https://github.com/nautxx) | ||||||
|  | 
 | ||||||
|  | Difference from base layout: HHKBish layout. HHKB Fn layer. Mac media layer. RGB control layer. | ||||||
|  | 
 | ||||||
|  | Intended usage: Daily driver for keyboard peacocking.  | ||||||
							
								
								
									
										2
									
								
								keyboards/jc65/v32a/keymaps/naut/rules.mk
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								keyboards/jc65/v32a/keymaps/naut/rules.mk
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,2 @@ | ||||||
|  | RGBLIGHT_ENABLE = yes | ||||||
|  | BACKLIGHT_ENABLE = yes | ||||||
							
								
								
									
										106
									
								
								keyboards/jc65/v32a/matrix.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								keyboards/jc65/v32a/matrix.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,106 @@ | ||||||
|  | /*
 | ||||||
|  | Copyright 2017 Luiz Ribeiro <luizribeiro@gmail.com> | ||||||
|  | 
 | ||||||
|  | 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 <avr/io.h> | ||||||
|  | #include <util/delay.h> | ||||||
|  | 
 | ||||||
|  | #include "matrix.h" | ||||||
|  | 
 | ||||||
|  | #ifndef DEBOUNCE | ||||||
|  | #define DEBOUNCE	5 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | static uint8_t debouncing = DEBOUNCE; | ||||||
|  | 
 | ||||||
|  | static matrix_row_t matrix[MATRIX_ROWS]; | ||||||
|  | static matrix_row_t matrix_debouncing[MATRIX_ROWS]; | ||||||
|  | 
 | ||||||
|  | void matrix_init(void) { | ||||||
|  |     // all outputs for rows high
 | ||||||
|  |     DDRB = 0xFF; | ||||||
|  |     PORTB = 0xFF; | ||||||
|  |     // all inputs for columns
 | ||||||
|  |     DDRA = 0x00; | ||||||
|  |     DDRC &= ~(0x111111<<2); | ||||||
|  |     DDRD &= ~(1<<PIND7); | ||||||
|  |     // all columns are pulled-up
 | ||||||
|  |     PORTA = 0xFF; | ||||||
|  |     PORTC |= (0b111111<<2); | ||||||
|  |     PORTD |= (1<<PIND7); | ||||||
|  | 
 | ||||||
|  |     // initialize matrix state: all keys off
 | ||||||
|  |     for (uint8_t row = 0; row < MATRIX_ROWS; row++) { | ||||||
|  |         matrix[row] = 0x00; | ||||||
|  |         matrix_debouncing[row] = 0x00; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void matrix_set_row_status(uint8_t row) { | ||||||
|  |     DDRB = (1 << row); | ||||||
|  |     PORTB = ~(1 << row); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | uint8_t bit_reverse(uint8_t x) { | ||||||
|  |     x = ((x >> 1) & 0x55) | ((x << 1) & 0xaa); | ||||||
|  |     x = ((x >> 2) & 0x33) | ((x << 2) & 0xcc); | ||||||
|  |     x = ((x >> 4) & 0x0f) | ((x << 4) & 0xf0); | ||||||
|  |     return x; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | uint8_t matrix_scan(void) { | ||||||
|  |     for (uint8_t row = 0; row < MATRIX_ROWS; row++) { | ||||||
|  |         matrix_set_row_status(row); | ||||||
|  |         _delay_us(5); | ||||||
|  | 
 | ||||||
|  |         matrix_row_t cols = ( | ||||||
|  |             // cols 0..7, PORTA 0 -> 7
 | ||||||
|  |             (~PINA) & 0xFF | ||||||
|  |         ) | ( | ||||||
|  |             // cols 8..13, PORTC 7 -> 0
 | ||||||
|  |             bit_reverse((~PINC) & 0xFF) << 8 | ||||||
|  |         ) | ( | ||||||
|  |             // col 14, PORTD 7
 | ||||||
|  |             ((~PIND) & (1 << PIND7)) << 7 | ||||||
|  |         ); | ||||||
|  | 
 | ||||||
|  |         if (matrix_debouncing[row] != cols) { | ||||||
|  |             matrix_debouncing[row] = cols; | ||||||
|  |             debouncing = DEBOUNCE; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if (debouncing) { | ||||||
|  |         if (--debouncing) { | ||||||
|  |             _delay_ms(1); | ||||||
|  |         } else { | ||||||
|  |             for (uint8_t i = 0; i < MATRIX_ROWS; i++) { | ||||||
|  |                 matrix[i] = matrix_debouncing[i]; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     matrix_scan_user(); | ||||||
|  | 
 | ||||||
|  |     return 1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | inline matrix_row_t matrix_get_row(uint8_t row) { | ||||||
|  |     return matrix[row]; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void matrix_print(void) { | ||||||
|  | } | ||||||
							
								
								
									
										24
									
								
								keyboards/jc65/v32a/readme.md
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								keyboards/jc65/v32a/readme.md
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,24 @@ | ||||||
|  | JC65 ps2avrGB | ||||||
|  | ======= | ||||||
|  | 
 | ||||||
|  | A 65% keyboard with RGB | ||||||
|  | 
 | ||||||
|  | Keyboard Maintainer: [Jason Barnachea](https://github.com/nautxx) | ||||||
|  | 
 | ||||||
|  | Hardware Supported: JC65 rev.ps2avrgb | ||||||
|  | 
 | ||||||
|  | Hardware Availability: [keyclack.com](https://keyclack.com/) | ||||||
|  | 
 | ||||||
|  | The JC65 PCB actually has two revisions: A QMK native version, and a PS2AVRGB version. Jchan offered both PCBs as options during the M65-A Round 1 group buy, and were also available choices for the 65% acrylic case group buy. In the near future both PCB versions should be available from keyclack.com when the storefront part opens. | ||||||
|  | 
 | ||||||
|  | These docs are for the PS2AVRGB version of the PCB. More info on qmk.fm | ||||||
|  | 
 | ||||||
|  | Make example for this keyboard (after setting up your build environment): | ||||||
|  | 
 | ||||||
|  |     make jc65/v32a:default | ||||||
|  |      | ||||||
|  | Flash example for this keyboard: | ||||||
|  | 
 | ||||||
|  |     bootloadHID -r jc65_v32a_default.hex | ||||||
|  | 
 | ||||||
|  | See [build environment setup](https://docs.qmk.fm/build_environment_setup.html) then the [make instructions](https://docs.qmk.fm/make_instructions.html) for more information. | ||||||
							
								
								
									
										50
									
								
								keyboards/jc65/v32a/rules.mk
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								keyboards/jc65/v32a/rules.mk
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,50 @@ | ||||||
|  | # Copyright 2017 Luiz Ribeiro <luizribeiro@gmail.com>
 | ||||||
|  | #
 | ||||||
|  | # 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/>.
 | ||||||
|  | 
 | ||||||
|  | # MCU name
 | ||||||
|  | MCU = atmega32a | ||||||
|  | PROTOCOL = VUSB | ||||||
|  | 
 | ||||||
|  | # unsupported features for now
 | ||||||
|  | NO_UART = yes | ||||||
|  | NO_SUSPEND_POWER_DOWN = yes | ||||||
|  | 
 | ||||||
|  | # processor frequency
 | ||||||
|  | F_CPU = 12000000 | ||||||
|  | 
 | ||||||
|  | # Bootloader
 | ||||||
|  | #     This definition is optional, and if your keyboard supports multiple bootloaders of
 | ||||||
|  | #     different sizes, comment this out, and the correct address will be loaded 
 | ||||||
|  | #     automatically (+60). See bootloader.mk for all options.
 | ||||||
|  | BOOTLOADER = bootloadHID | ||||||
|  | 
 | ||||||
|  | # build options
 | ||||||
|  | BOOTMAGIC_ENABLE = yes | ||||||
|  | MOUSEKEY_ENABLE = yes | ||||||
|  | EXTRAKEY_ENABLE = yes | ||||||
|  | CONSOLE_ENABLE = yes | ||||||
|  | COMMAND_ENABLE = yes | ||||||
|  | BACKLIGHT_ENABLE = yes | ||||||
|  | RGBLIGHT_ENABLE = yes | ||||||
|  | RGBLIGHT_CUSTOM_DRIVER = yes | ||||||
|  | 
 | ||||||
|  | OPT_DEFS = -DDEBUG_LEVEL=0 | ||||||
|  | 
 | ||||||
|  | # custom matrix setup
 | ||||||
|  | CUSTOM_MATRIX = yes | ||||||
|  | SRC = matrix.c i2c.c | ||||||
|  | 
 | ||||||
|  | # programming options
 | ||||||
|  | PROGRAM_CMD = ./util/atmega32a_program.py $(TARGET).hex | ||||||
							
								
								
									
										396
									
								
								keyboards/jc65/v32a/usbconfig.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										396
									
								
								keyboards/jc65/v32a/usbconfig.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,396 @@ | ||||||
|  | /* Name: usbconfig.h
 | ||||||
|  |  * Project: V-USB, virtual USB port for Atmel's(r) AVR(r) microcontrollers | ||||||
|  |  * Author: Christian Starkjohann | ||||||
|  |  * Creation Date: 2005-04-01 | ||||||
|  |  * Tabsize: 4 | ||||||
|  |  * Copyright: (c) 2005 by OBJECTIVE DEVELOPMENT Software GmbH | ||||||
|  |  * License: GNU GPL v2 (see License.txt), GNU GPL v3 or proprietary (CommercialLicense.txt) | ||||||
|  |  * This Revision: $Id: usbconfig-prototype.h 785 2010-05-30 17:57:07Z cs $ | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | #ifndef __usbconfig_h_included__ | ||||||
|  | #define __usbconfig_h_included__ | ||||||
|  | 
 | ||||||
|  | #include "config.h" | ||||||
|  | 
 | ||||||
|  | /*
 | ||||||
|  | General Description: | ||||||
|  | This file is an example configuration (with inline documentation) for the USB | ||||||
|  | driver. It configures V-USB for USB D+ connected to Port D bit 2 (which is | ||||||
|  | also hardware interrupt 0 on many devices) and USB D- to Port D bit 4. You may | ||||||
|  | wire the lines to any other port, as long as D+ is also wired to INT0 (or any | ||||||
|  | other hardware interrupt, as long as it is the highest level interrupt, see | ||||||
|  | section at the end of this file). | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | /* ---------------------------- Hardware Config ---------------------------- */ | ||||||
|  | 
 | ||||||
|  | #define USB_CFG_IOPORTNAME      D | ||||||
|  | /* This is the port where the USB bus is connected. When you configure it to
 | ||||||
|  |  * "B", the registers PORTB, PINB and DDRB will be used. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_DMINUS_BIT      3 | ||||||
|  | /* This is the bit number in USB_CFG_IOPORT where the USB D- line is connected.
 | ||||||
|  |  * This may be any bit in the port. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_DPLUS_BIT       2 | ||||||
|  | /* This is the bit number in USB_CFG_IOPORT where the USB D+ line is connected.
 | ||||||
|  |  * This may be any bit in the port. Please note that D+ must also be connected | ||||||
|  |  * to interrupt pin INT0! [You can also use other interrupts, see section | ||||||
|  |  * "Optional MCU Description" below, or you can connect D- to the interrupt, as | ||||||
|  |  * it is required if you use the USB_COUNT_SOF feature. If you use D- for the | ||||||
|  |  * interrupt, the USB interrupt will also be triggered at Start-Of-Frame | ||||||
|  |  * markers every millisecond.] | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_CLOCK_KHZ       (F_CPU/1000) | ||||||
|  | /* Clock rate of the AVR in kHz. Legal values are 12000, 12800, 15000, 16000,
 | ||||||
|  |  * 16500, 18000 and 20000. The 12.8 MHz and 16.5 MHz versions of the code | ||||||
|  |  * require no crystal, they tolerate +/- 1% deviation from the nominal | ||||||
|  |  * frequency. All other rates require a precision of 2000 ppm and thus a | ||||||
|  |  * crystal! | ||||||
|  |  * Since F_CPU should be defined to your actual clock rate anyway, you should | ||||||
|  |  * not need to modify this setting. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_CHECK_CRC       0 | ||||||
|  | /* Define this to 1 if you want that the driver checks integrity of incoming
 | ||||||
|  |  * data packets (CRC checks). CRC checks cost quite a bit of code size and are | ||||||
|  |  * currently only available for 18 MHz crystal clock. You must choose | ||||||
|  |  * USB_CFG_CLOCK_KHZ = 18000 if you enable this option. | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | /* ----------------------- Optional Hardware Config ------------------------ */ | ||||||
|  | 
 | ||||||
|  | /* #define USB_CFG_PULLUP_IOPORTNAME   D */ | ||||||
|  | /* If you connect the 1.5k pullup resistor from D- to a port pin instead of
 | ||||||
|  |  * V+, you can connect and disconnect the device from firmware by calling | ||||||
|  |  * the macros usbDeviceConnect() and usbDeviceDisconnect() (see usbdrv.h). | ||||||
|  |  * This constant defines the port on which the pullup resistor is connected. | ||||||
|  |  */ | ||||||
|  | /* #define USB_CFG_PULLUP_BIT          4 */ | ||||||
|  | /* This constant defines the bit number in USB_CFG_PULLUP_IOPORT (defined
 | ||||||
|  |  * above) where the 1.5k pullup resistor is connected. See description | ||||||
|  |  * above for details. | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | /* --------------------------- Functional Range ---------------------------- */ | ||||||
|  | 
 | ||||||
|  | #define USB_CFG_HAVE_INTRIN_ENDPOINT    1 | ||||||
|  | /* Define this to 1 if you want to compile a version with two endpoints: The
 | ||||||
|  |  * default control endpoint 0 and an interrupt-in endpoint (any other endpoint | ||||||
|  |  * number). | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_HAVE_INTRIN_ENDPOINT3   1 | ||||||
|  | /* Define this to 1 if you want to compile a version with three endpoints: The
 | ||||||
|  |  * default control endpoint 0, an interrupt-in endpoint 3 (or the number | ||||||
|  |  * configured below) and a catch-all default interrupt-in endpoint as above. | ||||||
|  |  * You must also define USB_CFG_HAVE_INTRIN_ENDPOINT to 1 for this feature. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_EP3_NUMBER              3 | ||||||
|  | /* If the so-called endpoint 3 is used, it can now be configured to any other
 | ||||||
|  |  * endpoint number (except 0) with this macro. Default if undefined is 3. | ||||||
|  |  */ | ||||||
|  | /* #define USB_INITIAL_DATATOKEN           USBPID_DATA1 */ | ||||||
|  | /* The above macro defines the startup condition for data toggling on the
 | ||||||
|  |  * interrupt/bulk endpoints 1 and 3. Defaults to USBPID_DATA1. | ||||||
|  |  * Since the token is toggled BEFORE sending any data, the first packet is | ||||||
|  |  * sent with the oposite value of this configuration! | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_IMPLEMENT_HALT          0 | ||||||
|  | /* Define this to 1 if you also want to implement the ENDPOINT_HALT feature
 | ||||||
|  |  * for endpoint 1 (interrupt endpoint). Although you may not need this feature, | ||||||
|  |  * it is required by the standard. We have made it a config option because it | ||||||
|  |  * bloats the code considerably. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_SUPPRESS_INTR_CODE      0 | ||||||
|  | /* Define this to 1 if you want to declare interrupt-in endpoints, but don't
 | ||||||
|  |  * want to send any data over them. If this macro is defined to 1, functions | ||||||
|  |  * usbSetInterrupt() and usbSetInterrupt3() are omitted. This is useful if | ||||||
|  |  * you need the interrupt-in endpoints in order to comply to an interface | ||||||
|  |  * (e.g. HID), but never want to send any data. This option saves a couple | ||||||
|  |  * of bytes in flash memory and the transmit buffers in RAM. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_INTR_POLL_INTERVAL      1 | ||||||
|  | /* If you compile a version with endpoint 1 (interrupt-in), this is the poll
 | ||||||
|  |  * interval. The value is in milliseconds and must not be less than 10 ms for | ||||||
|  |  * low speed devices. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_IS_SELF_POWERED         0 | ||||||
|  | /* Define this to 1 if the device has its own power supply. Set it to 0 if the
 | ||||||
|  |  * device is powered from the USB bus. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_MAX_BUS_POWER           500 | ||||||
|  | /* Set this variable to the maximum USB bus power consumption of your device.
 | ||||||
|  |  * The value is in milliamperes. [It will be divided by two since USB | ||||||
|  |  * communicates power requirements in units of 2 mA.] | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_IMPLEMENT_FN_WRITE      1 | ||||||
|  | /* Set this to 1 if you want usbFunctionWrite() to be called for control-out
 | ||||||
|  |  * transfers. Set it to 0 if you don't need it and want to save a couple of | ||||||
|  |  * bytes. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_IMPLEMENT_FN_READ       0 | ||||||
|  | /* Set this to 1 if you need to send control replies which are generated
 | ||||||
|  |  * "on the fly" when usbFunctionRead() is called. If you only want to send | ||||||
|  |  * data from a static buffer, set it to 0 and return the data from | ||||||
|  |  * usbFunctionSetup(). This saves a couple of bytes. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_IMPLEMENT_FN_WRITEOUT   0 | ||||||
|  | /* Define this to 1 if you want to use interrupt-out (or bulk out) endpoints.
 | ||||||
|  |  * You must implement the function usbFunctionWriteOut() which receives all | ||||||
|  |  * interrupt/bulk data sent to any endpoint other than 0. The endpoint number | ||||||
|  |  * can be found in 'usbRxToken'. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_HAVE_FLOWCONTROL        0 | ||||||
|  | /* Define this to 1 if you want flowcontrol over USB data. See the definition
 | ||||||
|  |  * of the macros usbDisableAllRequests() and usbEnableAllRequests() in | ||||||
|  |  * usbdrv.h. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_DRIVER_FLASH_PAGE       0 | ||||||
|  | /* If the device has more than 64 kBytes of flash, define this to the 64 k page
 | ||||||
|  |  * where the driver's constants (descriptors) are located. Or in other words: | ||||||
|  |  * Define this to 1 for boot loaders on the ATMega128. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_LONG_TRANSFERS          0 | ||||||
|  | /* Define this to 1 if you want to send/receive blocks of more than 254 bytes
 | ||||||
|  |  * in a single control-in or control-out transfer. Note that the capability | ||||||
|  |  * for long transfers increases the driver size. | ||||||
|  |  */ | ||||||
|  | /* #define USB_RX_USER_HOOK(data, len)     if(usbRxToken == (uchar)USBPID_SETUP) blinkLED(); */ | ||||||
|  | /* This macro is a hook if you want to do unconventional things. If it is
 | ||||||
|  |  * defined, it's inserted at the beginning of received message processing. | ||||||
|  |  * If you eat the received message and don't want default processing to | ||||||
|  |  * proceed, do a return after doing your things. One possible application | ||||||
|  |  * (besides debugging) is to flash a status LED on each packet. | ||||||
|  |  */ | ||||||
|  | /* #define USB_RESET_HOOK(resetStarts)     if(!resetStarts){hadUsbReset();} */ | ||||||
|  | /* This macro is a hook if you need to know when an USB RESET occurs. It has
 | ||||||
|  |  * one parameter which distinguishes between the start of RESET state and its | ||||||
|  |  * end. | ||||||
|  |  */ | ||||||
|  | /* #define USB_SET_ADDRESS_HOOK()              hadAddressAssigned(); */ | ||||||
|  | /* This macro (if defined) is executed when a USB SET_ADDRESS request was
 | ||||||
|  |  * received. | ||||||
|  |  */ | ||||||
|  | #define USB_COUNT_SOF                   1 | ||||||
|  | /* define this macro to 1 if you need the global variable "usbSofCount" which
 | ||||||
|  |  * counts SOF packets. This feature requires that the hardware interrupt is | ||||||
|  |  * connected to D- instead of D+. | ||||||
|  |  */ | ||||||
|  | /* #ifdef __ASSEMBLER__
 | ||||||
|  |  * macro myAssemblerMacro | ||||||
|  |  *     in      YL, TCNT0 | ||||||
|  |  *     sts     timer0Snapshot, YL | ||||||
|  |  *     endm | ||||||
|  |  * #endif | ||||||
|  |  * #define USB_SOF_HOOK                    myAssemblerMacro | ||||||
|  |  * This macro (if defined) is executed in the assembler module when a | ||||||
|  |  * Start Of Frame condition is detected. It is recommended to define it to | ||||||
|  |  * the name of an assembler macro which is defined here as well so that more | ||||||
|  |  * than one assembler instruction can be used. The macro may use the register | ||||||
|  |  * YL and modify SREG. If it lasts longer than a couple of cycles, USB messages | ||||||
|  |  * immediately after an SOF pulse may be lost and must be retried by the host. | ||||||
|  |  * What can you do with this hook? Since the SOF signal occurs exactly every | ||||||
|  |  * 1 ms (unless the host is in sleep mode), you can use it to tune OSCCAL in | ||||||
|  |  * designs running on the internal RC oscillator. | ||||||
|  |  * Please note that Start Of Frame detection works only if D- is wired to the | ||||||
|  |  * interrupt, not D+. THIS IS DIFFERENT THAN MOST EXAMPLES! | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_CHECK_DATA_TOGGLING     0 | ||||||
|  | /* define this macro to 1 if you want to filter out duplicate data packets
 | ||||||
|  |  * sent by the host. Duplicates occur only as a consequence of communication | ||||||
|  |  * errors, when the host does not receive an ACK. Please note that you need to | ||||||
|  |  * implement the filtering yourself in usbFunctionWriteOut() and | ||||||
|  |  * usbFunctionWrite(). Use the global usbCurrentDataToken and a static variable | ||||||
|  |  * for each control- and out-endpoint to check for duplicate packets. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_HAVE_MEASURE_FRAME_LENGTH   0 | ||||||
|  | /* define this macro to 1 if you want the function usbMeasureFrameLength()
 | ||||||
|  |  * compiled in. This function can be used to calibrate the AVR's RC oscillator. | ||||||
|  |  */ | ||||||
|  | #define USB_USE_FAST_CRC                0 | ||||||
|  | /* The assembler module has two implementations for the CRC algorithm. One is
 | ||||||
|  |  * faster, the other is smaller. This CRC routine is only used for transmitted | ||||||
|  |  * messages where timing is not critical. The faster routine needs 31 cycles | ||||||
|  |  * per byte while the smaller one needs 61 to 69 cycles. The faster routine | ||||||
|  |  * may be worth the 32 bytes bigger code size if you transmit lots of data and | ||||||
|  |  * run the AVR close to its limit. | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | /* -------------------------- Device Description --------------------------- */ | ||||||
|  | 
 | ||||||
|  | #define USB_CFG_VENDOR_ID       (VENDOR_ID & 0xFF), ((VENDOR_ID >> 8) & 0xFF) | ||||||
|  | /* USB vendor ID for the device, low byte first. If you have registered your
 | ||||||
|  |  * own Vendor ID, define it here. Otherwise you may use one of obdev's free | ||||||
|  |  * shared VID/PID pairs. Be sure to read USB-IDs-for-free.txt for rules! | ||||||
|  |  * *** IMPORTANT NOTE *** | ||||||
|  |  * This template uses obdev's shared VID/PID pair for Vendor Class devices | ||||||
|  |  * with libusb: 0x16c0/0x5dc.  Use this VID/PID pair ONLY if you understand | ||||||
|  |  * the implications! | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_DEVICE_ID       (PRODUCT_ID & 0xFF), ((PRODUCT_ID >> 8) & 0xFF) | ||||||
|  | /* This is the ID of the product, low byte first. It is interpreted in the
 | ||||||
|  |  * scope of the vendor ID. If you have registered your own VID with usb.org | ||||||
|  |  * or if you have licensed a PID from somebody else, define it here. Otherwise | ||||||
|  |  * you may use one of obdev's free shared VID/PID pairs. See the file | ||||||
|  |  * USB-IDs-for-free.txt for details! | ||||||
|  |  * *** IMPORTANT NOTE *** | ||||||
|  |  * This template uses obdev's shared VID/PID pair for Vendor Class devices | ||||||
|  |  * with libusb: 0x16c0/0x5dc.  Use this VID/PID pair ONLY if you understand | ||||||
|  |  * the implications! | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_DEVICE_VERSION  0x00, 0x02 | ||||||
|  | /* Version number of the device: Minor number first, then major number.
 | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_VENDOR_NAME     'w', 'i', 'n', 'k', 'e', 'y', 'l', 'e', 's', 's', '.', 'k', 'r' | ||||||
|  | #define USB_CFG_VENDOR_NAME_LEN 13 | ||||||
|  | /* These two values define the vendor name returned by the USB device. The name
 | ||||||
|  |  * must be given as a list of characters under single quotes. The characters | ||||||
|  |  * are interpreted as Unicode (UTF-16) entities. | ||||||
|  |  * If you don't want a vendor name string, undefine these macros. | ||||||
|  |  * ALWAYS define a vendor name containing your Internet domain name if you use | ||||||
|  |  * obdev's free shared VID/PID pair. See the file USB-IDs-for-free.txt for | ||||||
|  |  * details. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_DEVICE_NAME     'p', 's', '2', 'a', 'v', 'r', 'G', 'B' | ||||||
|  | #define USB_CFG_DEVICE_NAME_LEN 8 | ||||||
|  | /* Same as above for the device name. If you don't want a device name, undefine
 | ||||||
|  |  * the macros. See the file USB-IDs-for-free.txt before you assign a name if | ||||||
|  |  * you use a shared VID/PID. | ||||||
|  |  */ | ||||||
|  | /*#define USB_CFG_SERIAL_NUMBER   'N', 'o', 'n', 'e' */ | ||||||
|  | /*#define USB_CFG_SERIAL_NUMBER_LEN   0 */ | ||||||
|  | /* Same as above for the serial number. If you don't want a serial number,
 | ||||||
|  |  * undefine the macros. | ||||||
|  |  * It may be useful to provide the serial number through other means than at | ||||||
|  |  * compile time. See the section about descriptor properties below for how | ||||||
|  |  * to fine tune control over USB descriptors such as the string descriptor | ||||||
|  |  * for the serial number. | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_DEVICE_CLASS        0 | ||||||
|  | #define USB_CFG_DEVICE_SUBCLASS     0 | ||||||
|  | /* See USB specification if you want to conform to an existing device class.
 | ||||||
|  |  * Class 0xff is "vendor specific". | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_INTERFACE_CLASS     3   /* HID */ | ||||||
|  | #define USB_CFG_INTERFACE_SUBCLASS  1   /* Boot */ | ||||||
|  | #define USB_CFG_INTERFACE_PROTOCOL  1   /* Keyboard */ | ||||||
|  | /* See USB specification if you want to conform to an existing device class or
 | ||||||
|  |  * protocol. The following classes must be set at interface level: | ||||||
|  |  * HID class is 3, no subclass and protocol required (but may be useful!) | ||||||
|  |  * CDC class is 2, use subclass 2 and protocol 1 for ACM | ||||||
|  |  */ | ||||||
|  | #define USB_CFG_HID_REPORT_DESCRIPTOR_LENGTH    0 | ||||||
|  | /* Define this to the length of the HID report descriptor, if you implement
 | ||||||
|  |  * an HID device. Otherwise don't define it or define it to 0. | ||||||
|  |  * If you use this define, you must add a PROGMEM character array named | ||||||
|  |  * "usbHidReportDescriptor" to your code which contains the report descriptor. | ||||||
|  |  * Don't forget to keep the array and this define in sync! | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | /* #define USB_PUBLIC static */ | ||||||
|  | /* Use the define above if you #include usbdrv.c instead of linking against it.
 | ||||||
|  |  * This technique saves a couple of bytes in flash memory. | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | /* ------------------- Fine Control over USB Descriptors ------------------- */ | ||||||
|  | /* If you don't want to use the driver's default USB descriptors, you can
 | ||||||
|  |  * provide our own. These can be provided as (1) fixed length static data in | ||||||
|  |  * flash memory, (2) fixed length static data in RAM or (3) dynamically at | ||||||
|  |  * runtime in the function usbFunctionDescriptor(). See usbdrv.h for more | ||||||
|  |  * information about this function. | ||||||
|  |  * Descriptor handling is configured through the descriptor's properties. If | ||||||
|  |  * no properties are defined or if they are 0, the default descriptor is used. | ||||||
|  |  * Possible properties are: | ||||||
|  |  *   + USB_PROP_IS_DYNAMIC: The data for the descriptor should be fetched | ||||||
|  |  *     at runtime via usbFunctionDescriptor(). If the usbMsgPtr mechanism is | ||||||
|  |  *     used, the data is in FLASH by default. Add property USB_PROP_IS_RAM if | ||||||
|  |  *     you want RAM pointers. | ||||||
|  |  *   + USB_PROP_IS_RAM: The data returned by usbFunctionDescriptor() or found | ||||||
|  |  *     in static memory is in RAM, not in flash memory. | ||||||
|  |  *   + USB_PROP_LENGTH(len): If the data is in static memory (RAM or flash), | ||||||
|  |  *     the driver must know the descriptor's length. The descriptor itself is | ||||||
|  |  *     found at the address of a well known identifier (see below). | ||||||
|  |  * List of static descriptor names (must be declared PROGMEM if in flash): | ||||||
|  |  *   char usbDescriptorDevice[]; | ||||||
|  |  *   char usbDescriptorConfiguration[]; | ||||||
|  |  *   char usbDescriptorHidReport[]; | ||||||
|  |  *   char usbDescriptorString0[]; | ||||||
|  |  *   int usbDescriptorStringVendor[]; | ||||||
|  |  *   int usbDescriptorStringDevice[]; | ||||||
|  |  *   int usbDescriptorStringSerialNumber[]; | ||||||
|  |  * Other descriptors can't be provided statically, they must be provided | ||||||
|  |  * dynamically at runtime. | ||||||
|  |  * | ||||||
|  |  * Descriptor properties are or-ed or added together, e.g.: | ||||||
|  |  * #define USB_CFG_DESCR_PROPS_DEVICE   (USB_PROP_IS_RAM | USB_PROP_LENGTH(18)) | ||||||
|  |  * | ||||||
|  |  * The following descriptors are defined: | ||||||
|  |  *   USB_CFG_DESCR_PROPS_DEVICE | ||||||
|  |  *   USB_CFG_DESCR_PROPS_CONFIGURATION | ||||||
|  |  *   USB_CFG_DESCR_PROPS_STRINGS | ||||||
|  |  *   USB_CFG_DESCR_PROPS_STRING_0 | ||||||
|  |  *   USB_CFG_DESCR_PROPS_STRING_VENDOR | ||||||
|  |  *   USB_CFG_DESCR_PROPS_STRING_PRODUCT | ||||||
|  |  *   USB_CFG_DESCR_PROPS_STRING_SERIAL_NUMBER | ||||||
|  |  *   USB_CFG_DESCR_PROPS_HID | ||||||
|  |  *   USB_CFG_DESCR_PROPS_HID_REPORT | ||||||
|  |  *   USB_CFG_DESCR_PROPS_UNKNOWN (for all descriptors not handled by the driver) | ||||||
|  |  * | ||||||
|  |  * Note about string descriptors: String descriptors are not just strings, they | ||||||
|  |  * are Unicode strings prefixed with a 2 byte header. Example: | ||||||
|  |  * int  serialNumberDescriptor[] = { | ||||||
|  |  *     USB_STRING_DESCRIPTOR_HEADER(6), | ||||||
|  |  *     'S', 'e', 'r', 'i', 'a', 'l' | ||||||
|  |  * }; | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | #define USB_CFG_DESCR_PROPS_DEVICE                  0 | ||||||
|  | #define USB_CFG_DESCR_PROPS_CONFIGURATION           USB_PROP_IS_DYNAMIC | ||||||
|  | //#define USB_CFG_DESCR_PROPS_CONFIGURATION           0
 | ||||||
|  | #define USB_CFG_DESCR_PROPS_STRINGS                 0 | ||||||
|  | #define USB_CFG_DESCR_PROPS_STRING_0                0 | ||||||
|  | #define USB_CFG_DESCR_PROPS_STRING_VENDOR           0 | ||||||
|  | #define USB_CFG_DESCR_PROPS_STRING_PRODUCT          0 | ||||||
|  | #define USB_CFG_DESCR_PROPS_STRING_SERIAL_NUMBER    0 | ||||||
|  | #define USB_CFG_DESCR_PROPS_HID                     USB_PROP_IS_DYNAMIC | ||||||
|  | //#define USB_CFG_DESCR_PROPS_HID                     0
 | ||||||
|  | #define USB_CFG_DESCR_PROPS_HID_REPORT              USB_PROP_IS_DYNAMIC | ||||||
|  | //#define USB_CFG_DESCR_PROPS_HID_REPORT              0
 | ||||||
|  | #define USB_CFG_DESCR_PROPS_UNKNOWN                 0 | ||||||
|  | 
 | ||||||
|  | #define usbMsgPtr_t unsigned short | ||||||
|  | /* If usbMsgPtr_t is not defined, it defaults to 'uchar *'. We define it to
 | ||||||
|  |  * a scalar type here because gcc generates slightly shorter code for scalar | ||||||
|  |  * arithmetics than for pointer arithmetics. Remove this define for backward | ||||||
|  |  * type compatibility or define it to an 8 bit type if you use data in RAM only | ||||||
|  |  * and all RAM is below 256 bytes (tiny memory model in IAR CC). | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | /* ----------------------- Optional MCU Description ------------------------ */ | ||||||
|  | 
 | ||||||
|  | /* The following configurations have working defaults in usbdrv.h. You
 | ||||||
|  |  * usually don't need to set them explicitly. Only if you want to run | ||||||
|  |  * the driver on a device which is not yet supported or with a compiler | ||||||
|  |  * which is not fully supported (such as IAR C) or if you use a differnt | ||||||
|  |  * interrupt than INT0, you may have to define some of these. | ||||||
|  |  */ | ||||||
|  | /* #define USB_INTR_CFG            MCUCR */ | ||||||
|  | /* #define USB_INTR_CFG_SET        ((1 << ISC00) | (1 << ISC01)) */ | ||||||
|  | /* #define USB_INTR_CFG_CLR        0 */ | ||||||
|  | /* #define USB_INTR_ENABLE         GIMSK */ | ||||||
|  | /* #define USB_INTR_ENABLE_BIT     INT0 */ | ||||||
|  | /* #define USB_INTR_PENDING        GIFR */ | ||||||
|  | /* #define USB_INTR_PENDING_BIT    INTF0 */ | ||||||
|  | /* #define USB_INTR_VECTOR         INT0_vect */ | ||||||
|  | 
 | ||||||
|  | /* Set INT1 for D- falling edge to count SOF */ | ||||||
|  | /* #define USB_INTR_CFG            EICRA */ | ||||||
|  | #define USB_INTR_CFG_SET        ((1 << ISC11) | (0 << ISC10)) | ||||||
|  | /* #define USB_INTR_CFG_CLR        0 */ | ||||||
|  | /* #define USB_INTR_ENABLE         EIMSK */ | ||||||
|  | #define USB_INTR_ENABLE_BIT     INT1 | ||||||
|  | /* #define USB_INTR_PENDING        EIFR */ | ||||||
|  | #define USB_INTR_PENDING_BIT    INTF1 | ||||||
|  | #define USB_INTR_VECTOR         INT1_vect | ||||||
|  | 
 | ||||||
|  | #endif /* __usbconfig_h_included__ */ | ||||||
							
								
								
									
										65
									
								
								keyboards/jc65/v32a/v32a.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								keyboards/jc65/v32a/v32a.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,65 @@ | ||||||
|  | /*
 | ||||||
|  | Copyright 2017 Luiz Ribeiro <luizribeiro@gmail.com> | ||||||
|  | 
 | ||||||
|  | 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 "v32a.h" | ||||||
|  | #ifdef BACKLIGHT_ENABLE | ||||||
|  | #include "backlight.h" | ||||||
|  | #endif | ||||||
|  | #ifdef RGBLIGHT_ENABLE | ||||||
|  | #include "rgblight.h" | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #include <avr/pgmspace.h> | ||||||
|  | 
 | ||||||
|  | #include "action_layer.h" | ||||||
|  | #include "i2c.h" | ||||||
|  | #include "quantum.h" | ||||||
|  | 
 | ||||||
|  | extern rgblight_config_t rgblight_config; | ||||||
|  | 
 | ||||||
|  | void rgblight_set(void) { | ||||||
|  |     if (!rgblight_config.enable) { | ||||||
|  |         for (uint8_t i = 0; i < RGBLED_NUM; i++) { | ||||||
|  |             led[i].r = 0; | ||||||
|  |             led[i].g = 0; | ||||||
|  |             led[i].b = 0; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     i2c_init(); | ||||||
|  |     i2c_send(0xb0, (uint8_t*)led, 3 * RGBLED_NUM); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | __attribute__ ((weak)) | ||||||
|  | void matrix_scan_user(void) { | ||||||
|  |     rgblight_task(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void backlight_init_ports(void) { | ||||||
|  | 	DDRD |= (1<<0 | 1<<1 | 1<<4 | 1<<6); | ||||||
|  | 	PORTD &= ~(1<<0 | 1<<1 | 1<<4 | 1<<6); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void backlight_set(uint8_t level) { | ||||||
|  | 	if (level == 0) { | ||||||
|  | 		// Turn out the lights
 | ||||||
|  | 		PORTD &= ~(1<<0 | 1<<1 | 1<<4 | 1<<6); | ||||||
|  | 	} else { | ||||||
|  | 		// Turn on the lights
 | ||||||
|  | 		PORTD |= (1<<0 | 1<<1 | 1<<4 | 1<<6); | ||||||
|  | 	} | ||||||
|  | } | ||||||
							
								
								
									
										58
									
								
								keyboards/jc65/v32a/v32a.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								keyboards/jc65/v32a/v32a.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,58 @@ | ||||||
|  | /*
 | ||||||
|  | Copyright 2017 Luiz Ribeiro <luizribeiro@gmail.com> | ||||||
|  | 
 | ||||||
|  | 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/>.
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | #ifndef V32A_H | ||||||
|  | #define V32A_H | ||||||
|  | 
 | ||||||
|  | #include "quantum.h" | ||||||
|  | 
 | ||||||
|  | #define KEYMAP( \ | ||||||
|  |   K04,K14,K24,K34,K44,K54,K16,KB6,KB7,K17,KA4,KB4,KC4,KD4,KE4,KD0, \ | ||||||
|  |   K03,K13,K23,K33,K43,K53,K26,KC6,KC7,K27,KA3,KB3,KC3,    KD3,K67, \ | ||||||
|  |   K02,K12,K22,K32,K42,K52,K36,KD6,KD7,K37,KA2,KB2,KC2,    KD2,K87, \ | ||||||
|  |   K01,K30,K11,K21,K31,K41,K51,K46,KE6,KE7,K47,KA1,    KB1,K86,K77, \ | ||||||
|  |   K00,K10,K20,    K40,K56,K50,            K57,KB0,KC0,K96,K76,K66  \ | ||||||
|  | ){ \ | ||||||
|  |   {   K00,  K10,  K20,  K30,  K40,  K50,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,  KB0,  KC0,  KD0,KC_NO,KC_NO }, \ | ||||||
|  |   {   K01,  K11,  K21,  K31,  K41,  K51,KC_NO,KC_NO,KC_NO,KC_NO,  KA1,  KB1,KC_NO,KC_NO,KC_NO,KC_NO }, \ | ||||||
|  |   {   K02,  K12,  K22,  K32,  K42,  K52,KC_NO,KC_NO,KC_NO,KC_NO,  KA2,  KB2,  KC2,  KD2,KC_NO,KC_NO }, \ | ||||||
|  |   {   K03,  K13,  K23,  K33,  K43,  K53,KC_NO,KC_NO,KC_NO,KC_NO,  KA3,  KB3,  KC3,  KD3,KC_NO,KC_NO }, \ | ||||||
|  |   {   K04,  K14,  K24,  K34,  K44,  K54,KC_NO,KC_NO,KC_NO,KC_NO,  KA4,  KB4,  KC4,  KD4,  KE4,KC_NO }, \ | ||||||
|  |   { KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO,KC_NO }, \ | ||||||
|  |   { KC_NO,  K16,  K26,  K36,  K46,  K56,  K66,  K76,  K86,  K96,KC_NO,  KB6,  KC6,  KD6,  KE6,KC_NO }, \ | ||||||
|  |   { KC_NO,  K17,  K27,  K37,  K47,  K57,  K67,  K77,  K87,KC_NO,KC_NO,  KB7,  KC7,  KD7,  KE7,KC_NO }  \ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #define KC_KEYMAP( \ | ||||||
|  |   K04,K14,K24,K34,K44,K54,K16,KB6,KB7,K17,KA4,KB4,KC4,KD4,KE4,KD0, \ | ||||||
|  |   K03,K13,K23,K33,K43,K53,K26,KC6,KC7,K27,KA3,KB3,KC3,    KD3,K67, \ | ||||||
|  |   K02,K12,K22,K32,K42,K52,K36,KD6,KD7,K37,KA2,KB2,KC2,    KD2,K87, \ | ||||||
|  |   K01,K30,K11,K21,K31,K41,K51,K46,KE6,KE7,K47,KA1,    KB1,K86,K77, \ | ||||||
|  |   K00,K10,K20,    K40,K56,K50,            K57,KB0,KC0,K96,K76,K66  \ | ||||||
|  | ) \ | ||||||
|  | { \ | ||||||
|  |   { KC_##K00,KC_##K10,KC_##K20,KC_##K30,KC_##K40,KC_##K50,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,KC_##KB0,KC_##KC0,KC_##KD0,   KC_NO,KC_NO }, \ | ||||||
|  |   { KC_##K01,KC_##K11,KC_##K21,KC_##K31,KC_##K41,KC_##K51,   KC_NO,   KC_NO,   KC_NO,   KC_NO,KC_##KA1,KC_##KB1,   KC_NO,   KC_NO,   KC_NO,KC_NO }, \ | ||||||
|  |   { KC_##K02,KC_##K12,KC_##K22,KC_##K32,KC_##K42,KC_##K52,   KC_NO,   KC_NO,   KC_NO,   KC_NO,KC_##KA2,KC_##KB2,KC_##KC2,KC_##KD2,   KC_NO,KC_NO }, \ | ||||||
|  |   { KC_##K03,KC_##K13,KC_##K23,KC_##K33,KC_##K43,KC_##K53,   KC_NO,   KC_NO,   KC_NO,   KC_NO,KC_##KA3,KC_##KB3,KC_##KC3,KC_##KD3,   KC_NO,KC_NO }, \ | ||||||
|  |   { KC_##K04,KC_##K14,KC_##K24,KC_##K34,KC_##K44,KC_##K54,   KC_NO,   KC_NO,   KC_NO,   KC_NO,KC_##KA4,KC_##KB4,KC_##KC4,KC_##KD4,KC_##KE4,KC_NO }, \ | ||||||
|  |   {    KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,   KC_NO,KC_NO }, \ | ||||||
|  |   {    KC_NO,KC_##K16,KC_##K26,KC_##K36,KC_##K46,KC_##K56,KC_##K66,KC_##K76,KC_##K86,KC_##K96,   KC_NO,KC_##KB6,KC_##KC6,KC_##KD6,KC_##KE6,KC_NO }, \ | ||||||
|  |   {    KC_NO,KC_##K17,KC_##K27,KC_##K37,KC_##K47,KC_##K57,KC_##K67,KC_##K77,KC_##K87,   KC_NO,   KC_NO,KC_##KB7,KC_##KC7,KC_##KD7,KC_##KE7,KC_NO }  \ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
| #include "jc65.h" | #include "v32u4.h" | ||||||
| 
 | 
 | ||||||
| const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||||
|   [0] = KEYMAP( |   [0] = KEYMAP( | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
| #include "jc65.h" | #include "v32u4.h" | ||||||
| 
 | 
 | ||||||
| const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||||
|   [0] = KEYMAP( |   [0] = KEYMAP( | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
| #include "jc65.h" | #include "v32u4.h" | ||||||
| 
 | 
 | ||||||
| const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||||
|   [0] = KEYMAP( |   [0] = KEYMAP( | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
| #include "jc65.h" | #include "v32u4.h" | ||||||
| 
 | 
 | ||||||
| const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||||
|   [0] = KEYMAP( |   [0] = KEYMAP( | ||||||
							
								
								
									
										22
									
								
								keyboards/jc65/v32u4/readme.md
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								keyboards/jc65/v32u4/readme.md
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,22 @@ | ||||||
|  | JC65 | ||||||
|  | === | ||||||
|  | 
 | ||||||
|  |  | ||||||
|  | 
 | ||||||
|  | The JC65 PCB actually has two revisions: A QMK native version, and a PS2AVRGB version. Jchan offered both PCBs as options during the M65-A Round 1 group buy, and were also available choices for the 65% acrylic case group buy. In the near future both PCB versions should be available from keyclack.com when the storefront part opens. | ||||||
|  | 
 | ||||||
|  | These docs are for the QMK version of the PCB. [More info on qmk.fm](http://qmk.fm/planck/) | ||||||
|  | 
 | ||||||
|  | Keyboard Maintainer: [Ethan Madden](https://github.com/jetpacktuxedo) | ||||||
|  | Hardware Supported: JC65 rev.qmk | ||||||
|  | Hardware Availability: [keyclack.com](https://keyclack.com/) | ||||||
|  | 
 | ||||||
|  | Make example for this keyboard (after setting up your build environment): | ||||||
|  | 
 | ||||||
|  |     make jc65/v32u4:default | ||||||
|  | 
 | ||||||
|  | Or to make and flash: | ||||||
|  | 
 | ||||||
|  |     make jc65/v32u4:default:dfu | ||||||
|  | 
 | ||||||
|  | See [build environment setup](https://docs.qmk.fm/build_environment_setup.html) then the [make instructions](https://docs.qmk.fm/make_instructions.html) for more information. | ||||||
							
								
								
									
										68
									
								
								keyboards/jc65/v32u4/rules.mk
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								keyboards/jc65/v32u4/rules.mk
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,68 @@ | ||||||
|  | # MCU name
 | ||||||
|  | #MCU = at90usb1287
 | ||||||
|  | MCU = atmega32u4 | ||||||
|  | 
 | ||||||
|  | # Processor frequency.
 | ||||||
|  | #     This will define a symbol, F_CPU, in all source code files equal to the
 | ||||||
|  | #     processor frequency in Hz. You can then use this symbol in your source code to
 | ||||||
|  | #     calculate timings. Do NOT tack on a 'UL' at the end, this will be done
 | ||||||
|  | #     automatically to create a 32-bit value in your source code.
 | ||||||
|  | #
 | ||||||
|  | #     This will be an integer division of F_USB below, as it is sourced by
 | ||||||
|  | #     F_USB after it has run through any CPU prescalers. Note that this value
 | ||||||
|  | #     does not *change* the processor frequency - it should merely be updated to
 | ||||||
|  | #     reflect the processor speed set externally so that the code can use accurate
 | ||||||
|  | #     software delays.
 | ||||||
|  | F_CPU = 16000000 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #
 | ||||||
|  | # LUFA specific
 | ||||||
|  | #
 | ||||||
|  | # Target architecture (see library "Board Types" documentation).
 | ||||||
|  | ARCH = AVR8 | ||||||
|  | 
 | ||||||
|  | # Input clock frequency.
 | ||||||
|  | #     This will define a symbol, F_USB, in all source code files equal to the
 | ||||||
|  | #     input clock frequency (before any prescaling is performed) in Hz. This value may
 | ||||||
|  | #     differ from F_CPU if prescaling is used on the latter, and is required as the
 | ||||||
|  | #     raw input clock is fed directly to the PLL sections of the AVR for high speed
 | ||||||
|  | #     clock generation for the USB and other AVR subsections. Do NOT tack on a 'UL'
 | ||||||
|  | #     at the end, this will be done automatically to create a 32-bit value in your
 | ||||||
|  | #     source code.
 | ||||||
|  | #
 | ||||||
|  | #     If no clock division is performed on the input clock inside the AVR (via the
 | ||||||
|  | #     CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU.
 | ||||||
|  | F_USB = $(F_CPU) | ||||||
|  | 
 | ||||||
|  | # Interrupt driven control endpoint task(+60)
 | ||||||
|  | OPT_DEFS += -DINTERRUPT_CONTROL_ENDPOINT | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Boot Section Size in *bytes*
 | ||||||
|  | #   Teensy halfKay   512
 | ||||||
|  | #   Teensy++ halfKay 1024
 | ||||||
|  | #   Atmel DFU loader 4096
 | ||||||
|  | #   LUFA bootloader  4096
 | ||||||
|  | #   USBaspLoader     2048
 | ||||||
|  | OPT_DEFS += -DBOOTLOADER_SIZE=4096 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Build Options
 | ||||||
|  | #   change yes to no to disable
 | ||||||
|  | #
 | ||||||
|  | BOOTMAGIC_ENABLE = no      # Virtual DIP switch configuration(+1000) | ||||||
|  | MOUSEKEY_ENABLE = yes       # Mouse keys(+4700) | ||||||
|  | EXTRAKEY_ENABLE = yes       # Audio control and System control(+450) | ||||||
|  | CONSOLE_ENABLE = no        # Console for debug(+400) | ||||||
|  | COMMAND_ENABLE = no        # Commands for debug and configuration | ||||||
|  | # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE
 | ||||||
|  | SLEEP_LED_ENABLE = no       # Breathing sleep LED during USB suspend | ||||||
|  | # if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work
 | ||||||
|  | NKRO_ENABLE = yes           # USB Nkey Rollover | ||||||
|  | BACKLIGHT_ENABLE = yes       # Enable keyboard backlight functionality on B7 by default | ||||||
|  | RGBLIGHT_ENABLE = yes | ||||||
|  | MIDI_ENABLE = no            # MIDI controls | ||||||
|  | UNICODE_ENABLE = no         # Unicode | ||||||
|  | BLUETOOTH_ENABLE = no       # Enable Bluetooth with the Adafruit EZ-Key HID | ||||||
|  | AUDIO_ENABLE = no           # Audio output on port C6 | ||||||
							
								
								
									
										36
									
								
								keyboards/jc65/v32u4/v32u4.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								keyboards/jc65/v32u4/v32u4.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,36 @@ | ||||||
|  | #include "v32u4.h" | ||||||
|  | 
 | ||||||
|  | void matrix_init_kb(void) { | ||||||
|  | 	// put your keyboard start-up code here
 | ||||||
|  | 	// runs once when the firmware starts up
 | ||||||
|  | 
 | ||||||
|  | 	matrix_init_user(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void matrix_scan_kb(void) { | ||||||
|  | 	// put your looping keyboard code here
 | ||||||
|  | 	// runs every cycle (a lot)
 | ||||||
|  | 
 | ||||||
|  | 	matrix_scan_user(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool process_record_kb(uint16_t keycode, keyrecord_t *record) { | ||||||
|  | 	// put your per-action keyboard code here
 | ||||||
|  | 	// runs for every action, just before processing by the firmware
 | ||||||
|  | 
 | ||||||
|  | 	return process_record_user(keycode, record); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void led_set_kb(uint8_t usb_led) { | ||||||
|  | 	// put your keyboard LED indicator (ex: Caps Lock LED) toggling code here
 | ||||||
|  |     if (usb_led & (1<<USB_LED_CAPS_LOCK)) { | ||||||
|  |         // output low
 | ||||||
|  |         DDRB |= (1<<2); | ||||||
|  |         PORTB &= ~(1<<2); | ||||||
|  |     } else { | ||||||
|  |         // Hi-Z
 | ||||||
|  |         DDRB &= ~(1<<2); | ||||||
|  |         PORTB &= ~(1<<2); | ||||||
|  |     } | ||||||
|  | 	led_set_user(usb_led); | ||||||
|  | } | ||||||
							
								
								
									
										21
									
								
								keyboards/jc65/v32u4/v32u4.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								keyboards/jc65/v32u4/v32u4.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,21 @@ | ||||||
|  | #ifndef V32U4_H | ||||||
|  | #define V32U4_H | ||||||
|  | 
 | ||||||
|  | #include "quantum.h" | ||||||
|  | 
 | ||||||
|  | #define KEYMAP( \ | ||||||
|  |     K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, K0E, K0F, \ | ||||||
|  |      K10, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D,   K1E,   K1F, \ | ||||||
|  |       K20, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C,     K2D,     K2F, \ | ||||||
|  |      K30, K31, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B,   K3D,   K3E, K3F, \ | ||||||
|  |     K40,  K41,  K43,    K44,      K46,      K48,      K4A, K4B, K4C, K4D, K4E, K4F \ | ||||||
|  | )\ | ||||||
|  | {\ | ||||||
|  |   {K00, K01,   K02,   K03, K04, K05,   K06, K07,   K08, K09,   K0A, K0B, K0C,   K0D, K0E,   K0F}, \ | ||||||
|  |   {K10, KC_NO, K12,   K13, K14, K15,   K16, K17,   K18, K19,   K1A, K1B, K1C,   K1D, K1E,   K1F}, \ | ||||||
|  |   {K20, KC_NO, K22,   K23, K24, K25,   K26, K27,   K28, K29,   K2A, K2B, K2C,   K2D, KC_NO, K2F}, \ | ||||||
|  |   {K30, K31,   K32,   K33, K34, K35,   K36, K37,   K38, K39,   K3A, K3B, KC_NO, K3D, K3E,   K3F}, \ | ||||||
|  |   {K40, K41,   KC_NO, K43, K44, KC_NO, K46, KC_NO, K48, KC_NO, K4A, K4B, K4C,   K4D, K4E,   K4F}, \ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Jason Barnachea
						Jason Barnachea