mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-14 20:29:23 +08:00
353 lines
12 KiB
C
353 lines
12 KiB
C
|
//*****************************************************************************
|
||
|
//
|
||
|
// usbdcdc.h - USBLib support for generic CDC ACM (serial) device.
|
||
|
//
|
||
|
// Copyright (c) 2008-2010 Texas Instruments Incorporated. All rights reserved.
|
||
|
// Software License Agreement
|
||
|
//
|
||
|
// Texas Instruments (TI) is supplying this software for use solely and
|
||
|
// exclusively on TI's microcontroller products. The software is owned by
|
||
|
// TI and/or its suppliers, and is protected under applicable copyright
|
||
|
// laws. You may not combine this software with "viral" open-source
|
||
|
// software in order to form a larger program.
|
||
|
//
|
||
|
// THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS.
|
||
|
// NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT
|
||
|
// NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||
|
// A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY
|
||
|
// CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
|
||
|
// DAMAGES, FOR ANY REASON WHATSOEVER.
|
||
|
//
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
|
||
|
#ifndef __USBDCDC_H__
|
||
|
#define __USBDCDC_H__
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
// If building with a C++ compiler, make all of the definitions in this header
|
||
|
// have a C binding.
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
#ifdef __cplusplus
|
||
|
extern "C"
|
||
|
{
|
||
|
#endif
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
//! \addtogroup cdc_device_class_api
|
||
|
//! @{
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
// PRIVATE
|
||
|
//
|
||
|
// The first few sections of this header are private defines that are used by
|
||
|
// the USB CDC Serial code and are here only to help with the application
|
||
|
// allocating the correct amount of memory for the CDC Serial device code.
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
// PRIVATE
|
||
|
//
|
||
|
// This enumeration holds the various states that the device can be in during
|
||
|
// normal operation.
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
typedef enum
|
||
|
{
|
||
|
//
|
||
|
// Unconfigured.
|
||
|
//
|
||
|
CDC_STATE_UNCONFIGURED,
|
||
|
|
||
|
//
|
||
|
// No outstanding transaction remains to be completed.
|
||
|
//
|
||
|
CDC_STATE_IDLE,
|
||
|
|
||
|
//
|
||
|
// Waiting on completion of a send or receive transaction.
|
||
|
//
|
||
|
CDC_STATE_WAIT_DATA,
|
||
|
|
||
|
//
|
||
|
// Waiting for client to process data.
|
||
|
//
|
||
|
CDC_STATE_WAIT_CLIENT
|
||
|
}
|
||
|
tCDCState;
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
// PRIVATE
|
||
|
//
|
||
|
// This structure defines the private instance data and state variables for the
|
||
|
// CDC Serial device. The memory for this structure is pointed to by the
|
||
|
// psPrivateCDCSerData field in the tUSBDCDCDevice structure passed on
|
||
|
// USBDCDCInit().
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
typedef struct
|
||
|
{
|
||
|
uint32 ulUSBBase;
|
||
|
tDeviceInfo *psDevInfo;
|
||
|
tConfigDescriptor *psConfDescriptor;
|
||
|
volatile tCDCState eCDCRxState;
|
||
|
volatile tCDCState eCDCTxState;
|
||
|
volatile tCDCState eCDCRequestState;
|
||
|
volatile tCDCState eCDCInterruptState;
|
||
|
volatile uint8 ucPendingRequest;
|
||
|
uint16 usBreakDuration;
|
||
|
uint16 usControlLineState;
|
||
|
uint16 usSerialState;
|
||
|
volatile uint16 usDeferredOpFlags;
|
||
|
uint16 usLastTxSize;
|
||
|
tLineCoding sLineCoding;
|
||
|
volatile tBoolean bRxBlocked;
|
||
|
volatile tBoolean bControlBlocked;
|
||
|
volatile tBoolean bConnected;
|
||
|
uint8 ucControlEndpoint;
|
||
|
uint8 ucBulkINEndpoint;
|
||
|
uint8 ucBulkOUTEndpoint;
|
||
|
uint8 ucInterfaceControl;
|
||
|
uint8 ucInterfaceData;
|
||
|
}
|
||
|
tCDCSerInstance;
|
||
|
|
||
|
|
||
|
#ifndef DEPRECATED
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
// The number of bytes of workspace required by the CDC device class driver.
|
||
|
// The client must provide a block of RAM of at least this size in the
|
||
|
// psPrivateCDCSerData field of the tUSBCDCDevice structure passed on
|
||
|
// USBDCDCInit().
|
||
|
//
|
||
|
// This value is deprecated and should not be used, any new code should just
|
||
|
// pass in a tUSBCDCDevice structure in the psPrivateCDCSerData field.
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
#define USB_CDCSER_WORKSPACE_SIZE (sizeof(tCDCSerInstance))
|
||
|
#endif
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
// The following defines are used when working with composite devices.
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
//! The size of the memory that should be allocated to create a configuration
|
||
|
//! descriptor for a single instance of the USB Serial CDC Device.
|
||
|
//! This does not include the configuration descriptor which is automatically
|
||
|
//! ignored by the composite device class.
|
||
|
//
|
||
|
// For reference this is sizeof(g_pIADSerDescriptor) +
|
||
|
// sizeof(g_pCDCSerCommInterface) + sizeof(g_pCDCSerDataInterface)
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
#define COMPOSITE_DCDC_SIZE (8 + 35 + 23)
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
// CDC-specific events These events are provided to the application in the
|
||
|
// \e ulMsg parameter of the tUSBCallback function.
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
|
||
|
//
|
||
|
//! The host requests that the device send a BREAK condition on its
|
||
|
//! serial communication channel. The BREAK should remain active until
|
||
|
//! a USBD_CDC_EVENT_CLEAR_BREAK event is received.
|
||
|
//
|
||
|
#define USBD_CDC_EVENT_SEND_BREAK (USBD_CDC_EVENT_BASE + 0)
|
||
|
|
||
|
//
|
||
|
//! The host requests that the device stop sending a BREAK condition on its
|
||
|
//! serial communication channel.
|
||
|
//
|
||
|
#define USBD_CDC_EVENT_CLEAR_BREAK (USBD_CDC_EVENT_BASE + 1)
|
||
|
|
||
|
//
|
||
|
//! The host requests that the device set the RS232 signaling lines to
|
||
|
//! a particular state. The ulMsgValue parameter contains the RTS and
|
||
|
//! DTR control line states as defined in table 51 of the USB CDC class
|
||
|
//! definition and is a combination of the following values:
|
||
|
//!
|
||
|
//! (RTS) USB_CDC_DEACTIVATE_CARRIER or USB_CDC_ACTIVATE_CARRIER
|
||
|
//! (DTR) USB_CDC_DTE_NOT_PRESENT or USB_CDC_DTE_PRESENT
|
||
|
//
|
||
|
#define USBD_CDC_EVENT_SET_CONTROL_LINE_STATE (USBD_CDC_EVENT_BASE + 2)
|
||
|
|
||
|
//
|
||
|
//! The host requests that the device set the RS232 communication
|
||
|
//! parameters. The pvMsgData parameter points to a tLineCoding structure
|
||
|
//! defining the required number of bits per character, parity mode,
|
||
|
//! number of stop bits and the baud rate.
|
||
|
//
|
||
|
#define USBD_CDC_EVENT_SET_LINE_CODING (USBD_CDC_EVENT_BASE + 3)
|
||
|
|
||
|
//
|
||
|
//! The host is querying the current RS232 communication parameters. The
|
||
|
//! pvMsgData parameter points to a tLineCoding structure that the
|
||
|
//! application must fill with the current settings prior to returning
|
||
|
//! from the callback.
|
||
|
//
|
||
|
#define USBD_CDC_EVENT_GET_LINE_CODING (USBD_CDC_EVENT_BASE + 4)
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
//! The structure used by the application to define operating parameters for
|
||
|
//! the CDC device.
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
typedef struct
|
||
|
{
|
||
|
//
|
||
|
//! The vendor ID that this device is to present in the device descriptor.
|
||
|
//
|
||
|
uint16 usVID;
|
||
|
|
||
|
//
|
||
|
//! The product ID that this device is to present in the device descriptor.
|
||
|
//
|
||
|
uint16 usPID;
|
||
|
|
||
|
//
|
||
|
//! The maximum power consumption of the device, expressed in milliamps.
|
||
|
//
|
||
|
uint16 usMaxPowermA;
|
||
|
|
||
|
//
|
||
|
//! Indicates whether the device is self- or bus-powered and whether or not
|
||
|
//! it supports remote wakeup. Valid values are USB_CONF_ATTR_SELF_PWR or
|
||
|
//! USB_CONF_ATTR_BUS_PWR, optionally ORed with USB_CONF_ATTR_RWAKE.
|
||
|
//
|
||
|
uint8 ucPwrAttributes;
|
||
|
|
||
|
//
|
||
|
//! A pointer to the callback function which will be called to notify
|
||
|
//! the application of all asynchronous control events related to the
|
||
|
//! operation of the device.
|
||
|
//
|
||
|
tUSBCallback pfnControlCallback;
|
||
|
|
||
|
//
|
||
|
//! A client-supplied pointer which will be sent as the first
|
||
|
//! parameter in all calls made to the control channel callback,
|
||
|
//! pfnControlCallback.
|
||
|
//
|
||
|
void *pvControlCBData;
|
||
|
|
||
|
//
|
||
|
//! A pointer to the callback function which will be called to notify
|
||
|
//! the application of events related to the device's data receive channel.
|
||
|
//
|
||
|
tUSBCallback pfnRxCallback;
|
||
|
|
||
|
//
|
||
|
//! A client-supplied pointer which will be sent as the first
|
||
|
//! parameter in all calls made to the receive channel callback,
|
||
|
//! pfnRxCallback.
|
||
|
//
|
||
|
void *pvRxCBData;
|
||
|
|
||
|
//
|
||
|
//! A pointer to the callback function which will be called to notify
|
||
|
//! the application of events related to the device's data transmit
|
||
|
//! channel.
|
||
|
//
|
||
|
tUSBCallback pfnTxCallback;
|
||
|
|
||
|
//
|
||
|
//! A client-supplied pointer which will be sent as the first
|
||
|
//! parameter in all calls made to the transmit channel callback,
|
||
|
//! pfnTxCallback.
|
||
|
//
|
||
|
void *pvTxCBData;
|
||
|
|
||
|
//
|
||
|
//! A pointer to the string descriptor array for this device. This array
|
||
|
//! must contain the following string descriptor pointers in this order.
|
||
|
//! Language descriptor, Manufacturer name string (language 1), Product
|
||
|
//! name string (language 1), Serial number string (language 1),
|
||
|
//! Control interface description string (language 1), Configuration
|
||
|
//! description string (language 1).
|
||
|
//!
|
||
|
//! If supporting more than 1 language, the strings for indices 1 through 5
|
||
|
//! must be repeated for each of the other languages defined in the
|
||
|
//! language descriptor.
|
||
|
//
|
||
|
const uint8 * const *ppStringDescriptors;
|
||
|
|
||
|
//
|
||
|
//! The number of descriptors provided in the ppStringDescriptors
|
||
|
//! array. This must be 1 + (5 * number of supported languages).
|
||
|
//
|
||
|
uint32 ulNumStringDescriptors;
|
||
|
|
||
|
//
|
||
|
//! A pointer to the private instance data for this device. This memory
|
||
|
//! must remain accessible for as long as the CDC device is in use and must
|
||
|
//! not be modified by any code outside the CDC class driver.
|
||
|
//
|
||
|
tCDCSerInstance *psPrivateCDCSerData;
|
||
|
}
|
||
|
tUSBDCDCDevice;
|
||
|
|
||
|
extern tDeviceInfo g_sCDCSerDeviceInfo;
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
// API Function Prototypes
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
extern void * USBDCDCCompositeInit(uint32 ulIndex,
|
||
|
const tUSBDCDCDevice *psCDCDevice);
|
||
|
extern void *USBDCDCInit(uint32 ulIndex,
|
||
|
const tUSBDCDCDevice *psCDCDevice);
|
||
|
extern void USBDCDCTerm(void *pvInstance);
|
||
|
extern void *USBDCDCSetControlCBData(void *pvInstance, void *pvCBData);
|
||
|
extern void *USBDCDCSetRxCBData(void *pvInstance, void *pvCBData);
|
||
|
extern void *USBDCDCSetTxCBData(void *pvInstance, void *pvCBData);
|
||
|
extern uint32 USBDCDCPacketWrite(void *pvInstance,
|
||
|
uint8 *pcData,
|
||
|
uint32 ulLength,
|
||
|
tBoolean bLast);
|
||
|
extern uint32 USBDCDCPacketRead(void *pvInstance,
|
||
|
uint8 *pcData,
|
||
|
uint32 ulLength,
|
||
|
tBoolean bLast);
|
||
|
extern uint32 USBDCDCTxPacketAvailable(void *pvInstance);
|
||
|
extern uint32 USBDCDCRxPacketAvailable(void *pvInstance);
|
||
|
extern void USBDCDCSerialStateChange(void *pvInstance,
|
||
|
uint16 usState);
|
||
|
extern void USBDCDCPowerStatusSet(void *pvInstance, uint8 ucPower);
|
||
|
extern tBoolean USBDCDCRemoteWakeupRequest(void *pvInstance);
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
// Close the Doxygen group.
|
||
|
//! @}
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
|
||
|
//*****************************************************************************
|
||
|
//
|
||
|
// Mark the end of the C bindings section for C++ compilers.
|
||
|
//
|
||
|
//*****************************************************************************
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif // __USBDCDC_H__
|