Make XPLAINBridge serial bridge much more reliable for the reception of characters...
[pub/USBasp.git] / LUFA / Drivers / USB / LowLevel / Endpoint.h
index 68413b8..daf3d81 100644 (file)
                                 *
                                 *  \ingroup Group_EndpointRW
                                 *
                                 *
                                 *  \ingroup Group_EndpointRW
                                 *
-                                *  \return Total number of bytes in the currently selected Endpoint's FIFO buffer
+                                *  \return Total number of bytes in the currently selected Endpoint's FIFO buffer.
                                 */
                                static inline uint16_t Endpoint_BytesInEndpoint(void);
                        
                                 */
                                static inline uint16_t Endpoint_BytesInEndpoint(void);
                        
                                 *  the currently selected endpoint number so that it can be restored after another endpoint has
                                 *  been manipulated.
                                 *
                                 *  the currently selected endpoint number so that it can be restored after another endpoint has
                                 *  been manipulated.
                                 *
-                                *  \return Index of the currently selected endpoint
+                                *  \return Index of the currently selected endpoint.
                                 */
                                static inline uint8_t Endpoint_GetCurrentEndpoint(void);
                                
                                 */
                                static inline uint8_t Endpoint_GetCurrentEndpoint(void);
                                
                                 *  Any endpoint operations which do not require the endpoint number to be indicated will operate on
                                 *  the currently selected endpoint.
                                 *
                                 *  Any endpoint operations which do not require the endpoint number to be indicated will operate on
                                 *  the currently selected endpoint.
                                 *
-                                *  \param[in] EndpointNumber Endpoint number to select
+                                *  \param[in] EndpointNumber Endpoint number to select.
                                 */
                                static inline void Endpoint_SelectEndpoint(uint8_t EndpointNumber);
                                
                                /** Resets the endpoint bank FIFO. This clears all the endpoint banks and resets the USB controller's
                                 *  In and Out pointers to the bank's contents.
                                 *
                                 */
                                static inline void Endpoint_SelectEndpoint(uint8_t EndpointNumber);
                                
                                /** Resets the endpoint bank FIFO. This clears all the endpoint banks and resets the USB controller's
                                 *  In and Out pointers to the bank's contents.
                                 *
-                                *  \param[in] EndpointNumber Endpoint number whose FIFO buffers are to be reset
+                                *  \param[in] EndpointNumber Endpoint number whose FIFO buffers are to be reset.
                                 */
                                static inline void Endpoint_ResetFIFO(uint8_t EndpointNumber);
                                
                                 */
                                static inline void Endpoint_ResetFIFO(uint8_t EndpointNumber);
                                
                                
                                /** Determines if the currently selected endpoint is enabled, but not necessarily configured.
                                 *
                                
                                /** Determines if the currently selected endpoint is enabled, but not necessarily configured.
                                 *
-                                * \return Boolean True if the currently selected endpoint is enabled, false otherwise
+                                * \return Boolean True if the currently selected endpoint is enabled, false otherwise.
                                 */
                                static inline bool Endpoint_IsEnabled(void);
                                
                                 */
                                static inline bool Endpoint_IsEnabled(void);
                                
                                 *
                                 *  \ingroup Group_EndpointPacketManagement
                                 *
                                 *
                                 *  \ingroup Group_EndpointPacketManagement
                                 *
-                                *  \return Boolean true if the currently selected endpoint may be read from or written to, depending on its direction
+                                *  \return Boolean true if the currently selected endpoint may be read from or written to, depending on its direction.
                                 */
                                static inline bool Endpoint_IsReadWriteAllowed(void);
                                
                                /** Determines if the currently selected endpoint is configured.
                                 *
                                 */
                                static inline bool Endpoint_IsReadWriteAllowed(void);
                                
                                /** Determines if the currently selected endpoint is configured.
                                 *
-                                *  \return Boolean true if the currently selected endpoint has been configured, false otherwise
+                                *  \return Boolean true if the currently selected endpoint has been configured, false otherwise.
                                 */
                                static inline bool Endpoint_IsConfigured(void);
                                
                                 */
                                static inline bool Endpoint_IsConfigured(void);
                                
                                 *  interrupt duration has elapsed. Which endpoints have interrupted can be determined by
                                 *  masking the return value against (1 << {Endpoint Number}).
                                 *
                                 *  interrupt duration has elapsed. Which endpoints have interrupted can be determined by
                                 *  masking the return value against (1 << {Endpoint Number}).
                                 *
