3      Copyright (C) Dean Camera, 2011. 
   5   dean [at] fourwalledcubicle [dot] com 
  10   Copyright 2011  Dean Camera (dean [at] fourwalledcubicle [dot] com) 
  12   Permission to use, copy, modify, distribute, and sell this 
  13   software and its documentation for any purpose is hereby granted 
  14   without fee, provided that the above copyright notice appear in 
  15   all copies and that both that the copyright notice and this 
  16   permission notice and warranty disclaimer appear in supporting 
  17   documentation, and that the name of the author not be used in 
  18   advertising or publicity pertaining to distribution of the 
  19   software without specific, written prior permission. 
  21   The author disclaim all warranties with regard to this 
  22   software, including all implied warranties of merchantability 
  23   and fitness.  In no event shall the author be liable for any 
  24   special, indirect or consequential damages or any damages 
  25   whatsoever resulting from loss of use, data or profits, whether 
  26   in an action of contract, negligence or other tortious action, 
  27   arising out of or in connection with the use or performance of 
  32  *  \brief Host mode driver for the library USB Audio 1.0 Class driver. 
  34  *  Host mode driver for the library USB Audio 1.0 Class driver. 
  36  *  \note This file should not be included directly. It is automatically included as needed by the USB module driver 
  37  *        dispatch header located in LUFA/Drivers/USB.h. 
  40 /** \ingroup Group_USBClassAudio 
  41  *  \defgroup Group_USBClassAudioHost Audio 1.0 Class Host Mode Driver 
  43  *  \section Sec_Dependencies Module Source Dependencies 
  44  *  The following files must be built with any user project that uses this module: 
  45  *    - LUFA/Drivers/USB/Class/Host/Audio.c <i>(Makefile source module name: LUFA_SRC_USBCLASS)</i> 
  47  *  \section Sec_ModDescription Module Description 
  48  *  Host Mode USB Class driver framework interface, for the Audio 1.0 USB Class driver. 
  53 #ifndef __AUDIO_CLASS_HOST_H__ 
  54 #define __AUDIO_CLASS_HOST_H__ 
  57                 #include "../../USB.h" 
  58                 #include "../Common/Audio.h" 
  60         /* Enable C linkage for C++ Compilers: */ 
  61                 #if defined(__cplusplus) 
  65         /* Preprocessor Checks: */ 
  66                 #if !defined(__INCLUDE_FROM_AUDIO_DRIVER) 
  67                         #error Do not include this file directly. Include LUFA/Drivers/USB.h instead. 
  70         /* Public Interface - May be used in end-application: */ 
  72                         /** \brief Audio Class Host Mode Configuration and State Structure. 
  74                          *  Class state structure. An instance of this structure should be made within the user application, 
  75                          *  and passed to each of the Audio class driver functions as the \c AudioInterfaceInfo parameter. This 
  76                          *  stores each Audio interface's configuration and state information. 
  82                                         uint8_t  DataINPipeNumber
; /**< Pipe number of the Audio interface's IN data pipe. */ 
  83                                         uint8_t  DataOUTPipeNumber
; /**< Pipe number of the Audio interface's OUT data pipe. */ 
  84                                 } Config
; /**< Config data for the USB class interface within the device. All elements in this section 
  85                                            *   <b>must</b> be set or the interface will fail to enumerate and operate correctly. 
  89                                         bool IsActive
; /**< Indicates if the current interface instance is connected to an attached device, valid 
  90                                                         *   after \ref Audio_Host_ConfigurePipes() is called and the Host state machine is in the 
  93                                         uint8_t ControlInterfaceNumber
; /**< Interface index of the Audio Control interface within the attached device. */ 
  94                                         uint8_t StreamingInterfaceNumber
; /**< Interface index of the Audio Streaming interface within the attached device. */ 
  96                                         uint8_t EnabledStreamingAltIndex
; /**< Alternative setting index of the Audio Streaming interface when the stream is enabled. */ 
  98                                         uint16_t DataINPipeSize
; /**< Size in bytes of the Audio interface's IN data pipe. */ 
  99                                         uint16_t DataOUTPipeSize
;  /**< Size in bytes of the Audio interface's OUT data pipe. */ 
 100                                 } State
