this software.\r
*/\r
\r
-#include "USBMode.h"\r
+#include "../HighLevel/USBMode.h"\r
+\r
#if defined(USB_CAN_BE_DEVICE)\r
\r
#define INCLUDE_FROM_ENDPOINT_C\r
uint8_t USB_ControlEndpointSize = ENDPOINT_CONTROLEP_DEFAULT_SIZE;\r
#endif\r
\r
-#if !defined(STATIC_ENDPOINT_CONFIGURATION)\r
-bool Endpoint_ConfigureEndpoint(const uint8_t Number, const uint8_t Type, const uint8_t Direction,\r
- const uint16_t Size, const uint8_t Banks)\r
+uint8_t Endpoint_BytesToEPSizeMaskDynamic(const uint16_t Size)\r
{\r
- Endpoint_SelectEndpoint(Number);\r
- Endpoint_EnableEndpoint();\r
-\r
- UECFG1X = 0; \r
-\r
- UECFG0X = ((Type << EPTYPE0) | Direction);\r
- UECFG1X = ((1 << ALLOC) | Banks | Endpoint_BytesToEPSizeMask(Size));\r
-\r
- return Endpoint_IsConfigured();\r
+ return Endpoint_BytesToEPSizeMask(Size);\r
}\r
-#else\r
-bool Endpoint_ConfigureEndpointStatic(const uint8_t Number, const uint8_t UECFG0XData, const uint8_t UECFG1XData)\r
+\r
+bool Endpoint_ConfigureEndpoint_Prv(const uint8_t Number, const uint8_t UECFG0XData, const uint8_t UECFG1XData)\r
{\r
Endpoint_SelectEndpoint(Number);\r
Endpoint_EnableEndpoint();\r
\r
- UECFG1X = 0; \r
+ UECFG1X = 0;\r
\r
UECFG0X = UECFG0XData;\r
UECFG1X = UECFG1XData;\r
\r
return Endpoint_IsConfigured();\r
}\r
-#endif\r
\r
void Endpoint_ClearEndpoints(void)\r
{\r
}\r
}\r
\r
+#if !defined(CONTROL_ONLY_DEVICE)\r
uint8_t Endpoint_WaitUntilReady(void)\r
{\r
- uint8_t TimeoutMSRem = USB_STREAM_TIMEOUT_MS;\r
+ #if (USB_STREAM_TIMEOUT_MS < 0xFF)\r
+ uint8_t TimeoutMSRem = USB_STREAM_TIMEOUT_MS; \r
+ #else\r
+ uint16_t TimeoutMSRem = USB_STREAM_TIMEOUT_MS;\r
+ #endif\r
\r
- USB_INT_Clear(USB_INT_SOFI);\r
-\r
- while (!(Endpoint_ReadWriteAllowed()))\r
+ for (;;)\r
{\r
+ if (Endpoint_GetEndpointDirection() == ENDPOINT_DIR_IN)\r
+ {\r
+ if (Endpoint_IsINReady())\r
+ return ENDPOINT_READYWAIT_NoError;\r
+ }\r
+ else\r
+ {\r
+ if (Endpoint_IsOUTReceived())\r
+ return ENDPOINT_READYWAIT_NoError; \r
+ }\r
+ \r
if (!(USB_IsConnected))\r
return ENDPOINT_READYWAIT_DeviceDisconnected;\r
else if (Endpoint_IsStalled())\r
return ENDPOINT_READYWAIT_Timeout;\r
}\r
}\r
- \r
- return ENDPOINT_READYWAIT_NoError;\r
}\r
\r
uint8_t Endpoint_Discard_Stream(uint16_t Length\r
#if !defined(NO_STREAM_CALLBACKS)\r
- , uint8_t (* const Callback)(void)\r
+ , StreamCallbackPtr_t Callback\r
#endif\r
)\r
{\r
if ((ErrorCode = Endpoint_WaitUntilReady()))\r
return ErrorCode;\r
\r
- while (Length--)\r
+ #if defined(FAST_STREAM_TRANSFERS)\r
+ uint8_t BytesRemToAlignment = (Endpoint_BytesInEndpoint() & 0x07);\r
+\r
+ if (Length >= 8)\r
{\r
- if (!(Endpoint_ReadWriteAllowed()))\r
+ Length -= BytesRemToAlignment;\r
+\r
+ switch (BytesRemToAlignment)\r
{\r
- Endpoint_ClearCurrentBank();\r
+ default:\r
+ do\r
+ {\r
+ if (!(Endpoint_IsReadWriteAllowed()))\r
+ {\r
+ Endpoint_ClearOUT();\r
+\r
+ #if !defined(NO_STREAM_CALLBACKS)\r
+ if ((Callback != NULL) && (Callback() == STREAMCALLBACK_Abort))\r
+ return ENDPOINT_RWSTREAM_CallbackAborted;\r
+ #endif\r
+\r
+ if ((ErrorCode = Endpoint_WaitUntilReady()))\r
+ return ErrorCode;\r
+ }\r
+\r
+ Length -= 8;\r
+ \r
+ Endpoint_Discard_Byte();\r
+ case 7: Endpoint_Discard_Byte();\r
+ case 6: Endpoint_Discard_Byte();\r
+ case 5: Endpoint_Discard_Byte();\r
+ case 4: Endpoint_Discard_Byte();\r
+ case 3: Endpoint_Discard_Byte();\r
+ case 2: Endpoint_Discard_Byte();\r
+ case 1: Endpoint_Discard_Byte();\r
+ } while (Length >= 8); \r
+ }\r
+ }\r
+ #endif\r
+\r
+ while (Length)\r
+ {\r
+ if (!(Endpoint_IsReadWriteAllowed()))\r
+ {\r
+ Endpoint_ClearOUT();\r
\r
#if !defined(NO_STREAM_CALLBACKS)\r
if ((Callback != NULL) && (Callback() == STREAMCALLBACK_Abort))\r
- return ENDPOINT_RWSTREAM_ERROR_CallbackAborted;\r
+ return ENDPOINT_RWSTREAM_CallbackAborted;\r
#endif\r
\r
if ((ErrorCode = Endpoint_WaitUntilReady()))\r
return ErrorCode;\r
}\r
-\r
- Endpoint_Discard_Byte();\r
+ else\r
+ {\r
+ Endpoint_Discard_Byte();\r
+ Length--;\r
+ }\r
}\r
\r
- return ENDPOINT_RWSTREAM_ERROR_NoError;\r
+ return ENDPOINT_RWSTREAM_NoError;\r
}\r
\r
uint8_t Endpoint_Write_Stream_LE(const void* Buffer, uint16_t Length\r
#if !defined(NO_STREAM_CALLBACKS)\r
- , uint8_t (* const Callback)(void)\r
+ , StreamCallbackPtr_t Callback\r
#endif\r
)\r
{\r
if ((ErrorCode = Endpoint_WaitUntilReady()))\r
return ErrorCode;\r
\r
- while (Length--)\r
+ #if defined(FAST_STREAM_TRANSFERS)\r
+ uint8_t BytesRemToAlignment = (Endpoint_BytesInEndpoint() & 0x07);\r
+\r
+ if (Length >= 8)\r
+ {\r
+ Length -= BytesRemToAlignment;\r
+\r
+ switch (BytesRemToAlignment)\r
+ {\r
+ default:\r
+ do\r
+ {\r
+ if (!(Endpoint_IsReadWriteAllowed()))\r
+ {\r
+ Endpoint_ClearIN();\r
+\r
+ #if !defined(NO_STREAM_CALLBACKS)\r
+ if ((Callback != NULL) && (Callback() == STREAMCALLBACK_Abort))\r
+ return ENDPOINT_RWSTREAM_CallbackAborted;\r
+ #endif\r
+\r
+ if ((ErrorCode = Endpoint_WaitUntilReady()))\r
+ return ErrorCode;\r
+ }\r
+\r
+ Length -= 8;\r
+ \r
+ Endpoint_Write_Byte(*(DataStream++));\r
+ case 7: Endpoint_Write_Byte(*(DataStream++));\r
+ case 6: Endpoint_Write_Byte(*(DataStream++));\r
+ case 5: Endpoint_Write_Byte(*(DataStream++));\r
+ case 4: Endpoint_Write_Byte(*(DataStream++));\r
+ case 3: Endpoint_Write_Byte(*(DataStream++));\r
+ case 2: Endpoint_Write_Byte(*(DataStream++));\r
+ case 1: Endpoint_Write_Byte(*(DataStream++));\r
+ } while (Length >= 8); \r
+ }\r
+ }\r
+ #endif\r
+\r
+ while (Length)\r
{\r
- if (!(Endpoint_ReadWriteAllowed()))\r
+ if (!(Endpoint_IsReadWriteAllowed()))\r
{\r
- Endpoint_ClearCurrentBank();\r
+ Endpoint_ClearIN();\r
\r
#if !defined(NO_STREAM_CALLBACKS)\r
if ((Callback != NULL) && (Callback() == STREAMCALLBACK_Abort))\r
- return ENDPOINT_RWSTREAM_ERROR_CallbackAborted;\r
+ return ENDPOINT_RWSTREAM_CallbackAborted;\r
#endif\r
\r
if ((ErrorCode = Endpoint_WaitUntilReady()))\r
return ErrorCode;\r
}\r
-\r
- Endpoint_Write_Byte(*(DataStream++));\r
+ else\r
+ {\r
+ Endpoint_Write_Byte(*(DataStream++));\r
+ Length--;\r
+ }\r
}\r
- \r
- return ENDPOINT_RWSTREAM_ERROR_NoError;\r
+\r
+ return ENDPOINT_RWSTREAM_NoError;\r
}\r
\r
uint8_t Endpoint_Write_Stream_BE(const void* Buffer, uint16_t Length\r
#if !defined(NO_STREAM_CALLBACKS)\r
- , uint8_t (* const Callback)(void)\r
+ , StreamCallbackPtr_t Callback\r
#endif\r
)\r
{\r
if ((ErrorCode = Endpoint_WaitUntilReady()))\r
return ErrorCode;\r
\r
- while (Length--)\r
+ #if defined(FAST_STREAM_TRANSFERS)\r
+ uint8_t BytesRemToAlignment = (Endpoint_BytesInEndpoint() & 0x07);\r
+\r
+ if (Length >= 8)\r
{\r
- if (!(Endpoint_ReadWriteAllowed()))\r
+ Length -= BytesRemToAlignment;\r
+\r
+ switch (BytesRemToAlignment)\r
{\r
- Endpoint_ClearCurrentBank();\r
+ default:\r
+ do\r
+ {\r
+ if (!(Endpoint_IsReadWriteAllowed()))\r
+ {\r
+ Endpoint_ClearIN();\r
+\r
+ #if !defined(NO_STREAM_CALLBACKS)\r
+ if ((Callback != NULL) && (Callback() == STREAMCALLBACK_Abort))\r
+ return ENDPOINT_RWSTREAM_CallbackAborted;\r
+ #endif\r
+\r
+ if ((ErrorCode = Endpoint_WaitUntilReady()))\r
+ return ErrorCode;\r
+ }\r
+\r
+ Length -= 8;\r
+ \r
+ Endpoint_Write_Byte(*(DataStream--));\r
+ case 7: Endpoint_Write_Byte(*(DataStream--));\r
+ case 6: Endpoint_Write_Byte(*(DataStream--));\r
+ case 5: Endpoint_Write_Byte(*(DataStream--));\r
+ case 4: Endpoint_Write_Byte(*(DataStream--));\r
+ case 3: Endpoint_Write_Byte(*(DataStream--));\r
+ case 2: Endpoint_Write_Byte(*(DataStream--));\r
+ case 1: Endpoint_Write_Byte(*(DataStream--));\r
+ } while (Length >= 8); \r
+ }\r
+ }\r
+ #endif\r
+\r
+ while (Length)\r
+ {\r
+ if (!(Endpoint_IsReadWriteAllowed()))\r
+ {\r
+ Endpoint_ClearIN();\r
\r
#if !defined(NO_STREAM_CALLBACKS)\r
if ((Callback != NULL) && (Callback() == STREAMCALLBACK_Abort))\r
- return ENDPOINT_RWSTREAM_ERROR_CallbackAborted;\r
+ return ENDPOINT_RWSTREAM_CallbackAborted;\r
#endif\r
\r
if ((ErrorCode = Endpoint_WaitUntilReady()))\r
return ErrorCode;\r
}\r
-\r
- Endpoint_Write_Byte(*(DataStream--));\r
+ else\r
+ {\r
+ Endpoint_Write_Byte(*(DataStream--));\r
+ Length--;\r
+ }\r
}\r
- \r
- return ENDPOINT_RWSTREAM_ERROR_NoError;\r
+\r
+ return ENDPOINT_RWSTREAM_NoError;\r
}\r
\r
uint8_t Endpoint_Read_Stream_LE(void* Buffer, uint16_t Length\r
#if !defined(NO_STREAM_CALLBACKS)\r
- , uint8_t (* const Callback)(void)\r
+ , StreamCallbackPtr_t Callback\r
#endif\r
)\r
{\r
if ((ErrorCode = Endpoint_WaitUntilReady()))\r
return ErrorCode;\r
\r
- while (Length--)\r
+ #if defined(FAST_STREAM_TRANSFERS)\r
+ uint8_t BytesRemToAlignment = (Endpoint_BytesInEndpoint() & 0x07);\r
+\r
+ if (Length >= 8)\r
+ {\r
+ Length -= BytesRemToAlignment;\r
+\r
+ switch (BytesRemToAlignment)\r
+ {\r
+ default:\r
+ do\r
+ {\r
+ if (!(Endpoint_IsReadWriteAllowed()))\r
+ {\r
+ Endpoint_ClearOUT();\r
+\r
+ #if !defined(NO_STREAM_CALLBACKS)\r
+ if ((Callback != NULL) && (Callback() == STREAMCALLBACK_Abort))\r
+ return ENDPOINT_RWSTREAM_CallbackAborted;\r
+ #endif\r
+\r
+ if ((ErrorCode = Endpoint_WaitUntilReady()))\r
+ return ErrorCode;\r
+ }\r
+\r
+ Length -= 8;\r
+ \r
+ *(DataStream++) = Endpoint_Read_Byte();\r
+ case 7: *(DataStream++) = Endpoint_Read_Byte();\r
+ case 6: *(DataStream++) = Endpoint_Read_Byte();\r
+ case 5: *(DataStream++) = Endpoint_Read_Byte();\r
+ case 4: *(DataStream++) = Endpoint_Read_Byte();\r
+ case 3: *(DataStream++) = Endpoint_Read_Byte();\r
+ case 2: *(DataStream++) = Endpoint_Read_Byte();\r
+ case 1: *(DataStream++) = Endpoint_Read_Byte();\r
+ } while (Length >= 8); \r
+ }\r
+ }\r
+ #endif\r
+\r
+ while (Length)\r
{\r
- if (!(Endpoint_ReadWriteAllowed()))\r
+ if (!(Endpoint_IsReadWriteAllowed()))\r
{\r
- Endpoint_ClearCurrentBank();\r
+ Endpoint_ClearOUT();\r
\r
#if !defined(NO_STREAM_CALLBACKS)\r
if ((Callback != NULL) && (Callback() == STREAMCALLBACK_Abort))\r
- return ENDPOINT_RWSTREAM_ERROR_CallbackAborted;\r
+ return ENDPOINT_RWSTREAM_CallbackAborted;\r
#endif\r
\r
if ((ErrorCode = Endpoint_WaitUntilReady()))\r
return ErrorCode;\r
}\r
- \r
- *(DataStream++) = Endpoint_Read_Byte();\r
+ else\r
+ {\r
+ *(DataStream++) = Endpoint_Read_Byte();\r
+ Length--;\r
+ }\r
}\r
- \r
- return ENDPOINT_RWSTREAM_ERROR_NoError;\r
+\r
+ return ENDPOINT_RWSTREAM_NoError;\r
}\r
\r
uint8_t Endpoint_Read_Stream_BE(void* Buffer, uint16_t Length\r
#if !defined(NO_STREAM_CALLBACKS)\r
- , uint8_t (* const Callback)(void)\r
+ , StreamCallbackPtr_t Callback\r
#endif\r
)\r
{\r
if ((ErrorCode = Endpoint_WaitUntilReady()))\r
return ErrorCode;\r
\r
- while (Length--)\r
+ #if defined(FAST_STREAM_TRANSFERS)\r
+ uint8_t BytesRemToAlignment = (Endpoint_BytesInEndpoint() & 0x07);\r
+\r
+ if (Length >= 8)\r
+ {\r
+ Length -= BytesRemToAlignment;\r
+\r
+ switch (BytesRemToAlignment)\r
+ {\r
+ default:\r
+ do\r
+ {\r
+ if (!(Endpoint_IsReadWriteAllowed()))\r
+ {\r
+ Endpoint_ClearOUT();\r
+\r
+ #if !defined(NO_STREAM_CALLBACKS)\r
+ if ((Callback != NULL) && (Callback() == STREAMCALLBACK_Abort))\r
+ return ENDPOINT_RWSTREAM_CallbackAborted;\r
+ #endif\r
+\r
+ if ((ErrorCode = Endpoint_WaitUntilReady()))\r
+ return ErrorCode;\r
+ }\r
+\r
+ Length -= 8;\r
+ \r
+ *(DataStream--) = Endpoint_Read_Byte();\r
+ case 7: *(DataStream--) = Endpoint_Read_Byte();\r
+ case 6: *(DataStream--) = Endpoint_Read_Byte();\r
+ case 5: *(DataStream--) = Endpoint_Read_Byte();\r
+ case 4: *(DataStream--) = Endpoint_Read_Byte();\r
+ case 3: *(DataStream--) = Endpoint_Read_Byte();\r
+ case 2: *(DataStream--) = Endpoint_Read_Byte();\r
+ case 1: *(DataStream--) = Endpoint_Read_Byte();\r
+ } while (Length >= 8); \r
+ }\r
+ }\r
+ #endif\r
+\r
+ while (Length)\r
{\r
- if (!(Endpoint_ReadWriteAllowed()))\r
+ if (!(Endpoint_IsReadWriteAllowed()))\r
{\r
- Endpoint_ClearCurrentBank();\r
+ Endpoint_ClearOUT();\r
\r
#if !defined(NO_STREAM_CALLBACKS)\r
if ((Callback != NULL) && (Callback() == STREAMCALLBACK_Abort))\r
- return ENDPOINT_RWSTREAM_ERROR_CallbackAborted;\r
+ return ENDPOINT_RWSTREAM_CallbackAborted;\r
#endif\r
\r
if ((ErrorCode = Endpoint_WaitUntilReady()))\r
return ErrorCode;\r
}\r
- \r
- *(DataStream--) = Endpoint_Read_Byte();\r
+ else\r
+ {\r
+ *(DataStream--) = Endpoint_Read_Byte();\r
+ Length--;\r
+ }\r
}\r
- \r
- return ENDPOINT_RWSTREAM_ERROR_NoError;\r
+\r
+ return ENDPOINT_RWSTREAM_NoError;\r
}\r
+#endif\r
\r
uint8_t Endpoint_Write_Control_Stream_LE(const void* Buffer, uint16_t Length)\r
{\r
- uint8_t* DataStream = (uint8_t*)Buffer;\r
- bool SendZLP = true;\r
+ uint8_t* DataStream = (uint8_t*)Buffer;\r
+ bool LastPacketFull = false;\r
+ \r
+ if (Length > USB_ControlRequest.wLength)\r
+ Length = USB_ControlRequest.wLength;\r
\r
- while (Length && !(Endpoint_IsSetupOUTReceived()))\r
+ while (Length && !(Endpoint_IsOUTReceived()))\r
{\r
- while (!(Endpoint_IsSetupINReady()));\r
+ while (!(Endpoint_IsINReady()));\r
\r
while (Length && (Endpoint_BytesInEndpoint() < USB_ControlEndpointSize))\r
{\r
Endpoint_Write_Byte(*(DataStream++));\r
- \r
Length--;\r
}\r
\r
- SendZLP = (Endpoint_BytesInEndpoint() == USB_ControlEndpointSize);\r
- Endpoint_ClearSetupIN();\r
+ LastPacketFull = (Endpoint_BytesInEndpoint() == USB_ControlEndpointSize);\r
+ Endpoint_ClearIN();\r
}\r
\r
- if (Endpoint_IsSetupOUTReceived())\r
- return ENDPOINT_RWCSTREAM_ERROR_HostAborted;\r
+ if (Endpoint_IsOUTReceived())\r
+ return ENDPOINT_RWCSTREAM_HostAborted;\r
\r
- if (SendZLP)\r
+ if (LastPacketFull)\r
{\r
- while (!(Endpoint_IsSetupINReady()));\r
- Endpoint_ClearSetupIN();\r
+ while (!(Endpoint_IsINReady()));\r
+ Endpoint_ClearIN();\r
}\r
\r
- while (!(Endpoint_IsSetupOUTReceived()));\r
+ while (!(Endpoint_IsOUTReceived()));\r
\r
- return ENDPOINT_RWCSTREAM_ERROR_NoError;\r
+ return ENDPOINT_RWCSTREAM_NoError;\r
}\r
\r
uint8_t Endpoint_Write_Control_Stream_BE(const void* Buffer, uint16_t Length)\r
{\r
- uint8_t* DataStream = (uint8_t*)(Buffer + Length - 1);\r
- bool SendZLP = true;\r
+ uint8_t* DataStream = (uint8_t*)(Buffer + Length - 1);\r
+ bool LastPacketFull = false;\r
\r
- while (Length && !(Endpoint_IsSetupOUTReceived()))\r
+ if (Length > USB_ControlRequest.wLength)\r
+ Length = USB_ControlRequest.wLength;\r
+\r
+ while (Length && !(Endpoint_IsOUTReceived()))\r
{\r
- while (!(Endpoint_IsSetupINReady()));\r
- \r
- while (Length && (Endpoint_BytesInEndpoint() < USB_ControlEndpointSize))\r
+ if (Endpoint_IsINReady())\r
{\r
- Endpoint_Write_Byte(*(DataStream--));\r
+ while (Length && (Endpoint_BytesInEndpoint() < USB_ControlEndpointSize))\r
+ {\r
+ Endpoint_Write_Byte(*(DataStream--));\r
+ Length--;\r
+ }\r
\r
- Length--;\r
+ LastPacketFull = (Endpoint_BytesInEndpoint() == USB_ControlEndpointSize);\r
+ Endpoint_ClearIN();\r
}\r
- \r
- SendZLP = (Endpoint_BytesInEndpoint() == USB_ControlEndpointSize);\r
- Endpoint_ClearSetupIN();\r
}\r
\r
- if (Endpoint_IsSetupOUTReceived())\r
- return ENDPOINT_RWCSTREAM_ERROR_HostAborted;\r
+ if (Endpoint_IsOUTReceived())\r
+ return ENDPOINT_RWCSTREAM_HostAborted;\r
\r
- if (SendZLP)\r
+ if (LastPacketFull)\r
{\r
- while (!(Endpoint_IsSetupINReady()));\r
- Endpoint_ClearSetupIN();\r
+ while (!(Endpoint_IsINReady()));\r
+ Endpoint_ClearIN();\r
}\r
\r
- while (!(Endpoint_IsSetupOUTReceived()));\r
+ while (!(Endpoint_IsOUTReceived()));\r
\r
- return ENDPOINT_RWCSTREAM_ERROR_NoError;\r
+ return ENDPOINT_RWCSTREAM_NoError;\r
}\r
\r
uint8_t Endpoint_Read_Control_Stream_LE(void* Buffer, uint16_t Length)\r
\r
while (Length)\r
{\r
- while (!(Endpoint_IsSetupOUTReceived()));\r
- \r
- while (Length && Endpoint_BytesInEndpoint())\r
+ if (Endpoint_IsOUTReceived())\r
{\r
- *(DataStream++) = Endpoint_Read_Byte();\r
+ while (Length && Endpoint_BytesInEndpoint())\r
+ {\r
+ *(DataStream++) = Endpoint_Read_Byte();\r
+ Length--;\r
+ }\r
\r
- Length--;\r
+ Endpoint_ClearOUT();\r
}\r
- \r
- Endpoint_ClearSetupOUT();\r
}\r
\r
- while (!(Endpoint_IsSetupINReady()));\r
+ while (!(Endpoint_IsINReady()));\r
\r
- return ENDPOINT_RWCSTREAM_ERROR_NoError;\r
+ return ENDPOINT_RWCSTREAM_NoError;\r
}\r
\r
uint8_t Endpoint_Read_Control_Stream_BE(void* Buffer, uint16_t Length)\r
\r
while (Length)\r
{\r
- while (!(Endpoint_IsSetupOUTReceived()));\r
- \r
- while (Length && Endpoint_BytesInEndpoint())\r
+ if (Endpoint_IsOUTReceived())\r
{\r
- *(DataStream--) = Endpoint_Read_Byte();\r
+ while (Length && Endpoint_BytesInEndpoint())\r
+ {\r
+ *(DataStream--) = Endpoint_Read_Byte();\r
+ Length--;\r
+ }\r
\r
- Length--;\r
+ Endpoint_ClearOUT();\r
}\r
- \r
- Endpoint_ClearSetupOUT();\r
}\r
\r
- while (!(Endpoint_IsSetupINReady()));\r
+ while (!(Endpoint_IsINReady()));\r
\r
- return ENDPOINT_RWCSTREAM_ERROR_NoError;\r
+ return ENDPOINT_RWCSTREAM_NoError;\r
}\r
\r
#endif\r