mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-11-03 23:02:34 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			179 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			179 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
             LUFA Library
 | 
						|
     Copyright (C) Dean Camera, 2010.
 | 
						|
              
 | 
						|
  dean [at] fourwalledcubicle [dot] com
 | 
						|
      www.fourwalledcubicle.com
 | 
						|
*/
 | 
						|
 | 
						|
/*
 | 
						|
  Copyright 2010  Dean Camera (dean [at] fourwalledcubicle [dot] com)
 | 
						|
 | 
						|
  Permission to use, copy, modify, distribute, and sell this 
 | 
						|
  software and its documentation for any purpose is hereby granted
 | 
						|
  without fee, provided that the above copyright notice appear in 
 | 
						|
  all copies and that both that the copyright notice and this
 | 
						|
  permission notice and warranty disclaimer appear in supporting 
 | 
						|
  documentation, and that the name of the author not be used in 
 | 
						|
  advertising or publicity pertaining to distribution of the 
 | 
						|
  software without specific, written prior permission.
 | 
						|
 | 
						|
  The author disclaim all warranties with regard to this
 | 
						|
  software, including all implied warranties of merchantability
 | 
						|
  and fitness.  In no event shall the author be liable for any
 | 
						|
  special, indirect or consequential damages or any damages
 | 
						|
  whatsoever resulting from loss of use, data or profits, whether
 | 
						|
  in an action of contract, negligence or other tortious action,
 | 
						|
  arising out of or in connection with the use or performance of
 | 
						|
  this software.
 | 
						|
*/
 | 
						|
 | 
						|
/** \ingroup Group_USBClassHID
 | 
						|
 *  @defgroup Group_USBClassHIDCommon  Common Class Definitions
 | 
						|
 *
 | 
						|
 *  \section Module Description
 | 
						|
 *  Constants, Types and Enum definitions that are common to both Device and Host modes for the USB
 | 
						|
 *  HID Class.
 | 
						|
 *
 | 
						|
 *  @{
 | 
						|
 */
 | 
						|
 
 | 
						|
#ifndef _HID_CLASS_COMMON_H_
 | 
						|
