mirror of
https://github.com/qmk/qmk_firmware
synced 2024-11-14 07:55:28 +00:00
bluetooth working with usb
This commit is contained in:
parent
bbb21f60e9
commit
71a8fd8b12
8 changed files with 182 additions and 40 deletions
|
@ -124,13 +124,13 @@ COMMAND_ENABLE = yes # Commands for debug and configuration
|
||||||
# SLEEP_LED_ENABLE = yes # Breathing sleep LED during USB suspend
|
# SLEEP_LED_ENABLE = yes # Breathing sleep LED during USB suspend
|
||||||
# NKRO_ENABLE = yes # USB Nkey Rollover - not yet supported in LUFA
|
# NKRO_ENABLE = yes # USB Nkey Rollover - not yet supported in LUFA
|
||||||
BACKLIGHT_ENABLE = yes # Enable keyboard backlight functionality
|
BACKLIGHT_ENABLE = yes # Enable keyboard backlight functionality
|
||||||
# MIDI_ENABLE = YES # MIDI controls
|
MIDI_ENABLE = YES # MIDI controls
|
||||||
# UNICODE_ENABLE = YES # Unicode
|
# UNICODE_ENABLE = YES # Unicode
|
||||||
# BLUETOOTH_ENABLE = yes # Enable Bluetooth with the Adafruit EZ-Key HID
|
BLUETOOTH_ENABLE = yes # Enable Bluetooth with the Adafruit EZ-Key HID
|
||||||
|
|
||||||
ifdef MIDI_ENABLE
|
ifdef MIDI_ENABLE
|
||||||
SRC += keymap_midi.c
|
SRC += keymap_midi.c \
|
||||||
# beeps.c
|
beeps.c
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifdef UNICODE_ENABLE
|
ifdef UNICODE_ENABLE
|
||||||
|
@ -144,17 +144,7 @@ endif
|
||||||
VPATH += $(TARGET_DIR)
|
VPATH += $(TARGET_DIR)
|
||||||
VPATH += $(TOP_DIR)
|
VPATH += $(TOP_DIR)
|
||||||
|
|
||||||
|
include $(TOP_DIR)/protocol/lufa.mk
|
||||||
|
|
||||||
ifdef BLUETOOTH_ENABLE
|
|
||||||
BLUEFRUIT_TRACE_SERIAL=true
|
|
||||||
|
|
||||||
include $(TOP_DIR)/protocol.mk
|
|
||||||
include $(TOP_DIR)/protocol/bluefruit.mk
|
|
||||||
include $(TOP_DIR)/protocol.mk
|
|
||||||
else
|
|
||||||
include $(TOP_DIR)/protocol/lufa.mk
|
|
||||||
endif
|
|
||||||
|
|
||||||
include $(TOP_DIR)/common.mk
|
include $(TOP_DIR)/common.mk
|
||||||
include $(TOP_DIR)/rules.mk
|
include $(TOP_DIR)/rules.mk
|
||||||
|
|
|
@ -131,10 +131,10 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* disable debug print */
|
/* disable debug print */
|
||||||
// #define NO_DEBUG
|
#define NO_DEBUG
|
||||||
|
|
||||||
/* disable print */
|
/* disable print */
|
||||||
// #define NO_PRINT
|
#define NO_PRINT
|
||||||
|
|
||||||
/* disable action features */
|
/* disable action features */
|
||||||
//#define NO_ACTION_LAYER
|
//#define NO_ACTION_LAYER
|
||||||
|
|
|
@ -75,33 +75,33 @@ const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
|
||||||
default_layer_and(0);
|
default_layer_and(0);
|
||||||
default_layer_or((1<<5));
|
default_layer_or((1<<5));
|
||||||
|
|
||||||
uint8_t low = boot_lock_fuse_bits_get(0x0000);
|
// uint8_t low = boot_lock_fuse_bits_get(0x0000);
|
||||||
uint8_t high = boot_lock_fuse_bits_get(0x0003);
|
// uint8_t high = boot_lock_fuse_bits_get(0x0003);
|
||||||
uint8_t ext = boot_lock_fuse_bits_get(0x0002);
|
// uint8_t ext = boot_lock_fuse_bits_get(0x0002);
|
||||||
uint8_t lock = boot_lock_fuse_bits_get(0x0001);
|
// uint8_t lock = boot_lock_fuse_bits_get(0x0001);
|
||||||
|
|
||||||
register_code(hextokeycode((low & 0xF0) >> 4));
|
// register_code(hextokeycode((low & 0xF0) >> 4));
|
||||||
unregister_code(hextokeycode((low & 0xF0) >> 4));
|
// unregister_code(hextokeycode((low & 0xF0) >> 4));
|
||||||
register_code(hextokeycode((low & 0x0F)));
|
// register_code(hextokeycode((low & 0x0F)));
|
||||||
unregister_code(hextokeycode((low & 0x0F)));
|
// unregister_code(hextokeycode((low & 0x0F)));
|
||||||
|
|
||||||
|
|
||||||
register_code(hextokeycode((high & 0xF0) >> 4));
|
// register_code(hextokeycode((high & 0xF0) >> 4));
|
||||||
unregister_code(hextokeycode((high & 0xF0) >> 4));
|
// unregister_code(hextokeycode((high & 0xF0) >> 4));
|
||||||
register_code(hextokeycode((high & 0x0F)));
|
// register_code(hextokeycode((high & 0x0F)));
|
||||||
unregister_code(hextokeycode((high & 0x0F)));
|
// unregister_code(hextokeycode((high & 0x0F)));
|
||||||
|
|
||||||
|
|
||||||
register_code(hextokeycode((ext & 0xF0) >> 4));
|
// register_code(hextokeycode((ext & 0xF0) >> 4));
|
||||||
unregister_code(hextokeycode((ext & 0xF0) >> 4));
|
// unregister_code(hextokeycode((ext & 0xF0) >> 4));
|
||||||
register_code(hextokeycode((ext & 0x0F)));
|
// register_code(hextokeycode((ext & 0x0F)));
|
||||||
unregister_code(hextokeycode((ext & 0x0F)));
|
// unregister_code(hextokeycode((ext & 0x0F)));
|
||||||
|
|
||||||
|
|
||||||
register_code(hextokeycode((lock & 0xF0) >> 4));
|
// register_code(hextokeycode((lock & 0xF0) >> 4));
|
||||||
unregister_code(hextokeycode((lock & 0xF0) >> 4));
|
// unregister_code(hextokeycode((lock & 0xF0) >> 4));
|
||||||
register_code(hextokeycode((lock & 0x0F)));
|
// register_code(hextokeycode((lock & 0x0F)));
|
||||||
unregister_code(hextokeycode((lock & 0x0F)));
|
// unregister_code(hextokeycode((lock & 0x0F)));
|
||||||
|
|
||||||
// note(0+12, 20);
|
// note(0+12, 20);
|
||||||
// note(0+24, 20);
|
// note(0+24, 20);
|
||||||
|
|
|
@ -29,6 +29,11 @@ ifdef MIDI_ENABLE
|
||||||
$(LUFA_SRC_USBCLASS)
|
$(LUFA_SRC_USBCLASS)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifdef BLUETOOTH_ENABLE
|
||||||
|
LUFA_SRC += $(LUFA_DIR)/bluetooth.c \
|
||||||
|
$(LUFA_DIR)/../serial_uart.c
|
||||||
|
endif
|
||||||
|
|
||||||
SRC += $(LUFA_SRC)
|
SRC += $(LUFA_SRC)
|
||||||
|
|
||||||
# Search Path
|
# Search Path
|
||||||
|
|
37
protocol/lufa/bluetooth.c
Normal file
37
protocol/lufa/bluetooth.c
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
/*
|
||||||
|
Bluefruit Protocol for TMK firmware
|
||||||
|
Author: Benjamin Gould, 2013
|
||||||
|
Jack Humbert, 2015
|
||||||
|
Based on code Copyright 2011 Jun Wako <wakojun@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 <stdint.h>
|
||||||
|
#include "report.h"
|
||||||
|
#include "print.h"
|
||||||
|
#include "debug.h"
|
||||||
|
#include "../serial.h"
|
||||||
|
#include "bluetooth.h"
|
||||||
|
|
||||||
|
void bluefruit_keyboard_print_report(report_keyboard_t *report)
|
||||||
|
{
|
||||||
|
if (!debug_keyboard) return;
|
||||||
|
dprintf("keys: "); for (int i = 0; i < KEYBOARD_REPORT_KEYS; i++) { debug_hex8(report->keys[i]); dprintf(" "); }
|
||||||
|
dprintf(" mods: "); debug_hex8(report->mods);
|
||||||
|
dprintf(" reserved: "); debug_hex8(report->reserved);
|
||||||
|
dprintf("\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
void bluefruit_serial_send(uint8_t data)
|
||||||
|
{
|
||||||
|
serial_send(data);
|
||||||
|
}
|
63
protocol/lufa/bluetooth.h
Normal file
63
protocol/lufa/bluetooth.h
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
/*
|
||||||
|
Bluefruit Protocol for TMK firmware
|
||||||
|
Author: Benjamin Gould, 2013
|
||||||
|
Jack Humbert, 2015
|
||||||
|
Based on code Copyright 2011 Jun Wako <wakojun@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 BLUETOOTH_H
|
||||||
|
#define BLUETOOTH_H
|
||||||
|
|
||||||
|
void bluefruit_serial_send(uint8_t data);
|
||||||
|
|
||||||
|
/*
|
||||||
|
+-----------------+-------------------+-------+
|
||||||
|
| Consumer Key | Bit Map | Hex |
|
||||||
|
+-----------------+-------------------+-------+
|
||||||
|
| Home | 00000001 00000000 | 01 00 |
|
||||||
|
| KeyboardLayout | 00000010 00000000 | 02 00 |
|
||||||
|
| Search | 00000100 00000000 | 04 00 |
|
||||||
|
| Snapshot | 00001000 00000000 | 08 00 |
|
||||||
|
| VolumeUp | 00010000 00000000 | 10 00 |
|
||||||
|
| VolumeDown | 00100000 00000000 | 20 00 |
|
||||||
|
| Play/Pause | 01000000 00000000 | 40 00 |
|
||||||
|
| Fast Forward | 10000000 00000000 | 80 00 |
|
||||||
|
| Rewind | 00000000 00000001 | 00 01 |
|
||||||
|
| Scan Next Track | 00000000 00000010 | 00 02 |
|
||||||
|
| Scan Prev Track | 00000000 00000100 | 00 04 |
|
||||||
|
| Random Play | 00000000 00001000 | 00 08 |
|
||||||
|
| Stop | 00000000 00010000 | 00 10 |
|
||||||
|
+-------------------------------------+-------+
|
||||||
|
*/
|
||||||
|
#define CONSUMER2BLUEFRUIT(usage) \
|
||||||
|
(usage == AUDIO_MUTE ? 0x0000 : \
|
||||||
|
(usage == AUDIO_VOL_UP ? 0x1000 : \
|
||||||
|
(usage == AUDIO_VOL_DOWN ? 0x2000 : \
|
||||||
|
(usage == TRANSPORT_NEXT_TRACK ? 0x0002 : \
|
||||||
|
(usage == TRANSPORT_PREV_TRACK ? 0x0004 : \
|
||||||
|
(usage == TRANSPORT_STOP ? 0x0010 : \
|
||||||
|
(usage == TRANSPORT_STOP_EJECT ? 0x0000 : \
|
||||||
|
(usage == TRANSPORT_PLAY_PAUSE ? 0x4000 : \
|
||||||
|
(usage == AL_CC_CONFIG ? 0x0000 : \
|
||||||
|
(usage == AL_EMAIL ? 0x0000 : \
|
||||||
|
(usage == AL_CALCULATOR ? 0x0000 : \
|
||||||
|
(usage == AL_LOCAL_BROWSER ? 0x0000 : \
|
||||||
|
(usage == AC_SEARCH ? 0x0400 : \
|
||||||
|
(usage == AC_HOME ? 0x0100 : \
|
||||||
|
(usage == AC_BACK ? 0x0000 : \
|
||||||
|
(usage == AC_FORWARD ? 0x0000 : \
|
||||||
|
(usage == AC_STOP ? 0x0000 : \
|
||||||
|
(usage == AC_REFRESH ? 0x0000 : \
|
||||||
|
(usage == AC_BOOKMARKS ? 0x0000 : 0)))))))))))))))))))
|
||||||
|
|
||||||
|
#endif
|
|
@ -51,8 +51,13 @@
|
||||||
|
|
||||||
#include "descriptor.h"
|
#include "descriptor.h"
|
||||||
#include "lufa.h"
|
#include "lufa.h"
|
||||||
|
|
||||||
#ifdef MIDI_ENABLE
|
#ifdef MIDI_ENABLE
|
||||||
#include <beeps.h>
|
#include <beeps.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef BLUETOOTH_ENABLE
|
||||||
|
#include "bluetooth.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// #include <LUFA/Version.h>
|
// #include <LUFA/Version.h>
|
||||||
|
@ -89,7 +94,6 @@ host_driver_t lufa_driver = {
|
||||||
usb_get_midi,
|
usb_get_midi,
|
||||||
midi_usb_init,
|
midi_usb_init,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void SetupHardware(void);
|
void SetupHardware(void);
|
||||||
|
@ -477,6 +481,13 @@ static void send_keyboard(report_keyboard_t *report)
|
||||||
Endpoint_ClearIN();
|
Endpoint_ClearIN();
|
||||||
|
|
||||||
keyboard_report_sent = *report;
|
keyboard_report_sent = *report;
|
||||||
|
|
||||||
|
#ifdef BLUETOOTH_ENABLE
|
||||||
|
bluefruit_serial_send(0xFD);
|
||||||
|
for (uint8_t i = 0; i < KEYBOARD_EPSIZE; i++) {
|
||||||
|
bluefruit_serial_send(report->raw[i]);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void send_mouse(report_mouse_t *report)
|
static void send_mouse(report_mouse_t *report)
|
||||||
|
@ -499,6 +510,20 @@ static void send_mouse(report_mouse_t *report)
|
||||||
|
|
||||||
/* Finalize the stream transfer to send the last packet */
|
/* Finalize the stream transfer to send the last packet */
|
||||||
Endpoint_ClearIN();
|
Endpoint_ClearIN();
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef BLUETOOTH_ENABLE
|
||||||
|
bluefruit_serial_send(0xFD);
|
||||||
|
bluefruit_serial_send(0x00);
|
||||||
|
bluefruit_serial_send(0x03);
|
||||||
|
bluefruit_serial_send(report->buttons);
|
||||||
|
bluefruit_serial_send(report->x);
|
||||||
|
bluefruit_serial_send(report->y);
|
||||||
|
bluefruit_serial_send(report->v); // should try sending the wheel v here
|
||||||
|
bluefruit_serial_send(report->h); // should try sending the wheel h here
|
||||||
|
bluefruit_serial_send(0x00);
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -542,6 +567,23 @@ static void send_consumer(uint16_t data)
|
||||||
|
|
||||||
Endpoint_Write_Stream_LE(&r, sizeof(report_extra_t), NULL);
|
Endpoint_Write_Stream_LE(&r, sizeof(report_extra_t), NULL);
|
||||||
Endpoint_ClearIN();
|
Endpoint_ClearIN();
|
||||||
|
|
||||||
|
#ifdef BLUETOOTH_ENABLE
|
||||||
|
static uint16_t last_data = 0;
|
||||||
|
if (data == last_data) return;
|
||||||
|
last_data = data;
|
||||||
|
uint16_t bitmap = CONSUMER2BLUEFRUIT(data);
|
||||||
|
bluefruit_serial_send(0xFD);
|
||||||
|
bluefruit_serial_send(0x00);
|
||||||
|
bluefruit_serial_send(0x02);
|
||||||
|
bluefruit_serial_send((bitmap>>8)&0xFF);
|
||||||
|
bluefruit_serial_send(bitmap&0xFF);
|
||||||
|
bluefruit_serial_send(0x00);
|
||||||
|
bluefruit_serial_send(0x00);
|
||||||
|
bluefruit_serial_send(0x00);
|
||||||
|
bluefruit_serial_send(0x00);
|
||||||
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -838,6 +880,11 @@ int main(void)
|
||||||
// midi_send_noteoff(&midi_device, 0, 64, 127);
|
// midi_send_noteoff(&midi_device, 0, 64, 127);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef BLUETOOTH_ENABLE
|
||||||
|
print_set_sendchar(sendchar);
|
||||||
|
serial_init();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* wait for USB startup & debug output */
|
/* wait for USB startup & debug output */
|
||||||
while (USB_DeviceState != DEVICE_STATE_Configured) {
|
while (USB_DeviceState != DEVICE_STATE_Configured) {
|
||||||
|
|
|
@ -49,7 +49,7 @@
|
||||||
#include <LUFA/Drivers/USB/USB.h>
|
#include <LUFA/Drivers/USB/USB.h>
|
||||||
#include "host.h"
|
#include "host.h"
|
||||||
#ifdef MIDI_ENABLE
|
#ifdef MIDI_ENABLE
|
||||||
#include "midi/midi.h"
|
#include "midi/midi.h"
|
||||||
#endif
|
#endif
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
|
Loading…
Reference in a new issue