Refactor Bluetooth Handling
Refactored Bluetooth support to make adding new Bluetooth modules easier in the future. * Remove `OUT_BLE` key from QMK's keymap. `OUT_BT` is all we need now as there's no difference anymore. * Made BLUETOOTH_ENABLE build option legacy as not to break existing keymaps (Falls back to existing EZ Key support if on) * Removed `ADAFRUIT_BLE_ENABLE` build option * Created new build option `BLUETOOTH` with module option (Currently `AdafruitEZKey` & `AdafruitBLE`) * Moved all LUFA bluetooth key/mouse events under `BLUETOOTH_ENABLE` ifdef with selected modules output.
This commit is contained in:
		
							parent
							
								
									7a9437a2e3
								
							
						
					
					
						commit
						ddc036b69e
					
				| @ -294,14 +294,6 @@ bool process_record_quantum(keyrecord_t *record) { | |||||||
|       return false; |       return false; | ||||||
|       break; |       break; | ||||||
|     #endif |     #endif | ||||||
|     #ifdef ADAFRUIT_BLE_ENABLE |  | ||||||
|     case OUT_BLE: |  | ||||||
|       if (record->event.pressed) { |  | ||||||
|         set_output(OUTPUT_ADAFRUIT_BLE); |  | ||||||
|       } |  | ||||||
|       return false; |  | ||||||
|       break; |  | ||||||
|     #endif |  | ||||||
|     #endif |     #endif | ||||||
|     case MAGIC_SWAP_CONTROL_CAPSLOCK ... MAGIC_TOGGLE_NKRO: |     case MAGIC_SWAP_CONTROL_CAPSLOCK ... MAGIC_TOGGLE_NKRO: | ||||||
|       if (record->event.pressed) { |       if (record->event.pressed) { | ||||||
|  | |||||||
| @ -159,9 +159,6 @@ enum quantum_keycodes { | |||||||
| #ifdef BLUETOOTH_ENABLE | #ifdef BLUETOOTH_ENABLE | ||||||
|     OUT_BT, |     OUT_BT, | ||||||
| #endif | #endif | ||||||
| #ifdef ADAFRUIT_BLE_ENABLE |  | ||||||
|     OUT_BLE, |  | ||||||
| #endif |  | ||||||
| 
 | 
 | ||||||
|     // always leave at the end
 |     // always leave at the end
 | ||||||
|     SAFE_RANGE |     SAFE_RANGE | ||||||
|  | |||||||
| @ -93,11 +93,15 @@ ifeq ($(strip $(BACKLIGHT_ENABLE)), yes) | |||||||
|     TMK_COMMON_DEFS += -DBACKLIGHT_ENABLE |     TMK_COMMON_DEFS += -DBACKLIGHT_ENABLE | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq ($(strip $(ADAFRUIT_BLE_ENABLE)), yes) | ifeq ($(strip $(BLUETOOTH_ENABLE)), yes) | ||||||
|     TMK_COMMON_DEFS += -DADAFRUIT_BLE_ENABLE |     TMK_COMMON_DEFS += -DBLUETOOTH_ENABLE | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq ($(strip $(BLUETOOTH_ENABLE)), yes) | ifeq ($(strip $(BLUETOOTH)), AdafruitBLE) | ||||||
|  | 		TMK_COMMON_DEFS += -DBLUETOOTH_ENABLE | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | ifeq ($(strip $(BLUETOOTH)), AdafruitEZKey) | ||||||
| 		TMK_COMMON_DEFS += -DBLUETOOTH_ENABLE | 		TMK_COMMON_DEFS += -DBLUETOOTH_ENABLE | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -22,11 +22,16 @@ ifeq ($(strip $(MIDI_ENABLE)), yes) | |||||||
| 	include $(TMK_PATH)/protocol/midi.mk | 	include $(TMK_PATH)/protocol/midi.mk | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq ($(strip $(ADAFRUIT_BLE_ENABLE)), yes) | ifeq ($(strip $(BLUETOOTH_ENABLE)), yes) | ||||||
|  | 	LUFA_SRC += $(LUFA_DIR)/bluetooth.c \
 | ||||||
|  | 	$(TMK_DIR)/protocol/serial_uart.c | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | ifeq ($(strip $(BLUETOOTH)), AdafruitBLE) | ||||||
| 		LUFA_SRC += $(LUFA_DIR)/adafruit_ble.cpp | 		LUFA_SRC += $(LUFA_DIR)/adafruit_ble.cpp | ||||||
| endif | endif | ||||||
| 
 | 
 | ||||||
| ifeq ($(strip $(BLUETOOTH_ENABLE)), yes) | ifeq ($(strip $(BLUETOOTH)), AdafruitEZKey) | ||||||
| 	LUFA_SRC += $(LUFA_DIR)/bluetooth.c \
 | 	LUFA_SRC += $(LUFA_DIR)/bluetooth.c \
 | ||||||
| 	$(TMK_DIR)/protocol/serial_uart.c | 	$(TMK_DIR)/protocol/serial_uart.c | ||||||
| endif | endif | ||||||
| @ -54,6 +59,7 @@ LUFA_OPTS += -DUSE_FLASH_DESCRIPTORS | |||||||
| LUFA_OPTS += -DUSE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" | LUFA_OPTS += -DUSE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" | ||||||
| #LUFA_OPTS += -DINTERRUPT_CONTROL_ENDPOINT
 | #LUFA_OPTS += -DINTERRUPT_CONTROL_ENDPOINT
 | ||||||
| LUFA_OPTS += -DFIXED_CONTROL_ENDPOINT_SIZE=8  | LUFA_OPTS += -DFIXED_CONTROL_ENDPOINT_SIZE=8  | ||||||
|  | LUFA_OPTS += -DFIXED_CONTROL_ENDPOINT_SIZE=8 | ||||||
| LUFA_OPTS += -DFIXED_NUM_CONFIGURATIONS=1 | LUFA_OPTS += -DFIXED_NUM_CONFIGURATIONS=1 | ||||||
| 
 | 
 | ||||||
| # Remote wakeup fix for ATmega32U2        https://github.com/tmk/tmk_keyboard/issues/361
 | # Remote wakeup fix for ATmega32U2        https://github.com/tmk/tmk_keyboard/issues/361
 | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
|  * Supports the Adafruit BLE board built around the nRF51822 chip. |  * Supports the Adafruit BLE board built around the nRF51822 chip. | ||||||
|  */ |  */ | ||||||
| #pragma once | #pragma once | ||||||
| #ifdef ADAFRUIT_BLE_ENABLE | #ifdef MODULE_ADAFRUIT_BLE | ||||||
| #include <stdbool.h> | #include <stdbool.h> | ||||||
| #include <stdint.h> | #include <stdint.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
| @ -57,4 +57,4 @@ extern bool adafruit_ble_set_power_level(int8_t level); | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #endif // ADAFRUIT_BLE_ENABLE
 | #endif // MODULE_ADAFRUIT_BLE
 | ||||||
|  | |||||||
| @ -67,10 +67,11 @@ | |||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #ifdef BLUETOOTH_ENABLE | #ifdef BLUETOOTH_ENABLE | ||||||
|     #include "bluetooth.h" |   #ifdef MODULE_ADAFRUIT_BLE | ||||||
| #endif |  | ||||||
| #ifdef ADAFRUIT_BLE_ENABLE |  | ||||||
|     #include "adafruit_ble.h" |     #include "adafruit_ble.h" | ||||||
|  |   #else | ||||||
|  |     #include "bluetooth.h" | ||||||
|  |   #endif | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #ifdef VIRTSER_ENABLE | #ifdef VIRTSER_ENABLE | ||||||
| @ -602,18 +603,14 @@ static void send_keyboard(report_keyboard_t *report) | |||||||
|     uint8_t where = where_to_send(); |     uint8_t where = where_to_send(); | ||||||
| 
 | 
 | ||||||
| #ifdef BLUETOOTH_ENABLE | #ifdef BLUETOOTH_ENABLE | ||||||
|     if (where == OUTPUT_BLUETOOTH || where == OUTPUT_USB_AND_BT) { |   #ifdef MODULE_ADAFRUIT_BLE | ||||||
|  |     adafruit_ble_send_keys(report->mods, report->keys, sizeof(report->keys)); | ||||||
|  |   #else | ||||||
|     bluefruit_serial_send(0xFD); |     bluefruit_serial_send(0xFD); | ||||||
|     for (uint8_t i = 0; i < KEYBOARD_EPSIZE; i++) { |     for (uint8_t i = 0; i < KEYBOARD_EPSIZE; i++) { | ||||||
|       bluefruit_serial_send(report->raw[i]); |       bluefruit_serial_send(report->raw[i]); | ||||||
|     } |     } | ||||||
|     } |   #endif | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #ifdef ADAFRUIT_BLE_ENABLE |  | ||||||
|     if (where == OUTPUT_ADAFRUIT_BLE) { |  | ||||||
|       adafruit_ble_send_keys(report->mods, report->keys, sizeof(report->keys)); |  | ||||||
|     } |  | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|     if (where != OUTPUT_USB && where != OUTPUT_USB_AND_BT) { |     if (where != OUTPUT_USB && where != OUTPUT_USB_AND_BT) { | ||||||
| @ -661,6 +658,10 @@ static void send_mouse(report_mouse_t *report) | |||||||
| 
 | 
 | ||||||
| #ifdef BLUETOOTH_ENABLE | #ifdef BLUETOOTH_ENABLE | ||||||
|   if (where == OUTPUT_BLUETOOTH || where == OUTPUT_USB_AND_BT) { |   if (where == OUTPUT_BLUETOOTH || where == OUTPUT_USB_AND_BT) { | ||||||
|  |     #ifdef MODULE_ADAFRUIT_BLE | ||||||
|  |       // FIXME: mouse buttons
 | ||||||
|  |       adafruit_ble_send_mouse_move(report->x, report->y, report->v, report->h); | ||||||
|  |     #else | ||||||
|       bluefruit_serial_send(0xFD); |       bluefruit_serial_send(0xFD); | ||||||
|       bluefruit_serial_send(0x00); |       bluefruit_serial_send(0x00); | ||||||
|       bluefruit_serial_send(0x03); |       bluefruit_serial_send(0x03); | ||||||
| @ -670,13 +671,7 @@ static void send_mouse(report_mouse_t *report) | |||||||
|       bluefruit_serial_send(report->v); // should try sending the wheel v here
 |       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(report->h); // should try sending the wheel h here
 | ||||||
|       bluefruit_serial_send(0x00); |       bluefruit_serial_send(0x00); | ||||||
|     } |     #endif | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #ifdef ADAFRUIT_BLE_ENABLE |  | ||||||
|     if (where == OUTPUT_ADAFRUIT_BLE) { |  | ||||||
|       // FIXME: mouse buttons
 |  | ||||||
|       adafruit_ble_send_mouse_move(report->x, report->y, report->v, report->h); |  | ||||||
|   } |   } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| @ -727,6 +722,9 @@ static void send_consumer(uint16_t data) | |||||||
| 
 | 
 | ||||||
| #ifdef BLUETOOTH_ENABLE | #ifdef BLUETOOTH_ENABLE | ||||||
|     if (where == OUTPUT_BLUETOOTH || where == OUTPUT_USB_AND_BT) { |     if (where == OUTPUT_BLUETOOTH || where == OUTPUT_USB_AND_BT) { | ||||||
|  |       #ifdef MODULE_ADAFRUIT_BLE | ||||||
|  |         adafruit_ble_send_consumer_key(data, 0); | ||||||
|  |       #else | ||||||
|         static uint16_t last_data = 0; |         static uint16_t last_data = 0; | ||||||
|         if (data == last_data) return; |         if (data == last_data) return; | ||||||
|         last_data = data; |         last_data = data; | ||||||
| @ -740,12 +738,7 @@ static void send_consumer(uint16_t data) | |||||||
|         bluefruit_serial_send(0x00); |         bluefruit_serial_send(0x00); | ||||||
|         bluefruit_serial_send(0x00); |         bluefruit_serial_send(0x00); | ||||||
|         bluefruit_serial_send(0x00); |         bluefruit_serial_send(0x00); | ||||||
|     } |       #endif | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #ifdef ADAFRUIT_BLE_ENABLE |  | ||||||
|     if (where == OUTPUT_ADAFRUIT_BLE) { |  | ||||||
|       adafruit_ble_send_consumer_key(data, 0); |  | ||||||
|     } |     } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| @ -1130,10 +1123,6 @@ int main(void) | |||||||
|     // midi_send_noteoff(&midi_device, 0, 64, 127);
 |     // midi_send_noteoff(&midi_device, 0, 64, 127);
 | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #ifdef BLUETOOTH_ENABLE |  | ||||||
|     serial_init(); |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
|     /* wait for USB startup & debug output */ |     /* wait for USB startup & debug output */ | ||||||
| 
 | 
 | ||||||
| #ifdef WAIT_FOR_USB | #ifdef WAIT_FOR_USB | ||||||
| @ -1161,7 +1150,7 @@ int main(void) | |||||||
| 
 | 
 | ||||||
|     print("Keyboard start.\n"); |     print("Keyboard start.\n"); | ||||||
|     while (1) { |     while (1) { | ||||||
|         #if !defined(BLUETOOTH_ENABLE) && !defined(ADAFRUIT_BLE_ENABLE) |         #if !defined(BLUETOOTH_ENABLE) | ||||||
|         while (USB_DeviceState == DEVICE_STATE_Suspended) { |         while (USB_DeviceState == DEVICE_STATE_Suspended) { | ||||||
|             print("[s]"); |             print("[s]"); | ||||||
|             suspend_power_down(); |             suspend_power_down(); | ||||||
| @ -1182,7 +1171,11 @@ int main(void) | |||||||
|         rgblight_task(); |         rgblight_task(); | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #ifdef ADAFRUIT_BLE_ENABLE | #ifdef MODULE_ADAFRUIT_EZKEY | ||||||
|  |     serial_init(); | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #ifdef MODULE_ADAFRUIT_BLE | ||||||
|         adafruit_ble_task(); |         adafruit_ble_task(); | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -14,7 +14,7 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>. | |||||||
| 
 | 
 | ||||||
| #include "lufa.h" | #include "lufa.h" | ||||||
| #include "outputselect.h" | #include "outputselect.h" | ||||||
| #ifdef ADAFRUIT_BLE_ENABLE | #ifdef MODULE_ADAFRUIT_BLE | ||||||
|     #include "adafruit_ble.h" |     #include "adafruit_ble.h" | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| @ -34,9 +34,9 @@ uint8_t auto_detect_output(void) { | |||||||
|         return OUTPUT_USB; |         return OUTPUT_USB; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| #ifdef ADAFRUIT_BLE_ENABLE | #ifdef MODULE_ADAFRUIT_BLE | ||||||
|     if (adafruit_ble_is_connected()) { |     if (adafruit_ble_is_connected()) { | ||||||
|         return OUTPUT_ADAFRUIT_BLE; |         return OUTPUT_BLUETOOTH; | ||||||
|     } |     } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -18,7 +18,6 @@ enum outputs { | |||||||
|     OUTPUT_NONE, |     OUTPUT_NONE, | ||||||
|     OUTPUT_USB, |     OUTPUT_USB, | ||||||
|     OUTPUT_BLUETOOTH, |     OUTPUT_BLUETOOTH, | ||||||
|     OUTPUT_ADAFRUIT_BLE, |  | ||||||
| 
 | 
 | ||||||
|     // backward compatibility
 |     // backward compatibility
 | ||||||
|     OUTPUT_USB_AND_BT |     OUTPUT_USB_AND_BT | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user