//***************************************************************************** // // usbdmsc.h - USB mass storage device class driver. // // Copyright (c) 2009-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. // // This is part of revision 6288 of the Stellaris USB Library. // //***************************************************************************** #ifndef __USBDMSC_H__ #define __USBDMSC_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 msc_device_class_api //! @{ // //***************************************************************************** //***************************************************************************** // // USBDMSCMediaChange() ulStatus values. // //***************************************************************************** typedef enum { USBDMSC_MEDIA_PRESENT, USBDMSC_MEDIA_NOTPRESENT, USBDMSC_MEDIA_UNKNOWN } tUSBDMSCMediaStatus; //***************************************************************************** // //! Media Access functions. // //***************************************************************************** typedef struct { // //! This function is used to initialize and open the physical drive number //! associated with the parameter ulDrive. The function will return zero if //! the drive could not be opened for some reason. In the case of removable //! device like an SD card this function should return zero if the SD card //! is not present. //! The function returns a pointer to data that should be passed to other //! APIs or it will return 0 if no drive was found. // void *(* Open)(unsigned int ulDrive); //***************************************************************************** // // This function close the drive number in use by the mass storage class device. // // /param pvDrive is the pointer that was returned from a call to // USBDMSCStorageOpen(). // // This function is used to close the physical drive number associated with the // parameter /e pvDrive. This function will return 0 if the drive was closed // successfully and any other value will indicate a failure. // // /return Returns 0 if the drive was successfully closed or non-zero for a // failure. // //***************************************************************************** void (* Close)(void * pvDrive); //***************************************************************************** // // This function will read a block from a device opened by the // USBDMSCStorageOpen() call. // // /param pvDrive is the pointer that was returned from a call to // USBDMSCStorageOpen(). // /param pucData is the buffer that data will be written into. // /param ulSector is the block address to read. // /param ulNumBlocks is the number of blocks to read. // // This function is use to read blocks from a physical device and return them // in the /e pucData buffer. The data area pointed to by /e pucData should be // at least /e ulNumBlocks * Block Size bytes to prevent overwriting data. // // /return Returns the number of bytes that were read from the device. // //***************************************************************************** unsigned int (* BlockRead)(void * pvDrive, unsigned char *pucData, unsigned int ulSector, unsigned int ulNumBlocks); //***************************************************************************** // // This function will write a block to a device opened by the // USBDMSCStorageOpen() call. // // /param pvDrive is the pointer that was returned from a call to // USBDMSCStorageOpen(). // /param pucData is the buffer that data will be used for writing. // /param ulNumBlocks is the number of blocks to write. // // This function is use to write blocks to a physical device from the buffer // pointed to by the /e pucData buffer. If the number of blocks is greater than // one then the block address will increment and write to the next block until // /e ulNumBlocks * Block Size bytes have been written. // // /return Returns the number of bytes that were written to the device. // //***************************************************************************** unsigned int (* BlockWrite)(void * pvDrive, unsigned char *pucData, unsigned int ulSector, unsigned int ulNumBlocks); //***************************************************************************** // // This function will return the number of blocks present on a device. // // /param pvDrive is the pointer that was returned from a call to // USBDMSCStorageOpen(). // // This function is used to return the total number of blocks on a physical // device based on the /e pvDrive parameter. // // /return Returns the number of blocks that are present in a device. // //***************************************************************************** unsigned int (* NumBlocks)(void * pvDrive); } tMSCDMedia; //***************************************************************************** // // These defines control the sizes of USB transfers for data and commands. // //***************************************************************************** #define DEVICE_BLOCK_SIZE 512 //***************************************************************************** // // PRIVATE // // This structure defines the private instance data and state variables for the // mass storage class. The memory for this structure is pointed to by // the psPrivateData field in the tUSBDMSCDevice structure passed on // USBDMSCInit() and should not be modified by any code outside of the mass // storage device code. // //***************************************************************************** typedef struct { unsigned int ulUSBBase; tDeviceInfo *psDevInfo; tConfigDescriptor *psConfDescriptor; // // These three values are used to return the current sense data for an // instance of the mass storage class. // unsigned char ucErrorCode; unsigned char ucSenseKey; unsigned short usAddSenseCode; // // The pointer to the instance returned from the Open call to the media. // void *pvMedia; volatile tBoolean bConnected; // // Holds the flag settings for this instance. // unsigned int ulFlags; tUSBDMSCMediaStatus eMediaStatus; unsigned int pulBuffer[DEVICE_BLOCK_SIZE]; unsigned int ulBytesToTransfer; unsigned int ulCurrentLBA; unsigned char ucINEndpoint; unsigned char ucINDMA; unsigned char ucOUTEndpoint; unsigned char ucOUTDMA; unsigned char ucInterface; unsigned char ucSCSIState; } tMSCInstance; //***************************************************************************** // // //***************************************************************************** #ifdef DEPRECATED //***************************************************************************** // // This is the size in bytes of the private data for the mass storage class. // // This value is deprecated and should not be used, any new code should just // pass in a tMSCInstance structure in the psPrivateData field. // //***************************************************************************** #define USB_MSC_WORKSPACE_SIZE sizeof(tMSCInstance); #endif //***************************************************************************** // //! The size of the memory that should be allocated to create a configuration //! descriptor for a single instance of the USB Audio Device. //! This does not include the configuration descriptor which is automatically //! ignored by the composite device class. // // For reference this is sizeof(g_pAudioControlInterface) + // sizeof(g_pAudioStreamInterface // //***************************************************************************** #define COMPOSITE_DMSC_SIZE (23) //***************************************************************************** // //! The structure used by the application to define operating parameters for //! the mass storage device. // //***************************************************************************** typedef struct { // //! The vendor ID that this device is to present in the device descriptor. // unsigned short usVID; // //! The product ID that this device is to present in the device descriptor. // unsigned short usPID; // //! 8 byte vendor string. // unsigned char pucVendor[8]; // //! 16 byte vendor string. // unsigned char pucProduct[16]; // //! 4 byte vendor string. // unsigned char pucVersion[4]; // //! The maximum power consumption of the device, expressed in milliamps. // unsigned short 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. // unsigned char ucPwrAttributes; // //! 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), MSC //! Interface description string (language 1), Configuration description //! string (language 1). //! //! If supporting more than 1 language, the descriptor block (except for //! string descriptor 0) must be repeated for each language defined in the //! language descriptor. //! // const unsigned char * const *ppStringDescriptors; // //! The number of descriptors provided in the ppStringDescriptors //! array. This must be 1 + ((5 + (num HID strings)) * (num languages)). // unsigned int ulNumStringDescriptors; // //! This structure holds the access functions for the media used by this //! instance of the mass storage class device. All of the functions in this //! structure are required to be filled out with valid functions. // tMSCDMedia sMediaFunctions; // //! This is the callback function for various events that occur during //! mass storage class operation. // tUSBCallback pfnEventCallback; // //! A pointer to the private instance data for this device. This memory //! must remain accessible for as long as the MSC device is in use and must //! not be modified by any code outside the MSC class driver. // tMSCInstance *psPrivateData; } tUSBDMSCDevice; //***************************************************************************** // // MSC-specific device class driver events // //***************************************************************************** //***************************************************************************** // //! This event indicates that the host has completed other operations and is //! no longer accessing the device. // //***************************************************************************** #define USBD_MSC_EVENT_IDLE (USBD_MSC_EVENT_BASE + 0) //***************************************************************************** // //! This event indicates that the host is reading the storage media. // //***************************************************************************** #define USBD_MSC_EVENT_READING (USBD_MSC_EVENT_BASE + 1) //***************************************************************************** // //! This event indicates that the host is writing to the storage media. // //***************************************************************************** #define USBD_MSC_EVENT_WRITING (USBD_MSC_EVENT_BASE + 2) extern tDeviceInfo g_sMSCDeviceInfo; //***************************************************************************** // // API Function Prototypes // //***************************************************************************** extern void *USBDMSCInit(unsigned int ulIndex, const tUSBDMSCDevice *psMSCDevice); extern void *USBDMSCCompositeInit(unsigned int ulIndex, const tUSBDMSCDevice *psMSCDevice); extern void USBDMSCTerm(void *pvInstance); extern void USBDMSCMediaChange(void *pvInstance, tUSBDMSCMediaStatus eMediaStatus); //***************************************************************************** // // Close the Doxygen group. //! @} // //***************************************************************************** //***************************************************************************** // // Mark the end of the C bindings section for C++ compilers. // //***************************************************************************** #ifdef __cplusplus } #endif #endif