Browse Source
* Split core USB init from USB HID init. * Tweak logging to avoid "log loop" causing spurious buffer messages on startup.xmkb
Peter Johanson
3 years ago
committed by
Pete Johanson
7 changed files with 82 additions and 53 deletions
@ -0,0 +1,9 @@
@@ -0,0 +1,9 @@
|
||||
/*
|
||||
* Copyright (c) 2020 The ZMK Contributors |
||||
* |
||||
* SPDX-License-Identifier: MIT |
||||
*/ |
||||
|
||||
#pragma once |
||||
|
||||
int zmk_usb_hid_send_report(const uint8_t *report, size_t len); |
@ -0,0 +1,64 @@
@@ -0,0 +1,64 @@
|
||||
/*
|
||||
* Copyright (c) 2020 The ZMK Contributors |
||||
* |
||||
* SPDX-License-Identifier: MIT |
||||
*/ |
||||
|
||||
#include <device.h> |
||||
#include <init.h> |
||||
|
||||
#include <usb/usb_device.h> |
||||
#include <usb/class/usb_hid.h> |
||||
|
||||
#include <zmk/usb.h> |
||||
#include <zmk/hid.h> |
||||
#include <zmk/keymap.h> |
||||
#include <zmk/event_manager.h> |
||||
|
||||
LOG_MODULE_DECLARE(zmk, CONFIG_ZMK_LOG_LEVEL); |
||||
|
||||
static const struct device *hid_dev; |
||||
|
||||
static K_SEM_DEFINE(hid_sem, 1, 1); |
||||
|
||||
static void in_ready_cb(const struct device *dev) { k_sem_give(&hid_sem); } |
||||
|
||||
static const struct hid_ops ops = { |
||||
.int_in_ready = in_ready_cb, |
||||
}; |
||||
|
||||
int zmk_usb_hid_send_report(const uint8_t *report, size_t len) { |
||||
switch (zmk_usb_get_status()) { |
||||
case USB_DC_SUSPEND: |
||||
return usb_wakeup_request(); |
||||
case USB_DC_ERROR: |
||||
case USB_DC_RESET: |
||||
case USB_DC_DISCONNECTED: |
||||
case USB_DC_UNKNOWN: |
||||
return -ENODEV; |
||||
default: |
||||
k_sem_take(&hid_sem, K_MSEC(30)); |
||||
int err = hid_int_ep_write(hid_dev, report, len, NULL); |
||||
|
||||
if (err) { |
||||
k_sem_give(&hid_sem); |
||||
} |
||||
|
||||
return err; |
||||
} |
||||
} |
||||
|
||||
static int zmk_usb_hid_init(const struct device *_arg) { |
||||
hid_dev = device_get_binding("HID_0"); |
||||
if (hid_dev == NULL) { |
||||
LOG_ERR("Unable to locate HID device"); |
||||
return -EINVAL; |
||||
} |
||||
|
||||
usb_hid_register_device(hid_dev, zmk_hid_report_desc, sizeof(zmk_hid_report_desc), &ops); |
||||
usb_hid_init(hid_dev); |
||||
|
||||
return 0; |
||||
} |
||||
|
||||
SYS_INIT(zmk_usb_hid_init, APPLICATION, CONFIG_APPLICATION_INIT_PRIORITY); |
Loading…
Reference in new issue