//***************************************************************************** // // 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__