Merge branch 'Lauszus-dev' into dev
# Conflicts: # right/src/usb_interfaces/usb_interface_basic_keyboard.c # right/src/usb_interfaces/usb_interface_media_keyboard.c # right/src/usb_interfaces/usb_interface_mouse.c # right/src/usb_interfaces/usb_interface_system_keyboard.c # right/src/usb_report_updater.c
This commit is contained in:
@@ -1,5 +1,6 @@
|
||||
#include "led_display.h"
|
||||
#include "usb_composite_device.h"
|
||||
#include "usb_report_updater.h"
|
||||
|
||||
static usb_basic_keyboard_report_t usbBasicKeyboardReports[2];
|
||||
uint32_t UsbBasicKeyboardActionCounter;
|
||||
@@ -23,18 +24,17 @@ void ResetActiveUsbBasicKeyboardReport(void)
|
||||
|
||||
usb_status_t UsbBasicKeyboardAction(void)
|
||||
{
|
||||
if (!UsbCompositeDevice.attach)
|
||||
if (!UsbCompositeDevice.attach) {
|
||||
return kStatus_USB_Error; // The device is not attached
|
||||
}
|
||||
|
||||
if (((usb_device_hid_struct_t *)UsbCompositeDevice.basicKeyboardHandle)->interruptInPipeBusy)
|
||||
return kStatus_USB_Busy; // The previous report has not been sent yet
|
||||
|
||||
UsbBasicKeyboardActionCounter++;
|
||||
SwitchActiveUsbBasicKeyboardReport(); // Switch the active report
|
||||
usb_status_t usb_status = USB_DeviceHidSend(
|
||||
UsbCompositeDevice.basicKeyboardHandle, USB_BASIC_KEYBOARD_ENDPOINT_INDEX,
|
||||
(uint8_t*)GetInactiveUsbBasicKeyboardReport(), USB_BASIC_KEYBOARD_REPORT_LENGTH);
|
||||
if (usb_status != kStatus_USB_Success) {
|
||||
if (usb_status == kStatus_USB_Success) {
|
||||
UsbBasicKeyboardActionCounter++;
|
||||
} else {
|
||||
SwitchActiveUsbBasicKeyboardReport(); // Switch back, as the command failed
|
||||
}
|
||||
return usb_status;
|
||||
@@ -47,6 +47,7 @@ usb_status_t UsbBasicKeyboardCallback(class_handle_t handle, uint32_t event, voi
|
||||
switch (event) {
|
||||
// This report is received when the report has been sent
|
||||
case kUSB_DeviceHidEventSendResponse:
|
||||
UsbReportUpdateSemaphore &= ~(1 << USB_BASIC_KEYBOARD_INTERFACE_INDEX);
|
||||
if (UsbCompositeDevice.attach) {
|
||||
error = kStatus_USB_Success;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user