forked from kofal.net/zmk
Refactor build/config/keymaps.
* Move all headers to `include/zmk` directory. * Update includes to reference them properly. * Add `keymap.c` file from keymap, if found. * Toplevel CONFIG_ZMK_BLE aggregate config setting.
This commit is contained in:
@@ -8,7 +8,7 @@
|
||||
#include <bluetooth/uuid.h>
|
||||
#include <bluetooth/gatt.h>
|
||||
|
||||
#include "keys.h"
|
||||
#include <zmk/keys.h>
|
||||
|
||||
static struct bt_conn *auth_passkey_entry_conn;
|
||||
static u8_t passkey_entries[6] = {0, 0, 0, 0, 0, 0};
|
||||
|
||||
@@ -1,5 +0,0 @@
|
||||
|
||||
#pragma once
|
||||
|
||||
int zmk_ble_init();
|
||||
bool zmk_ble_handle_key_user(struct zmk_key_event *key_event);
|
||||
@@ -1,8 +1,8 @@
|
||||
|
||||
#include "endpoints.h"
|
||||
#include "hid.h"
|
||||
#include "usb_hid.h"
|
||||
#include "hog.h"
|
||||
#include <zmk/endpoints.h>
|
||||
#include <zmk/hid.h>
|
||||
#include <zmk/usb_hid.h>
|
||||
#include <zmk/hog.h>
|
||||
|
||||
int zmk_endpoints_init()
|
||||
{
|
||||
@@ -15,6 +15,7 @@ int zmk_endpoints_init()
|
||||
return err;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_ZMK_BLE
|
||||
err = zmk_hog_init();
|
||||
if (err)
|
||||
{
|
||||
@@ -22,6 +23,8 @@ int zmk_endpoints_init()
|
||||
return err;
|
||||
}
|
||||
|
||||
#endif /* CONFIG_ZMK_BLE */
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -46,12 +49,14 @@ int zmk_endpoints_send_key_event(struct zmk_key_event key_event)
|
||||
// // LOG_DBG("USB Send Failed");
|
||||
// }
|
||||
|
||||
#ifdef CONFIG_ZMK_BLE
|
||||
err = zmk_hog_send_report(report);
|
||||
if (err)
|
||||
{
|
||||
printk("FAILED TO SEND OVER HOG: %d\n", err);
|
||||
// LOG_DBG("HID Over GATTP Send Failed");
|
||||
}
|
||||
#endif /* CONFIG_ZMK_BLE */
|
||||
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,6 +0,0 @@
|
||||
#pragma once
|
||||
|
||||
#include "keys.h"
|
||||
|
||||
int zmk_endpoints_init();
|
||||
int zmk_endpoints_send_key_event(struct zmk_key_event key_event);
|
||||
@@ -1,8 +1,7 @@
|
||||
|
||||
#include "handlers.h"
|
||||
|
||||
#include "ble.h"
|
||||
#include "endpoints.h"
|
||||
#include <zmk/ble.h>
|
||||
#include <zmk/handlers.h>
|
||||
#include <zmk/endpoints.h>
|
||||
|
||||
__attribute__((weak)) bool zmk_handle_key_user(struct zmk_key_event *key_event)
|
||||
{
|
||||
@@ -16,10 +15,12 @@ void zmk_handle_key(struct zmk_key_event key_event)
|
||||
return;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_ZMK_BLE
|
||||
if (!zmk_ble_handle_key_user(&key_event))
|
||||
{
|
||||
return;
|
||||
}
|
||||
#endif /* CONFIG_ZMK_BLE */
|
||||
|
||||
zmk_endpoints_send_key_event(key_event);
|
||||
};
|
||||
|
||||
@@ -1,8 +0,0 @@
|
||||
#pragma once
|
||||
|
||||
#include <dt-bindings/zmk/keys.h>
|
||||
|
||||
#include "keymap.h"
|
||||
#include "keys.h"
|
||||
|
||||
void zmk_handle_key(struct zmk_key_event key_event);
|
||||
@@ -1,4 +1,4 @@
|
||||
#include "hid.h"
|
||||
#include <zmk/hid.h>
|
||||
|
||||
static struct zmk_hid_report report = {
|
||||
.modifiers = 0,
|
||||
@@ -53,4 +53,4 @@ int zmk_hid_release_key(zmk_key code)
|
||||
struct zmk_hid_report *zmk_hid_get_report()
|
||||
{
|
||||
return &report;
|
||||
}
|
||||
}
|
||||
|
||||
107
src/hid.h
107
src/hid.h
@@ -1,107 +0,0 @@
|
||||
#pragma once
|
||||
|
||||
#include <usb/usb_device.h>
|
||||
#include <usb/class/usb_hid.h>
|
||||
|
||||
#include <dt-bindings/zmk/keys.h>
|
||||
|
||||
#include "keys.h"
|
||||
|
||||
#define ZMK_HID_MAX_KEYCODE KC_APP
|
||||
|
||||
static const u8_t zmk_hid_report_desc[] = {
|
||||
/* USAGE_PAGE (Generic Desktop) */
|
||||
HID_GI_USAGE_PAGE,
|
||||
USAGE_GEN_DESKTOP,
|
||||
/* USAGE (Keyboard) */
|
||||
HID_LI_USAGE,
|
||||
USAGE_GEN_DESKTOP_KEYBOARD,
|
||||
/* COLLECTION (Application) */
|
||||
HID_MI_COLLECTION,
|
||||
COLLECTION_APPLICATION,
|
||||
/* REPORT ID (1) */
|
||||
HID_GI_REPORT_ID,
|
||||
0x01,
|
||||
/* USAGE_PAGE (Keypad) */
|
||||
HID_GI_USAGE_PAGE,
|
||||
USAGE_GEN_DESKTOP_KEYPAD,
|
||||
/* USAGE_MINIMUM (Keyboard LeftControl) */
|
||||
HID_LI_USAGE_MIN(1),
|
||||
0xE0,
|
||||
/* USAGE_MAXIMUM (Keyboard Right GUI) */
|
||||
HID_LI_USAGE_MAX(1),
|
||||
0xE7,
|
||||
/* LOGICAL_MINIMUM (0) */
|
||||
HID_GI_LOGICAL_MIN(1),
|
||||
0x00,
|
||||
/* LOGICAL_MAXIMUM (1) */
|
||||
HID_GI_LOGICAL_MAX(1),
|
||||
0x01,
|
||||
|
||||
/* REPORT_SIZE (1) */
|
||||
HID_GI_REPORT_SIZE,
|
||||
0x01,
|
||||
/* REPORT_COUNT (8) */
|
||||
HID_GI_REPORT_COUNT,
|
||||
0x08,
|
||||
/* INPUT (Data,Var,Abs) */
|
||||
HID_MI_INPUT,
|
||||
0x02,
|
||||
|
||||
/* USAGE_PAGE (Keypad) */
|
||||
HID_GI_USAGE_PAGE,
|
||||
USAGE_GEN_DESKTOP_KEYPAD,
|
||||
/* LOGICAL_MINIMUM (0) */
|
||||
HID_GI_LOGICAL_MIN(1),
|
||||
0x00,
|
||||
/* LOGICAL_MAXIMUM (101) */
|
||||
HID_GI_LOGICAL_MAX(1),
|
||||
0x01,
|
||||
/* USAGE_MINIMUM (Reserved) */
|
||||
HID_LI_USAGE_MIN(1),
|
||||
0x00,
|
||||
/* USAGE_MAXIMUM (Keyboard Application) */
|
||||
HID_LI_USAGE_MAX(1),
|
||||
ZMK_HID_MAX_KEYCODE,
|
||||
/* REPORT_SIZE (8) */
|
||||
HID_GI_REPORT_SIZE,
|
||||
0x01,
|
||||
/* REPORT_COUNT (6) */
|
||||
HID_GI_REPORT_COUNT,
|
||||
ZMK_HID_MAX_KEYCODE + 1,
|
||||
/* INPUT (Data,Ary,Abs) */
|
||||
HID_MI_INPUT,
|
||||
0x02,
|
||||
/* USAGE_PAGE (Keypad) */
|
||||
HID_GI_USAGE_PAGE,
|
||||
USAGE_GEN_DESKTOP_KEYPAD,
|
||||
/* REPORT_SIZE (8) */
|
||||
HID_GI_REPORT_SIZE,
|
||||
0x02,
|
||||
/* REPORT_COUNT (6) */
|
||||
HID_GI_REPORT_COUNT,
|
||||
0x01,
|
||||
/* INPUT (Cnst,Var,Abs) */
|
||||
HID_MI_INPUT,
|
||||
0x03,
|
||||
/* END_COLLECTION */
|
||||
HID_MI_COLLECTION_END,
|
||||
};
|
||||
|
||||
// struct zmk_hid_boot_report
|
||||
// {
|
||||
// u8_t modifiers;
|
||||
// u8_t _unused;
|
||||
// u8_t keys[6];
|
||||
// } __packed;
|
||||
|
||||
struct zmk_hid_report
|
||||
{
|
||||
u8_t modifiers;
|
||||
u8_t keys[13];
|
||||
} __packed;
|
||||
|
||||
int zmk_hid_press_key(zmk_key key);
|
||||
int zmk_hid_release_key(zmk_key key);
|
||||
|
||||
struct zmk_hid_report *zmk_hid_get_report();
|
||||
@@ -3,9 +3,9 @@
|
||||
#include <bluetooth/bluetooth.h>
|
||||
#include <bluetooth/gatt.h>
|
||||
|
||||
#include "ble.h"
|
||||
#include "hog.h"
|
||||
#include "hid.h"
|
||||
#include <zmk/ble.h>
|
||||
#include <zmk/hog.h>
|
||||
#include <zmk/hid.h>
|
||||
|
||||
int zmk_hog_init()
|
||||
{
|
||||
|
||||
@@ -1,9 +0,0 @@
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "keys.h"
|
||||
#include "hid.h"
|
||||
|
||||
int zmk_hog_init();
|
||||
|
||||
int zmk_hog_send_report(struct zmk_hid_report *report);
|
||||
@@ -1,5 +1,5 @@
|
||||
|
||||
#include "keymap.h"
|
||||
#include <zmk/keymap.h>
|
||||
|
||||
static u32_t zmk_keymap_layer_state = 0;
|
||||
static u8_t zmk_keymap_layer_default = 0;
|
||||
|
||||
18
src/keymap.h
18
src/keymap.h
@@ -1,18 +0,0 @@
|
||||
#pragma once
|
||||
|
||||
#include <devicetree.h>
|
||||
#include <usb/usb_device.h>
|
||||
#include <usb/class/usb_hid.h>
|
||||
#include "dt-bindings/zmk/keys.h"
|
||||
|
||||
#include "zmk.h"
|
||||
#include "keys.h"
|
||||
|
||||
#define ZMK_KEYMAP_NODE DT_CHOSEN(zmk_keymap)
|
||||
#define ZMK_KEYMAP_LAYERS_LEN DT_PROP_LEN(ZMK_KEYMAP_NODE, layers)
|
||||
|
||||
bool zmk_keymap_layer_activate(u8_t layer);
|
||||
bool zmk_keymap_layer_deactivate(u8_t layer);
|
||||
|
||||
zmk_key
|
||||
zmk_keymap_keycode_from_position(u32_t row, u32_t column);
|
||||
12
src/keys.h
12
src/keys.h
@@ -1,12 +0,0 @@
|
||||
#pragma once
|
||||
|
||||
#include <zephyr.h>
|
||||
#include <dt-bindings/zmk/keys.h>
|
||||
|
||||
typedef u64_t zmk_key;
|
||||
|
||||
struct zmk_key_event
|
||||
{
|
||||
zmk_key key;
|
||||
bool pressed;
|
||||
};
|
||||
@@ -11,9 +11,8 @@
|
||||
|
||||
LOG_MODULE_REGISTER(zmk_kscan, CONFIG_ZMK_KSCAN_LOG_LEVEL);
|
||||
|
||||
#include "keymap.h"
|
||||
#include "usb_hid.h"
|
||||
#include "handlers.h"
|
||||
#include <zmk/keymap.h>
|
||||
#include <zmk/handlers.h>
|
||||
|
||||
#define ZMK_KSCAN_EVENT_STATE_PRESSED 0
|
||||
#define ZMK_KSCAN_EVENT_STATE_RELEASED 1
|
||||
|
||||
@@ -1,3 +0,0 @@
|
||||
#pragma once
|
||||
|
||||
int zmk_kscan_init(char *name);
|
||||
@@ -8,9 +8,9 @@
|
||||
#include <device.h>
|
||||
#include <devicetree.h>
|
||||
|
||||
#include "zmk.h"
|
||||
#include "kscan.h"
|
||||
#include "endpoints.h"
|
||||
#include <zmk/matrix.h>
|
||||
#include <zmk/kscan.h>
|
||||
#include <zmk/endpoints.h>
|
||||
|
||||
#define ZMK_KSCAN_DEV DT_LABEL(ZMK_MATRIX_NODE_ID)
|
||||
|
||||
|
||||
@@ -5,8 +5,8 @@
|
||||
#include <usb/class/usb_hid.h>
|
||||
#include <dt-bindings/zmk/keys.h>
|
||||
|
||||
#include "hid.h"
|
||||
#include "keymap.h"
|
||||
#include <zmk/hid.h>
|
||||
#include <zmk/keymap.h>
|
||||
|
||||
LOG_MODULE_REGISTER(zmk_usb_hid, CONFIG_ZMK_USB_HID_LOG_LEVEL);
|
||||
|
||||
|
||||
@@ -1,14 +0,0 @@
|
||||
#ifndef ZMK_USB_HID
|
||||
#define ZMK_USB_HID
|
||||
|
||||
#include <usb/usb_device.h>
|
||||
#include <usb/class/usb_hid.h>
|
||||
|
||||
#include "keys.h"
|
||||
#include "hid.h"
|
||||
|
||||
int zmk_usb_hid_init();
|
||||
|
||||
int zmk_usb_hid_send_report(const struct zmk_hid_report *report);
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user