; /**< State data for the USB class interface within the device. All elements in this section 
 101                                                   *   <b>may</b> be set to initial values, but may also be ignored to default to sane values when 
 102                                                   *   the interface is enumerated. 
 104                         } USB_ClassInfo_Audio_Host_t
; 
 107                         /** Enum for the possible error codes returned by the \ref Audio_Host_ConfigurePipes() function. */ 
 108                         enum AUDIO_Host_EnumerationFailure_ErrorCodes_t
 
 110                                 AUDIO_ENUMERROR_NoError                    
= 0, /**< Configuration Descriptor was processed successfully. */ 
 111                                 AUDIO_ENUMERROR_InvalidConfigDescriptor    
= 1, /**< The device returned an invalid Configuration Descriptor. */ 
 112                                 AUDIO_ENUMERROR_NoCompatibleInterfaceFound 
= 2, /**< A compatible AUDIO interface was not found in the device's Configuration Descriptor. */ 
 113                                 AUDIO_ENUMERROR_PipeConfigurationFailed    
= 3, /**< One or more pipes for the specified interface could not be configured correctly. */ 
 116                 /* Function Prototypes: */ 
 117                         /** Host interface configuration routine, to configure a given Audio host interface instance using the Configuration 
 118                          *  Descriptor read from an attached USB device. This function automatically updates the given Audio Host instance's 
 119                          *  state values and configures the pipes required to communicate with the interface if it is found within the 
 120                          *  device. This should be called once after the stack has enumerated the attached device, while the host state 
 121                          *  machine is in the Addressed state. 
 123                          *  \param[in,out] AudioInterfaceInfo      Pointer to a structure containing an Audio Class host configuration and state. 
 124                          *  \param[in]     ConfigDescriptorSize    Length of the attached device's Configuration Descriptor. 
 125                          *  \param[in]     DeviceConfigDescriptor  Pointer to a buffer containing the attached device's Configuration Descriptor. 
 127                          *  \return A value from the \ref AUDIO_Host_EnumerationFailure_ErrorCodes_t enum. 
 129                         uint8_t Audio_Host_ConfigurePipes(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
, 
 130                                                           uint16_t ConfigDescriptorSize
, 
 131                                                           void* DeviceConfigDescriptor
) ATTR_NON_NULL_PTR_ARG(1) ATTR_NON_NULL_PTR_ARG(3); 
 133                         /** Starts or stops the audio streaming for the given configured Audio Host interface, allowing for audio samples to be 
 134                          *  send and/or received. 
 136                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class host configuration and state. 
 137                          *  \param[in]     EnableStreaming     Boolean true to enable streaming of the specified interface, false to disable 
 139                          *  \return A value from the \ref USB_Host_SendControlErrorCodes_t enum. 
 141                         uint8_t Audio_Host_StartStopStreaming(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
, 
 142                                                               bool EnableStreaming
); 
 144                         /** Gets or sets the specified property of a streaming audio class endpoint that is bound to a pipe in the given 
 147                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class host configuration and state. 
 148                          *  \param[in]     DataPipeIndex       Index of the data pipe whose bound endpoint is to be altered. 
 149                          *  \param[in]     EndpointProperty    Property of the endpoint to get or set, a value from \ref Audio_ClassRequests_t. 
 150                          *  \param[in]     EndpointControl     Parameter of the endpoint to get or set, a value from \ref Audio_EndpointControls_t. 
 151                          *  \param[in,out] DataLength          For SET operations, the length of the parameter data to set. For GET operations, the maximum 
 152                          *                                     length of the retrieved data. 
 153                          *  \param[in,out] Data                Pointer to a location where the parameter data is stored for SET operations, or where 
 154                          *                                     the retrieved data is to be stored for GET operations. 
 156                          *  \return A value from the \ref USB_Host_SendControlErrorCodes_t enum. 
 158                         uint8_t Audio_GetSetEndpointProperty(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
, 
 159                                                              const uint8_t DataPipeIndex
, 
 160                                                              const uint8_t EndpointProperty
, 
 161                                                              const uint8_t EndpointControl
, 
 162                                                              uint16_t* const DataLength
, 
 165                 /* Inline Functions: */ 
 166                         /** General management task for a given Audio host class interface, required for the correct operation of 
 167                          *  the interface. This should be called frequently in the main program loop, before the master USB management task 
 168                          *  \ref USB_USBTask(). 
 170                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class host configuration and state. 
 172                         static inline void Audio_Host_USBTask(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
); 
 173                         static inline void Audio_Host_USBTask(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 175                                 (void)AudioInterfaceInfo
; 
 178                         /** Determines if the given audio interface is ready for a sample to be read from it, and selects the streaming 
 179                          *  IN pipe ready for reading. 
 181                          *  \pre This function must only be called when the Host state machine is in the \ref HOST_STATE_Configured state or 
 182                          *       the call will fail. 
 184                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class configuration and state. 
 186                          *  \return Boolean \c true if the given Audio interface has a sample to be read, \c false otherwise. 
 188                         static inline bool Audio_Host_IsSampleReceived(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 189                                                                          ATTR_NON_NULL_PTR_ARG(1) ATTR_ALWAYS_INLINE
; 
 190                         static inline bool Audio_Host_IsSampleReceived(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 192                                 if ((USB_HostState 
!= HOST_STATE_Configured
) || !(AudioInterfaceInfo
->State
.IsActive
)) 
 195                                 Pipe_SelectPipe(AudioInterfaceInfo
->Config
.DataOUTPipeNumber
); 
 196                                 return Pipe_IsINReceived(); 
 199                         /** Determines if the given audio interface is ready to accept the next sample to be written to it, and selects 
 200                          *  the streaming OUT pipe ready for writing. 
 202                          *  \pre This function must only be called when the Host state machine is in the \ref HOST_STATE_Configured state or 
 203                          *       the call will fail. 
 205                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class configuration and state. 
 207                          *  \return Boolean \c true if the given Audio interface is ready to accept the next sample, \c false otherwise. 
 209                         static inline bool Audio_Host_IsReadyForNextSample(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 210                                                                              ATTR_NON_NULL_PTR_ARG(1) ATTR_ALWAYS_INLINE
; 
 211                         static inline bool Audio_Host_IsReadyForNextSample(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 213                                 if ((USB_HostState 
!= HOST_STATE_Configured
) || !(AudioInterfaceInfo
->State
.IsActive
)) 
 216                                 Pipe_SelectPipe(AudioInterfaceInfo
->Config
.DataINPipeNumber
); 
 217                                 return Pipe_IsOUTReady(); 
 220                         /** Reads the next 8-bit audio sample from the current audio interface. 
 222                          *  \pre This should be preceded immediately by a call to the \ref Audio_Host_IsSampleReceived() function to ensure 
 223                          *       that the correct pipe is selected and ready for data. 
 225                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class configuration and state. 
 227                          *  \return  Signed 8-bit audio sample from the audio interface. 
 229                         static inline int8_t Audio_Host_ReadSample8(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 230                                                                       ATTR_NON_NULL_PTR_ARG(1) ATTR_ALWAYS_INLINE
; 
 231                         static inline int8_t Audio_Host_ReadSample8(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 235                                 (void)AudioInterfaceInfo
; 
 237                                 Sample 
= Pipe_Read_8(); 
 239                                 if (!(Pipe_BytesInPipe())) 
 245                         /** Reads the next 16-bit audio sample from the current audio interface. 
 247                          *  \pre This should be preceded immediately by a call to the \ref Audio_Host_IsSampleReceived() function to ensure 
 248                          *       that the correct pipe is selected and ready for data. 
 250                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class configuration and state. 
 252                          *  \return  Signed 16-bit audio sample from the audio interface. 
 254                         static inline int16_t Audio_Host_ReadSample16(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 255                                                                         ATTR_NON_NULL_PTR_ARG(1) ATTR_ALWAYS_INLINE
; 
 256                         static inline int16_t Audio_Host_ReadSample16(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 260                                 (void)AudioInterfaceInfo
; 
 262                                 Sample 
= (int16_t)Pipe_Read_16_LE(); 
 264                                 if (!(Pipe_BytesInPipe())) 
 270                         /** Reads the next 24-bit audio sample from the current audio interface. 
 272                          *  \pre This should be preceded immediately by a call to the \ref Audio_Host_IsSampleReceived() function to ensure 
 273                          *       that the correct pipe is selected and ready for data. 
 275                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class configuration and state. 
 277                          *  \return Signed 24-bit audio sample from the audio interface. 
 279                         static inline int32_t Audio_Host_ReadSample24(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 280                                                                         ATTR_NON_NULL_PTR_ARG(1) ATTR_ALWAYS_INLINE
; 
 281                         static inline int32_t Audio_Host_ReadSample24(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
) 
 285                                 (void)AudioInterfaceInfo
; 
 287                                 Sample 
= (((uint32_t)Pipe_Read_8() << 16) | Pipe_Read_16_LE()); 
 289                                 if (!(Pipe_BytesInPipe())) 
 295                         /** Writes the next 8-bit audio sample to the current audio interface. 
 297                          *  \pre This should be preceded immediately by a call to the \ref Audio_Host_IsReadyForNextSample() function to 
 298                          *       ensure that the correct pipe is selected and ready for data. 
 300                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class configuration and state. 
 301                          *  \param[in]     Sample              Signed 8-bit audio sample. 
 303                         static inline void Audio_Host_WriteSample8(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
, 
 304                                                                      const int8_t Sample
) ATTR_NON_NULL_PTR_ARG(1) ATTR_ALWAYS_INLINE
; 
 305                         static inline void Audio_Host_WriteSample8(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
, 
 308                                 Pipe_Write_8(Sample
); 
 310                                 if (Pipe_BytesInPipe() == AudioInterfaceInfo
->State
.DataINPipeSize
) 
 314                         /** Writes the next 16-bit audio sample to the current audio interface. 
 316                          *  \pre This should be preceded immediately by a call to the \ref Audio_Host_IsReadyForNextSample() function to 
 317                          *       ensure that the correct pipe is selected and ready for data. 
 319                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class configuration and state. 
 320                          *  \param[in]     Sample              Signed 16-bit audio sample. 
 322                         static inline void Audio_Host_WriteSample16(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
, 
 323                                                                       const int16_t Sample
) ATTR_NON_NULL_PTR_ARG(1) ATTR_ALWAYS_INLINE
; 
 324                         static inline void Audio_Host_WriteSample16(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
, 
 325                                                                       const int16_t Sample
) 
 327                                 Pipe_Write_16_LE(Sample
); 
 329                                 if (Pipe_BytesInPipe() == AudioInterfaceInfo
->State
.DataINPipeSize
) 
 333                         /** Writes the next 24-bit audio sample to the current audio interface. 
 335                          *  \pre This should be preceded immediately by a call to the \ref Audio_Host_IsReadyForNextSample() function to 
 336                          *       ensure that the correct pipe is selected and ready for data. 
 338                          *  \param[in,out] AudioInterfaceInfo  Pointer to a structure containing an Audio Class configuration and state. 
 339                          *  \param[in]     Sample              Signed 24-bit audio sample. 
 341                         static inline void Audio_Host_WriteSample24(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
, 
 342                                                                       const int32_t Sample
) ATTR_NON_NULL_PTR_ARG(1) ATTR_ALWAYS_INLINE
; 
 343                         static inline void Audio_Host_WriteSample24(USB_ClassInfo_Audio_Host_t
* const AudioInterfaceInfo
, 
 344                                                                       const int32_t Sample
) 
 346                                 Pipe_Write_16_LE(Sample
); 
 347                                 Pipe_Write_8(Sample 
>> 16); 
 349                                 if (Pipe_BytesInPipe() == AudioInterfaceInfo
->State
.DataINPipeSize
) 
 353         /* Private Interface - For use in library only: */ 
 354         #if !defined(__DOXYGEN__) 
 355                 /* Function Prototypes: */ 
 356                         #if defined(__INCLUDE_FROM_AUDIO_HOST_C) 
 357                                 static uint8_t DComp_NextAudioControlInterface(void* CurrentDescriptor
); 
 358                                 static uint8_t DComp_NextAudioStreamInterface(void* CurrentDescriptor
); 
 359                                 static uint8_t DComp_NextAudioInterfaceDataEndpoint(void* CurrentDescriptor
); 
 363         /* Disable C linkage for C++ Compilers: */ 
 364                 #if defined(__cplusplus)