mirror of
https://github.com/azure-rtos/usbx.git
synced 2025-01-28 07:03:07 +08:00
ef2fa7717b
8b59a1d4 Add support for Get String requests with 0 wIndex 106c1b06 Update cfs usage 2d45d315 Optimize SRAM for extracted USB descriptors cf97e6e9 Fixed allocated buffer pointer checking issue. 6468c588 Guard basic types. 60b3a232 Update CFS usage
2918 lines
201 KiB
C
2918 lines
201 KiB
C
/**************************************************************************/
|
|
/* */
|
|
/* Copyright (c) Microsoft Corporation. All rights reserved. */
|
|
/* */
|
|
/* This software is licensed under the Microsoft Software License */
|
|
/* Terms for Microsoft Azure RTOS. Full text of the license can be */
|
|
/* found in the LICENSE file at https://aka.ms/AzureRTOS_EULA */
|
|
/* and in the root directory of this software. */
|
|
/* */
|
|
/**************************************************************************/
|
|
|
|
|
|
/**************************************************************************/
|
|
/**************************************************************************/
|
|
/** */
|
|
/** USBX Component */
|
|
/** */
|
|
/** Application Interface (API) */
|
|
/** */
|
|
/**************************************************************************/
|
|
/**************************************************************************/
|
|
|
|
|
|
/**************************************************************************/
|
|
/* */
|
|
/* APPLICATION INTERFACE DEFINITION RELEASE */
|
|
/* */
|
|
/* ux_api.h PORTABLE C */
|
|
/* 6.x */
|
|
/* AUTHOR */
|
|
/* */
|
|
/* Chaoqiong Xiao, Microsoft Corporation */
|
|
/* */
|
|
/* DESCRIPTION */
|
|
/* */
|
|
/* This file defines the basic Application Interface (API) to the */
|
|
/* high-performance USBX real-time USB stack. All service prototypes */
|
|
/* and data structure definitions are defined in this file. */
|
|
/* Please note that basic data type definitions and other architecture-*/
|
|
/* specific information is contained in the file ux_port.h. */
|
|
/* */
|
|
/* RELEASE HISTORY */
|
|
/* */
|
|
/* DATE NAME DESCRIPTION */
|
|
/* */
|
|
/* 05-19-2020 Chaoqiong Xiao Initial Version 6.0 */
|
|
/* 09-30-2020 Chaoqiong Xiao Modified comment(s), */
|
|
/* added query usage of device */
|
|
/* ClassSubclassProtocol, */
|
|
/* added option to disable FX */
|
|
/* media integration, prefixed */
|
|
/* UX to MS_TO_TICK, added */
|
|
/* APIs and macros related to */
|
|
/* uninitialize, optimized */
|
|
/* based on compile */
|
|
/* definitions, updated */
|
|
/* product constants, used */
|
|
/* host class extension */
|
|
/* pointer for class specific */
|
|
/* structured data, used UX */
|
|
/* prefix to refer to TX */
|
|
/* symbols instead of using */
|
|
/* them directly, */
|
|
/* resulting in version 6.1 */
|
|
/* 11-09-2020 Chaoqiong Xiao Modified comment(s), */
|
|
/* used unsigned defines, */
|
|
/* added HCD uninit command, */
|
|
/* modified HCD status code, */
|
|
/* fixed compile warnings, */
|
|
/* resulting in version 6.1.2 */
|
|
/* 12-31-2020 Chaoqiong Xiao Modified comment(s), */
|
|
/* added BOS support, */
|
|
/* resulting in version 6.1.3 */
|
|
/* 02-02-2021 Chaoqiong Xiao Modified comment(s), */
|
|
/* added configuration activate*/
|
|
/* and deactivate support, */
|
|
/* added host printer get */
|
|
/* device ID support, */
|
|
/* added host device string */
|
|
/* descriptor get support, */
|
|
/* added events for device */
|
|
/* connection/disconnection, */
|
|
/* resulting in version 6.1.4 */
|
|
/* 03-02-2021 Chaoqiong Xiao Modified comment(s), */
|
|
/* resulting in version 6.1.5 */
|
|
/* 04-02-2021 Chaoqiong Xiao Modified comment(s), */
|
|
/* added macros for Word/DWord */
|
|
/* to bytes extraction, */
|
|
/* resulting in version 6.1.6 */
|
|
/* 06-02-2021 Chaoqiong Xiao Modified comment(s), */
|
|
/* added trace dependency test,*/
|
|
/* changed transfer timeout */
|
|
/* value, */
|
|
/* resulting in version 6.1.7 */
|
|
/* 08-02-2021 Chaoqiong Xiao Modified comment(s), */
|
|
/* fixed spelling error, */
|
|
/* fixed trace ID order error, */
|
|
/* resulting in version 6.1.8 */
|
|
/* 10-15-2021 Chaoqiong Xiao Modified comment(s), */
|
|
/* improved assert macros, */
|
|
/* added transfer size field, */
|
|
/* improved traceX support, */
|
|
/* resulting in version 6.1.9 */
|
|
/* 01-31-2022 Chaoqiong Xiao Modified comment(s), */
|
|
/* added too many ports error, */
|
|
/* moved tx_api.h include and */
|
|
/* typedefs to ux_port.h, */
|
|
/* added standalone support, */
|
|
/* added device HID trace IDs, */
|
|
/* added some general errors, */
|
|
/* added printer trace IDs, */
|
|
/* resulting in version 6.1.10 */
|
|
/* 04-25-2022 Chaoqiong Xiao Modified comment(s), */
|
|
/* assumed OS types to avoid */
|
|
/* standalone compiling error, */
|
|
/* added CCID trace IDs, */
|
|
/* resulting in version 6.1.11 */
|
|
/* 07-29-2022 Chaoqiong Xiao Modified comment(s), */
|
|
/* fixed parameter/variable */
|
|
/* names conflict C++ keyword, */
|
|
/* added feedback size defs, */
|
|
/* added shared device config */
|
|
/* descriptor for enum scan, */
|
|
/* resulting in version 6.1.12 */
|
|
/* 10-31-2022 Chaoqiong Xiao Modified comment(s), */
|
|
/* added some ETH error codes, */
|
|
/* allowed align minimal def, */
|
|
/* added interface instance */
|
|
/* creation strategy control, */
|
|
/* resulting in version 6.2.0 */
|
|
/* 03-08-2023 Chaoqiong Xiao Modified comment(s), */
|
|
/* accepted UX_MAX_CLASSES as */
|
|
/* max class driver configure, */
|
|
/* added a new error code, */
|
|
/* resulting in version 6.2.1 */
|
|
/* xx-xx-xxxx Chaoqiong Xiao Modified comment(s), */
|
|
/* optimized USB descriptors, */
|
|
/* added error checks support, */
|
|
/* resulting in version 6.x */
|
|
/* */
|
|
/**************************************************************************/
|
|
|
|
#ifndef UX_API_H
|
|
#define UX_API_H
|
|
|
|
/* Determine if a C++ compiler is being used. If so, ensure that standard
|
|
C is used to process the API information. */
|
|
|
|
#ifdef __cplusplus
|
|
|
|
/* Yes, C++ compiler is present. Use standard C. */
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
/* Include USBX port specific file. */
|
|
|
|
#include "ux_port.h"
|
|
|
|
/* Process compile options:
|
|
*
|
|
* - UX_HOST_SIDE_ONLY/UX_HOST_STANDALONE:
|
|
* Must not be defined at the same time,
|
|
* When defined, only host/device side APIs are available.
|
|
*
|
|
* - UX_STANDALONE:
|
|
* Defined, whole RTOS dependencies are removed from USBX.
|
|
*
|
|
* - UX_DEVICE_STANDALONE/UX_HOST_STANDALONE
|
|
* Internal definitions for different parts,
|
|
* _DEVICE_STANDALONE removes RTOS dependencies of DCD, device stack and classes,
|
|
* _HOST_STANDALONE removes RTOS dependencies of HCD, host stack and classes,
|
|
* if UX_STANDALONE is not defined, RTOS is always enabled in system and utilities.
|
|
*/
|
|
#if defined(UX_STANDALONE)
|
|
#if !defined(UX_DEVICE_STANDALONE)
|
|
#define UX_DEVICE_STANDALONE
|
|
#endif
|
|
#if !defined(UX_HOST_STANDALONE)
|
|
#define UX_HOST_STANDALONE
|
|
#endif
|
|
#if !defined(UX_OTG_STANDALONE)
|
|
#define UX_OTG_STANDALONE
|
|
#endif
|
|
#else
|
|
#if defined(UX_DEVICE_STANDALONE) && defined(UX_HOST_STANDALONE) && defined(UX_OTG_STANDALONE) ||\
|
|
defined(UX_DEVICE_STANDALONE) && defined(UX_DEVICE_SIDE_ONLY) ||\
|
|
defined(UX_HOST_STANDALONE) && defined(UX_HOST_SIDE_ONLY)
|
|
#define UX_STANDALONE
|
|
#endif
|
|
#endif
|
|
|
|
/* Internal option: enable the basic USBX error checking. This define is typically used
|
|
while debugging application. */
|
|
#if defined(UX_ENABLE_ERROR_CHECKING) && !defined(UX_SYSTEM_ENABLE_ERROR_CHECKING)
|
|
#define UX_SYSTEM_ENABLE_ERROR_CHECKING
|
|
#endif
|
|
|
|
/* Internal option: enable the basic USBX error checking. This define is typically used
|
|
while debugging application. */
|
|
#if defined(UX_ENABLE_ERROR_CHECKING) && !defined(UX_DEVICE_STACK_ENABLE_ERROR_CHECKING)
|
|
#define UX_DEVICE_STACK_ENABLE_ERROR_CHECKING
|
|
#endif
|
|
|
|
/* Internal option: enable the basic USBX error checking. This define is typically used
|
|
while debugging application. */
|
|
#if defined(UX_ENABLE_ERROR_CHECKING) && !defined(UX_HOST_STACK_ENABLE_ERROR_CHECKING)
|
|
#define UX_HOST_STACK_ENABLE_ERROR_CHECKING
|
|
#endif
|
|
|
|
|
|
/* Define the maximum length for class names (exclude string null-terminator). */
|
|
#define UX_MAX_CLASS_NAME_LENGTH 63
|
|
|
|
/* Define the maximum length for HCD names (exclude string null-terminator). */
|
|
#define UX_MAX_HCD_NAME_LENGTH 63
|
|
|
|
/* Disable warning of parameter not used. */
|
|
#ifndef UX_PARAMETER_NOT_USED
|
|
#define UX_PARAMETER_NOT_USED(p) ((VOID)(p))
|
|
#endif
|
|
|
|
/* Define additional generic USBX types. */
|
|
|
|
#ifndef SCHAR
|
|
typedef signed char SCHAR;
|
|
#endif
|
|
|
|
/* If the port file did not define the memory barrier instruction, define it
|
|
to nothing since this is platform-specific. */
|
|
#ifndef UX_DATA_MEMORY_BARRIER
|
|
#define UX_DATA_MEMORY_BARRIER
|
|
#endif
|
|
|
|
|
|
/* This defines the ASSERT and process on ASSERT fail. */
|
|
#ifdef UX_ENABLE_ASSERT
|
|
#ifndef UX_ASSERT_FAIL
|
|
#ifdef TX_API_H
|
|
#define UX_ASSERT_FAIL for (;;) {tx_thread_sleep(UX_WAIT_FOREVER); }
|
|
#else
|
|
#define UX_ASSERT_FAIL for (;;) {}
|
|
#endif
|
|
#endif
|
|
#define UX_ASSERT(s) if (!(s)) {UX_ASSERT_FAIL}
|
|
#else
|
|
#define UX_ASSERT(s)
|
|
#endif /* UX_ENABLE_ASSERT */
|
|
|
|
|
|
/* Convert from millisecond to ThreadX Tick value. */
|
|
#define UX_MS_TO_TICK(ms) ((ms) * (UX_PERIODIC_RATE) / 1000)
|
|
#define UX_MS_TO_TICK_NON_ZERO(ms) UX_MAX(1, UX_MS_TO_TICK(ms))
|
|
|
|
/* Deprecated, left to be compatible with apps already using MS_TO_TICK. */
|
|
#define MS_TO_TICK(ms) UX_MS_TO_TICK(ms)
|
|
|
|
|
|
/* If UX_DEVICE_INITIALIZE_FRAMEWORK_SCAN_DISABLE is defined,
|
|
it define USBX device max number of endpoints (1~n).
|
|
else max number of endpoints are from scan result.
|
|
It must be equal to or larger than max number of endpoints
|
|
can be activated at the same time. */
|
|
#ifndef UX_MAX_DEVICE_ENDPOINTS
|
|
#define UX_MAX_DEVICE_ENDPOINTS 6
|
|
#endif
|
|
|
|
/* If UX_DEVICE_INITIALIZE_FRAMEWORK_SCAN_DISABLE is defined,
|
|
it define USBX device max number of interfacess (1~n).
|
|
else max number of interfacess are from scan result.
|
|
It must be equal to or larger than max number of interfaces
|
|
in a activated configuration. */
|
|
#ifndef UX_MAX_DEVICE_INTERFACES
|
|
#define UX_MAX_DEVICE_INTERFACES 6
|
|
#endif
|
|
|
|
|
|
/* Define USBX device max bInterfaceNumber of interfaces (0 ~ n),
|
|
it must be larger than max bInterfaceNumber in USB
|
|
framework descriptors. */
|
|
#ifndef UX_MAX_SLAVE_INTERFACES
|
|
#define UX_MAX_SLAVE_INTERFACES 16
|
|
#endif
|
|
|
|
/* Define USBX max number of classes (1 ~ n). */
|
|
#ifndef UX_MAX_CLASSES
|
|
#define UX_MAX_CLASSES 2
|
|
#endif
|
|
#ifndef UX_MAX_CLASS_DRIVER
|
|
#define UX_MAX_CLASS_DRIVER UX_MAX_CLASSES
|
|
#endif
|
|
|
|
/* Define USBX max number of devices (1 ~ n). */
|
|
#ifndef UX_MAX_DEVICES
|
|
#define UX_MAX_DEVICES 4
|
|
#endif
|
|
|
|
/* Define USBX max number of HCDs (1 ~ n). */
|
|
#ifndef UX_MAX_HCD
|
|
#define UX_MAX_HCD 2
|
|
#endif
|
|
|
|
/* Define USBX max root hub port (1 ~ n). */
|
|
#ifndef UX_MAX_ROOTHUB_PORT
|
|
#define UX_MAX_ROOTHUB_PORT 4
|
|
#endif
|
|
|
|
/* Define USBX max TT. */
|
|
#ifndef UX_MAX_TT
|
|
#define UX_MAX_TT 8
|
|
#endif
|
|
|
|
/* Define USBX Host Enum Thread Stack Size. */
|
|
#ifndef UX_HOST_ENUM_THREAD_STACK_SIZE
|
|
#define UX_HOST_ENUM_THREAD_STACK_SIZE UX_THREAD_STACK_SIZE
|
|
#endif
|
|
|
|
/* Define USBX Host Thread Stack Size. */
|
|
#ifndef UX_HOST_HCD_THREAD_STACK_SIZE
|
|
#define UX_HOST_HCD_THREAD_STACK_SIZE UX_THREAD_STACK_SIZE
|
|
#endif
|
|
|
|
/* Define USBX Host HNP Polling Thread Stack Size */
|
|
#ifndef UX_HOST_HNP_POLLING_THREAD_STACK
|
|
#define UX_HOST_HNP_POLLING_THREAD_STACK UX_THREAD_STACK_SIZE
|
|
#endif
|
|
|
|
/* Define basic constants for the USBX Stack. */
|
|
#define AZURE_RTOS_USBX
|
|
#define USBX_MAJOR_VERSION 6
|
|
#define USBX_MINOR_VERSION 2
|
|
#define USBX_PATCH_VERSION 1
|
|
|
|
/* Macros for concatenating tokens, where UX_CONCATn concatenates n tokens. */
|
|
|
|
#define UX_CONCAT_BASE(x,y) x ## y
|
|
#define UX_CONCAT2(s0,s1) UX_CONCAT_BASE(s0,s1)
|
|
|
|
/* Static assert that can report an error at compile time. */
|
|
#define UX_COMPILE_TIME_ASSERT(exp, meaningful_name_as_variable) \
|
|
typedef char UX_CONCAT2(meaningful_name_as_variable, __LINE__)[!(exp) ? -1 : 1];
|
|
|
|
/* Arithmetic. */
|
|
|
|
#define UX_MIN(a, b) ((a) < (b) ? (a) : (b))
|
|
#define UX_MAX(a, b) ((a) > (b) ? (a) : (b))
|
|
|
|
#define UX_W0(word) ( (word) & 0xFF)
|
|
#define UX_W1(word) (((word) >> 8) & 0xFF)
|
|
|
|
#define UX_DW0(dword) ( (dword) & 0xFF)
|
|
#define UX_DW1(dword) (((dword) >> 8) & 0xFF)
|
|
#define UX_DW2(dword) (((dword) >> 16) & 0xFF)
|
|
#define UX_DW3(dword) (((dword) >> 24) & 0xFF)
|
|
|
|
/* Safe arithmetic check macros. */
|
|
|
|
#ifndef UX_DISABLE_ARITHMETIC_CHECK
|
|
|
|
/* Calculate and check if result overflow/underflow. */
|
|
|
|
#define UX_OVERFLOW_CHECK_ADD_ULONG(a, b) ((a) > 0xFFFFFFFFul - (b))
|
|
#define UX_OVERFLOW_CHECK_ADD_USHORT(a, b) ((a) > 0xFFFFul - (b))
|
|
#define UX_OVERFLOW_CHECK_ADD_UCHAR(a, b) ((a) > 0xFFul - (b))
|
|
|
|
#define UX_UNDERFLOW_CHECK_MINUS(a, b) ((a) < (b))
|
|
|
|
/* Overflow check optimized in case multiplying a 2nd factor of const. */
|
|
#define UX_OVERFLOW_CHECK_MULC_ULONG(v, c) (((c) != 0) && ((v) > 0xFFFFFFFFul / (c)))
|
|
#define UX_OVERFLOW_CHECK_MULC_USHORT(v, c) (((c) != 0) && ((v) > 0xFFFFul / (c)))
|
|
#define UX_OVERFLOW_CHECK_MULC_UCHAR(v, c) (((c) != 0) && ((v) > 0xFFul / (c)))
|
|
|
|
/* Overflow check optimized in case multiplying factors of variables and division instruction unavailable. */
|
|
#define UX_OVERFLOW_CHECK_MULV_ULONG(v, v1) ((v) * (v1) < UX_MIN(v, v1))
|
|
#define UX_OVERFLOW_CHECK_MULV_USHORT(v, v1) ((USHORT)((v) * (v1)) < UX_MIN(v, v1))
|
|
#define UX_OVERFLOW_CHECK_MULV_UCHAR(v, v1) ((UCHAR)((v) * (v1)) < UX_MIN(v, v1))
|
|
|
|
#else
|
|
|
|
/* There is no overflow/underflow, always 0 (false). */
|
|
|
|
#define UX_OVERFLOW_CHECK_ADD_ULONG(a, b) (0)
|
|
#define UX_OVERFLOW_CHECK_ADD_USHORT(a, b) (0)
|
|
#define UX_OVERFLOW_CHECK_ADD_UCHAR(a, b) (0)
|
|
|
|
#define UX_OVERFLOW_CHECK_MULC_ULONG(v, c) (0)
|
|
#define UX_OVERFLOW_CHECK_MULC_USHORT(v, c) (0)
|
|
#define UX_OVERFLOW_CHECK_MULC_UCHAR(v, c) (0)
|
|
|
|
#define UX_OVERFLOW_CHECK_MULV_ULONG(v, v1) (0)
|
|
#define UX_OVERFLOW_CHECK_MULV_USHORT(v, v1) (0)
|
|
#define UX_OVERFLOW_CHECK_MULV_UCHAR(v, v1) (0)
|
|
#endif
|
|
|
|
/* Define the default extension to hold the control block for 64-bit mode. */
|
|
|
|
#ifndef UX_THREAD_EXTENSION_PTR_SET
|
|
#define UX_THREAD_EXTENSION_PTR_SET(a, b)
|
|
#endif
|
|
|
|
#ifndef UX_THREAD_EXTENSION_PTR_GET
|
|
#define UX_THREAD_EXTENSION_PTR_GET(a, b, c) (a) = (b *)(c);
|
|
#endif
|
|
|
|
#ifndef UX_TIMER_EXTENSION_PTR_SET
|
|
#define UX_TIMER_EXTENSION_PTR_SET(a, b)
|
|
#endif
|
|
|
|
#ifndef UX_TIMER_EXTENSION_PTR_GET
|
|
#define UX_TIMER_EXTENSION_PTR_GET(a, b, c) (a) = (b *)(c);
|
|
#endif
|
|
|
|
/* Determine if error log is enabled. */
|
|
|
|
#ifdef UX_ENABLE_DEBUG_LOG
|
|
|
|
#ifndef UX_DEBUG_LOG_SIZE
|
|
#define UX_DEBUG_LOG_SIZE (1024 * 32)
|
|
#endif
|
|
|
|
/* Map the error log macros to internal USBX function. */
|
|
|
|
#define UX_DEBUG_LOG(debug_location, debug_message, debug_code, debug_parameter_1, debug_parameter_2) _ux_utility_debug_log((UCHAR *) debug_location, (UCHAR *) debug_message, (ULONG) debug_code, (ULONG) debug_parameter_1, (ULONG) debug_parameter_2);
|
|
|
|
VOID _ux_utility_debug_log(UCHAR *debug_location, UCHAR *debug_message, ULONG debug_code, ULONG debug_parameter_1, ULONG debug_parameter_2);
|
|
|
|
/* DEBUG LOG MESSAGES SHOULD BE WRITTEN LIKE THIS IN THE CODE : */
|
|
/* If error log is enabled, insert this error message into the log buffer. */
|
|
/* UX_DEBUG_LOG("_ux_host_stack_rh_device_insertion", "Device insertion", port_index, port_index, 0) */
|
|
|
|
|
|
#else
|
|
|
|
/* If Log is not defined, map it to nothing so that debug messages can stay in the code. */
|
|
#define UX_DEBUG_LOG(debug_location, debug_message, debug_code, debug_parameter_1, debug_parameter_2)
|
|
#endif
|
|
|
|
/* Determine if tracing is enabled. */
|
|
|
|
#if defined(TX_ENABLE_EVENT_TRACE) && !defined(UX_STANDALONE)
|
|
#define UX_ENABLE_EVENT_TRACE
|
|
#endif
|
|
|
|
#ifdef UX_ENABLE_EVENT_TRACE
|
|
|
|
/* Trace is enabled. Remap calls so that interrupts can be disabled around the actual event logging. */
|
|
|
|
#include "tx_trace.h"
|
|
|
|
|
|
/* Map the trace macros to internal USBX versions so we can get interrupt protection. */
|
|
|
|
#define UX_TRACE_OBJECT_REGISTER(t,p,n,a,b) _ux_trace_object_register(t, (VOID *) p, (CHAR *) n, (ULONG) a, (ULONG) b);
|
|
#define UX_TRACE_OBJECT_UNREGISTER(o) _ux_trace_object_unregister((VOID *) o);
|
|
#define UX_TRACE_IN_LINE_INSERT(i,a,b,c,d,f,g,h) _ux_trace_event_insert((ULONG) i, (ULONG) a, (ULONG) b, (ULONG) c, (ULONG) d, (ULONG) f, g, h);
|
|
#define UX_TRACE_EVENT_UPDATE(e,t,i,a,b,c,d) _ux_trace_event_update((TX_TRACE_BUFFER_ENTRY *) e, (ULONG) t, (ULONG) i, (ULONG) a, (ULONG) b, (ULONG) c, (ULONG) d);
|
|
|
|
|
|
/* Define USBX trace prototypes. */
|
|
|
|
VOID _ux_trace_object_register(UCHAR object_type, VOID *object_ptr, CHAR *object_name, ULONG parameter_1, ULONG parameter_2);
|
|
VOID _ux_trace_object_unregister(VOID *object_ptr);
|
|
VOID _ux_trace_event_insert(ULONG event_id, ULONG info_field_1, ULONG info_field_2, ULONG info_field_3, ULONG info_field_4, ULONG filter, TX_TRACE_BUFFER_ENTRY **current_event, ULONG *current_timestamp);
|
|
VOID _ux_trace_event_update(TX_TRACE_BUFFER_ENTRY *event, ULONG timestamp, ULONG event_id, ULONG info_field_1, ULONG info_field_2, ULONG info_field_3, ULONG info_field_4);
|
|
|
|
|
|
/* Define USBX event trace constants. */
|
|
|
|
#define UX_TRACE_OBJECT_TYPE_BASE 20
|
|
#define UX_TRACE_HOST_OBJECT_TYPE_DEVICE (UX_TRACE_OBJECT_TYPE_BASE + 1)
|
|
#define UX_TRACE_HOST_OBJECT_TYPE_INTERFACE (UX_TRACE_OBJECT_TYPE_BASE + 2)
|
|
#define UX_TRACE_HOST_OBJECT_TYPE_ENDPOINT (UX_TRACE_OBJECT_TYPE_BASE + 3)
|
|
#define UX_TRACE_HOST_OBJECT_TYPE_CLASS_INSTANCE (UX_TRACE_OBJECT_TYPE_BASE + 4)
|
|
|
|
#define UX_TRACE_DEVICE_OBJECT_TYPE_DEVICE (UX_TRACE_OBJECT_TYPE_BASE + 5)
|
|
#define UX_TRACE_DEVICE_OBJECT_TYPE_INTERFACE (UX_TRACE_OBJECT_TYPE_BASE + 6)
|
|
#define UX_TRACE_DEVICE_OBJECT_TYPE_ENDPOINT (UX_TRACE_OBJECT_TYPE_BASE + 7)
|
|
#define UX_TRACE_DEVICE_OBJECT_TYPE_CLASS_INSTANCE (UX_TRACE_OBJECT_TYPE_BASE + 8)
|
|
|
|
/* Define event filters that can be used to selectively disable certain events or groups of events. */
|
|
|
|
#define UX_TRACE_ALL_EVENTS 0x7F000000 /* All USBX events */
|
|
#define UX_TRACE_ERRORS 0x01000000 /* USBX Errors events */
|
|
#define UX_TRACE_HOST_STACK_EVENTS 0x02000000 /* USBX Host Class Events */
|
|
#define UX_TRACE_DEVICE_STACK_EVENTS 0x04000000 /* USBX Device Class Events */
|
|
#define UX_TRACE_HOST_CONTROLLER_EVENTS 0x08000000 /* USBX Host Controller Events */
|
|
#define UX_TRACE_DEVICE_CONTROLLER_EVENTS 0x10000000 /* USBX Device Controllers Events */
|
|
#define UX_TRACE_HOST_CLASS_EVENTS 0x20000000 /* USBX Host Class Events */
|
|
#define UX_TRACE_DEVICE_CLASS_EVENTS 0x40000000 /* USBX Device Class Events */
|
|
|
|
|
|
/* Define the trace events in USBX, if not defined. */
|
|
|
|
/* Define the USBX host stack events. */
|
|
|
|
#define UX_TRACE_HOST_STACK_EVENTS_BASE 600
|
|
#define UX_TRACE_HOST_STACK_CLASS_INSTANCE_CREATE (UX_TRACE_HOST_STACK_EVENTS_BASE + 1) /* I1 = class , I2 = class instance */
|
|
#define UX_TRACE_HOST_STACK_CLASS_INSTANCE_DESTROY (UX_TRACE_HOST_STACK_EVENTS_BASE + 2) /* I1 = class , I2 = class instance */
|
|
#define UX_TRACE_HOST_STACK_CONFIGURATION_DELETE (UX_TRACE_HOST_STACK_EVENTS_BASE + 3) /* I1 = configuration */
|
|
#define UX_TRACE_HOST_STACK_CONFIGURATION_ENUMERATE (UX_TRACE_HOST_STACK_EVENTS_BASE + 4) /* I1 = device */
|
|
#define UX_TRACE_HOST_STACK_CONFIGURATION_INSTANCE_CREATE (UX_TRACE_HOST_STACK_EVENTS_BASE + 5) /* I1 = configuration */
|
|
#define UX_TRACE_HOST_STACK_CONFIGURATION_INSTANCE_DELETE (UX_TRACE_HOST_STACK_EVENTS_BASE + 6) /* I1 = configuration */
|
|
#define UX_TRACE_HOST_STACK_CONFIGURATION_SET (UX_TRACE_HOST_STACK_EVENTS_BASE + 7) /* I1 = configuration */
|
|
#define UX_TRACE_HOST_STACK_DEVICE_ADDRESS_SET (UX_TRACE_HOST_STACK_EVENTS_BASE + 8) /* I1 = device , I2 = device address */
|
|
#define UX_TRACE_HOST_STACK_DEVICE_CONFIGURATION_GET (UX_TRACE_HOST_STACK_EVENTS_BASE + 9) /* I1 = device , I2 = configuration */
|
|
#define UX_TRACE_HOST_STACK_DEVICE_CONFIGURATION_SELECT (UX_TRACE_HOST_STACK_EVENTS_BASE + 10) /* I1 = device , I2 = configuration */
|
|
#define UX_TRACE_HOST_STACK_DEVICE_DESCRIPTOR_READ (UX_TRACE_HOST_STACK_EVENTS_BASE + 11) /* I1 = device */
|
|
#define UX_TRACE_HOST_STACK_DEVICE_GET (UX_TRACE_HOST_STACK_EVENTS_BASE + 12) /* I1 = device index */
|
|
#define UX_TRACE_HOST_STACK_DEVICE_REMOVE (UX_TRACE_HOST_STACK_EVENTS_BASE + 13) /* I1 = hcd , I2 = parent , I3 = port index , I4 = device */
|
|
#define UX_TRACE_HOST_STACK_DEVICE_RESOURCE_FREE (UX_TRACE_HOST_STACK_EVENTS_BASE + 14) /* I1 = device */
|
|
#define UX_TRACE_HOST_STACK_ENDPOINT_INSTANCE_CREATE (UX_TRACE_HOST_STACK_EVENTS_BASE + 15) /* I1 = device , I2 = endpoint */
|
|
#define UX_TRACE_HOST_STACK_ENDPOINT_INSTANCE_DELETE (UX_TRACE_HOST_STACK_EVENTS_BASE + 16) /* I1 = device , I2 = endpoint */
|
|
#define UX_TRACE_HOST_STACK_ENDPOINT_RESET (UX_TRACE_HOST_STACK_EVENTS_BASE + 17) /* I1 = device , I2 = endpoint */
|
|
#define UX_TRACE_HOST_STACK_ENDPOINT_TRANSFER_ABORT (UX_TRACE_HOST_STACK_EVENTS_BASE + 18) /* I1 = endpoint */
|
|
#define UX_TRACE_HOST_STACK_HCD_REGISTER (UX_TRACE_HOST_STACK_EVENTS_BASE + 19) /* I1 = hcd name , I2 = parameter 1 , I3 = parameter 2 */
|
|
#define UX_TRACE_HOST_STACK_INITIALIZE (UX_TRACE_HOST_STACK_EVENTS_BASE + 20) /* */
|
|
#define UX_TRACE_HOST_STACK_INTERFACE_ENDPOINT_GET (UX_TRACE_HOST_STACK_EVENTS_BASE + 21) /* I1 = interface , I2 = endpoint index */
|
|
#define UX_TRACE_HOST_STACK_INTERFACE_INSTANCE_CREATE (UX_TRACE_HOST_STACK_EVENTS_BASE + 22) /* I1 = interface */
|
|
#define UX_TRACE_HOST_STACK_INTERFACE_INSTANCE_DELETE (UX_TRACE_HOST_STACK_EVENTS_BASE + 23) /* I1 = interface */
|
|
#define UX_TRACE_HOST_STACK_INTERFACE_SET (UX_TRACE_HOST_STACK_EVENTS_BASE + 24) /* I1 = interface */
|
|
#define UX_TRACE_HOST_STACK_INTERFACE_SETTING_SELECT (UX_TRACE_HOST_STACK_EVENTS_BASE + 25) /* I1 = interface */
|
|
#define UX_TRACE_HOST_STACK_NEW_CONFIGURATION_CREATE (UX_TRACE_HOST_STACK_EVENTS_BASE + 26) /* I1 = device , I2 = configuration */
|
|
#define UX_TRACE_HOST_STACK_NEW_DEVICE_CREATE (UX_TRACE_HOST_STACK_EVENTS_BASE + 27) /* I1 = hcd , I2 = device owner , I3 = port index , I4 = device */
|
|
#define UX_TRACE_HOST_STACK_NEW_ENDPOINT_CREATE (UX_TRACE_HOST_STACK_EVENTS_BASE + 28) /* I1 = interface , I2 = endpoint */
|
|
#define UX_TRACE_HOST_STACK_RH_CHANGE_PROCESS (UX_TRACE_HOST_STACK_EVENTS_BASE + 29) /* I1 = port index */
|
|
#define UX_TRACE_HOST_STACK_RH_DEVICE_EXTRACTION (UX_TRACE_HOST_STACK_EVENTS_BASE + 30) /* I1 = hcd , I2 = port index */
|
|
#define UX_TRACE_HOST_STACK_RH_DEVICE_INSERTION (UX_TRACE_HOST_STACK_EVENTS_BASE + 31) /* I1 = hcd , I2 = port index */
|
|
#define UX_TRACE_HOST_STACK_TRANSFER_REQUEST (UX_TRACE_HOST_STACK_EVENTS_BASE + 32) /* I1 = device , I2 = endpoint , I3 = transfer request */
|
|
#define UX_TRACE_HOST_STACK_TRANSFER_REQUEST_ABORT (UX_TRACE_HOST_STACK_EVENTS_BASE + 33) /* I1 = device , I2 = endpoint , I3 = transfer request */
|
|
#define UX_TRACE_HOST_STACK_UNINITIALIZE (UX_TRACE_HOST_STACK_EVENTS_BASE + 34) /* */
|
|
#define UX_TRACE_HOST_STACK_HCD_UNREGISTER (UX_TRACE_HOST_STACK_EVENTS_BASE + 35) /* I1 = hcd name , I2 = parameter 1 , I3 = parameter 2 */
|
|
#define UX_TRACE_HOST_STACK_CLASS_REGISTER (UX_TRACE_HOST_STACK_EVENTS_BASE + 36) /* I1 = class name , I2 = entry function */
|
|
#define UX_TRACE_HOST_STACK_CLASS_UNREGISTER (UX_TRACE_HOST_STACK_EVENTS_BASE + 37) /* I1 = class entry */
|
|
#define UX_TRACE_HOST_STACK_DEVICE_STRING_GET (UX_TRACE_HOST_STACK_EVENTS_BASE + 38) /* I1 = device , I2 = buffer , I3 = length , I4 = (langID<<16) | index */
|
|
#define UX_TRACE_HOST_STACK_DEVICE_CONFIGURATION_ACTIVATE (UX_TRACE_HOST_STACK_EVENTS_BASE + 39) /* I1 = device , I2 = configuration */
|
|
#define UX_TRACE_HOST_STACK_DEVICE_CONFIGURATION_DEACTIVATE (UX_TRACE_HOST_STACK_EVENTS_BASE + 40) /* I1 = device , I2 = configuration */
|
|
|
|
/* Define the USBX host class events. */
|
|
|
|
#define UX_TRACE_HOST_CLASS_EVENTS_BASE 650
|
|
#define UX_TRACE_HOST_CLASS_ASIX_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 1) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_ASIX_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 2) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_ASIX_INTERRUPT_NOTIFICATION (UX_TRACE_HOST_CLASS_EVENTS_BASE + 3) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_ASIX_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 4) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_ASIX_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 5) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
|
|
#define UX_TRACE_HOST_CLASS_AUDIO_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 10) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_AUDIO_CONTROL_VALUE_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 11) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_AUDIO_CONTROL_VALUE_SET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 12) /* I1 = class instance , I2 = audio control */
|
|
#define UX_TRACE_HOST_CLASS_AUDIO_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 13) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_AUDIO_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 14) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_AUDIO_STREAMING_SAMPLING_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 15) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_AUDIO_STREAMING_SAMPLING_SET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 16) /* I1 = class instance , I2 = audio sampling */
|
|
#define UX_TRACE_HOST_CLASS_AUDIO_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 17) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 20) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 21) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_IOCTL_SET_LINE_CODING (UX_TRACE_HOST_CLASS_EVENTS_BASE + 22) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_IOCTL_GET_LINE_CODING (UX_TRACE_HOST_CLASS_EVENTS_BASE + 23) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_IOCTL_SET_LINE_STATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 24) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_IOCTL_SEND_BREAK (UX_TRACE_HOST_CLASS_EVENTS_BASE + 25) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_IOCTL_ABORT_IN_PIPE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 26) /* I1 = class instance , I2 = endpoint */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_IOCTL_ABORT_OUT_PIPE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 27) /* I1 = class instance , I2 = endpointr */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_IOCTL_NOTIFICATION_CALLBACK (UX_TRACE_HOST_CLASS_EVENTS_BASE + 28) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_IOCTL_GET_DEVICE_STATUS (UX_TRACE_HOST_CLASS_EVENTS_BASE + 29) /* I1 = class instance , I2 = device status */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 30) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_RECEPTION_START (UX_TRACE_HOST_CLASS_EVENTS_BASE + 31) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_RECEPTION_STOP (UX_TRACE_HOST_CLASS_EVENTS_BASE + 32) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ACM_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 33) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
|
|
#define UX_TRACE_HOST_CLASS_CDC_ECM_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 35) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ECM_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 36) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ECM_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 37) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ECM_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 38) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_CDC_ECM_INTERRUPT_NOTIFICATION (UX_TRACE_HOST_CLASS_EVENTS_BASE + 39) /* I1 = class instance */
|
|
|
|
#define UX_TRACE_HOST_CLASS_HID_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 40) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_HID_CLIENT_REGISTER (UX_TRACE_HOST_CLASS_EVENTS_BASE + 41) /* I1 = hid client name */
|
|
#define UX_TRACE_HOST_CLASS_HID_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 42) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_HID_IDLE_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 43) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_HID_IDLE_SET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 44) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_HID_KEYBOARD_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 45) /* I1 = class instance , I2 = hid client instance */
|
|
#define UX_TRACE_HOST_CLASS_HID_KEYBOARD_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 46) /* I1 = class instance , I2 = hid client instance */
|
|
#define UX_TRACE_HOST_CLASS_HID_MOUSE_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 47) /* I1 = class instance , I2 = hid client instance */
|
|
#define UX_TRACE_HOST_CLASS_HID_MOUSE_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 48) /* I1 = class instance , I2 = hid client instance */
|
|
#define UX_TRACE_HOST_CLASS_HID_REMOTE_CONTROL_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 49) /* I1 = class instance , I2 = hid client instance */
|
|
#define UX_TRACE_HOST_CLASS_HID_REMOTE_CONTROL_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 50) /* I1 = class instance , I2 = hid client instance */
|
|
#define UX_TRACE_HOST_CLASS_HID_REPORT_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 51) /* I1 = class instance , I2 = client report */
|
|
#define UX_TRACE_HOST_CLASS_HID_REPORT_SET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 52) /* I1 = class instance , I2 = client report */
|
|
#define UX_TRACE_HOST_CLASS_HID_REMOTE_CONTROL_CALLBACK (UX_TRACE_HOST_CLASS_EVENTS_BASE + 53) /* I1 = client instance , I2 = remote control instance */
|
|
|
|
#define UX_TRACE_HOST_CLASS_HUB_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 60) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_HUB_CHANGE_DETECT (UX_TRACE_HOST_CLASS_EVENTS_BASE + 62) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_HUB_PORT_CHANGE_CONNECTION_PROCESS (UX_TRACE_HOST_CLASS_EVENTS_BASE + 63) /* I1 = class instance , I2 = port , I3 = port status */
|
|
#define UX_TRACE_HOST_CLASS_HUB_PORT_CHANGE_ENABLE_PROCESS (UX_TRACE_HOST_CLASS_EVENTS_BASE + 64) /* I1 = class instance , I2 = port , I3 = port status */
|
|
#define UX_TRACE_HOST_CLASS_HUB_PORT_CHANGE_OVER_CURRENT_PROCESS (UX_TRACE_HOST_CLASS_EVENTS_BASE + 65) /* I1 = class instance , I2 = port , I3 = port status */
|
|
#define UX_TRACE_HOST_CLASS_HUB_PORT_CHANGE_RESET_PROCESS (UX_TRACE_HOST_CLASS_EVENTS_BASE + 66) /* I1 = class instance , I2 = port , I3 = port status */
|
|
#define UX_TRACE_HOST_CLASS_HUB_PORT_CHANGE_SUSPEND_PROCESS (UX_TRACE_HOST_CLASS_EVENTS_BASE + 67) /* I1 = class instance , I2 = port , I3 = port status */
|
|
#define UX_TRACE_HOST_CLASS_HUB_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 68) /* I1 = class instance */
|
|
|
|
#define UX_TRACE_HOST_CLASS_PIMA_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 70) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 71) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_DEVICE_INFO_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 72) /* I1 = class instance , I2 = pima device */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_DEVICE_RESET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 73) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_NOTIFICATION (UX_TRACE_HOST_CLASS_EVENTS_BASE + 74) /* I1 = class instance , I2 = event code , I3 = transaction ID , I4 = parameter1 */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_NUM_OBJECTS_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 75) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_OBJECT_CLOSE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 76) /* I1 = class instance , I2 = object */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_OBJECT_COPY (UX_TRACE_HOST_CLASS_EVENTS_BASE + 77) /* I1 = class instance , I2 = object handle */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_OBJECT_DELETE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 78) /* I1 = class instance , I2 = object handle */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_OBJECT_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 79) /* I1 = class instance , I2 = object handle , I3 = object */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_OBJECT_INFO_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 80) /* I1 = class instance , I2 = object handle , I3 = object */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_OBJECT_INFO_SEND (UX_TRACE_HOST_CLASS_EVENTS_BASE + 81) /* I1 = class instance , I2 = object */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_OBJECT_MOVE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 82) /* I1 = class instance , I2 = object handle */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_OBJECT_SEND (UX_TRACE_HOST_CLASS_EVENTS_BASE + 83) /* I1 = class instance , I2 = object , I3 = object_buffer , I4 = object length */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_OBJECT_TRANSFER_ABORT (UX_TRACE_HOST_CLASS_EVENTS_BASE + 84) /* I1 = class instance , I2 = object handle , I3 = object */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 85) /* I1 = class instance , I2 = data pointer , I3 = data length */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_REQUEST_CANCEL (UX_TRACE_HOST_CLASS_EVENTS_BASE + 86) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_SESSION_CLOSE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 87) /* I1 = class instance , I2 = pima session */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_SESSION_OPEN (UX_TRACE_HOST_CLASS_EVENTS_BASE + 88) /* I1 = class instance , I2 = pima session */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_STORAGE_IDS_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 89) /* I1 = class instance , I2 = storage ID array, I3 = storage ID length */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_STORAGE_INFO_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 90) /* I1 = class instance , I2 = storage ID , I3 = storage */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_THUMB_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 91) /* I1 = class instance , I2 = object handle */
|
|
#define UX_TRACE_HOST_CLASS_PIMA_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 92) /* I1 = class instance , I2 = data pointer , I3 = data length */
|
|
|
|
#define UX_TRACE_HOST_CLASS_PRINTER_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 100) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PRINTER_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 101) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PRINTER_NAME_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 102) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PRINTER_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 103) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_PRINTER_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 104) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_PRINTER_SOFT_RESET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 105) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PRINTER_STATUS_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 106) /* I1 = class instance , I2 = printer status */
|
|
#define UX_TRACE_HOST_CLASS_PRINTER_DEVICE_ID_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 107) /* I1 = class instance , I2 = printer , I3 = data pointer , I4 = buffer length */
|
|
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 110) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 111) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_IOCTL_SET_LINE_CODING (UX_TRACE_HOST_CLASS_EVENTS_BASE + 112) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_IOCTL_GET_LINE_CODING (UX_TRACE_HOST_CLASS_EVENTS_BASE + 113) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_IOCTL_SET_LINE_STATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 114) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_IOCTL_PURGE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 115) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_IOCTL_SEND_BREAK (UX_TRACE_HOST_CLASS_EVENTS_BASE + 116) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_IOCTL_ABORT_IN_PIPE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 117) /* I1 = class instance , I2 = endpoint */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_IOCTL_ABORT_OUT_PIPE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 118) /* I1 = class instance , I2 = endpointr */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_IOCTL_REPORT_DEVICE_STATUS_CHANGE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 119) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_IOCTL_GET_DEVICE_STATUS (UX_TRACE_HOST_CLASS_EVENTS_BASE + 120) /* I1 = class instance , I2 = device status */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 121) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_RECEPTION_START (UX_TRACE_HOST_CLASS_EVENTS_BASE + 122) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_RECEPTION_STOP (UX_TRACE_HOST_CLASS_EVENTS_BASE + 123) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_PROLIFIC_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 124) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 130) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 131) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_MEDIA_CAPACITY_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 132) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_MEDIA_FORMAT_CAPACITY_GET (UX_TRACE_HOST_CLASS_EVENTS_BASE + 133) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_MEDIA_MOUNT (UX_TRACE_HOST_CLASS_EVENTS_BASE + 134) /* I1 = class instance , I2 = sector */
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_MEDIA_OPEN (UX_TRACE_HOST_CLASS_EVENTS_BASE + 135) /* I1 = class instance , I2 = media */
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_MEDIA_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 136) /* I1 = class instance , I2 = sector start , I3 = sector count , I4 = data pointer */
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_MEDIA_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 137) /* I1 = class instance , I2 = sector start , I3 = sector count , I4 = data pointer */
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_REQUEST_SENSE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 138) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_START_STOP (UX_TRACE_HOST_CLASS_EVENTS_BASE + 139) /* I1 = class instance , I2 = start stop signal */
|
|
#define UX_TRACE_HOST_CLASS_STORAGE_UNIT_READY_TEST (UX_TRACE_HOST_CLASS_EVENTS_BASE + 140) /* I1 = class instance */
|
|
|
|
#define UX_TRACE_HOST_CLASS_DPUMP_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 150) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_DPUMP_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 151) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_DPUMP_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 152) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_DPUMP_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 153) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
|
|
#define UX_TRACE_HOST_CLASS_SWAR_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 160) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_SWAR_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 161) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_SWAR_IOCTL_ABORT_IN_PIPE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 162) /* I1 = class instance , I2 = endpoint */
|
|
#define UX_TRACE_HOST_CLASS_SWAR_IOCTL_ABORT_OUT_PIPE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 163) /* I1 = class instance , I2 = endpointr */
|
|
#define UX_TRACE_HOST_CLASS_SWAR_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 164) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_SWAR_RECEPTION_START (UX_TRACE_HOST_CLASS_EVENTS_BASE + 165) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_SWAR_RECEPTION_STOP (UX_TRACE_HOST_CLASS_EVENTS_BASE + 166) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_SWAR_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 167) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
|
|
#define UX_TRACE_HOST_CLASS_GSER_ACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 170) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_GSER_DEACTIVATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 171) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_GSER_IOCTL_SET_LINE_CODING (UX_TRACE_HOST_CLASS_EVENTS_BASE + 172) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_GSER_IOCTL_GET_LINE_CODING (UX_TRACE_HOST_CLASS_EVENTS_BASE + 173) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_GSER_IOCTL_SET_LINE_STATE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 174) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_GSER_IOCTL_PURGE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 175) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_GSER_IOCTL_SEND_BREAK (UX_TRACE_HOST_CLASS_EVENTS_BASE + 176) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_GSER_IOCTL_ABORT_IN_PIPE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 177) /* I1 = class instance , I2 = endpoint */
|
|
#define UX_TRACE_HOST_CLASS_GSER_IOCTL_ABORT_OUT_PIPE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 178) /* I1 = class instance , I2 = endpointr */
|
|
#define UX_TRACE_HOST_CLASS_GSER_IOCTL_REPORT_DEVICE_STATUS_CHANGE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 179) /* I1 = class instance , I2 = parameter */
|
|
#define UX_TRACE_HOST_CLASS_GSER_IOCTL_GET_DEVICE_STATUS (UX_TRACE_HOST_CLASS_EVENTS_BASE + 180) /* I1 = class instance , I2 = device status */
|
|
#define UX_TRACE_HOST_CLASS_GSER_IOCTL_NOTIFICATION_CALLBACK (UX_TRACE_HOST_CLASS_EVENTS_BASE + 181) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_GSER_READ (UX_TRACE_HOST_CLASS_EVENTS_BASE + 182) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
#define UX_TRACE_HOST_CLASS_GSER_RECEPTION_START (UX_TRACE_HOST_CLASS_EVENTS_BASE + 183) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_GSER_RECEPTION_STOP (UX_TRACE_HOST_CLASS_EVENTS_BASE + 184) /* I1 = class instance */
|
|
#define UX_TRACE_HOST_CLASS_GSER_WRITE (UX_TRACE_HOST_CLASS_EVENTS_BASE + 185) /* I1 = class instance , I2 = data pointer , I3 = requested length */
|
|
|
|
/* Define the USBX device stack events. */
|
|
|
|
#define UX_TRACE_DEVICE_STACK_EVENTS_BASE 850
|
|
#define UX_TRACE_DEVICE_STACK_ALTERNATE_SETTING_GET (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 1) /* I1 = interface value */
|
|
#define UX_TRACE_DEVICE_STACK_ALTERNATE_SETTING_SET (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 2) /* I1 = interface value , I2 = alternate setting value */
|
|
#define UX_TRACE_DEVICE_STACK_CLASS_REGISTER (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 3) /* I1 = class name , I2 = interface number, I3 = parameter */
|
|
#define UX_TRACE_DEVICE_STACK_CLEAR_FEATURE (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 4) /* I1 = request type , I2 = request value , I3 = request index */
|
|
#define UX_TRACE_DEVICE_STACK_CONFIGURATION_GET (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 5) /* I1 = configuration value */
|
|
#define UX_TRACE_DEVICE_STACK_CONFIGURATION_SET (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 6) /* I1 = configuration value */
|
|
#define UX_TRACE_DEVICE_STACK_CONNECT (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 7) /* */
|
|
#define UX_TRACE_DEVICE_STACK_DESCRIPTOR_SEND (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 8) /* I1 = descriptor type , I2 = request index */
|
|
#define UX_TRACE_DEVICE_STACK_DISCONNECT (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 9) /* I1 = device */
|
|
#define UX_TRACE_DEVICE_STACK_ENDPOINT_STALL (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 10) /* I1 = endpoint */
|
|
#define UX_TRACE_DEVICE_STACK_GET_STATUS (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 11) /* I1 = request type , I2 = request value , I3 = request index */
|
|
#define UX_TRACE_DEVICE_STACK_HOST_WAKEUP (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 12) /* */
|
|
#define UX_TRACE_DEVICE_STACK_INITIALIZE (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 13) /* */
|
|
#define UX_TRACE_DEVICE_STACK_INTERFACE_DELETE (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 14) /* I1 = interface */
|
|
#define UX_TRACE_DEVICE_STACK_INTERFACE_GET (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 15) /* I1 = interface value */
|
|
#define UX_TRACE_DEVICE_STACK_INTERFACE_SET (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 16) /* I1 = alternate setting value */
|
|
#define UX_TRACE_DEVICE_STACK_SET_FEATURE (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 17) /* I1 = request value , I2 = request index */
|
|
#define UX_TRACE_DEVICE_STACK_TRANSFER_ABORT (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 18) /* I1 = transfer request, I2 = completion code */
|
|
#define UX_TRACE_DEVICE_STACK_TRANSFER_ALL_REQUEST_ABORT (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 19) /* I1 = endpoint , I2 = completion code */
|
|
#define UX_TRACE_DEVICE_STACK_TRANSFER_REQUEST (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 20) /* I1 = transfer request */
|
|
#define UX_TRACE_DEVICE_STACK_MICROSOFT_EXTENSION_REGISTER (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 21) /* I1 = transfer request */
|
|
#define UX_TRACE_DEVICE_STACK_CLASS_UNREGISTER (UX_TRACE_DEVICE_STACK_EVENTS_BASE + 22) /* I1 = class name */
|
|
|
|
/* Define the USBX device stack events first. */
|
|
|
|
#define UX_TRACE_DEVICE_CLASS_EVENTS_BASE 900
|
|
#define UX_TRACE_DEVICE_CLASS_DPUMP_ACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 1) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_DPUMP_DEACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 2) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_DPUMP_READ (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 3) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
#define UX_TRACE_DEVICE_CLASS_DPUMP_WRITE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 4) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
#define UX_TRACE_DEVICE_CLASS_DPUMP_CHANGE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 5) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ACM_ACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 10) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ACM_DEACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 11) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ACM_READ (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 12) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ACM_WRITE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 13) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
|
|
#define UX_TRACE_DEVICE_CLASS_HID_ACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 20) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_HID_DEACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 21) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_HID_EVENT_GET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 22) /* I1 = class instance , I2 = hid event */
|
|
#define UX_TRACE_DEVICE_CLASS_HID_EVENT_SET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 23) /* I1 = class instance , I2 = hid event */
|
|
#define UX_TRACE_DEVICE_CLASS_HID_REPORT_GET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 24) /* I1 = class instance , I2 = descriptor type , I3 = request index */
|
|
#define UX_TRACE_DEVICE_CLASS_HID_REPORT_SET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 25) /* I1 = class instance , I2 = descriptor type , I3 = request index */
|
|
#define UX_TRACE_DEVICE_CLASS_HID_DESCRIPTOR_SEND (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 26) /* I1 = class instance , I2 = descriptor type , I3 = request index */
|
|
#define UX_TRACE_DEVICE_CLASS_HID_READ (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 27) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
#define UX_TRACE_DEVICE_CLASS_HID_RECEIVER_EVENT_GET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 28) /* I1 = class instance , I2 = receiver event , I3 = wait_option */
|
|
#define UX_TRACE_DEVICE_CLASS_HID_RECEIVER_EVENT_FREE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 29) /* I1 = class instance , I2 = receiver event */
|
|
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_ACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 30) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_DEACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 31) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_DEVICE_INFO_SEND (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 32) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_EVENT_GET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 33) /* I1 = class instance , I2 = pima event */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_EVENT_SET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 34) /* I1 = class instance , I2 = pima event */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_OBJECT_ADD (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 35) /* I1 = class instance , I2 = object handle */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_OBJECT_DATA_GET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 36) /* I1 = class instance , I2 = object handle */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_OBJECT_DATA_SEND (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 37) /* I1 = class instance , I2 = object handle */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_OBJECT_DELETE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 38) /* I1 = class instance , I2 = object handle */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_OBJECT_HANDLES_SEND (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 39) /* I1 = class instance , I2 = storage id , I3 = object format code, I4 = object association */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_OBJECT_INFO_GET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 40) /* I1 = class instance , I2 = object handle */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_OBJECT_INFO_SEND (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 41) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_OBJECTS_NUMBER_SEND (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 42) /* I1 = class instance , I2 = storage id , I3 = object format code, I4 = object association */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_PARTIAL_OBJECT_DATA_GET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 43) /* I1 = class instance , I2 = object handle , I3 = offset requested , I4 = length requested */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_RESPONSE_SEND (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 44) /* I1 = class instance , I2 = response code , I3 = number parameter , I4 = pima parameter 1 */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_STORAGE_ID_SEND (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 45) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_STORAGE_INFO_SEND (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 46) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_GET_DEVICE_PROP_DESC_GET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 47) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_GET_DEVICE_PROP_VALUE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 48) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_GET_DEVICE_PROP_VALUE_SET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 49) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_GET_OBJECT_PROP_DESC (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 50) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_GET_OBJECT_PROP_VALUE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 51) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_OBJECTS_PROPS_SUPPORTED_GET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 52) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_GET_OBJECT_REFERENCES (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 53) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_OBJECTS_PROPS_SUPPORTED_SET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 54) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_SET_OBJECT_REFERENCES (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 55) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_STORAGE_FORMAT (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 56) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_DEVICE_RESET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 57) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PIMA_SET_OBJECT_PROP_VALUE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 58) /* I1 = class instance */
|
|
|
|
#define UX_TRACE_DEVICE_CLASS_RNDIS_ACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 60) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_RNDIS_DEACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 61) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_RNDIS_PACKET_RECEIVE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 62) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_RNDIS_PACKET_TRANSMIT (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 63) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_RNDIS_MSG_QUERY (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 64) /* I1 = class instance , I2 = rndis OID */
|
|
#define UX_TRACE_DEVICE_CLASS_RNDIS_MSG_KEEP_ALIVE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 65) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_RNDIS_MSG_RESET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 66) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_RNDIS_MSG_SET (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 67) /* I1 = class instance , I2 = rndis OID */
|
|
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_ACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 70) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_DEACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 71) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_FORMAT (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 72) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_INQUIRY (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 73) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_MODE_SELECT (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 74) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_MODE_SENSE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 75) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_PREVENT_ALLOW_MEDIA_REMOVAL (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 76) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_READ (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 77) /* I1 = class instance , I2 = lun , I3 = sector , I4 = number sectors */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_READ_CAPACITY (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 78) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_READ_FORMAT_CAPACITY (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 79) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_READ_TOC (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 80) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_REQUEST_SENSE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 81) /* I1 = class instance , I2 = lun , I3 = sense key , I4 = code */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_TEST_READY (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 82) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_START_STOP (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 83) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_VERIFY (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 84) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_WRITE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 85) /* I1 = class instance , I2 = lun , I3 = sector , I4 = number sectors */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_GET_CONFIGURATION (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 86) /* I1 = class instance , I2 = lun */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_SYNCHRONIZE_CACHE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 87) /* I1 = class instance , I2 = lun , I3 = sector , I4 = number sectors */
|
|
#define UX_TRACE_DEVICE_CLASS_STORAGE_OTHER (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 88) /* I1 = class instance , I2 = lun */
|
|
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ECM_ACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 90) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ECM_DEACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 91) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ECM_CHANGE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 92) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ECM_READ (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 93) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ECM_WRITE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 94) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ECM_PACKET_TRANSMIT (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 95) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
#define UX_TRACE_DEVICE_CLASS_CDC_ECM_PACKET_RECEIVE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 96) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
|
|
#define UX_TRACE_DEVICE_CLASS_DFU_ACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 97) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_DFU_DEACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 98) /* I1 = class instance */
|
|
|
|
#define UX_TRACE_DEVICE_CLASS_PRINTER_ACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 100) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PRINTER_DEACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 101) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_PRINTER_READ (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 102) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
#define UX_TRACE_DEVICE_CLASS_PRINTER_WRITE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 103) /* I1 = class instance , I2 = buffer , I3 = requested_length */
|
|
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_ACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 110) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_DEACTIVATE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 111) /* I1 = class instance */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_REQ_ABORT (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 112) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_ICC_POWER_ON (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 113) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_ICC_POWER_OFF (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 114) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_GET_SLOT_STATUS (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 115) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_XFR_BLOCK (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 116) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_GET_PARAMETERS (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 117) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_RESET_PARAMETERS (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 118) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_SET_PARAMETERS (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 119) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_ESCAPE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 120) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_ICC_CLOCK (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 121) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_T0_APDU (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 122) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_SECURE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 123) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_MECHANICAL (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 124) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_ABORT (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 125) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_PC_TO_RDR_SET_RATE_CLOCK (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 126) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_RDR_TO_PC_RESPONSE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 127) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_ICC_INSERT (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 128) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_ICC_REMOVE (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 129) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_AUTO_SEQ_START (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 130) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_AUTO_SEQ_STOP (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 131) /* I1 = class instance , I2 = slot */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_TIME_EXTENSION (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 132) /* I1 = class instance , I2 = slot , I3 = time */
|
|
#define UX_TRACE_DEVICE_CLASS_CCID_HARDWARE_ERROR (UX_TRACE_DEVICE_CLASS_EVENTS_BASE + 133) /* I1 = class instance , I2 = slot */
|
|
|
|
|
|
/* Define the USBX Error Event. */
|
|
|
|
#define UX_TRACE_ERROR 999
|
|
|
|
|
|
#else
|
|
#define UX_TRACE_OBJECT_REGISTER(t,p,n,a,b)
|
|
#define UX_TRACE_OBJECT_UNREGISTER(o)
|
|
#define UX_TRACE_IN_LINE_INSERT(i,a,b,c,d,f,g,h)
|
|
#define UX_TRACE_EVENT_UPDATE(e,t,i,a,b,c,d)
|
|
#endif
|
|
|
|
|
|
/* Define the system level for error trapping. */
|
|
#define UX_SYSTEM_LEVEL_INTERRUPT 1
|
|
#define UX_SYSTEM_LEVEL_THREAD 2
|
|
|
|
/* Define the system context for error trapping. */
|
|
#define UX_SYSTEM_CONTEXT_HCD 1
|
|
#define UX_SYSTEM_CONTEXT_DCD 2
|
|
#define UX_SYSTEM_CONTEXT_INIT 3
|
|
#define UX_SYSTEM_CONTEXT_ENUMERATOR 4
|
|
#define UX_SYSTEM_CONTEXT_ROOT_HUB 5
|
|
#define UX_SYSTEM_CONTEXT_HUB 6
|
|
#define UX_SYSTEM_CONTEXT_CLASS 7
|
|
#define UX_SYSTEM_CONTEXT_UTILITY 8
|
|
#define UX_SYSTEM_CONTEXT_DEVICE_STACK 9
|
|
#define UX_SYSTEM_CONTEXT_HOST_STACK 10
|
|
|
|
|
|
/* Defines the number of ThreadX timer ticks per seconds. By default, the ThreadX timer tick is 10ms,
|
|
so the default value for this constant is 100. If TX_TIMER_TICKS_PER_SECOND is defined,
|
|
this value is derived from TX_TIMER_TICKS_PER_SECOND. */
|
|
|
|
#ifndef UX_PERIODIC_RATE
|
|
#ifdef TX_TIMER_TICKS_PER_SECOND
|
|
#define UX_PERIODIC_RATE (TX_TIMER_TICKS_PER_SECOND)
|
|
#else
|
|
#define UX_PERIODIC_RATE 100
|
|
#endif
|
|
#endif
|
|
|
|
|
|
/* Define interrupts lockout constructs to protect the memory allocation/release which could happen
|
|
under ISR in the device stack. */
|
|
|
|
#ifndef UX_INTERRUPT_SAVE_AREA
|
|
#ifdef TX_INTERRUPT_SAVE_AREA
|
|
#define UX_INTERRUPT_SAVE_AREA TX_INTERRUPT_SAVE_AREA
|
|
#else
|
|
#define UX_INTERRUPT_SAVE_AREA ALIGN_TYPE saved_flags;
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_DISABLE
|
|
#ifdef TX_DISABLE
|
|
#define UX_DISABLE TX_DISABLE
|
|
#else
|
|
#define UX_DISABLE saved_flags = _ux_utility_interrupt_disable();
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_RESTORE
|
|
#ifdef TX_RESTORE
|
|
#define UX_RESTORE TX_RESTORE
|
|
#else
|
|
#define UX_RESTORE _ux_utility_interrupt_restore(saved_flags);
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_INT_SAVE_AREA /* Backword compatible. */
|
|
#define UX_INT_SAVE_AREA UX_INTERRUPT_SAVE_AREA
|
|
#endif
|
|
#ifndef UX_DISABLE_INTS /* Backword compatible. */
|
|
#define UX_DISABLE_INTS UX_DISABLE
|
|
#endif
|
|
#ifndef UX_RESTORE_INTS /* Backword compatible. */
|
|
#define UX_RESTORE_INTS UX_RESTORE
|
|
#endif
|
|
|
|
|
|
/* Define thread/timer related things. */
|
|
|
|
#ifndef UX_EMPTY
|
|
#ifdef TX_EMPTY
|
|
#define UX_EMPTY TX_EMPTY
|
|
#else
|
|
#define UX_EMPTY (0)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_TIMER
|
|
#ifdef TX_API_H
|
|
#define UX_TIMER TX_TIMER
|
|
#else
|
|
#define UX_TIMER VOID* /* Dummy type for standalone compile. */
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_THREAD
|
|
#ifdef TX_API_H
|
|
#define UX_THREAD TX_THREAD
|
|
#else
|
|
#define UX_THREAD VOID* /* Dummy type for standalone compile. */
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_AUTO_START
|
|
#ifdef TX_AUTO_START
|
|
#define UX_AUTO_START TX_AUTO_START
|
|
#else
|
|
#define UX_AUTO_START (1ul)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_DONT_START
|
|
#ifdef TX_DONT_START
|
|
#define UX_DONT_START TX_DONT_START
|
|
#else
|
|
#define UX_DONT_START (0ul)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_AUTO_ACTIVATE
|
|
#ifdef TX_AUTO_ACTIVATE
|
|
#define UX_AUTO_ACTIVATE TX_AUTO_ACTIVATE
|
|
#else
|
|
#define UX_AUTO_ACTIVATE (1ul)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_NO_ACTIVATE
|
|
#ifdef TX_NO_ACTIVATE
|
|
#define UX_NO_ACTIVATE TX_NO_ACTIVATE
|
|
#else
|
|
#define UX_NO_ACTIVATE (0ul)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_THREAD_GET_SYSTEM_STATE
|
|
#define UX_THREAD_GET_SYSTEM_STATE TX_THREAD_GET_SYSTEM_STATE
|
|
#endif
|
|
|
|
#ifndef UX_WAIT_FOREVER
|
|
#ifdef TX_WAIT_FOREVER
|
|
#define UX_WAIT_FOREVER TX_WAIT_FOREVER
|
|
#else
|
|
#define UX_WAIT_FOREVER (0xFFFFFFFFul)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_NO_WAIT
|
|
#ifdef TX_NO_WAIT
|
|
#define UX_NO_WAIT TX_NO_WAIT
|
|
#else
|
|
#define UX_NO_WAIT (0ul)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_NO_TIME_SLICE
|
|
#ifdef TX_NO_TIME_SLICE
|
|
#define UX_NO_TIME_SLICE TX_NO_TIME_SLICE
|
|
#else
|
|
#define UX_NO_TIME_SLICE (0ul)
|
|
#endif
|
|
#endif
|
|
|
|
|
|
/* Define semaphore related things. */
|
|
|
|
#ifndef UX_SEMAPHORE
|
|
#ifdef TX_API_H
|
|
#define UX_SEMAPHORE TX_SEMAPHORE
|
|
#else
|
|
#define UX_SEMAPHORE VOID* /* Dummy type for standalone compile. */
|
|
#endif
|
|
#endif
|
|
|
|
|
|
/* Define mutex related things. */
|
|
|
|
#ifndef UX_MUTEX
|
|
#ifdef TX_API_H
|
|
#define UX_MUTEX TX_MUTEX
|
|
#else
|
|
#define UX_MUTEX VOID* /* Dummy type for standalone compile. */
|
|
#endif
|
|
#endif
|
|
|
|
|
|
/* Define event flags group related things. */
|
|
|
|
#ifndef UX_EVENT_FLAGS_GROUP
|
|
#ifdef TX_API_H
|
|
#define UX_EVENT_FLAGS_GROUP TX_EVENT_FLAGS_GROUP
|
|
#else
|
|
#define UX_EVENT_FLAGS_GROUP VOID* /* Dummy type for standalone compile. */
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_OR_CLEAR
|
|
#ifdef TX_OR_CLEAR
|
|
#define UX_OR_CLEAR TX_OR_CLEAR
|
|
#else
|
|
#define UX_OR_CLEAR (1u)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_OR
|
|
#ifdef TX_OR
|
|
#define UX_OR TX_OR
|
|
#else
|
|
#define UX_OR (0u)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_AND_CLEAR
|
|
#ifdef TX_AND_CLEAR
|
|
#define UX_AND_CLEAR TX_AND_CLEAR
|
|
#else
|
|
#define UX_AND_CLEAR (3u)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_AND
|
|
#ifdef TX_AND
|
|
#define UX_AND TX_AND
|
|
#else
|
|
#define UX_AND (2u)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef UX_NO_EVENTS
|
|
#ifdef TX_NO_EVENTS
|
|
#define UX_NO_EVENTS TX_NO_EVENTS
|
|
#else
|
|
#define UX_NO_EVENTS (7u)
|
|
#endif
|
|
#endif
|
|
|
|
|
|
/* Define basic USBX constants. */
|
|
|
|
#define UX_NULL ((void*)0)
|
|
#define UX_INVALID_PTR ((void*)(~((ALIGN_TYPE)0)))
|
|
#define UX_TRUE 1u
|
|
#define UX_FALSE 0u
|
|
#define UX_TT_MASK 0x1FFu
|
|
#define UX_TT_BANDWIDTH 6000u
|
|
#define UX_SLAVE_ENDPOINT_DEFAULT_BUFFER_SIZE 256u
|
|
|
|
#define UX_MAX_BYTES_PER_FRAME_FS 1157u
|
|
#define UX_MAX_BYTES_PER_MICROFRAME_HS 5785u
|
|
|
|
/* Define USBX command request constants. */
|
|
|
|
#define UX_SETUP_REQUEST_TYPE 0u
|
|
#define UX_SETUP_REQUEST 1u
|
|
#define UX_SETUP_VALUE 2u
|
|
#define UX_SETUP_INDEX 4u
|
|
#define UX_SETUP_LENGTH 6u
|
|
#define UX_SETUP_SIZE 8u
|
|
|
|
|
|
/* Define USBX standard commands. */
|
|
|
|
#define UX_GET_STATUS 0u
|
|
#define UX_CLEAR_FEATURE 1u
|
|
#define UX_SET_FEATURE 3u
|
|
#define UX_SET_ADDRESS 5u
|
|
#define UX_GET_DESCRIPTOR 6u
|
|
#define UX_SET_DESCRIPTOR 7u
|
|
#define UX_GET_CONFIGURATION 8u
|
|
#define UX_SET_CONFIGURATION 9u
|
|
#define UX_GET_INTERFACE 10u
|
|
#define UX_SET_INTERFACE 11u
|
|
#define UX_SYNCH_FRAME 12u
|
|
|
|
|
|
/* Define USBX command sub constants. */
|
|
|
|
#define UX_ENDPOINT_HALT 0u
|
|
|
|
/* Define USBX feature selector constants. */
|
|
#define UX_REQUEST_FEATURE_ENDPOINT_HALT 0u
|
|
#define UX_REQUEST_FEATURE_DEVICE_REMOTE_WAKEUP 1u
|
|
#define UX_REQUEST_FEATURE_TEST_MODE 2u
|
|
|
|
/* Define Generic USBX constants. */
|
|
|
|
#define UX_UNUSED 0
|
|
#define UX_USED 1
|
|
|
|
#define UX_MEMORY_UNUSED 0x00000000u
|
|
#define UX_MEMORY_USED 0x80000000u
|
|
#define UX_REGULAR_MEMORY 0
|
|
#define UX_CACHE_SAFE_MEMORY 1
|
|
|
|
#define UX_NO_ALIGN 0u
|
|
#define UX_ALIGN_16 0x0fu
|
|
#define UX_ALIGN_32 0x1fu
|
|
#define UX_ALIGN_64 0x3fu
|
|
#define UX_ALIGN_128 0x7fu
|
|
#define UX_ALIGN_256 0xffu
|
|
#define UX_ALIGN_512 0x1ffu
|
|
#define UX_ALIGN_1024 0x3ffu
|
|
#define UX_ALIGN_2048 0x7ffu
|
|
#define UX_ALIGN_4096 0xfffu
|
|
#define UX_SAFE_ALIGN 0xffffffffu
|
|
#define UX_MAX_SCATTER_GATHER_ALIGNMENT 4096
|
|
#ifndef UX_ALIGN_MIN
|
|
#define UX_ALIGN_MIN UX_ALIGN_16
|
|
#endif
|
|
|
|
#define UX_MAX_USB_DEVICES 127
|
|
|
|
#define UX_ENDPOINT_DIRECTION 0x80u
|
|
#define UX_ENDPOINT_IN 0x80u
|
|
#define UX_ENDPOINT_OUT 0x00u
|
|
|
|
#define UX_MASK_ENDPOINT_TYPE 3u
|
|
#define UX_CONTROL_ENDPOINT 0u
|
|
#define UX_ISOCHRONOUS_ENDPOINT 1u
|
|
#define UX_BULK_ENDPOINT 2u
|
|
#define UX_INTERRUPT_ENDPOINT 3u
|
|
|
|
#define UX_ISOCHRONOUS_ENDPOINT_IN 0x81u
|
|
#define UX_ISOCHRONOUS_ENDPOINT_OUT 0x01u
|
|
#define UX_BULK_ENDPOINT_IN 0x82u
|
|
#define UX_BULK_ENDPOINT_OUT 0x02u
|
|
#define UX_INTERRUPT_ENDPOINT_IN 0x83u
|
|
#define UX_INTERRUPT_ENDPOINT_OUT 0x03u
|
|
|
|
#define UX_MAX_PACKET_SIZE_MASK 0x7ffu
|
|
#define UX_MAX_NUMBER_OF_TRANSACTIONS_MASK 0x1800u
|
|
#define UX_MAX_NUMBER_OF_TRANSACTIONS_SHIFT 11
|
|
|
|
#define UX_FEEDBACK_SIZE_FULL_SPEED 3 /* 10.10 format fits into 3 bytes. */
|
|
#define UX_FEEDBACK_SIZE_HIGH_SPEED 4 /* 12.13 format fits into 4 bytes. */
|
|
|
|
#define UX_REQUEST_DIRECTION 0x80u
|
|
#define UX_REQUEST_IN 0x80u
|
|
#define UX_REQUEST_OUT 0x00u
|
|
|
|
#define UX_REQUEST_TYPE 0x60u
|
|
#define UX_REQUEST_TYPE_STANDARD 0x00u
|
|
#define UX_REQUEST_TYPE_CLASS 0x20u
|
|
#define UX_REQUEST_TYPE_VENDOR 0x40u
|
|
|
|
#define UX_REQUEST_TARGET 0x03u
|
|
#define UX_REQUEST_TARGET_DEVICE 0x00u
|
|
#define UX_REQUEST_TARGET_INTERFACE 0x01u
|
|
#define UX_REQUEST_TARGET_ENDPOINT 0x02u
|
|
#define UX_REQUEST_TARGET_OTHER 0x03u
|
|
|
|
#define UX_DEVICE_RESET 0
|
|
#define UX_DEVICE_ATTACHED 1
|
|
#define UX_DEVICE_ADDRESSED 2
|
|
#define UX_DEVICE_CONFIGURED 3
|
|
#define UX_DEVICE_SUSPENDED 4
|
|
#define UX_DEVICE_RESUMED 5
|
|
#define UX_DEVICE_SELF_POWERED_STATE 6
|
|
#define UX_DEVICE_BUS_POWERED_STATE 7
|
|
#define UX_DEVICE_REMOTE_WAKEUP 8
|
|
#define UX_DEVICE_BUS_RESET_COMPLETED 9
|
|
#define UX_DEVICE_REMOVED 10
|
|
#define UX_DEVICE_FORCE_DISCONNECT 11
|
|
|
|
#define UX_ENDPOINT_RESET 0
|
|
#define UX_ENDPOINT_RUNNING 1
|
|
#define UX_ENDPOINT_HALTED 2
|
|
|
|
#define UX_DEVICE_DESCRIPTOR_ITEM 1u
|
|
#define UX_CONFIGURATION_DESCRIPTOR_ITEM 2u
|
|
#define UX_STRING_DESCRIPTOR_ITEM 3u
|
|
#define UX_INTERFACE_DESCRIPTOR_ITEM 4u
|
|
#define UX_ENDPOINT_DESCRIPTOR_ITEM 5u
|
|
#define UX_DEVICE_QUALIFIER_DESCRIPTOR_ITEM 6u
|
|
#define UX_OTHER_SPEED_DESCRIPTOR_ITEM 7u
|
|
#define UX_OTG_DESCRIPTOR_ITEM 9u
|
|
#define UX_INTERFACE_ASSOCIATION_DESCRIPTOR_ITEM 11u
|
|
#define UX_BOS_DESCRIPTOR_ITEM 15u
|
|
#define UX_DEVICE_CAPABILITY_DESCRIPTOR_ITEM 16u
|
|
#define UX_DFU_FUNCTIONAL_DESCRIPTOR_ITEM 0x21u
|
|
#define UX_HUB_DESCRIPTOR_ITEM 0x29u
|
|
|
|
#define UX_CAPABILITY_WIRELESS_USB 0x01u
|
|
#define UX_CAPABILITY_USB_2_0_EXTENSION 0x02u
|
|
#define UX_CAPABILITY_SUPERSPEED_USB 0x03u
|
|
#define UX_CAPABILITY_CONTAINER_ID 0x04u
|
|
#define UX_CAPABILITY_PLATFORM 0x05u
|
|
#define UX_CAPABILITY_POWER_DELIVERY 0x06u
|
|
#define UX_CAPABILITY_BATTERY_INFO 0x07u
|
|
#define UX_CAPABILITY_PD_CONSUMER_PORT 0x08u
|
|
#define UX_CAPABILITY_PD_PROVIDER_PORT 0x09u
|
|
#define UX_CAPABILITY_SUPERSPEED_PLUS 0x0Au
|
|
#define UX_CAPABILITY_PRECISION_TIME_MEASUREMENT 0x0Bu
|
|
#define UX_CAPABILITY_WIRELESS_USB_EXT 0x0Cu
|
|
#define UX_CAPABILITY_BILLBOARD 0x0Du
|
|
#define UX_CAPABILITY_AUTHENTICATION 0x0Eu
|
|
#define UX_CAPABILITY_BILLBOARD_EX 0x0Fu
|
|
#define UX_CAPABILITY_CONFIGURATION_SUMMARY 0x10u
|
|
|
|
|
|
#ifndef UX_CONTROL_TRANSFER_TIMEOUT
|
|
#define UX_CONTROL_TRANSFER_TIMEOUT 10000
|
|
#endif
|
|
|
|
#ifndef UX_NON_CONTROL_TRANSFER_TIMEOUT
|
|
#define UX_NON_CONTROL_TRANSFER_TIMEOUT 50000
|
|
#endif
|
|
#define UX_PORT_ENABLE_WAIT 50
|
|
#define UX_DEVICE_ADDRESS_SET_WAIT 50
|
|
#define UX_HIGH_SPEED_DETECTION_HANDSHAKE_SUSPEND_WAIT 200
|
|
#define UX_ENUMERATION_THREAD_WAIT 200
|
|
|
|
|
|
/* USB Billboard constants. */
|
|
|
|
#define UX_CLASS_BILLBOARD_CLASS 0x11
|
|
#define UX_CLASS_BILLBOARD_SUBCLASS 0x00
|
|
#define UX_CLASS_BILLBOARD_PROTOCOL 0x00
|
|
#define UX_CLASS_BILLBOARD_DESCRIPTOR_BILLBOARD 0x0D
|
|
#define UX_CLASS_BILLBOARD_DESCRIPTOR_ALTERNATE_MODE 0x0F
|
|
#define UX_CLASS_BILLBOARD_MAX_NUM_ALT_MODE 0x34
|
|
|
|
/* USBX 5.8 BACKWARD COMPATIBILITY DEFINITIONS. THESE DEFINITIONS ARE NOW OBSOLETE
|
|
BUT DEFINED HERE FOR COMPATIBILITY REASONS. */
|
|
|
|
#ifndef UX_CONTROL_TRANSFER_TIMEOUT_IN_MS
|
|
#define UX_CONTROL_TRANSFER_TIMEOUT_IN_MS 10000
|
|
#endif
|
|
|
|
#ifndef UX_NON_CONTROL_TRANSFER_TIMEOUT_IN_MS
|
|
#define UX_NON_CONTROL_TRANSFER_TIMEOUT_IN_MS 50000
|
|
#endif
|
|
|
|
#ifndef UX_PORT_ENABLE_WAIT_IN_MS
|
|
#define UX_PORT_ENABLE_WAIT_IN_MS 500
|
|
#endif
|
|
|
|
#ifndef UX_DEVICE_ADDRESS_SET_WAIT_IN_MS
|
|
#define UX_DEVICE_ADDRESS_SET_WAIT_IN_MS 500
|
|
#endif
|
|
|
|
#ifndef UX_HIGH_SPEED_DETECTION_HANDSHAKE_SUSPEND_WAIT_IN_MS
|
|
#define UX_HIGH_SPEED_DETECTION_HANDSHAKE_SUSPEND_WAIT_IN_MS 2000
|
|
#endif
|
|
|
|
/* END OF 5.8 BACKWARD COMPATIBILITY DEFINITIONS. */
|
|
|
|
#define UX_TRANSFER_PHASE_SETUP 1
|
|
#define UX_TRANSFER_PHASE_DATA_IN 2
|
|
#define UX_TRANSFER_PHASE_DATA_OUT 3
|
|
#define UX_TRANSFER_PHASE_STATUS_IN 4
|
|
#define UX_TRANSFER_PHASE_STATUS_OUT 5
|
|
|
|
|
|
/* Host change callback events : _callback(event, *class, *instance) */
|
|
|
|
#define UX_DEVICE_INSERTION 0x01u
|
|
#define UX_DEVICE_REMOVAL 0x02u
|
|
#define UX_HID_CLIENT_INSERTION 0x03u
|
|
#define UX_HID_CLIENT_REMOVAL 0x04u
|
|
#define UX_STORAGE_MEDIA_INSERTION 0x05u
|
|
#define UX_STORAGE_MEDIA_REMOVAL 0x06u
|
|
|
|
/* Host change callback events : _callback(event, NULL, *device_instance) */
|
|
|
|
#define UX_DEVICE_CONNECTION 0x81u
|
|
#define UX_DEVICE_DISCONNECTION 0x82u
|
|
|
|
/* Host change callback events : _callback(event, NULL, NULL) */
|
|
|
|
#define UX_STANDALONE_WAIT_BACKGROUND_TASK 0x00u
|
|
|
|
|
|
/* Define USBX transfer request status constants. */
|
|
|
|
#define UX_TRANSFER_STATUS_NOT_PENDING 0
|
|
#define UX_TRANSFER_STATUS_PENDING 1
|
|
#define UX_TRANSFER_STATUS_COMPLETED 2
|
|
#define UX_TRANSFER_STATUS_ABORT 4
|
|
|
|
/* Define USBX device power constants. */
|
|
|
|
#define UX_DEVICE_BUS_POWERED 1u
|
|
#define UX_DEVICE_SELF_POWERED 2u
|
|
#define UX_MAX_SELF_POWER (500u/2)
|
|
#define UX_MAX_BUS_POWER (100u/2)
|
|
#define UX_CONFIGURATION_DEVICE_BUS_POWERED 0x80u
|
|
#define UX_CONFIGURATION_DEVICE_SELF_POWERED 0x40u
|
|
#define UX_STATUS_DEVICE_SELF_POWERED 1u
|
|
|
|
/* Define USBX OTG constants. */
|
|
|
|
#define UX_OTG_BM_ATTRIBUTES 2u
|
|
#define UX_OTG_SRP_SUPPORT 1u
|
|
#define UX_OTG_HNP_SUPPORT 2u
|
|
#define UX_HCD_OTG_CAPABLE 1u
|
|
#define UX_DCD_OTG_CAPABLE 1u
|
|
|
|
#define UX_OTG_FEATURE_B_HNP_ENABLE 3u
|
|
#define UX_OTG_FEATURE_A_HNP_SUPPORT 4u
|
|
#define UX_OTG_FEATURE_A_ALT_HNP_SUPPORT 5u
|
|
#define UX_OTG_STATUS_SELECTOR 0xF000u
|
|
#define UX_OTG_HOST_REQUEST_FLAG 0x01u
|
|
|
|
#define UX_OTG_IDLE 0u
|
|
#define UX_OTG_IDLE_TO_HOST 1u
|
|
#define UX_OTG_IDLE_TO_SLAVE 2u
|
|
#define UX_OTG_HOST_TO_IDLE 3u
|
|
#define UX_OTG_HOST_TO_SLAVE 4u
|
|
#define UX_OTG_SLAVE_TO_IDLE 5u
|
|
#define UX_OTG_SLAVE_TO_HOST 6u
|
|
#define UX_OTG_SLAVE_SRP 7u
|
|
|
|
#define UX_OTG_MODE_IDLE 0u
|
|
#define UX_OTG_MODE_SLAVE 1u
|
|
#define UX_OTG_MODE_HOST 2u
|
|
|
|
#define UX_OTG_DEVICE_IDLE 0u
|
|
#define UX_OTG_DEVICE_A 1u
|
|
#define UX_OTG_DEVICE_B 2u
|
|
|
|
#define UX_OTG_VBUS_IDLE 0u
|
|
#define UX_OTG_VBUS_ON 1u
|
|
#define UX_OTG_VBUS_OFF 2u
|
|
|
|
|
|
#define UX_OTG_HNP_THREAD_SLEEP_TIME (2 * UX_PERIODIC_RATE)
|
|
|
|
/* Define USBX device speed constants. */
|
|
|
|
#define UX_DEFAULT_HS_MPS 64
|
|
#define UX_DEFAULT_MPS 8
|
|
|
|
#define UX_LOW_SPEED_DEVICE 0
|
|
#define UX_FULL_SPEED_DEVICE 1
|
|
#define UX_HIGH_SPEED_DEVICE 2
|
|
|
|
|
|
/* Define USBX generic port status constants. */
|
|
|
|
#define UX_PS_CCS 0x01u
|
|
#define UX_PS_CPE 0x01u
|
|
#define UX_PS_PES 0x02u
|
|
#define UX_PS_PSS 0x04u
|
|
#define UX_PS_POCI 0x08u
|
|
#define UX_PS_PRS 0x10u
|
|
#define UX_PS_PPS 0x20u
|
|
#define UX_PS_DS_LS 0x00u
|
|
#define UX_PS_DS_FS 0x40u
|
|
#define UX_PS_DS_HS 0x80u
|
|
|
|
#define UX_PS_DS 6u
|
|
|
|
|
|
/* Define USBX generic state machine constants. */
|
|
|
|
#define UX_STATE_RESET 0u
|
|
#define UX_STATE_EXIT 1u
|
|
#define UX_STATE_IDLE 2u
|
|
#define UX_STATE_ERROR 3u
|
|
#define UX_STATE_NEXT 4u
|
|
#define UX_STATE_WAIT 5u
|
|
#define UX_STATE_LOCK 6u
|
|
#define UX_STATE_BUSY 6u
|
|
#define UX_STATE_STEP 0x20u
|
|
#define UX_STATE_STACK_STEP 0x20u
|
|
#define UX_STATE_DRIVER_STEP 0x40u
|
|
#define UX_STATE_CLASS_STEP 0x60u
|
|
#define UX_STATE_APP_STEP 0x80u
|
|
|
|
#define UX_STATE_IS_RESET(s) (!(s)) /* Reset state */
|
|
#define UX_STATE_IS_FATAL(s) ((s) && (s) < UX_STATE_ERROR) /* Fatal, break all pending loops. */
|
|
#define UX_STATE_IS_ERROR(s) ((s) == UX_STATE_ERROR) /* General error */
|
|
#define UX_STATE_IS_BUSY(s) ((s) >= UX_STATE_WAIT) /* Locked or pending */
|
|
#define UX_STATE_IS_LOCKED(s) ((s) >= UX_STATE_LOCK) /* Locked but not pendint */
|
|
|
|
|
|
/* Define USBX Error Code constants. The following format describes
|
|
their meaning:
|
|
|
|
0x00 : Success
|
|
0x0x : State machine return codes
|
|
0x1x : Configuration errors
|
|
0x2x : USB transport errors
|
|
0x3x : USB controller errors
|
|
0x4x : USB topology errors
|
|
0x5x : USB API errors
|
|
0x6x : USB Generic Class errors
|
|
0x7x : USB HID Class errors
|
|
0x8x : USB Audio Class errors
|
|
0x9x : USB CDC-ECM Class errors
|
|
...
|
|
0xfx : General errors
|
|
*/
|
|
|
|
#define UX_SUCCESS 0
|
|
|
|
#define UX_ERROR 0xff
|
|
#define UX_BUSY 0xfe
|
|
#define UX_TIMEOUT 0xfd
|
|
#define UX_REENTRY 0xfc
|
|
#define UX_INVALID_STATE 0xfb
|
|
#define UX_INVALID_PARAMETER 0xfa
|
|
#define UX_ABORTED 0xf9
|
|
#define UX_MATH_OVERFLOW 0xf8
|
|
#define UX_INVALID_BUILD_OPTION 0xf7
|
|
|
|
#define UX_TOO_MANY_DEVICES 0x11
|
|
#define UX_MEMORY_INSUFFICIENT 0x12
|
|
#define UX_NO_TD_AVAILABLE 0x13
|
|
#define UX_NO_ED_AVAILABLE 0x14
|
|
#define UX_SEMAPHORE_ERROR 0x15
|
|
#define UX_THREAD_ERROR 0x16
|
|
#define UX_MUTEX_ERROR 0x17
|
|
#define UX_EVENT_ERROR 0x18
|
|
#define UX_MEMORY_CORRUPTED 0x19
|
|
#define UX_MEMORY_ARRAY_FULL 0x1a
|
|
#define UX_FATAL_ERROR 0x1b
|
|
#define UX_ALREADY_ACTIVATED 0x1c
|
|
|
|
#define UX_TRANSFER_STALLED 0x21
|
|
#define UX_TRANSFER_NO_ANSWER 0x22
|
|
#define UX_TRANSFER_ERROR 0x23
|
|
#define UX_TRANSFER_MISSED_FRAME 0x24
|
|
#define UX_TRANSFER_NOT_READY 0x25
|
|
#define UX_TRANSFER_BUS_RESET 0x26
|
|
#define UX_TRANSFER_BUFFER_OVERFLOW 0x27
|
|
#define UX_TRANSFER_APPLICATION_RESET 0x28
|
|
#define UX_TRANSFER_DATA_LESS_THAN_EXPECTED 0x29
|
|
|
|
#define UX_PORT_RESET_FAILED 0x31
|
|
#define UX_CONTROLLER_INIT_FAILED 0x32
|
|
#define UX_CONTROLLER_DEAD 0x33
|
|
|
|
#define UX_NO_BANDWIDTH_AVAILABLE 0x41
|
|
#define UX_DESCRIPTOR_CORRUPTED 0x42
|
|
#define UX_OVER_CURRENT_CONDITION 0x43
|
|
#define UX_DEVICE_ENUMERATION_FAILURE 0x44
|
|
#define UX_TOO_MANY_HUB_PORTS 0x45
|
|
|
|
#define UX_DEVICE_HANDLE_UNKNOWN 0x50
|
|
#define UX_CONFIGURATION_HANDLE_UNKNOWN 0x51
|
|
#define UX_INTERFACE_HANDLE_UNKNOWN 0x52
|
|
#define UX_ENDPOINT_HANDLE_UNKNOWN 0x53
|
|
#define UX_FUNCTION_NOT_SUPPORTED 0x54
|
|
#define UX_CONTROLLER_UNKNOWN 0x55
|
|
#define UX_PORT_INDEX_UNKNOWN 0x56
|
|
#define UX_NO_CLASS_MATCH 0x57
|
|
#define UX_HOST_CLASS_ALREADY_INSTALLED 0x58
|
|
#define UX_HOST_CLASS_UNKNOWN 0x59
|
|
#define UX_CONNECTION_INCOMPATIBLE 0x5a
|
|
#define UX_HOST_CLASS_INSTANCE_UNKNOWN 0x5b
|
|
#define UX_TRANSFER_TIMEOUT 0x5c
|
|
#define UX_BUFFER_OVERFLOW 0x5d
|
|
#define UX_NO_ALTERNATE_SETTING 0x5e
|
|
#define UX_NO_DEVICE_CONNECTED 0x5f
|
|
|
|
#define UX_HOST_CLASS_PROTOCOL_ERROR 0x60
|
|
#define UX_HOST_CLASS_MEMORY_ERROR 0x61
|
|
#define UX_HOST_CLASS_MEDIA_NOT_SUPPORTED 0x62
|
|
#define UX_CLASS_MALFORMED_PACKET_RECEIVED_ERROR 0x63
|
|
|
|
#define UX_HOST_CLASS_HID_REPORT_OVERFLOW 0x70
|
|
#define UX_HOST_CLASS_HID_USAGE_OVERFLOW 0x71
|
|
#define UX_HOST_CLASS_HID_TAG_UNSUPPORTED 0x72
|
|
#define UX_HOST_CLASS_HID_PUSH_OVERFLOW 0x73
|
|
#define UX_HOST_CLASS_HID_POP_UNDERFLOW 0x74
|
|
#define UX_HOST_CLASS_HID_COLLECTION_OVERFLOW 0x75
|
|
#define UX_HOST_CLASS_HID_COLLECTION_UNDERFLOW 0x76
|
|
#define UX_HOST_CLASS_HID_MIN_MAX_ERROR 0x77
|
|
#define UX_HOST_CLASS_HID_DELIMITER_ERROR 0x78
|
|
#define UX_HOST_CLASS_HID_REPORT_ERROR 0x79
|
|
#define UX_HOST_CLASS_HID_PERIODIC_REPORT_ERROR 0x7A
|
|
#define UX_HOST_CLASS_HID_UNKNOWN 0x7B
|
|
|
|
#define UX_HOST_CLASS_AUDIO_WRONG_TYPE 0x80
|
|
#define UX_HOST_CLASS_AUDIO_WRONG_INTERFACE 0x81
|
|
#define UX_HOST_CLASS_AUDIO_WRONG_FREQUENCY 0x82
|
|
|
|
#define UX_CLASS_CDC_ECM_LINK_STATE_DOWN_ERROR 0x90
|
|
#define UX_CLASS_ETH_LINK_STATE_DOWN_ERROR 0x90
|
|
#define UX_CLASS_ETH_PACKET_POOL_ERROR 0x91
|
|
#define UX_CLASS_ETH_PACKET_ERROR 0x92
|
|
#define UX_CLASS_ETH_SIZE_ERROR 0x93
|
|
|
|
|
|
/* Define USBX HCD API function constants. */
|
|
|
|
#define UX_HCD_DISABLE_CONTROLLER 1
|
|
#define UX_HCD_GET_PORT_STATUS 2
|
|
#define UX_HCD_ENABLE_PORT 3
|
|
#define UX_HCD_DISABLE_PORT 4
|
|
#define UX_HCD_POWER_ON_PORT 5
|
|
#define UX_HCD_POWER_DOWN_PORT 6
|
|
#define UX_HCD_SUSPEND_PORT 7
|
|
#define UX_HCD_RESUME_PORT 8
|
|
#define UX_HCD_RESET_PORT 9
|
|
#define UX_HCD_GET_FRAME_NUMBER 10
|
|
#define UX_HCD_SET_FRAME_NUMBER 11
|
|
#define UX_HCD_TRANSFER_REQUEST 12
|
|
#define UX_HCD_TRANSFER_RUN 12
|
|
#define UX_HCD_TRANSFER_ABORT 13
|
|
#define UX_HCD_CREATE_ENDPOINT 14
|
|
#define UX_HCD_DESTROY_ENDPOINT 15
|
|
#define UX_HCD_RESET_ENDPOINT 16
|
|
#define UX_HCD_PROCESS_DONE_QUEUE 17
|
|
#define UX_HCD_TASKS_RUN 17
|
|
#define UX_HCD_UNINITIALIZE 18
|
|
|
|
/* Define USBX DCD API function constants. */
|
|
|
|
#define UX_DCD_DISABLE_CONTROLLER 1
|
|
#define UX_DCD_GET_PORT_STATUS 2
|
|
#define UX_DCD_ENABLE_PORT 3
|
|
#define UX_DCD_DISABLE_PORT 4
|
|
#define UX_DCD_POWER_ON_PORT 5
|
|
#define UX_DCD_POWER_DOWN_PORT 6
|
|
#define UX_DCD_SUSPEND_PORT 7
|
|
#define UX_DCD_RESUME_PORT 8
|
|
#define UX_DCD_RESET_PORT 9
|
|
#define UX_DCD_GET_FRAME_NUMBER 10
|
|
#define UX_DCD_SET_FRAME_NUMBER 11
|
|
#define UX_DCD_TRANSFER_REQUEST 12
|
|
#define UX_DCD_TRANSFER_RUN 12
|
|
#define UX_DCD_TRANSFER_ABORT 13
|
|
#define UX_DCD_CREATE_ENDPOINT 14
|
|
#define UX_DCD_DESTROY_ENDPOINT 15
|
|
#define UX_DCD_RESET_ENDPOINT 16
|
|
#define UX_DCD_SET_DEVICE_ADDRESS 17
|
|
#define UX_DCD_ISR_PENDING 18
|
|
#define UX_DCD_TASKS_RUN 18
|
|
#define UX_DCD_CHANGE_STATE 19
|
|
#define UX_DCD_STALL_ENDPOINT 20
|
|
#define UX_DCD_ENDPOINT_STATUS 21
|
|
|
|
|
|
/* Define USBX generic host controller constants. */
|
|
|
|
#define UX_HCD_STATUS_UNUSED 0
|
|
#define UX_HCD_STATUS_HALTED 1
|
|
#define UX_HCD_STATUS_OPERATIONAL 2
|
|
#define UX_HCD_STATUS_DEAD 3
|
|
|
|
/* Define USBX generic SLAVE controller constants. */
|
|
|
|
#define UX_DCD_STATUS_HALTED 0
|
|
#define UX_DCD_STATUS_OPERATIONAL 1
|
|
#define UX_DCD_STATUS_DEAD 2
|
|
|
|
/* Define USBX SLAVE controller VBUS constants. */
|
|
|
|
#define UX_DCD_VBUS_RESET 0
|
|
#define UX_DCD_VBUS_SET 1
|
|
|
|
/* Define USBX class interface constants. */
|
|
|
|
#define UX_HOST_CLASS_COMMAND_QUERY 1
|
|
#define UX_HOST_CLASS_COMMAND_ACTIVATE 2
|
|
#define UX_HOST_CLASS_COMMAND_DEACTIVATE 3
|
|
#define UX_HOST_CLASS_COMMAND_DESTROY 4
|
|
#define UX_HOST_CLASS_COMMAND_ACTIVATE_START UX_HOST_CLASS_COMMAND_ACTIVATE
|
|
#define UX_HOST_CLASS_COMMAND_ACTIVATE_WAIT 5
|
|
|
|
#define UX_SLAVE_CLASS_COMMAND_QUERY 1
|
|
#define UX_SLAVE_CLASS_COMMAND_ACTIVATE 2
|
|
#define UX_SLAVE_CLASS_COMMAND_DEACTIVATE 3
|
|
#define UX_SLAVE_CLASS_COMMAND_REQUEST 4
|
|
#define UX_SLAVE_CLASS_COMMAND_INITIALIZE 5
|
|
#define UX_SLAVE_CLASS_COMMAND_CHANGE 6
|
|
#define UX_SLAVE_CLASS_COMMAND_UNINITIALIZE 7
|
|
|
|
#define UX_HOST_CLASS_COMMAND_USAGE_PIDVID 1
|
|
#define UX_HOST_CLASS_COMMAND_USAGE_CSP 2
|
|
#define UX_HOST_CLASS_COMMAND_USAGE_DCSP 3
|
|
|
|
#define UX_HOST_CLASS_INSTANCE_FREE 0
|
|
#define UX_HOST_CLASS_INSTANCE_LIVE 1
|
|
#define UX_HOST_CLASS_INSTANCE_SHUTDOWN 2
|
|
#define UX_HOST_CLASS_INSTANCE_MOUNTING 3
|
|
|
|
|
|
/* Define USBX root HUB constants. */
|
|
|
|
#define UX_RH_ENUMERATION_RETRY 3
|
|
#define UX_RH_ENUMERATION_RETRY_DELAY 100
|
|
|
|
|
|
/* Define USBX PCI driver constants. */
|
|
|
|
#define UX_PCI_NB_FUNCTIONS 7
|
|
#define UX_PCI_NB_DEVICE 32
|
|
#define UX_PCI_NB_BUS 0xff
|
|
|
|
#define UX_PCI_CMD_IO_ENABLE 0x0001u
|
|
#define UX_PCI_CMD_MEM_ENABLE 0x0002u
|
|
#define UX_PCI_CMD_MASTER_ENABLE 0x0004u
|
|
#define UX_PCI_CMD_MONITOR_ENABLE 0x0008u
|
|
#define UX_PCI_CMD_MEM_WRITE_INV_ENABLE 0x0010u
|
|
#define UX_PCI_CMD_SNOOP_PALETTE_ENABLE 0x0020u
|
|
#define UX_PCI_CMD_PARITY_ERROR_ENABLE 0x0040u
|
|
#define UX_PCI_CMD_WAIT_CYCLE_CTRL_ENABLE 0x0080u
|
|
#define UX_PCI_CMD_SERR_ENABLE 0x0100u
|
|
#define UX_PCI_CMD_FBB_ENABLE 0x0200u
|
|
|
|
#define UX_PCI_CFG_CTRL_ADDRESS 0x0cf8u
|
|
#define UX_PCI_CFG_DATA_ADDRESS 0x0cfcu
|
|
|
|
#define UX_PCI_CFG_VENDOR_ID 0x00
|
|
#define UX_PCI_CFG_DEVICE_ID 0x02
|
|
#define UX_PCI_CFG_COMMAND 0x04
|
|
#define UX_PCI_CFG_STATUS 0x06
|
|
#define UX_PCI_CFG_REVISION 0x08
|
|
#define UX_PCI_CFG_PROGRAMMING_IF 0x09
|
|
#define UX_PCI_CFG_SUBCLASS 0x0a
|
|
#define UX_PCI_CFG_CLASS 0x0b
|
|
#define UX_PCI_CFG_CACHE_LINE_SIZE 0x0c
|
|
#define UX_PCI_CFG_LATENCY_TIMER 0x0d
|
|
#define UX_PCI_CFG_HEADER_TYPE 0x0e
|
|
#define UX_PCI_CFG_BIST 0x0f
|
|
#define UX_PCI_CFG_BASE_ADDRESS_0 0x10
|
|
#define UX_PCI_CFG_BASE_ADDRESS_1 0x14
|
|
#define UX_PCI_CFG_BASE_ADDRESS_2 0x18
|
|
#define UX_PCI_CFG_BASE_ADDRESS_3 0x1c
|
|
#define UX_PCI_CFG_BASE_ADDRESS_4 0x20
|
|
#define UX_PCI_CFG_BASE_ADDRESS_5 0x24
|
|
#define UX_PCI_CFG_CARDBUS_CIS 0x28
|
|
#define UX_PCI_CFG_SUB_VENDOR_ID 0x2c
|
|
#define UX_PCI_CFG_SUB_SYSTEM_ID 0x2e
|
|
#define UX_PCI_CFG_EXPANSION_ROM_ADDRESS 0x30
|
|
#define UX_PCI_CFG_RESERVED_0 0x34
|
|
#define UX_PCI_CFG_RESERVED_1 0x38
|
|
#define UX_PCI_CFG_INT_LINE 0x3c
|
|
#define UX_PCI_CFG_INT_PIN 0x3d
|
|
#define UX_PCI_CFG_MIN_GNT 0x3e
|
|
#define UX_PCI_CFG_MAX_LATENCY 0x3f
|
|
|
|
#define UX_PCI_CFG_SBRN 0x60
|
|
#define UX_PCI_CFG_FLADJ 0x61
|
|
|
|
/* Define DFU constants. */
|
|
#define UX_SYSTEM_DFU_STATE_APP_IDLE 0
|
|
#define UX_SYSTEM_DFU_STATE_APP_DETACH 1
|
|
#define UX_SYSTEM_DFU_STATE_DFU_IDLE 2
|
|
#define UX_SYSTEM_DFU_STATE_DFU_DNLOAD_SYNC 3
|
|
#define UX_SYSTEM_DFU_STATE_DFU_DNBUSY 4
|
|
#define UX_SYSTEM_DFU_STATE_DFU_DNLOAD_IDLE 5
|
|
#define UX_SYSTEM_DFU_STATE_DFU_MANIFEST_SYNC 6
|
|
#define UX_SYSTEM_DFU_STATE_DFU_MANIFEST 7
|
|
#define UX_SYSTEM_DFU_STATE_DFU_MANIFEST_WAIT_RESET 8
|
|
#define UX_SYSTEM_DFU_STATE_DFU_UPLOAD_IDLE 9
|
|
#define UX_SYSTEM_DFU_STATE_DFU_ERROR 10
|
|
|
|
/* Define basic class constants. */
|
|
|
|
#define UX_HOST_CLASS_PRINTER_NAME_LENGTH 64
|
|
|
|
|
|
/* Define USBX 2.0 TT Instance structure. */
|
|
|
|
typedef struct UX_HUB_TT_STRUCT
|
|
{
|
|
|
|
ULONG ux_hub_tt_port_mapping;
|
|
ULONG ux_hub_tt_max_bandwidth;
|
|
} UX_HUB_TT;
|
|
|
|
|
|
/* Define USBX Class calling command structure. */
|
|
|
|
typedef struct UX_HOST_CLASS_COMMAND_STRUCT
|
|
{
|
|
|
|
UINT ux_host_class_command_request;
|
|
VOID *ux_host_class_command_container;
|
|
VOID *ux_host_class_command_instance;
|
|
UINT ux_host_class_command_usage;
|
|
UINT ux_host_class_command_pid;
|
|
UINT ux_host_class_command_vid;
|
|
UINT ux_host_class_command_class;
|
|
UINT ux_host_class_command_subclass;
|
|
UINT ux_host_class_command_protocol;
|
|
UINT ux_host_class_command_iad_class;
|
|
UINT ux_host_class_command_iad_subclass;
|
|
UINT ux_host_class_command_iad_protocol;
|
|
|
|
struct UX_HOST_CLASS_STRUCT
|
|
*ux_host_class_command_class_ptr;
|
|
} UX_HOST_CLASS_COMMAND;
|
|
|
|
|
|
/* Define USBX Class container structure. */
|
|
|
|
typedef struct UX_HOST_CLASS_STRUCT
|
|
{
|
|
|
|
#if defined(UX_NAME_REFERENCED_BY_POINTER)
|
|
const UCHAR *ux_host_class_name;
|
|
#else
|
|
UCHAR ux_host_class_name[UX_MAX_CLASS_NAME_LENGTH + 1]; /* "+1" for string null-terminator */
|
|
#endif
|
|
|
|
#if defined(UX_HOST_STANDALONE)
|
|
UINT (*ux_host_class_task_function)(struct UX_HOST_CLASS_STRUCT *);
|
|
#endif
|
|
|
|
UINT ux_host_class_status;
|
|
UINT (*ux_host_class_entry_function) (struct UX_HOST_CLASS_COMMAND_STRUCT *);
|
|
VOID *ux_host_class_first_instance;
|
|
VOID *ux_host_class_client;
|
|
VOID *ux_host_class_media;
|
|
VOID *ux_host_class_ext;
|
|
|
|
} UX_HOST_CLASS;
|
|
|
|
|
|
/* Define USBX transfer request structure. */
|
|
|
|
typedef struct UX_TRANSFER_STRUCT
|
|
{
|
|
|
|
ULONG ux_transfer_request_status;
|
|
struct UX_ENDPOINT_STRUCT
|
|
*ux_transfer_request_endpoint;
|
|
UCHAR * ux_transfer_request_data_pointer;
|
|
ULONG ux_transfer_request_requested_length;
|
|
ULONG ux_transfer_request_actual_length;
|
|
UINT ux_transfer_request_type;
|
|
UINT ux_transfer_request_function;
|
|
UINT ux_transfer_request_value;
|
|
UINT ux_transfer_request_index;
|
|
VOID (*ux_transfer_request_completion_function) (struct UX_TRANSFER_STRUCT *);
|
|
VOID *ux_transfer_request_class_instance;
|
|
ULONG ux_transfer_request_maximum_length;
|
|
ULONG ux_transfer_request_timeout_value;
|
|
UINT ux_transfer_request_completion_code;
|
|
ULONG ux_transfer_request_packet_length;
|
|
struct UX_TRANSFER_STRUCT
|
|
*ux_transfer_request_next_transfer_request;
|
|
VOID *ux_transfer_request_user_specific;
|
|
#if !defined(UX_HOST_STANDALONE)
|
|
UX_SEMAPHORE ux_transfer_request_semaphore;
|
|
UX_THREAD *ux_transfer_request_thread_pending;
|
|
#else
|
|
UINT ux_transfer_request_state;
|
|
ULONG ux_transfer_request_time_start;
|
|
ULONG ux_transfer_request_flags;
|
|
struct UX_TRANSFER_STRUCT
|
|
*ux_transfer_request_next_pending;
|
|
#endif
|
|
} UX_TRANSFER;
|
|
|
|
#if defined(UX_HOST_STANDALONE)
|
|
#define UX_TRANSFER_STATE_RESET(tr) ((tr)->ux_transfer_request_state = UX_STATE_RESET)
|
|
#define UX_TRANSFER_STATE_IDLE(tr) ((tr)->ux_transfer_request_state = UX_STATE_IDLE)
|
|
#define UX_TRANSFER_STATE_IS_BUSY(tr) UX_STATE_IS_BUSY((tr)->ux_transfer_request_state)
|
|
#define UX_TRANSFER_STATE_IS_IDLE(tr) ((tr)->ux_transfer_request_state == UX_STATE_IDLE)
|
|
|
|
#define UX_TRANSFER_FLAGS_RESET(tr) ((tr)->ux_transfer_request_flags = 0)
|
|
#define UX_TRANSFER_FLAG_LOCK (0x1u << 0)
|
|
#define UX_TRANSFER_FLAG_AUTO_WAIT (0x1u << 1) /* Wait until transfer done. */
|
|
#define UX_TRANSFER_FLAG_AUTO_DEVICE_UNLOCK (0x1u << 2) /* In wait case, unlock device after transfer done. */
|
|
#endif
|
|
|
|
|
|
/* Define USBX Endpoint Descriptor structure. */
|
|
|
|
typedef struct UX_ENDPOINT_DESCRIPTOR_STRUCT
|
|
{
|
|
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
UCHAR bEndpointAddress;
|
|
UCHAR bmAttributes;
|
|
USHORT wMaxPacketSize;
|
|
UCHAR bInterval;
|
|
UCHAR _align_size[1];
|
|
} UX_ENDPOINT_DESCRIPTOR;
|
|
|
|
#define UX_ENDPOINT_DESCRIPTOR_ENTRIES 6
|
|
#define UX_ENDPOINT_DESCRIPTOR_LENGTH 7
|
|
|
|
|
|
/* Define USBX Endpoint Container structure. */
|
|
|
|
typedef struct UX_ENDPOINT_STRUCT
|
|
{
|
|
|
|
ULONG ux_endpoint;
|
|
ULONG ux_endpoint_state;
|
|
void *ux_endpoint_ed;
|
|
struct UX_ENDPOINT_DESCRIPTOR_STRUCT
|
|
ux_endpoint_descriptor;
|
|
struct UX_ENDPOINT_STRUCT
|
|
*ux_endpoint_next_endpoint;
|
|
struct UX_INTERFACE_STRUCT
|
|
*ux_endpoint_interface;
|
|
struct UX_DEVICE_STRUCT
|
|
*ux_endpoint_device;
|
|
struct UX_TRANSFER_STRUCT
|
|
ux_endpoint_transfer_request;
|
|
} UX_ENDPOINT;
|
|
|
|
|
|
/* Define USBX Device Descriptor structure. */
|
|
|
|
typedef struct UX_DEVICE_DESCRIPTOR_STRUCT
|
|
{
|
|
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
USHORT bcdUSB;
|
|
UCHAR bDeviceClass;
|
|
UCHAR bDeviceSubClass;
|
|
UCHAR bDeviceProtocol;
|
|
UCHAR bMaxPacketSize0;
|
|
USHORT idVendor;
|
|
USHORT idProduct;
|
|
USHORT bcdDevice;
|
|
UCHAR iManufacturer;
|
|
UCHAR iProduct;
|
|
UCHAR iSerialNumber;
|
|
UCHAR bNumConfigurations;
|
|
UCHAR _align_size[2];
|
|
} UX_DEVICE_DESCRIPTOR;
|
|
|
|
#define UX_DEVICE_DESCRIPTOR_ENTRIES 14
|
|
#define UX_DEVICE_DESCRIPTOR_LENGTH 18
|
|
|
|
|
|
/* Define USBX Device Qualifier Descriptor structure. */
|
|
|
|
typedef struct UX_DEVICE_QUALIFIER_DESCRIPTOR_STRUCT
|
|
{
|
|
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
USHORT bcdUSB;
|
|
UCHAR bDeviceClass;
|
|
UCHAR bDeviceSubClass;
|
|
UCHAR bDeviceProtocol;
|
|
UCHAR bMaxPacketSize0;
|
|
UCHAR bNumConfigurations;
|
|
UCHAR bReserved;
|
|
UCHAR _align_size[2];
|
|
} UX_DEVICE_QUALIFIER_DESCRIPTOR;
|
|
|
|
#define UX_DEVICE_QUALIFIER_DESCRIPTOR_ENTRIES 9
|
|
#define UX_DEVICE_QUALIFIER_DESCRIPTOR_LENGTH 10
|
|
|
|
|
|
/* Define USBX Other Speed Descriptor structure. */
|
|
|
|
typedef struct UX_OTHER_SPEED_DESCRIPTOR_STRUCT
|
|
{
|
|
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
USHORT wTotalLength;
|
|
UCHAR bNumInterfaces;
|
|
UCHAR bConfigurationValue;
|
|
UCHAR iConfiguration;
|
|
UCHAR bmAttributes;
|
|
ULONG MaxPower;
|
|
} UX_OTHER_SPEED_DESCRIPTOR;
|
|
|
|
#define UX_OTHER_SPEED_DESCRIPTOR_ENTRIES 8
|
|
#define UX_OTHER_SPEED_DESCRIPTOR_LENGTH 9
|
|
|
|
|
|
/* Define USBX OTG Descriptor structure. */
|
|
|
|
typedef struct UX_OTG_DESCRIPTOR_STRUCT
|
|
{
|
|
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
UCHAR bmAttributes;
|
|
UCHAR _align_bcdOTG[1];
|
|
USHORT bcdOTG;
|
|
UCHAR _algin_size[2];
|
|
} UX_OTG_DESCRIPTOR;
|
|
|
|
#define UX_OTG_DESCRIPTOR_ENTRIES 4
|
|
#define UX_OTG_DESCRIPTOR_LENGTH 5
|
|
|
|
|
|
/* Define USBX Interface Association Descriptor structure. */
|
|
|
|
typedef struct UX_INTERFACE_ASSOCIATION_DESCRIPTOR_STRUCT
|
|
{
|
|
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
UCHAR bFirstInterface;
|
|
UCHAR bInterfaceCount;
|
|
UCHAR bFunctionClass;
|
|
UCHAR bFunctionSubClass;
|
|
UCHAR bFunctionProtocol;
|
|
UCHAR iFunction;
|
|
} UX_INTERFACE_ASSOCIATION_DESCRIPTOR;
|
|
|
|
#define UX_INTERFACE_ASSOCIATION_DESCRIPTOR_ENTRIES 8
|
|
#define UX_INTERFACE_ASSOCIATION_DESCRIPTOR_LENGTH 8
|
|
|
|
|
|
/* Define USBX Device Container structure. */
|
|
|
|
typedef struct UX_DEVICE_STRUCT
|
|
{
|
|
|
|
ULONG ux_device_handle;
|
|
ULONG ux_device_type;
|
|
ULONG ux_device_state;
|
|
ULONG ux_device_address;
|
|
ULONG ux_device_speed;
|
|
ULONG ux_device_power_source;
|
|
struct UX_CONFIGURATION_STRUCT
|
|
*ux_device_current_configuration;
|
|
UCHAR *ux_device_packed_configuration;
|
|
ULONG ux_device_packed_configuration_keep_count;
|
|
#if !defined(UX_HOST_STANDALONE)
|
|
UX_SEMAPHORE ux_device_protection_semaphore;
|
|
#endif
|
|
struct UX_HOST_CLASS_STRUCT
|
|
*ux_device_class;
|
|
VOID *ux_device_class_instance;
|
|
struct UX_CONFIGURATION_STRUCT
|
|
*ux_device_first_configuration;
|
|
struct UX_DEVICE_DESCRIPTOR_STRUCT
|
|
ux_device_descriptor;
|
|
struct UX_ENDPOINT_STRUCT
|
|
ux_device_control_endpoint;
|
|
ULONG ux_device_port_location;
|
|
#if UX_MAX_HCD > 1
|
|
struct UX_HCD_STRUCT
|
|
*ux_device_hcd;
|
|
#endif
|
|
#if UX_MAX_DEVICES > 1
|
|
struct UX_DEVICE_STRUCT
|
|
*ux_device_parent;
|
|
ULONG ux_device_max_power;
|
|
struct UX_HUB_TT_STRUCT
|
|
ux_device_hub_tt[UX_MAX_TT];
|
|
#endif
|
|
|
|
#if defined(UX_HOST_STANDALONE)
|
|
ULONG ux_device_flags;
|
|
|
|
struct UX_DEVICE_STRUCT
|
|
*ux_device_enum_next;
|
|
struct UX_TRANSFER_STRUCT
|
|
*ux_device_enum_trans;
|
|
union {
|
|
struct UX_DEVICE_STRUCT
|
|
*device;
|
|
struct UX_CONFIGURATION_STRUCT
|
|
*configuration;
|
|
struct UX_INTERFACE_STRUCT
|
|
*interface;
|
|
VOID *ptr;
|
|
} ux_device_enum_inst;
|
|
|
|
ULONG ux_device_enum_wait_start;
|
|
ULONG ux_device_enum_wait_ms;
|
|
|
|
UCHAR ux_device_enum_state;
|
|
UCHAR ux_device_dbg_state;
|
|
UCHAR ux_device_enum_next_state;
|
|
UCHAR ux_device_enum_retry;
|
|
UCHAR ux_device_enum_port_status;
|
|
UCHAR ux_device_enum_index;
|
|
UCHAR reserved[2];
|
|
ULONG ux_device_dbg_state_count;
|
|
#endif
|
|
|
|
} UX_DEVICE;
|
|
|
|
#if defined(UX_HOST_STANDALONE)
|
|
#define UX_DEVICE_FLAG_LOCK 0x01u
|
|
#define UX_DEVICE_FLAG_RESET 0x02u
|
|
#define UX_DEVICE_FLAG_ENUM 0x04u
|
|
#define UX_DEVICE_FLAG_PROTECT 0x08u
|
|
#endif
|
|
|
|
#if UX_MAX_HCD > 1
|
|
#define UX_DEVICE_HCD_GET(d) ((d)->ux_device_hcd)
|
|
#define UX_DEVICE_HCD_SET(d,h) do { (d)->ux_device_hcd = (h); } while(0)
|
|
#define UX_DEVICE_HCD_MATCH(d,h) ((d)->ux_device_hcd == (h))
|
|
#else
|
|
#define UX_DEVICE_HCD_GET(d) (_ux_system_host->ux_system_host_hcd_array)
|
|
#define UX_DEVICE_HCD_SET(d,h)
|
|
#define UX_DEVICE_HCD_MATCH(d,h) (_ux_system_host->ux_system_host_hcd_array == (h))
|
|
#endif
|
|
|
|
|
|
#if UX_MAX_DEVICES > 1
|
|
#define UX_DEVICE_PARENT_GET(d) ((d)->ux_device_parent)
|
|
#define UX_DEVICE_PARENT_SET(d,p) do { (d)->ux_device_parent = (p); } while(0)
|
|
#define UX_DEVICE_PARENT_MATCH(d,p) ((d)->ux_device_parent == (p))
|
|
#define UX_DEVICE_PARENT_IS_HUB(d) ((d)->ux_device_parent != UX_NULL)
|
|
#define UX_DEVICE_PARENT_IS_ROOTHUB(d) ((d)->ux_device_parent == UX_NULL)
|
|
#define UX_DEVICE_MAX_POWER_GET(d) ((d)->ux_device_max_power)
|
|
#define UX_DEVICE_MAX_POWER_SET(d,p) do {(d)->ux_device_max_power = (p); } while(0)
|
|
#else
|
|
#define UX_DEVICE_PARENT_GET(d) (UX_NULL)
|
|
#define UX_DEVICE_PARENT_SET(d,p) UX_PARAMETER_NOT_USED(p)
|
|
#define UX_DEVICE_PARENT_MATCH(d,p) ((p) == UX_NULL)
|
|
#define UX_DEVICE_PARENT_IS_HUB(d) (UX_FALSE)
|
|
#define UX_DEVICE_PARENT_IS_ROOTHUB(d) (UX_TRUE)
|
|
#define UX_DEVICE_MAX_POWER_GET(d) (UX_MAX_SELF_POWER)
|
|
#define UX_DEVICE_MAX_POWER_SET(d,p) UX_PARAMETER_NOT_USED(p)
|
|
#endif
|
|
#define UX_DEVICE_PORT_LOCATION_GET(d) ((d)->ux_device_port_location)
|
|
#define UX_DEVICE_PORT_LOCATION_SET(d,l) do { (d)->ux_device_port_location = (l); } while(0)
|
|
#define UX_DEVICE_PORT_LOCATION_MATCH(d,l) ((d)->ux_device_port_location == (l))
|
|
|
|
|
|
/* Define USBX Configuration Descriptor structure. */
|
|
|
|
typedef struct UX_CONFIGURATION_DESCRIPTOR_STRUCT
|
|
{
|
|
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
USHORT wTotalLength;
|
|
UCHAR bNumInterfaces;
|
|
UCHAR bConfigurationValue;
|
|
UCHAR iConfiguration;
|
|
UCHAR bmAttributes;
|
|
ULONG MaxPower;
|
|
} UX_CONFIGURATION_DESCRIPTOR;
|
|
|
|
|
|
#define UX_CONFIGURATION_DESCRIPTOR_ENTRIES 8
|
|
#define UX_CONFIGURATION_DESCRIPTOR_LENGTH 9
|
|
|
|
|
|
/* Define USBX Configuration Container structure. */
|
|
|
|
typedef struct UX_CONFIGURATION_STRUCT
|
|
{
|
|
|
|
ULONG ux_configuration_handle;
|
|
ULONG ux_configuration_state;
|
|
ULONG ux_configuration_otg_capabilities;
|
|
struct UX_CONFIGURATION_DESCRIPTOR_STRUCT
|
|
ux_configuration_descriptor;
|
|
struct UX_INTERFACE_STRUCT
|
|
*ux_configuration_first_interface;
|
|
struct UX_CONFIGURATION_STRUCT
|
|
*ux_configuration_next_configuration;
|
|
struct UX_DEVICE_STRUCT
|
|
*ux_configuration_device;
|
|
ULONG ux_configuration_iad_class;
|
|
ULONG ux_configuration_iad_subclass;
|
|
ULONG ux_configuration_iad_protocol;
|
|
} UX_CONFIGURATION;
|
|
|
|
#define UX_HOST_STACK_CONFIGURATION_INSTANCE_CREATE_ALL 0 /* Default: all things created. */
|
|
#define UX_HOST_STACK_CONFIGURATION_INSTANCE_CREATE_OWNED 1 /* Owned: class owned things created. */
|
|
#ifndef UX_HOST_STACK_CONFIGURATION_INSTANCE_CREATE_CONTROL
|
|
#define UX_HOST_STACK_CONFIGURATION_INSTANCE_CREATE_CONTROL UX_HOST_STACK_CONFIGURATION_INSTANCE_CREATE_ALL
|
|
#endif
|
|
|
|
|
|
/* Define USBX Interface Descriptor structure. */
|
|
|
|
typedef struct UX_INTERFACE_DESCRIPTOR_STRUCT
|
|
{
|
|
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
UCHAR bInterfaceNumber;
|
|
UCHAR bAlternateSetting;
|
|
UCHAR bNumEndpoints;
|
|
UCHAR bInterfaceClass;
|
|
UCHAR bInterfaceSubClass;
|
|
UCHAR bInterfaceProtocol;
|
|
UCHAR iInterface;
|
|
UCHAR _align_size[3];
|
|
} UX_INTERFACE_DESCRIPTOR;
|
|
|
|
#define UX_INTERFACE_DESCRIPTOR_ENTRIES 9
|
|
#define UX_INTERFACE_DESCRIPTOR_LENGTH 9
|
|
|
|
|
|
/* Define USBX Interface Container structure. */
|
|
|
|
typedef struct UX_INTERFACE_STRUCT
|
|
{
|
|
|
|
ULONG ux_interface_handle;
|
|
ULONG ux_interface_state;
|
|
UINT ux_interface_current_alternate_setting;
|
|
struct UX_INTERFACE_DESCRIPTOR_STRUCT
|
|
ux_interface_descriptor;
|
|
struct UX_HOST_CLASS_STRUCT
|
|
*ux_interface_class;
|
|
VOID *ux_interface_class_instance;
|
|
struct UX_ENDPOINT_STRUCT
|
|
*ux_interface_first_endpoint;
|
|
struct UX_INTERFACE_STRUCT
|
|
*ux_interface_next_interface;
|
|
struct UX_CONFIGURATION_STRUCT
|
|
*ux_interface_configuration;
|
|
ULONG ux_interface_iad_class;
|
|
ULONG ux_interface_iad_subclass;
|
|
ULONG ux_interface_iad_protocol;
|
|
|
|
} UX_INTERFACE;
|
|
|
|
|
|
/* Define USBX String Descriptor structure. */
|
|
|
|
typedef struct UX_STRING_DESCRIPTOR_STRUCT
|
|
{
|
|
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
UCHAR bString[2];
|
|
} UX_STRING_DESCRIPTOR;
|
|
|
|
#define UX_STRING_DESCRIPTOR_ENTRIES 3
|
|
#define UX_STRING_DESCRIPTOR_LENGTH 4
|
|
|
|
|
|
/* Define USBX BOS Descriptor structure. */
|
|
|
|
typedef struct UX_BOS_DESCRIPTOR_STRUCT
|
|
{
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
USHORT wTotalLength;
|
|
UCHAR bNumDeviceCaps;
|
|
UCHAR _align_size[3];
|
|
} UX_BOS_DESCRIPTOR;
|
|
|
|
#define UX_BOS_DESCRIPTOR_ENTRIES 4
|
|
#define UX_BOS_DESCRIPTOR_LENGTH 5
|
|
|
|
|
|
/* Define USBX USB 2.0 Descriptor structure. */
|
|
|
|
typedef struct UX_USB_2_0_EXTENSION_DESCRIPTOR_STRUCT
|
|
{
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
UCHAR bDevCapabilityType;
|
|
UCHAR _align_bmAttributes[1];
|
|
ULONG bmAttributes;
|
|
} UX_USB_2_0_EXTENSION_DESCRIPTOR;
|
|
|
|
#define UX_USB_2_0_EXTENSION_DESCRIPTOR_ENTRIES 4
|
|
#define UX_USB_2_0_EXTENSION_DESCRIPTOR_LENGTH 7
|
|
|
|
|
|
/* Define USBX Container ID Descriptor structure. */
|
|
|
|
typedef struct UX_CONTAINER_ID_DESCRIPTOR_STRUCT
|
|
{
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
UCHAR bDevCapabilityType;
|
|
UCHAR bReserved;
|
|
ULONG ContainerID[4];
|
|
} UX_CONTAINER_ID_DESCRIPTOR;
|
|
|
|
#define UX_CONTAINER_ID_DESCRIPTOR_ENTRIES 8
|
|
#define UX_CONTAINER_ID_DESCRIPTOR_LENGTH 20
|
|
|
|
|
|
/* Define USBX DFU functional descriptor. */
|
|
|
|
typedef struct UX_DFU_FUNCTIONAL_DESCRIPTOR_STRUCT
|
|
{
|
|
|
|
UCHAR bLength;
|
|
UCHAR bDescriptorType;
|
|
UCHAR bmAttributes;
|
|
UCHAR _align_wDetachTimeOut[1];
|
|
USHORT wDetachTimeOut;
|
|
USHORT wTransferSize;
|
|
USHORT bcdDFUVersion;
|
|
UCHAR _align_size[2];
|
|
} UX_DFU_FUNCTIONAL_DESCRIPTOR;
|
|
|
|
#define UX_DFU_FUNCTIONAL_DESCRIPTOR_ENTRIES 6
|
|
#define UX_DFU_FUNCTIONAL_DESCRIPTOR_LENGTH 9
|
|
|
|
|
|
/* Define USBX Host Controller structure. */
|
|
|
|
typedef struct UX_HCD_STRUCT
|
|
{
|
|
|
|
#if defined(UX_NAME_REFERENCED_BY_POINTER)
|
|
const UCHAR *ux_hcd_name;
|
|
#else
|
|
UCHAR ux_hcd_name[UX_MAX_HCD_NAME_LENGTH + 1]; /* "+1" for string null-terminator */
|
|
#endif
|
|
|
|
UINT ux_hcd_status;
|
|
UINT ux_hcd_controller_type;
|
|
UINT ux_hcd_irq;
|
|
UINT ux_hcd_nb_root_hubs;
|
|
UINT ux_hcd_root_hub_signal[UX_MAX_ROOTHUB_PORT];
|
|
UINT ux_hcd_nb_devices;
|
|
UINT ux_hcd_thread_signal;
|
|
ULONG ux_hcd_rh_device_connection;
|
|
ULONG ux_hcd_io;
|
|
UINT (*ux_hcd_entry_function) (struct UX_HCD_STRUCT *, UINT, VOID *);
|
|
void *ux_hcd_controller_hardware;
|
|
|
|
#if defined(UX_OTG_SUPPORT)
|
|
UINT ux_hcd_otg_capabilities;
|
|
#endif
|
|
|
|
#if UX_MAX_DEVICES > 1
|
|
UCHAR ux_hcd_address[16];
|
|
UINT ux_hcd_power_switch;
|
|
ULONG ux_hcd_available_bandwidth;
|
|
ULONG ux_hcd_version;
|
|
#endif
|
|
|
|
#if defined(UX_HOST_STANDALONE)
|
|
ULONG ux_hcd_flags;
|
|
#endif
|
|
} UX_HCD;
|
|
|
|
|
|
/* Define USBX Device Transfer Request structure. */
|
|
|
|
typedef struct UX_SLAVE_TRANSFER_STRUCT
|
|
{
|
|
|
|
ULONG ux_slave_transfer_request_status;
|
|
ULONG ux_slave_transfer_request_type;
|
|
struct UX_SLAVE_ENDPOINT_STRUCT
|
|
*ux_slave_transfer_request_endpoint;
|
|
UCHAR *ux_slave_transfer_request_data_pointer;
|
|
UCHAR *ux_slave_transfer_request_current_data_pointer;
|
|
ULONG ux_slave_transfer_request_requested_length;
|
|
ULONG ux_slave_transfer_request_actual_length;
|
|
ULONG ux_slave_transfer_request_in_transfer_length;
|
|
ULONG ux_slave_transfer_request_transfer_length;
|
|
ULONG ux_slave_transfer_request_completion_code;
|
|
ULONG ux_slave_transfer_request_phase;
|
|
VOID (*ux_slave_transfer_request_completion_function) (struct UX_SLAVE_TRANSFER_STRUCT *);
|
|
#if defined(UX_DEVICE_STANDALONE)
|
|
ULONG ux_slave_transfer_request_state;
|
|
#else
|
|
UX_SEMAPHORE ux_slave_transfer_request_semaphore;
|
|
#endif
|
|
ULONG ux_slave_transfer_request_timeout;
|
|
ULONG ux_slave_transfer_request_force_zlp;
|
|
UCHAR ux_slave_transfer_request_setup[UX_SETUP_SIZE];
|
|
ULONG ux_slave_transfer_request_status_phase_ignore;
|
|
} UX_SLAVE_TRANSFER;
|
|
|
|
#if defined(UX_DEVICE_STANDALONE)
|
|
#define UX_SLAVE_TRANSFER_STATE_RESET(tr) ((tr)->ux_slave_transfer_request_state = UX_STATE_RESET)
|
|
#endif
|
|
|
|
|
|
/* Define USBX Device Controller Endpoint structure. */
|
|
|
|
typedef struct UX_SLAVE_ENDPOINT_STRUCT
|
|
{
|
|
|
|
ULONG ux_slave_endpoint_status;
|
|
ULONG ux_slave_endpoint_state;
|
|
void *ux_slave_endpoint_ed;
|
|
struct UX_ENDPOINT_DESCRIPTOR_STRUCT
|
|
ux_slave_endpoint_descriptor;
|
|
struct UX_SLAVE_ENDPOINT_STRUCT
|
|
*ux_slave_endpoint_next_endpoint;
|
|
struct UX_SLAVE_INTERFACE_STRUCT
|
|
*ux_slave_endpoint_interface;
|
|
struct UX_SLAVE_DEVICE_STRUCT
|
|
*ux_slave_endpoint_device;
|
|
struct UX_SLAVE_TRANSFER_STRUCT
|
|
ux_slave_endpoint_transfer_request;
|
|
} UX_SLAVE_ENDPOINT;
|
|
|
|
|
|
/* Define USBX Device Controller Interface structure. */
|
|
|
|
typedef struct UX_SLAVE_INTERFACE_STRUCT
|
|
{
|
|
ULONG ux_slave_interface_status;
|
|
struct UX_SLAVE_CLASS_STRUCT
|
|
*ux_slave_interface_class;
|
|
VOID *ux_slave_interface_class_instance;
|
|
|
|
struct UX_INTERFACE_DESCRIPTOR_STRUCT
|
|
ux_slave_interface_descriptor;
|
|
struct UX_SLAVE_INTERFACE_STRUCT
|
|
*ux_slave_interface_next_interface;
|
|
struct UX_SLAVE_ENDPOINT_STRUCT
|
|
*ux_slave_interface_first_endpoint;
|
|
} UX_SLAVE_INTERFACE;
|
|
|
|
|
|
/* Define USBX Device Controller structure. */
|
|
|
|
typedef struct UX_SLAVE_DEVICE_STRUCT
|
|
{
|
|
|
|
ULONG ux_slave_device_state;
|
|
struct UX_DEVICE_DESCRIPTOR_STRUCT
|
|
ux_slave_device_descriptor;
|
|
struct UX_SLAVE_ENDPOINT_STRUCT
|
|
ux_slave_device_control_endpoint;
|
|
ULONG ux_slave_device_configuration_selected;
|
|
struct UX_CONFIGURATION_DESCRIPTOR_STRUCT
|
|
ux_slave_device_configuration_descriptor;
|
|
struct UX_SLAVE_INTERFACE_STRUCT
|
|
*ux_slave_device_first_interface;
|
|
struct UX_SLAVE_INTERFACE_STRUCT
|
|
*ux_slave_device_interfaces_pool;
|
|
ULONG ux_slave_device_interfaces_pool_number;
|
|
struct UX_SLAVE_ENDPOINT_STRUCT
|
|
*ux_slave_device_endpoints_pool;
|
|
ULONG ux_slave_device_endpoints_pool_number;
|
|
ULONG ux_slave_device_power_state;
|
|
|
|
} UX_SLAVE_DEVICE;
|
|
|
|
|
|
/* Define USBX Device Controller structure. */
|
|
|
|
typedef struct UX_SLAVE_DCD_STRUCT
|
|
{
|
|
|
|
UINT ux_slave_dcd_status;
|
|
UINT ux_slave_dcd_controller_type;
|
|
UINT ux_slave_dcd_otg_capabilities;
|
|
UINT ux_slave_dcd_irq;
|
|
ULONG ux_slave_dcd_io;
|
|
ULONG ux_slave_dcd_device_address;
|
|
UINT (*ux_slave_dcd_function) (struct UX_SLAVE_DCD_STRUCT *,UINT, VOID *);
|
|
void *ux_slave_dcd_controller_hardware;
|
|
|
|
#if defined(UX_DEVICE_STANDALONE)
|
|
UINT (*ux_device_dcd_task_function)(struct UX_SLAVE_DCD_STRUCT *);
|
|
#endif
|
|
|
|
} UX_SLAVE_DCD;
|
|
|
|
/* Define USBX Device Class Command container structure. */
|
|
|
|
typedef struct UX_SLAVE_CLASS_COMMAND_STRUCT
|
|
{
|
|
|
|
UINT ux_slave_class_command_request;
|
|
VOID *ux_slave_class_command_container;
|
|
VOID *ux_slave_class_command_interface;
|
|
UINT ux_slave_class_command_pid;
|
|
UINT ux_slave_class_command_vid;
|
|
UINT ux_slave_class_command_class;
|
|
UINT ux_slave_class_command_subclass;
|
|
UINT ux_slave_class_command_protocol;
|
|
struct UX_SLAVE_CLASS_STRUCT
|
|
*ux_slave_class_command_class_ptr;
|
|
VOID *ux_slave_class_command_parameter;
|
|
VOID *ux_slave_class_command_interface_number;
|
|
|
|
} UX_SLAVE_CLASS_COMMAND;
|
|
|
|
|
|
/* Define USBX Device Class container structure. */
|
|
|
|
typedef struct UX_SLAVE_CLASS_STRUCT
|
|
{
|
|
|
|
#if defined(UX_NAME_REFERENCED_BY_POINTER)
|
|
const UCHAR *ux_slave_class_name;
|
|
#else
|
|
UCHAR ux_slave_class_name[UX_MAX_CLASS_NAME_LENGTH + 1]; /* "+1" for string null-terminator */
|
|
#endif
|
|
|
|
UINT ux_slave_class_status;
|
|
UINT (*ux_slave_class_entry_function) (struct UX_SLAVE_CLASS_COMMAND_STRUCT *);
|
|
VOID *ux_slave_class_instance;
|
|
VOID *ux_slave_class_client;
|
|
#if !defined(UX_DEVICE_STANDALONE)
|
|
UX_THREAD ux_slave_class_thread;
|
|
VOID *ux_slave_class_thread_stack;
|
|
#else
|
|
UINT (*ux_slave_class_task_function)(VOID *class_instance);
|
|
#endif
|
|
VOID *ux_slave_class_interface_parameter;
|
|
ULONG ux_slave_class_interface_number;
|
|
ULONG ux_slave_class_configuration_number;
|
|
struct UX_SLAVE_INTERFACE_STRUCT
|
|
*ux_slave_class_interface;
|
|
|
|
} UX_SLAVE_CLASS;
|
|
|
|
/* Define USBX Memory Management structure. */
|
|
|
|
typedef struct UX_MEMORY_BLOCK_STRUCT
|
|
{
|
|
|
|
ULONG ux_memory_block_size;
|
|
ULONG ux_memory_block_status;
|
|
struct UX_MEMORY_BLOCK_STRUCT
|
|
*ux_memory_block_next;
|
|
struct UX_MEMORY_BLOCK_STRUCT
|
|
*ux_memory_block_previous;
|
|
} UX_MEMORY_BLOCK;
|
|
|
|
|
|
typedef struct UX_SYSTEM_STRUCT
|
|
{
|
|
|
|
UX_MEMORY_BLOCK *ux_system_regular_memory_pool_start;
|
|
ULONG ux_system_regular_memory_pool_size;
|
|
ULONG ux_system_regular_memory_pool_free;
|
|
UX_MEMORY_BLOCK *ux_system_cache_safe_memory_pool_start;
|
|
ULONG ux_system_cache_safe_memory_pool_size;
|
|
ULONG ux_system_cache_safe_memory_pool_free;
|
|
#ifdef UX_ENABLE_MEMORY_STATISTICS
|
|
UCHAR *ux_system_regular_memory_pool_base;
|
|
ALIGN_TYPE ux_system_regular_memory_pool_max_start_offset;
|
|
ALIGN_TYPE ux_system_regular_memory_pool_min_free;
|
|
UCHAR *ux_system_cache_safe_memory_pool_base;
|
|
ALIGN_TYPE ux_system_cache_safe_memory_pool_max_start_offset;
|
|
ALIGN_TYPE ux_system_cache_safe_memory_pool_min_free;
|
|
ULONG ux_system_regular_memory_pool_alloc_count;
|
|
ULONG ux_system_regular_memory_pool_alloc_total;
|
|
ULONG ux_system_regular_memory_pool_alloc_max_count;
|
|
ULONG ux_system_regular_memory_pool_alloc_max_total;
|
|
ULONG ux_system_cache_safe_memory_pool_alloc_count;
|
|
ULONG ux_system_cache_safe_memory_pool_alloc_total;
|
|
ULONG ux_system_cache_safe_memory_pool_alloc_max_count;
|
|
ULONG ux_system_cache_safe_memory_pool_alloc_max_total;
|
|
#endif
|
|
|
|
UINT ux_system_thread_lowest_priority;
|
|
#if !defined(UX_STANDALONE)
|
|
UX_MUTEX ux_system_mutex;
|
|
#endif
|
|
|
|
#ifndef UX_DISABLE_ERROR_HANDLER
|
|
UINT ux_system_last_error;
|
|
UINT ux_system_error_count;
|
|
VOID (*ux_system_error_callback_function) (UINT system_level, UINT system_context, UINT error_code);
|
|
#endif
|
|
|
|
#ifdef UX_ENABLE_DEBUG_LOG
|
|
ULONG ux_system_debug_code;
|
|
ULONG ux_system_debug_count;
|
|
UCHAR *ux_system_debug_log_buffer;
|
|
UCHAR *ux_system_debug_log_head;
|
|
UCHAR *ux_system_debug_log_tail;
|
|
ULONG ux_system_debug_log_size;
|
|
VOID (*ux_system_debug_callback_function) (UCHAR *debug_message, ULONG debug_value);
|
|
#endif
|
|
} UX_SYSTEM;
|
|
|
|
|
|
/* Define USBX System Host Data structure. */
|
|
|
|
typedef struct UX_SYSTEM_HOST_STRUCT
|
|
{
|
|
|
|
#if UX_MAX_CLASS_DRIVER > 1
|
|
UINT ux_system_host_max_class;
|
|
#endif
|
|
UX_HOST_CLASS *ux_system_host_class_array;
|
|
|
|
#if UX_MAX_HCD > 1
|
|
UINT ux_system_host_max_hcd;
|
|
#endif
|
|
UINT ux_system_host_registered_hcd;
|
|
UX_HCD *ux_system_host_hcd_array;
|
|
|
|
#if UX_MAX_DEVICES > 1
|
|
ULONG ux_system_host_max_devices;
|
|
#endif
|
|
UX_DEVICE *ux_system_host_device_array;
|
|
|
|
ULONG ux_system_host_max_ed;
|
|
ULONG ux_system_host_max_td;
|
|
ULONG ux_system_host_max_iso_td;
|
|
|
|
#if !defined(UX_HOST_STANDALONE)
|
|
UCHAR *ux_system_host_enum_thread_stack;
|
|
UX_THREAD ux_system_host_enum_thread;
|
|
UX_SEMAPHORE ux_system_host_enum_semaphore;
|
|
#endif
|
|
|
|
#if UX_MAX_DEVICES > 1
|
|
VOID (*ux_system_host_enum_hub_function) (VOID);
|
|
#endif
|
|
|
|
#if !defined(UX_HOST_STANDALONE)
|
|
UCHAR *ux_system_host_hcd_thread_stack;
|
|
UX_THREAD ux_system_host_hcd_thread;
|
|
UX_SEMAPHORE ux_system_host_hcd_semaphore;
|
|
#endif
|
|
|
|
#if defined(UX_OTG_SUPPORT) && !defined(UX_OTG_STANDALONE)
|
|
UCHAR *ux_system_host_hnp_polling_thread_stack;
|
|
UX_THREAD ux_system_host_hnp_polling_thread;
|
|
#endif
|
|
|
|
#if defined(UX_HOST_STANDALONE)
|
|
struct UX_DEVICE_STRUCT
|
|
*ux_system_host_enum_device;
|
|
struct UX_DEVICE_STRUCT
|
|
*ux_system_host_enum_lock;
|
|
struct UX_TRANSFER_STRUCT
|
|
*ux_system_host_pending_transfers;
|
|
#if UX_MAX_DEVICES > 1
|
|
struct UX_HOST_CLASS_HUB_STRUCT
|
|
*ux_system_host_hub_list;
|
|
#endif
|
|
#endif
|
|
|
|
UINT (*ux_system_host_change_function) (ULONG, UX_HOST_CLASS *, VOID *);
|
|
} UX_SYSTEM_HOST;
|
|
|
|
#if UX_MAX_CLASS_DRIVER > 1
|
|
#define UX_SYSTEM_HOST_MAX_CLASS_GET() (_ux_system_host->ux_system_host_max_class)
|
|
#define UX_SYSTEM_HOST_MAX_CLASS_SET(n) do { _ux_system_host->ux_system_host_max_class = (n); } while(0)
|
|
#else
|
|
#define UX_SYSTEM_HOST_MAX_CLASS_GET() (1)
|
|
#define UX_SYSTEM_HOST_MAX_CLASS_SET(n) UX_PARAMETER_NOT_USED(n)
|
|
#endif
|
|
|
|
#if UX_MAX_HCD > 1
|
|
#define UX_SYSTEM_HOST_MAX_HCD_GET() (_ux_system_host->ux_system_host_max_hcd)
|
|
#define UX_SYSTEM_HOST_MAX_HCD_SET(n) do { _ux_system_host->ux_system_host_max_hcd = (n); } while(0)
|
|
#else
|
|
#define UX_SYSTEM_HOST_MAX_HCD_GET() (1)
|
|
#define UX_SYSTEM_HOST_MAX_HCD_SET(n) UX_PARAMETER_NOT_USED(n)
|
|
#endif
|
|
|
|
#if UX_MAX_DEVICES > 1
|
|
#define UX_SYSTEM_HOST_MAX_DEVICES_SET(n) do { _ux_system_host->ux_system_host_max_devices = (n); } while(0)
|
|
#define UX_SYSTEM_HOST_MAX_DEVICES_GET() (_ux_system_host->ux_system_host_max_devices)
|
|
#else
|
|
#define UX_SYSTEM_HOST_MAX_DEVICES_SET(n) UX_PARAMETER_NOT_USED(n)
|
|
#define UX_SYSTEM_HOST_MAX_DEVICES_GET() (1)
|
|
#endif
|
|
|
|
|
|
typedef struct UX_SYSTEM_SLAVE_STRUCT
|
|
{
|
|
|
|
UX_SLAVE_DCD ux_system_slave_dcd;
|
|
UX_SLAVE_DEVICE ux_system_slave_device;
|
|
UCHAR *ux_system_slave_device_framework;
|
|
ULONG ux_system_slave_device_framework_length;
|
|
UCHAR *ux_system_slave_device_framework_full_speed;
|
|
ULONG ux_system_slave_device_framework_length_full_speed;
|
|
UCHAR *ux_system_slave_device_framework_high_speed;
|
|
ULONG ux_system_slave_device_framework_length_high_speed;
|
|
UCHAR *ux_system_slave_string_framework;
|
|
ULONG ux_system_slave_string_framework_length;
|
|
UCHAR *ux_system_slave_language_id_framework;
|
|
ULONG ux_system_slave_language_id_framework_length;
|
|
UCHAR *ux_system_slave_dfu_framework;
|
|
ULONG ux_system_slave_dfu_framework_length;
|
|
#if UX_MAX_SLAVE_CLASS_DRIVER > 1
|
|
UINT ux_system_slave_max_class;
|
|
#endif
|
|
UX_SLAVE_CLASS *ux_system_slave_class_array;
|
|
UX_SLAVE_CLASS *ux_system_slave_interface_class_array[UX_MAX_SLAVE_INTERFACES];
|
|
ULONG ux_system_slave_speed;
|
|
ULONG ux_system_slave_power_state;
|
|
ULONG ux_system_slave_remote_wakeup_capability;
|
|
ULONG ux_system_slave_remote_wakeup_enabled;
|
|
ULONG ux_system_slave_device_dfu_capabilities;
|
|
ULONG ux_system_slave_device_dfu_detach_timeout;
|
|
ULONG ux_system_slave_device_dfu_transfer_size;
|
|
ULONG ux_system_slave_device_dfu_state_machine;
|
|
ULONG ux_system_slave_device_dfu_mode;
|
|
UINT (*ux_system_slave_change_function) (ULONG);
|
|
ULONG ux_system_slave_device_vendor_request;
|
|
UINT (*ux_system_slave_device_vendor_request_function) (ULONG, ULONG, ULONG, ULONG, UCHAR *, ULONG *);
|
|
|
|
} UX_SYSTEM_SLAVE;
|
|
|
|
#if UX_MAX_SLAVE_CLASS_DRIVER > 1
|
|
#define UX_SYSTEM_DEVICE_MAX_CLASS_SET(n) do { _ux_system_slave->ux_system_slave_max_class = (n); } while(0)
|
|
#define UX_SYSTEM_DEVICE_MAX_CLASS_GET() (_ux_system_slave->ux_system_slave_max_class)
|
|
#else
|
|
#define UX_SYSTEM_DEVICE_MAX_CLASS_SET(n) do { UX_PARAMETER_NOT_USED(n); } while(0)
|
|
#define UX_SYSTEM_DEVICE_MAX_CLASS_GET() (1)
|
|
#endif
|
|
|
|
typedef struct UX_SYSTEM_OTG_STRUCT
|
|
{
|
|
|
|
#if !defined(UX_OTG_STANDALONE)
|
|
UX_THREAD ux_system_otg_thread;
|
|
UCHAR *ux_system_otg_thread_stack;
|
|
UX_SEMAPHORE ux_system_otg_semaphore;
|
|
#endif
|
|
UINT (*ux_system_otg_function) (ULONG);
|
|
ULONG ux_system_otg_mode;
|
|
ULONG ux_system_otg_io;
|
|
ULONG ux_system_otg_vbus_state;
|
|
ULONG ux_system_otg_change_mode_event;
|
|
ULONG ux_system_otg_change_vbus_event;
|
|
ULONG ux_system_otg_slave_role_swap_flag;
|
|
ULONG ux_system_otg_slave_set_feature_flag;
|
|
ULONG ux_system_otg_device_type;
|
|
VOID (*ux_system_otg_vbus_function) (ULONG);
|
|
VOID (*ux_system_otg_change_mode_callback) (ULONG);
|
|
} UX_SYSTEM_OTG;
|
|
|
|
/* Define Data Pump Class instance structure. */
|
|
|
|
|
|
typedef struct UX_HOST_CLASS_DPUMP_STRUCT
|
|
{
|
|
|
|
struct UX_HOST_CLASS_DPUMP_STRUCT
|
|
*ux_host_class_dpump_next_instance;
|
|
UX_HOST_CLASS *ux_host_class_dpump_class;
|
|
UX_DEVICE *ux_host_class_dpump_device;
|
|
UX_INTERFACE *ux_host_class_dpump_interface;
|
|
UX_ENDPOINT *ux_host_class_dpump_bulk_out_endpoint;
|
|
UX_ENDPOINT *ux_host_class_dpump_bulk_in_endpoint;
|
|
UX_ENDPOINT *ux_host_class_dpump_interrupt_endpoint;
|
|
UINT ux_host_class_dpump_state;
|
|
#if !defined(UX_HOST_STANDALONE)
|
|
UX_SEMAPHORE ux_host_class_dpump_semaphore;
|
|
#else
|
|
ULONG ux_host_class_dpump_flags;
|
|
#endif
|
|
} UX_HOST_CLASS_DPUMP;
|
|
|
|
|
|
/* Define the system API mappings based on the error checking
|
|
selected by the user. Note: this section is only applicable to
|
|
application source code, hence the conditional that turns off this
|
|
stuff when the include file is processed by the ThreadX source. */
|
|
|
|
#ifndef UX_SOURCE_CODE
|
|
|
|
|
|
/* Define USBX Services. */
|
|
|
|
#if defined(UX_SYSTEM_ENABLE_ERROR_CHECKING)
|
|
#define ux_system_initialize _ux_system_initialize
|
|
#else
|
|
#define ux_system_initialize _uxe_system_initialize
|
|
#endif
|
|
|
|
#define ux_system_uninitialize _ux_system_uninitialize
|
|
#define ux_system_tasks_run _ux_system_tasks_run
|
|
|
|
#define ux_host_class_hub_entry _ux_host_class_hub_entry
|
|
|
|
#define ux_host_class_storage_entry _ux_host_class_storage_entry
|
|
|
|
#if defined(UX_HOST_STACK_ENABLE_ERROR_CHECKING)
|
|
|
|
#define ux_host_stack_class_get _uxe_host_stack_class_get
|
|
#define ux_host_stack_class_instance_get _uxe_host_stack_class_instance_get
|
|
#define ux_host_stack_class_register _uxe_host_stack_class_register
|
|
#define ux_host_stack_device_configuration_activate _uxe_host_stack_device_configuration_activate
|
|
#define ux_host_stack_device_configuration_deactivate _uxe_host_stack_device_configuration_deactivate
|
|
#define ux_host_stack_device_configuration_get _uxe_host_stack_device_configuration_get
|
|
#define ux_host_stack_device_get _uxe_host_stack_device_get
|
|
#define ux_host_stack_device_string_get _uxe_host_stack_device_string_get
|
|
#define ux_host_stack_endpoint_transfer_abort _uxe_host_stack_endpoint_transfer_abort
|
|
#define ux_host_stack_hcd_register _uxe_host_stack_hcd_register
|
|
#define ux_host_stack_hcd_unregister _uxe_host_stack_hcd_unregister
|
|
#define ux_host_stack_interface_endpoint_get _uxe_host_stack_interface_endpoint_get
|
|
#define ux_host_stack_interface_setting_select _uxe_host_stack_interface_setting_select
|
|
#define ux_host_stack_transfer_request _uxe_host_stack_transfer_request
|
|
#define ux_host_stack_transfer_request_abort _uxe_host_stack_transfer_request_abort
|
|
|
|
#else
|
|
|
|
#define ux_host_stack_class_get _ux_host_stack_class_get
|
|
#define ux_host_stack_class_instance_get _ux_host_stack_class_instance_get
|
|
#define ux_host_stack_class_register _ux_host_stack_class_register
|
|
#define ux_host_stack_device_configuration_activate _ux_host_stack_device_configuration_activate
|
|
#define ux_host_stack_device_configuration_deactivate _ux_host_stack_device_configuration_deactivate
|
|
#define ux_host_stack_device_configuration_get _ux_host_stack_device_configuration_get
|
|
#define ux_host_stack_device_get _ux_host_stack_device_get
|
|
#define ux_host_stack_device_string_get _ux_host_stack_device_string_get
|
|
#define ux_host_stack_endpoint_transfer_abort _ux_host_stack_endpoint_transfer_abort
|
|
#define ux_host_stack_hcd_register _ux_host_stack_hcd_register
|
|
#define ux_host_stack_hcd_unregister _ux_host_stack_hcd_unregister
|
|
#define ux_host_stack_interface_endpoint_get _ux_host_stack_interface_endpoint_get
|
|
#define ux_host_stack_interface_setting_select _ux_host_stack_interface_setting_select
|
|
#define ux_host_stack_transfer_request _ux_host_stack_transfer_request
|
|
#define ux_host_stack_transfer_request_abort _ux_host_stack_transfer_request_abort
|
|
|
|
#endif
|
|
|
|
#define ux_host_stack_class_instance_create _ux_host_stack_class_instance_create
|
|
#define ux_host_stack_class_instance_destroy _ux_host_stack_class_instance_destroy
|
|
#define ux_host_stack_class_unregister _ux_host_stack_class_unregister
|
|
#define ux_host_stack_configuration_interface_get _ux_host_stack_configuration_interface_get
|
|
#define ux_host_stack_device_configuration_reset _ux_host_stack_device_configuration_reset
|
|
#define ux_host_stack_device_configuration_select _ux_host_stack_device_configuration_select
|
|
#define ux_host_stack_initialize _ux_host_stack_initialize
|
|
#define ux_host_stack_uninitialize _ux_host_stack_uninitialize
|
|
#define ux_host_stack_hnp_polling_thread_entry _ux_host_stack_hnp_polling_thread_entry
|
|
#define ux_host_stack_role_swap _ux_host_stack_role_swap
|
|
|
|
#define ux_host_stack_tasks_run _ux_host_stack_tasks_run
|
|
#define ux_host_stack_transfer_run _ux_host_stack_transfer_run
|
|
|
|
#define ux_utility_pci_class_scan _ux_utility_pci_class_scan
|
|
#define ux_utility_pci_read _ux_utility_pci_read
|
|
#define ux_utility_pci_write _ux_utility_pci_write
|
|
|
|
#if defined(UX_DEVICE_STACK_ENABLE_ERROR_CHECKING)
|
|
|
|
#define ux_device_stack_class_register _uxe_device_stack_class_register
|
|
#define ux_device_stack_class_unregister _uxe_device_stack_class_unregister
|
|
#define ux_device_stack_initialize _uxe_device_stack_initialize
|
|
|
|
#else
|
|
|
|
#define ux_device_stack_class_register _ux_device_stack_class_register
|
|
#define ux_device_stack_class_unregister _ux_device_stack_class_unregister
|
|
#define ux_device_stack_initialize _ux_device_stack_initialize
|
|
|
|
#endif
|
|
#define ux_device_stack_uninitialize _ux_device_stack_uninitialize
|
|
|
|
#define ux_device_stack_alternate_setting_get _ux_device_stack_alternate_setting_get
|
|
#define ux_device_stack_alternate_setting_set _ux_device_stack_alternate_setting_set
|
|
#define ux_device_stack_configuration_get _ux_device_stack_configuration_get
|
|
#define ux_device_stack_configuration_set _ux_device_stack_configuration_set
|
|
#define ux_device_stack_descriptor_send _ux_device_stack_descriptor_send
|
|
#define ux_device_stack_connect _ux_device_stack_connect
|
|
#define ux_device_stack_disconnect _ux_device_stack_disconnect
|
|
#define ux_device_stack_endpoint_stall _ux_device_stack_endpoint_stall
|
|
#define ux_device_stack_host_wakeup _ux_device_stack_host_wakeup
|
|
#define ux_device_stack_interface_delete _ux_device_stack_interface_delete
|
|
#define ux_device_stack_interface_get _ux_device_stack_interface_get
|
|
#define ux_device_stack_interface_set _ux_device_stack_interface_set
|
|
#define ux_device_stack_interface_start _ux_device_stack_interface_start
|
|
#define ux_device_stack_transfer_request _ux_device_stack_transfer_request
|
|
#define ux_device_stack_transfer_abort _ux_device_stack_transfer_abort
|
|
|
|
#define ux_device_stack_tasks_run _ux_device_stack_tasks_run
|
|
#define ux_device_stack_transfer_run _ux_device_stack_transfer_run
|
|
|
|
#define ux_hcd_ehci_initialize _ux_hcd_ehci_initialize
|
|
#define ux_hcd_isp1161_initialize _ux_hcd_isp1161_initialize
|
|
#define ux_hcd_ohci_initialize _ux_hcd_ohci_initialize
|
|
#define ux_hcd_sim_host_initialize _ux_hcd_sim_host_initialize
|
|
#define ux_dcd_sim_slave_initialize _ux_dcd_sim_slave_initialize
|
|
|
|
#define ux_network_driver_init _ux_network_driver_init
|
|
|
|
#endif
|
|
|
|
|
|
/* Define USBX API prototypes. */
|
|
|
|
UINT ux_system_initialize(VOID *non_cached_memory_pool_start, ULONG non_cached_memory_size,
|
|
VOID *cached_memory_pool_start, ULONG cached_memory_size);
|
|
UINT ux_system_uninitialize(VOID);
|
|
UINT ux_system_tasks_run(VOID);
|
|
|
|
UINT uxe_system_initialize(VOID *non_cached_memory_pool_start, ULONG non_cached_memory_size,
|
|
VOID *cached_memory_pool_start, ULONG cached_memory_size);
|
|
|
|
|
|
/* Define USBX Host API prototypes. */
|
|
|
|
UINT ux_hcd_ehci_initialize(UX_HCD *hcd);
|
|
UINT ux_hcd_isp1161_initialize(UX_HCD *hcd);
|
|
UINT ux_hcd_ohci_initialize(UX_HCD *hcd);
|
|
UINT ux_hcd_sim_host_initialize(UX_HCD *hcd);
|
|
|
|
UINT ux_host_stack_class_get(UCHAR *class_name, UX_HOST_CLASS **host_class);
|
|
UINT ux_host_stack_class_instance_create(UX_HOST_CLASS *host_class, VOID *class_instance);
|
|
UINT ux_host_stack_class_instance_destroy(UX_HOST_CLASS *host_class, VOID *class_instance);
|
|
UINT ux_host_stack_class_instance_get(UX_HOST_CLASS *host_class, UINT class_index, VOID **class_instance);
|
|
UINT ux_host_stack_class_register(UCHAR *class_name, UINT (*class_entry_function)(struct UX_HOST_CLASS_COMMAND_STRUCT *));
|
|
UINT ux_host_stack_class_unregister(UINT (*class_entry_function)(struct UX_HOST_CLASS_COMMAND_STRUCT *));
|
|
UINT ux_host_stack_configuration_interface_get(UX_CONFIGURATION *configuration, UINT interface_index,
|
|
UINT alternate_setting_index, UX_INTERFACE **ux_interface);
|
|
UINT ux_host_stack_device_configuration_activate(UX_CONFIGURATION *configuration);
|
|
UINT ux_host_stack_device_configuration_deactivate(UX_DEVICE *device);
|
|
UINT ux_host_stack_device_configuration_get(UX_DEVICE *device, UINT configuration_index, UX_CONFIGURATION **configuration);
|
|
UINT ux_host_stack_device_configuration_select(UX_CONFIGURATION *configuration);
|
|
UINT ux_host_stack_device_get(ULONG device_index, UX_DEVICE **device);
|
|
UINT ux_host_stack_device_string_get(UX_DEVICE *device, UCHAR *descriptor_buffer, ULONG length, ULONG language_id, ULONG string_index);
|
|
UINT ux_host_stack_endpoint_transfer_abort(UX_ENDPOINT *endpoint);
|
|
UINT ux_host_stack_hcd_register(UCHAR *hcd_name, UINT (*hcd_initialize_function)(struct UX_HCD_STRUCT *), ULONG hcd_param1, ULONG hcd_param2);
|
|
UINT ux_host_stack_hcd_unregister(UCHAR *hcd_name, ULONG hcd_param1, ULONG hcd_param2);
|
|
UINT ux_host_stack_initialize(UINT (*ux_system_host_change_function)(ULONG, UX_HOST_CLASS *, VOID *));
|
|
UINT ux_host_stack_uninitialize(VOID);
|
|
UINT ux_host_stack_interface_endpoint_get(UX_INTERFACE *ux_interface, UINT endpoint_index, UX_ENDPOINT **endpoint);
|
|
UINT ux_host_stack_interface_setting_select(UX_INTERFACE *ux_interface);
|
|
UINT ux_host_stack_transfer_request(UX_TRANSFER *transfer_request);
|
|
UINT ux_host_stack_transfer_request_abort(UX_TRANSFER *transfer_request);
|
|
VOID ux_host_stack_hnp_polling_thread_entry(ULONG id);
|
|
UINT ux_host_stack_role_swap(UX_DEVICE *device);
|
|
UINT ux_host_stack_device_configuration_reset(UX_DEVICE *device);
|
|
|
|
UINT ux_host_stack_tasks_run(VOID);
|
|
UINT ux_host_stack_transfer_run(UX_TRANSFER *transfer_request);
|
|
|
|
/* Define USBX Device API prototypes. */
|
|
|
|
UINT ux_dcd_at91_initialize(ULONG dcd_io);
|
|
UINT ux_dcd_isp1181_initialize(ULONG dcd_io, ULONG dcd_irq, ULONG dcd_vbus_address);
|
|
UINT ux_dcd_ml6965_initialize(ULONG dcd_io, ULONG dcd_irq, ULONG dcd_vbus_address);
|
|
UINT ux_dcd_sim_slave_initialize(VOID);
|
|
|
|
UINT ux_device_class_storage_entry(UX_SLAVE_CLASS_COMMAND *command);
|
|
VOID ux_device_class_storage_thread(ULONG);
|
|
UINT ux_device_stack_alternate_setting_get(ULONG interface_value);
|
|
UINT ux_device_stack_alternate_setting_set(ULONG interface_value, ULONG alternate_setting_value);
|
|
UINT ux_device_stack_class_register(UCHAR *class_name,
|
|
UINT (*class_entry_function)(struct UX_SLAVE_CLASS_COMMAND_STRUCT *),
|
|
ULONG configuration_number,
|
|
ULONG interface_number,
|
|
VOID *parameter);
|
|
UINT ux_device_stack_class_unregister(UCHAR *class_name,
|
|
UINT (*class_entry_function)(struct UX_SLAVE_CLASS_COMMAND_STRUCT *));
|
|
UINT ux_device_stack_configuration_get(VOID);
|
|
UINT ux_device_stack_configuration_set(ULONG configuration_value);
|
|
UINT ux_device_stack_descriptor_send(ULONG descriptor_type, ULONG request_index, ULONG host_length);
|
|
UINT ux_device_stack_disconnect(VOID);
|
|
UINT ux_device_stack_endpoint_stall(UX_SLAVE_ENDPOINT *endpoint);
|
|
UINT ux_device_stack_host_wakeup(VOID);
|
|
UINT ux_device_stack_initialize(UCHAR * device_framework_high_speed, ULONG device_framework_length_high_speed,
|
|
UCHAR * device_framework_full_speed, ULONG device_framework_length_full_speed,
|
|
UCHAR * string_framework, ULONG string_framework_length,
|
|
UCHAR * language_id_framework, ULONG language_id_framework_length,
|
|
UINT (*ux_system_slave_change_function)(ULONG));
|
|
UINT ux_device_stack_uninitialize(VOID);
|
|
UINT ux_device_stack_interface_delete(UX_SLAVE_INTERFACE *ux_interface);
|
|
UINT ux_device_stack_interface_get(UINT interface_value);
|
|
UINT ux_device_stack_interface_set(UCHAR * device_framework, ULONG device_framework_length,
|
|
ULONG alternate_setting_value);
|
|
UINT ux_device_stack_interface_start(UX_SLAVE_INTERFACE *ux_interface);
|
|
UINT ux_device_stack_transfer_request(UX_SLAVE_TRANSFER *transfer_request, ULONG slave_length, ULONG host_length);
|
|
UINT ux_device_stack_transfer_request_abort(UX_SLAVE_TRANSFER *transfer_request, ULONG completion_code);
|
|
|
|
UINT ux_device_stack_tasks_run(VOID);
|
|
UINT ux_device_stack_transfer_run(UX_SLAVE_TRANSFER *transfer_request, ULONG slave_length, ULONG host_length);
|
|
|
|
/* Include USBX utility and system file. */
|
|
|
|
#include "ux_utility.h"
|
|
#include "ux_system.h"
|
|
|
|
|
|
|
|
|
|
/* Determine if a C++ compiler is being used. If so, complete the standard
|
|
C conditional started above. */
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
|
|
#endif
|
|
|
|
|