mirror of
https://github.com/qmk/qmk_firmware.git
synced 2025-06-09 02:14:20 +00:00
Add new functions to the HID host class driver, refine HID interface protocol matching.
Remove stray state variable from the CDC host class driver.
This commit is contained in:
parent
a2001ac1cc
commit
c86491af8b
@ -47,7 +47,8 @@
|
|||||||
#include <LUFA/Drivers/Misc/TerminalCodes.h>
|
#include <LUFA/Drivers/Misc/TerminalCodes.h>
|
||||||
#include <LUFA/Drivers/Peripheral/SerialStream.h>
|
#include <LUFA/Drivers/Peripheral/SerialStream.h>
|
||||||
#include <LUFA/Drivers/Board/LEDs.h>
|
#include <LUFA/Drivers/Board/LEDs.h>
|
||||||
#include <LUFA/Drivers/USB/USB.h>\
|
#include <LUFA/Drivers/USB/USB.h>
|
||||||
|
#include <LUFA/Drivers/USB/Class/CDC.h>
|
||||||
|
|
||||||
/* Macros: */
|
/* Macros: */
|
||||||
/** LED mask for the library LED driver, to indicate that the USB interface is not ready. */
|
/** LED mask for the library LED driver, to indicate that the USB interface is not ready. */
|
||||||
|
@ -47,7 +47,6 @@ USB_ClassInfo_HID_Host_t Mouse_HID_Interface =
|
|||||||
.DataINPipeNumber = 1,
|
.DataINPipeNumber = 1,
|
||||||
.DataOUTPipeNumber = 2,
|
.DataOUTPipeNumber = 2,
|
||||||
|
|
||||||
.MatchInterfaceProtocol = true,
|
|
||||||
.HIDInterfaceProtocol = 0x02,
|
.HIDInterfaceProtocol = 0x02,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -48,7 +48,7 @@
|
|||||||
#include <LUFA/Drivers/Peripheral/SerialStream.h>
|
#include <LUFA/Drivers/Peripheral/SerialStream.h>
|
||||||
#include <LUFA/Drivers/Board/LEDs.h>
|
#include <LUFA/Drivers/Board/LEDs.h>
|
||||||
#include <LUFA/Drivers/USB/USB.h>
|
#include <LUFA/Drivers/USB/USB.h>
|
||||||
#include <LUFA/Drivers/USB/Class/Host/HID.h>
|
#include <LUFA/Drivers/USB/Class/HID.h>
|
||||||
|
|
||||||
/* Macros: */
|
/* Macros: */
|
||||||
/** LED mask for the library LED driver, to indicate that the USB interface is not ready. */
|
/** LED mask for the library LED driver, to indicate that the USB interface is not ready. */
|
||||||
|
25
Demos/Host/ClassDriver/makefile
Normal file
25
Demos/Host/ClassDriver/makefile
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
#
|
||||||
|
# LUFA Library
|
||||||
|
# Copyright (C) Dean Camera, 2009.
|
||||||
|
#
|
||||||
|
# dean [at] fourwalledcubicle [dot] com
|
||||||
|
# www.fourwalledcubicle.com
|
||||||
|
#
|
||||||
|
|
||||||
|
# Makefile to build all the LUFA Host Demos. Call with "make all" to
|
||||||
|
# rebuild all Host demos.
|
||||||
|
|
||||||
|
# Projects are pre-cleaned before each one is built, to ensure any
|
||||||
|
# custom LUFA library build options are reflected in the compiled
|
||||||
|
# code.
|
||||||
|
|
||||||
|
all:
|
||||||
|
make -C CDCHost clean
|
||||||
|
make -C CDCHost all
|
||||||
|
|
||||||
|
make -C MouseHost clean
|
||||||
|
make -C MouseHost all
|
||||||
|
|
||||||
|
%:
|
||||||
|
make -C CDCHost $@
|
||||||
|
make -C MouseHost $@
|
File diff suppressed because one or more lines are too long
@ -52,9 +52,9 @@ uint8_t CDC_Host_ConfigurePipes(USB_ClassInfo_CDC_Host_t* CDCInterfaceInfo, uint
|
|||||||
|
|
||||||
CDCInterfaceInfo->State.ControlInterfaceNumber =
|
CDCInterfaceInfo->State.ControlInterfaceNumber =
|
||||||
#if defined(USE_NONSTANDARD_DESCRIPTOR_NAMES)
|
#if defined(USE_NONSTANDARD_DESCRIPTOR_NAMES)
|
||||||
DESCRIPTOR_CAST(ConfigDescriptorData, USB_Descriptor_Interface_t).InterfaceNumber;
|
DESCRIPTOR_CAST(ConfigDescriptorData, USB_Descriptor_Interface_t).InterfaceNumber;
|
||||||
#else
|
#else
|
||||||
DESCRIPTOR_CAST(ConfigDescriptorData, USB_Descriptor_Interface_t).bInterfaceNumber;
|
DESCRIPTOR_CAST(ConfigDescriptorData, USB_Descriptor_Interface_t).bInterfaceNumber;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
while (FoundEndpoints != (CDC_FOUND_DATAPIPE_IN | CDC_FOUND_DATAPIPE_OUT | CDC_FOUND_DATAPIPE_NOTIFICATION))
|
while (FoundEndpoints != (CDC_FOUND_DATAPIPE_IN | CDC_FOUND_DATAPIPE_OUT | CDC_FOUND_DATAPIPE_NOTIFICATION))
|
||||||
|
@ -71,8 +71,10 @@
|
|||||||
*/
|
*/
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
bool Active; /**< Indicates if the current interface instance is connected to an attached device */
|
bool Active; /**< Indicates if the current interface instance is connected to an attached device, valid
|
||||||
|
* after \ref HID_Host_ConfigurePipes() is called and the Host state machine is in the
|
||||||
|
* Configured state
|
||||||
|
*/
|
||||||
uint8_t ControlInterfaceNumber; /**< Interface index of the CDC-ACM control interface within the attached device */
|
uint8_t ControlInterfaceNumber; /**< Interface index of the CDC-ACM control interface within the attached device */
|
||||||
|
|
||||||
uint16_t DataINPipeSize; /**< Size in bytes of the CDC interface's IN data pipe */
|
uint16_t DataINPipeSize; /**< Size in bytes of the CDC interface's IN data pipe */
|
||||||
@ -91,8 +93,6 @@
|
|||||||
|
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
bool Active; /**< Indicates if the interface is currently active, i.e. attached to the connected device */
|
|
||||||
|
|
||||||
uint32_t BaudRateBPS; /**< Baud rate of the virtual serial port, in bits per second */
|
uint32_t BaudRateBPS; /**< Baud rate of the virtual serial port, in bits per second */
|
||||||
uint8_t CharFormat; /**< Character format of the virtual serial port, a value from the
|
uint8_t CharFormat; /**< Character format of the virtual serial port, a value from the
|
||||||
* CDCDevice_CDC_LineCodingFormats_t enum
|
* CDCDevice_CDC_LineCodingFormats_t enum
|
||||||
|
@ -46,6 +46,8 @@ uint8_t HID_Host_ConfigurePipes(USB_ClassInfo_HID_Host_t* HIDInterfaceInfo, uint
|
|||||||
if (DESCRIPTOR_TYPE(ConfigDescriptorData) != DTYPE_Configuration)
|
if (DESCRIPTOR_TYPE(ConfigDescriptorData) != DTYPE_Configuration)
|
||||||
return HID_ENUMERROR_InvalidConfigDescriptor;
|
return HID_ENUMERROR_InvalidConfigDescriptor;
|
||||||
|
|
||||||
|
USB_Descriptor_Interface_t* CurrentHIDInterface;
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
if (USB_GetNextDescriptorComp(&ConfigDescriptorSize, &ConfigDescriptorData,
|
if (USB_GetNextDescriptorComp(&ConfigDescriptorSize, &ConfigDescriptorData,
|
||||||
@ -53,9 +55,18 @@ uint8_t HID_Host_ConfigurePipes(USB_ClassInfo_HID_Host_t* HIDInterfaceInfo, uint
|
|||||||
{
|
{
|
||||||
return HID_ENUMERROR_NoHIDInterfaceFound;
|
return HID_ENUMERROR_NoHIDInterfaceFound;
|
||||||
}
|
}
|
||||||
} while (HIDInterfaceInfo->Config.MatchInterfaceProtocol &&
|
|
||||||
DESCRIPTOR_PCAST(ConfigDescriptorData,
|
CurrentHIDInterface = DESCRIPTOR_PCAST(ConfigDescriptorData, USB_Descriptor_Interface_t);
|
||||||
USB_Descriptor_Interface_t)->Protocol != HIDInterfaceInfo->Config.HIDInterfaceProtocol);
|
} while (HIDInterfaceInfo->Config.HIDInterfaceProtocol &&
|
||||||
|
(CurrentHIDInterface->Protocol != HIDInterfaceInfo->Config.HIDInterfaceProtocol));
|
||||||
|
|
||||||
|
HIDInterfaceInfo->State.InterfaceNumber =
|
||||||
|
#if defined(USE_NONSTANDARD_DESCRIPTOR_NAMES)
|
||||||
|
CurrentHIDInterface->InterfaceNumber;
|
||||||
|
#else
|
||||||
|
CurrentHIDInterface->bInterfaceNumber;
|
||||||
|
#endif
|
||||||
|
HIDInterfaceInfo->State.SupportsBootSubClass = (CurrentHIDInterface->SubClass != 0);
|
||||||
|
|
||||||
while (FoundEndpoints != ((1 << HID_FOUND_DATAPIPE_IN) | (1 << HID_FOUND_DATAPIPE_OUT)))
|
while (FoundEndpoints != ((1 << HID_FOUND_DATAPIPE_IN) | (1 << HID_FOUND_DATAPIPE_OUT)))
|
||||||
{
|
{
|
||||||
@ -144,4 +155,20 @@ bool HID_Host_IsReportReceived(USB_ClassInfo_HID_Host_t* HIDInterfaceInfo)
|
|||||||
return ReportReceived;
|
return ReportReceived;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint8_t USB_HID_Host_SetProtocol(USB_ClassInfo_HID_Host_t* HIDInterfaceInfo, bool UseReportProtocol)
|
||||||
|
{
|
||||||
|
USB_ControlRequest = (USB_Request_Header_t)
|
||||||
|
{
|
||||||
|
.bmRequestType = (REQDIR_HOSTTODEVICE | REQTYPE_CLASS | REQREC_INTERFACE),
|
||||||
|
.bRequest = REQ_SetProtocol,
|
||||||
|
.wValue = UseReportProtocol,
|
||||||
|
.wIndex = HIDInterfaceInfo->State.InterfaceNumber,
|
||||||
|
.wLength = 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
Pipe_SelectPipe(PIPE_CONTROLPIPE);
|
||||||
|
|
||||||
|
return USB_Host_SendControlRequest(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -66,23 +66,28 @@
|
|||||||
{
|
{
|
||||||
uint8_t DataINPipeNumber; /**< Pipe number of the HID interface's IN data pipe */
|
uint8_t DataINPipeNumber; /**< Pipe number of the HID interface's IN data pipe */
|
||||||
uint8_t DataOUTPipeNumber; /**< Pipe number of the HID interface's OUT data pipe */
|
uint8_t DataOUTPipeNumber; /**< Pipe number of the HID interface's OUT data pipe */
|
||||||
|
|
||||||
bool MatchInterfaceProtocol; /**< Indicates whether the driver should match the device's
|
uint8_t HIDInterfaceProtocol; /**< HID interface protocol value to match against if a specific
|
||||||
* HID interface protocol's value to the \ref HIDInterfaceProtocol
|
* boot subclass protocol is required (e.g. keyboard, mouse), or
|
||||||
* suppled (otherwise just accept all HID class devices)
|
* leave as 0 to match against the first HID interface found
|
||||||
*/
|
|
||||||
uint8_t HIDInterfaceProtocol; /**< HID interface protocol value to match against if the
|
|
||||||
* \ref MatchInterfaceProtocol is set to true (ignored otherwise)
|
|
||||||
*/
|
*/
|
||||||
} Config; /**< Config data for the USB class interface within the device. All elements in this section
|
} Config; /**< Config data for the USB class interface within the device. All elements in this section
|
||||||
* <b>must</b> be set or the interface will fail to enumerate and operate correctly.
|
* <b>must</b> be set or the interface will fail to enumerate and operate correctly.
|
||||||
*/
|
*/
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
bool Active; /**< Indicates if the current interface instance is connected to an attached device */
|
bool Active; /**< Indicates if the current interface instance is connected to an attached device, valid
|
||||||
|
* after \ref HID_Host_ConfigurePipes() is called and the Host state machine is in the
|
||||||
|
* Configured state
|
||||||
|
*/
|
||||||
|
uint8_t InterfaceNumber; /**< Interface index of the HID interface within the attached device */
|
||||||
|
|
||||||
uint16_t DataINPipeSize; /**< Size in bytes of the HID interface's IN data pipe */
|
uint16_t DataINPipeSize; /**< Size in bytes of the HID interface's IN data pipe */
|
||||||
uint16_t DataOUTPipeSize; /**< Size in bytes of the HID interface's OUT data pipe */
|
uint16_t DataOUTPipeSize; /**< Size in bytes of the HID interface's OUT data pipe */
|
||||||
|
|
||||||
|
bool SupportsBootSubClass; /**< Indicates if the current interface instance supports the HID Boot
|
||||||
|
* Protocol when enabled via \ref USB_HID_Host_SetProtocol()
|
||||||
|
*/
|
||||||
} State; /**< State data for the USB class interface within the device. All elements in this section
|
} State; /**< State data for the USB class interface within the device. All elements in this section
|
||||||
* <b>may</b> be set to initial values, but may also be ignored to default to sane values when
|
* <b>may</b> be set to initial values, but may also be ignored to default to sane values when
|
||||||
* the interface is enumerated.
|
* the interface is enumerated.
|
||||||
@ -103,7 +108,8 @@
|
|||||||
uint8_t HID_Host_ConfigurePipes(USB_ClassInfo_HID_Host_t* HIDInterfaceInfo, uint16_t ConfigDescriptorLength,
|
uint8_t HID_Host_ConfigurePipes(USB_ClassInfo_HID_Host_t* HIDInterfaceInfo, uint16_t ConfigDescriptorLength,
|
||||||
uint8_t* DeviceConfigDescriptor);
|
uint8_t* DeviceConfigDescriptor);
|
||||||
|
|
||||||
bool HID_Host_IsReportReceived(USB_ClassInfo_HID_Host_t* HIDInterfaceInfo);
|
bool HID_Host_IsReportReceived(USB_ClassInfo_HID_Host_t* HIDInterfaceInfo);
|
||||||
|
uint8_t USB_HID_Host_SetProtocol(USB_ClassInfo_HID_Host_t* HIDInterfaceInfo, bool UseReportProtocol);
|
||||||
|
|
||||||
/* Private Interface - For use in library only: */
|
/* Private Interface - For use in library only: */
|
||||||
#if !defined(__DOXYGEN__)
|
#if !defined(__DOXYGEN__)
|
||||||
|
Loading…
Reference in New Issue
Block a user