#define _HID_CLASS_COMMON_H_
 | 
						|
 | 
						|
	/* Includes: */
 | 
						|
		#include "../../USB.h"
 | 
						|
 | 
						|
		#include <string.h>
 | 
						|
 | 
						|
	/* Preprocessor Checks: */
 | 
						|
		#if !defined(__INCLUDE_FROM_HID_DRIVER)
 | 
						|
			#error Do not include this file directly. Include LUFA/Drivers/Class/HID.h instead.
 | 
						|
		#endif
 | 
						|
		
 | 
						|
	/* Macros: */
 | 
						|
		/** HID Class Specific Request to get the current HID report from the device. */
 | 
						|
		#define REQ_GetReport                   0x01
 | 
						|
 | 
						|
		/** HID Class Specific Request to get the current device idle count. */
 | 
						|
		#define REQ_GetIdle                     0x02
 | 
						|
 | 
						|
		/** HID Class Specific Request to set the current HID report to the device. */
 | 
						|
		#define REQ_SetReport                   0x09
 | 
						|
 | 
						|
		/** HID Class Specific Request to set the device's idle count. */
 | 
						|
		#define REQ_SetIdle                     0x0A
 | 
						|
 | 
						|
		/** HID Class Specific Request to get the current HID report protocol mode. */
 | 
						|
		#define REQ_GetProtocol                 0x03
 | 
						|
 | 
						|
		/** HID Class Specific Request to set the current HID report protocol mode. */
 | 
						|
		#define REQ_SetProtocol                 0x0B
 | 
						|
 | 
						|
		/** Descriptor header type value, to indicate a HID class HID descriptor. */
 | 
						|
		#define DTYPE_HID                       0x21
 | 
						|
		
 | 
						|
		/** Descriptor header type value, to indicate a HID class HID report descriptor. */
 | 
						|
		#define DTYPE_Report                    0x22
 | 
						|
		
 | 
						|
		/** Constant for the protocol value of a HID interface descriptor, indicating that the interface does not support
 | 
						|
		 *  any HID class boot protocol (see HID Class Specification).
 | 
						|
		 */
 | 
						|
		#define HID_NON_BOOT_PROTOCOL           0x00
 | 
						|
 | 
						|
		/** Constant for the protocol value of a HID interface descriptor, indicating that the interface supports the
 | 
						|
		 *  HID class Keyboard boot protocol (see HID Class Specification).
 | 
						|
		 */
 | 
						|
		#define HID_BOOT_KEYBOARD_PROTOCOL      0x01
 | 
						|
 | 
						|
		/** Constant for the protocol value of a HID interface descriptor, indicating that the interface supports the
 | 
						|
		 *  HID class Mouse boot protocol (see HID Class Specification).
 | 
						|
		 */
 | 
						|
		#define HID_BOOT_MOUSE_PROTOCOL         0x02
 | 
						|
		
 | 
						|
		/** Constant for a keyboard report modifier byte, indicating that the keyboard's left control key is currently pressed. */
 | 
						|
		#define HID_KEYBOARD_MODIFER_LEFTCTRL   (1 << 0)
 | 
						|
 | 
						|
		/** Constant for a keyboard report modifier byte, indicating that the keyboard's left shift key is currently pressed. */
 | 
						|
		#define HID_KEYBOARD_MODIFER_LEFTSHIFT  (1 << 1)
 | 
						|
 | 
						|
		/** Constant for a keyboard report modifier byte, indicating that the keyboard's left alt key is currently pressed. */
 | 
						|
		#define HID_KEYBOARD_MODIFER_LEFTALT    (1 << 2)
 | 
						|
 | 
						|
		/** Constant for a keyboard report modifier byte, indicating that the keyboard's left GUI key is currently pressed. */
 | 
						|
		#define HID_KEYBOARD_MODIFER_LEFTGUI    (1 << 3)
 | 
						|
 | 
						|
		/** Constant for a keyboard report modifier byte, indicating that the keyboard's right control key is currently pressed. */
 | 
						|
		#define HID_KEYBOARD_MODIFER_RIGHTCTRL  (1 << 4)
 | 
						|
 | 
						|
		/** Constant for a keyboard report modifier byte, indicating that the keyboard's right shift key is currently pressed. */
 | 
						|
		#define HID_KEYBOARD_MODIFER_RIGHTSHIFT (1 << 5)
 | 
						|
 | 
						|
		/** Constant for a keyboard report modifier byte, indicating that the keyboard's right alt key is currently pressed. */
 | 
						|
		#define HID_KEYBOARD_MODIFER_RIGHTALT   (1 << 6)
 | 
						|
 | 
						|
		/** Constant for a keyboard report modifier byte, indicating that the keyboard's right GUI key is currently pressed. */
 | 
						|
		#define HID_KEYBOARD_MODIFER_RIGHTGUI   (1 << 7)
 | 
						|
		
 | 
						|
		/** Constant for a keyboard output report LED byte, indicating that the host's NUM LOCK mode is currently set. */
 | 
						|
		#define HID_KEYBOARD_LED_NUMLOCK        (1 << 0)
 | 
						|
		
 | 
						|
		/** Constant for a keyboard output report LED byte, indicating that the host's CAPS LOCK mode is currently set. */
 | 
						|
		#define HID_KEYBOARD_LED_CAPSLOCK       (1 << 1)
 | 
						|
 | 
						|
		/** Constant for a keyboard output report LED byte, indicating that the host's SCROLL LOCK mode is currently set. */
 | 
						|
		#define HID_KEYBOARD_LED_SCROLLLOCK     (1 << 2)
 | 
						|
 | 
						|
		/** Constant for a keyboard output report LED byte, indicating that the host's KATANA mode is currently set. */
 | 
						|
		#define HID_KEYBOARD_LED_KATANA         (1 << 3)
 | 
						|
 | 
						|
	/* Type Defines: */
 | 
						|
		/** Enum for the different types of HID reports. */
 | 
						|
		enum HID_ReportItemTypes_t
 | 
						|
		{
 | 
						|
			REPORT_ITEM_TYPE_In                   = 0, /**< Indicates that the item is an IN report type. */
 | 
						|
			REPORT_ITEM_TYPE_Out                  = 1, /**< Indicates that the item is an OUT report type. */
 | 
						|
			REPORT_ITEM_TYPE_Feature              = 2, /**< Indicates that the item is a FEATURE report type. */
 | 
						|
		};
 | 
						|
 | 
						|
		/** Type define for the HID class specific HID descriptor, to describe the HID device's specifications. Refer to the HID
 | 
						|
		 *  specification for details on the structure elements.
 | 
						|
		 */
 | 
						|
		typedef struct
 | 
						|
		{
 | 
						|
			USB_Descriptor_Header_t  Header;
 | 
						|
				
 | 
						|
			uint16_t                 HIDSpec;
 | 
						|
			uint8_t                  CountryCode;
 | 
						|
		
 | 
						|
			uint8_t                  TotalReportDescriptors;
 | 
						|
 | 
						|
			uint8_t                  HIDReportType;
 | 
						|
			uint16_t                 HIDReportLength;
 | 
						|
		} USB_HID_Descriptor_t;
 | 
						|
 | 
						|
		/** Type define for a standard Boot Protocol Mouse report */
 | 
						|
		typedef struct
 | 
						|
		{
 | 
						|
			uint8_t Button; /**< Button mask for currently pressed buttons in the mouse */
 | 
						|
			int8_t  X; /**< Current delta X movement of the mouse */
 | 
						|
			int8_t  Y; /**< Current delta Y movement on the mouse */
 | 
						|
		} USB_MouseReport_Data_t;
 | 
						|
		
 | 
						|
		/** Type define for a standard Boot Protocol Keyboard report */
 | 
						|
		typedef struct
 | 
						|
		{
 | 
						|
			uint8_t Modifier; /**< Keyboard modifier byte, indicating pressed modifier keys (a combination of
 | 
						|
			                   *   HID_KEYBOARD_MODIFER_* masks)
 | 
						|
			                   */
 | 
						|
			uint8_t Reserved; /**< Reserved for OEM use, always set to 0 */
 | 
						|
			uint8_t KeyCode[6]; /**< Key codes of the currently pressed keys */
 | 
						|
		} USB_KeyboardReport_Data_t;
 | 
						|
 | 
						|
		/** Type define for the data type used to store HID report descriptor elements. */
 | 
						|
		typedef uint8_t USB_Descriptor_HIDReport_Datatype_t;
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
/** @} */
 |