-                                *  \return Mask whose bits indicate which endpoints have interrupted
+                                *  \return Mask whose bits indicate which endpoints have interrupted.
                                 */
                                static inline uint8_t Endpoint_GetEndpointInterrupts(void);
                                
                                /** Determines if the specified endpoint number has interrupted (valid only for INTERRUPT type
                                 *  endpoints).
                                 *
                                 */
                                static inline uint8_t Endpoint_GetEndpointInterrupts(void);
                                
                                /** Determines if the specified endpoint number has interrupted (valid only for INTERRUPT type
                                 *  endpoints).
                                 *
-                                *  \param[in] EndpointNumber  Index of the endpoint whose interrupt flag should be tested
+                                *  \param[in] EndpointNumber  Index of the endpoint whose interrupt flag should be tested.
                                 *
                                 *
-                                *  \return Boolean true if the specified endpoint has interrupted, false otherwise
+                                *  \return Boolean true if the specified endpoint has interrupted, false otherwise.
                                 */
                                static inline bool Endpoint_HasEndpointInterrupted(uint8_t EndpointNumber);
                                
                                 */
                                static inline bool Endpoint_HasEndpointInterrupted(uint8_t EndpointNumber);
                                
                                 *
                                 *  \ingroup Group_EndpointPacketManagement
                                 *
                                 *
                                 *  \ingroup Group_EndpointPacketManagement
                                 *
-                                *  \return Boolean true if the currently selected endpoint is stalled, false otherwise
+                                *  \return Boolean true if the currently selected endpoint is stalled, false otherwise.
                                 */
                                static inline bool Endpoint_IsStalled(void);
                                
                                 */
                                static inline bool Endpoint_IsStalled(void);
                                
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
-                        *  \return Next byte in the currently selected endpoint's FIFO buffer
+                        *  \return Next byte in the currently selected endpoint's FIFO buffer.
                         */
                        static inline uint8_t Endpoint_Read_Byte(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
                        static inline uint8_t Endpoint_Read_Byte(void)
                         */
                        static inline uint8_t Endpoint_Read_Byte(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
                        static inline uint8_t Endpoint_Read_Byte(void)
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
-                        *  \param[in] Byte  Next byte to write into the the currently selected endpoint's FIFO buffer
+                        *  \param[in] Byte  Next byte to write into the the currently selected endpoint's FIFO buffer.
                         */
                        static inline void Endpoint_Write_Byte(const uint8_t Byte) ATTR_ALWAYS_INLINE;
                        static inline void Endpoint_Write_Byte(const uint8_t Byte)
                         */
                        static inline void Endpoint_Write_Byte(const uint8_t Byte) ATTR_ALWAYS_INLINE;
                        static inline void Endpoint_Write_Byte(const uint8_t Byte)
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
-                        *  \return Next word in the currently selected endpoint's FIFO buffer
+                        *  \return Next word in the currently selected endpoint's FIFO buffer.
                         */
                        static inline uint16_t Endpoint_Read_Word_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
                        static inline uint16_t Endpoint_Read_Word_LE(void)
                         */
                        static inline uint16_t Endpoint_Read_Word_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
                        static inline uint16_t Endpoint_Read_Word_LE(void)
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
-                        *  \return Next word in the currently selected endpoint's FIFO buffer
+                        *  \return Next word in the currently selected endpoint's FIFO buffer.
                         */
                        static inline uint16_t Endpoint_Read_Word_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
                        static inline uint16_t Endpoint_Read_Word_BE(void)
                         */
                        static inline uint16_t Endpoint_Read_Word_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
                        static inline uint16_t Endpoint_Read_Word_BE(void)
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
-                        *  \param[in] Word  Next word to write to the currently selected endpoint's FIFO buffer
+                        *  \param[in] Word  Next word to write to the currently selected endpoint's FIFO buffer.
                         */
                        static inline void Endpoint_Write_Word_LE(const uint16_t Word) ATTR_ALWAYS_INLINE;
                        static inline void Endpoint_Write_Word_LE(const uint16_t Word)
                         */
                        static inline void Endpoint_Write_Word_LE(const uint16_t Word) ATTR_ALWAYS_INLINE;
                        static inline void Endpoint_Write_Word_LE(const uint16_t Word)
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
-                        *  \param[in] Word  Next word to write to the currently selected endpoint's FIFO buffer
+                        *  \param[in] Word  Next word to write to the currently selected endpoint's FIFO buffer.
                         */
                        static inline void Endpoint_Write_Word_BE(const uint16_t Word) ATTR_ALWAYS_INLINE;
                        static inline void Endpoint_Write_Word_BE(const uint16_t Word)
                         */
                        static inline void Endpoint_Write_Word_BE(const uint16_t Word) ATTR_ALWAYS_INLINE;
                        static inline void Endpoint_Write_Word_BE(const uint16_t Word)
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
-                        *  \return Next double word in the currently selected endpoint's FIFO buffer
+                        *  \return Next double word in the currently selected endpoint's FIFO buffer.
                         */
                        static inline uint32_t Endpoint_Read_DWord_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
                        static inline uint32_t Endpoint_Read_DWord_LE(void)
                         */
                        static inline uint32_t Endpoint_Read_DWord_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
                        static inline uint32_t Endpoint_Read_DWord_LE(void)
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
-                        *  \return Next double word in the currently selected endpoint's FIFO buffer
+                        *  \return Next double word in the currently selected endpoint's FIFO buffer.
                         */
                        static inline uint32_t Endpoint_Read_DWord_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
                        static inline uint32_t Endpoint_Read_DWord_BE(void)
                         */
                        static inline uint32_t Endpoint_Read_DWord_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
                        static inline uint32_t Endpoint_Read_DWord_BE(void)
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
-                        *  \param[in] DWord  Next double word to write to the currently selected endpoint's FIFO buffer
+                        *  \param[in] DWord  Next double word to write to the currently selected endpoint's FIFO buffer.
                         */
                        static inline void Endpoint_Write_DWord_LE(const uint32_t DWord) ATTR_ALWAYS_INLINE;
                        static inline void Endpoint_Write_DWord_LE(const uint32_t DWord)
                         */
                        static inline void Endpoint_Write_DWord_LE(const uint32_t DWord) ATTR_ALWAYS_INLINE;
                        static inline void Endpoint_Write_DWord_LE(const uint32_t DWord)
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
                         *
                         *  \ingroup Group_EndpointPrimitiveRW
                         *
-                        *  \param[in] DWord  Next double word to write to the currently selected endpoint's FIFO buffer
+                        *  \param[in] DWord  Next double word to write to the currently selected endpoint's FIFO buffer.
                         */
                        static inline void Endpoint_Write_DWord_BE(const uint32_t DWord) ATTR_ALWAYS_INLINE;
                        static inline void Endpoint_Write_DWord_BE(const uint32_t DWord)
                         */
                        static inline void Endpoint_Write_DWord_BE(const uint32_t DWord) ATTR_ALWAYS_INLINE;
                        static inline void Endpoint_Write_DWord_BE(const uint32_t DWord)
                         *
                         *  The banking mode may be either \ref ENDPOINT_BANK_SINGLE or \ref ENDPOINT_BANK_DOUBLE.
                         *
                         *
                         *  The banking mode may be either \ref ENDPOINT_BANK_SINGLE or \ref ENDPOINT_BANK_DOUBLE.
                         *
-                        *  \note The default control endpoint does not have to be manually configured, as it is automatically
-                        *        configured by the library internally.
+                        *  \note The default control endpoint should not be manually configured by the user application, as 
+                        *        it is automatically configured by the library internally.
                         *        \n\n
                         *
                         *  \note This routine will select the specified endpoint, and the endpoint will remain selected
                         *        once the routine completes regardless of if the endpoint configuration succeeds.
                         *
                         *        \n\n
                         *
                         *  \note This routine will select the specified endpoint, and the endpoint will remain selected
                         *        once the routine completes regardless of if the endpoint configuration succeeds.
                         *
-                        *  \return Boolean true if the configuration succeeded, false otherwise
+                        *  \return Boolean true if the configuration succeeded, false otherwise.
                         */
                        bool Endpoint_ConfigureEndpoint(const uint8_t  Number, const uint8_t Type, const uint8_t Direction,
                                                        const uint16_t Size, const uint8_t Banks);
                         */
                        bool Endpoint_ConfigureEndpoint(const uint8_t  Number, const uint8_t Type, const uint8_t Direction,
                                                        const uint16_t Size, const uint8_t Banks);
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[in] Length    Number of bytes to send via the currently selected endpoint.
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[in] Length    Number of bytes to send via the currently selected endpoint.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
 
                        /** FLASH buffer source version of \ref Endpoint_Write_Stream_LE().
                         *
 
                        /** FLASH buffer source version of \ref Endpoint_Write_Stream_LE().
                         *
-                        *  \note The FLASH data must be located in the first 64KB of FLASH for this function to work correctly.
+                        *  \pre The FLASH data must be located in the first 64KB of FLASH for this function to work correctly.
                         *
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
                         *
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
 
                        /** FLASH buffer source version of \ref Endpoint_Write_Stream_BE().
                         *
 
                        /** FLASH buffer source version of \ref Endpoint_Write_Stream_BE().
                         *
-                        *  \note The FLASH data must be located in the first 64KB of FLASH for this function to work correctly.
+                        *  \pre The FLASH data must be located in the first 64KB of FLASH for this function to work correctly.
                         *
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
                         *
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[in] Buffer    Pointer to the source data buffer to read from.
                         *  \param[in] Length    Number of bytes to read for the currently selected endpoint into the buffer.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \param[out] Buffer   Pointer to the destination data buffer to write to.
                         *  \param[in] Length    Number of bytes to send via the currently selected endpoint.
                         *
                         *  \param[out] Buffer   Pointer to the destination data buffer to write to.
                         *  \param[in] Length    Number of bytes to send via the currently selected endpoint.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \param[out] Buffer   Pointer to the destination data buffer to write to, located in EEPROM memory space.
                         *  \param[in] Length    Number of bytes to send via the currently selected endpoint.
                         *
                         *  \param[out] Buffer   Pointer to the destination data buffer to write to, located in EEPROM memory space.
                         *  \param[in] Length    Number of bytes to send via the currently selected endpoint.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \param[out] Buffer    Pointer to the destination data buffer to write to.
                         *  \param[in] Length    Number of bytes to send via the currently selected endpoint.
                         *
                         *  \param[out] Buffer    Pointer to the destination data buffer to write to.
                         *  \param[in] Length    Number of bytes to send via the currently selected endpoint.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \param[out] Buffer   Pointer to the destination data buffer to write to, located in EEPROM memory space.
                         *  \param[in] Length    Number of bytes to send via the currently selected endpoint.
                         *
                         *  \param[out] Buffer   Pointer to the destination data buffer to write to, located in EEPROM memory space.
                         *  \param[in] Length    Number of bytes to send via the currently selected endpoint.
-                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback
+                        *  \param[in] Callback  Name of a callback routine to call between successive USB packet transfers, NULL if no callback.
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_Stream_RW_ErrorCodes_t enum.
                         */
 
                        /** FLASH buffer source version of \ref Endpoint_Write_Control_Stream_LE().
                         *
 
                        /** FLASH buffer source version of \ref Endpoint_Write_Control_Stream_LE().
                         *
+                        *  \pre The FLASH data must be located in the first 64KB of FLASH for this function to work correctly.
+                        *
                         *  \note This function automatically clears the control transfer's status stage. Do not manually attempt
                         *        to clear the status stage when using this routine in a control transaction.
                         *        \n\n
                         *
                         *  \note This function automatically clears the control transfer's status stage. Do not manually attempt
                         *        to clear the status stage when using this routine in a control transaction.
                         *        \n\n
                         *
-                        *  \note The FLASH data must be located in the first 64KB of FLASH for this function to work correctly.
-                        *        \n\n
-                        *
                         *  \note This routine should only be used on CONTROL type endpoints.
                         *
                         *  \warning Unlike the standard stream read/write commands, the control stream commands cannot be chained
                         *  \note This routine should only be used on CONTROL type endpoints.
                         *
                         *  \warning Unlike the standard stream read/write commands, the control stream commands cannot be chained
 
                        /** FLASH buffer source version of \ref Endpoint_Write_Control_Stream_BE().
                         *
 
                        /** FLASH buffer source version of \ref Endpoint_Write_Control_Stream_BE().
                         *
+                        *  \pre The FLASH data must be located in the first 64KB of FLASH for this function to work correctly.
+                        *
                         *  \note This function automatically clears the control transfer's status stage. Do not manually attempt
                         *        to clear the status stage when using this routine in a control transaction.
                         *        \n\n
                         *
                         *  \note This function automatically clears the control transfer's status stage. Do not manually attempt
                         *        to clear the status stage when using this routine in a control transaction.
                         *        \n\n
                         *
-                        *  \note The FLASH data must be located in the first 64KB of FLASH for this function to work correctly.
-                        *        \n\n
-                        *
                         *  \note This routine should only be used on CONTROL type endpoints.
                         *
                         *  \warning Unlike the standard stream read/write commands, the control stream commands cannot be chained
                         *  \note This routine should only be used on CONTROL type endpoints.
                         *
                         *  \warning Unlike the standard stream read/write commands, the control stream commands cannot be chained
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[out] Buffer  Pointer to the destination data buffer to write to.
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[out] Buffer  Pointer to the destination data buffer to write to.
-                        *  \param[in] Length  Number of bytes to send via the currently selected endpoint.
+                        *  \param[in]  Length  Number of bytes to send via the currently selected endpoint.
                         *
                         *  \return A value from the \ref Endpoint_ControlStream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_ControlStream_RW_ErrorCodes_t enum.
                         */
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[out] Buffer  Pointer to the destination data buffer to write to.
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[out] Buffer  Pointer to the destination data buffer to write to.
-                        *  \param[in] Length  Number of bytes to send via the currently selected endpoint.
+                        *  \param[in]  Length  Number of bytes to send via the currently selected endpoint.
                         *
                         *  \return A value from the \ref Endpoint_ControlStream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_ControlStream_RW_ErrorCodes_t enum.
                         */
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[out] Buffer  Pointer to the destination data buffer to write to.
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[out] Buffer  Pointer to the destination data buffer to write to.
-                        *  \param[in] Length  Number of bytes to send via the currently selected endpoint.
+                        *  \param[in]  Length  Number of bytes to send via the currently selected endpoint.
                         *
                         *  \return A value from the \ref Endpoint_ControlStream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_ControlStream_RW_ErrorCodes_t enum.
                         */
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[out] Buffer  Pointer to the destination data buffer to write to.
                         *  \ingroup Group_EndpointStreamRW
                         *
                         *  \param[out] Buffer  Pointer to the destination data buffer to write to.
-                        *  \param[in] Length  Number of bytes to send via the currently selected endpoint.
+                        *  \param[in]  Length  Number of bytes to send via the currently selected endpoint.
                         *
                         *  \return A value from the \ref Endpoint_ControlStream_RW_ErrorCodes_t enum.
                         */
                         *
                         *  \return A value from the \ref Endpoint_ControlStream_RW_ErrorCodes_t enum.
                         */