\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
}\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
\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
}\r
}\r
\r
- return ENDPOINT_RWSTREAM_ERROR_NoError;\r
+ return ENDPOINT_RWSTREAM_NoError;\r
}\r
\r
uint8_t Endpoint_Write_Stream_BE(const void* Buffer, uint16_t Length\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
}\r
}\r
\r
- return ENDPOINT_RWSTREAM_ERROR_NoError;\r
+ return ENDPOINT_RWSTREAM_NoError;\r
}\r
\r
uint8_t Endpoint_Read_Stream_LE(void* Buffer, uint16_t Length\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
}\r
}\r
\r
- return ENDPOINT_RWSTREAM_ERROR_NoError;\r
+ return ENDPOINT_RWSTREAM_NoError;\r
}\r
\r
uint8_t Endpoint_Read_Stream_BE(void* Buffer, uint16_t Length\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
}\r
}\r
\r
- return ENDPOINT_RWSTREAM_ERROR_NoError;\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
+ uint8_t* DataStream = (uint8_t*)Buffer;\r
bool LastPacketFull = false;\r
- bool ShortTransfer = (Length < USB_ControlRequest.wLength);\r
+ \r
+ if (Length > USB_ControlRequest.wLength)\r
+ Length = USB_ControlRequest.wLength;\r
\r
while (Length && !(Endpoint_IsOUTReceived()))\r
{\r
}\r
\r
if (Endpoint_IsOUTReceived())\r
- return ENDPOINT_RWCSTREAM_ERROR_HostAborted;\r
+ return ENDPOINT_RWCSTREAM_HostAborted;\r
\r
- if (LastPacketFull || ShortTransfer)\r
+ if (LastPacketFull)\r
{\r
while (!(Endpoint_IsINReady()));\r
Endpoint_ClearIN();\r
\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 LastPacketFull = false;\r
- bool ShortTransfer = (Length < USB_ControlRequest.wLength);\r
\r
+ if (Length > USB_ControlRequest.wLength)\r
+ Length = USB_ControlRequest.wLength;\r
+\r
while (Length && !(Endpoint_IsOUTReceived()))\r
{\r
- while (!(Endpoint_IsINReady()));\r
- \r
- while (Length && (Endpoint_BytesInEndpoint() < USB_ControlEndpointSize))\r
+ if (Endpoint_IsINReady())\r
{\r
- Endpoint_Write_Byte(*(DataStream--));\r
- Length--;\r
+ while (Length && (Endpoint_BytesInEndpoint() < USB_ControlEndpointSize))\r
+ {\r
+ Endpoint_Write_Byte(*(DataStream--));\r
+ Length--;\r
+ }\r
+ \r
+ LastPacketFull = (Endpoint_BytesInEndpoint() == USB_ControlEndpointSize);\r
+ Endpoint_ClearIN();\r
}\r
- \r
- LastPacketFull = (Endpoint_BytesInEndpoint() == USB_ControlEndpointSize);\r
- Endpoint_ClearIN();\r
}\r
\r
if (Endpoint_IsOUTReceived())\r
- return ENDPOINT_RWCSTREAM_ERROR_HostAborted;\r
+ return ENDPOINT_RWCSTREAM_HostAborted;\r
\r
- if (LastPacketFull || ShortTransfer)\r
+ if (LastPacketFull)\r
{\r
while (!(Endpoint_IsINReady()));\r
Endpoint_ClearIN();\r
\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_IsOUTReceived()));\r
- \r
- while (Length && Endpoint_BytesInEndpoint())\r
+ if (Endpoint_IsOUTReceived())\r
{\r
- *(DataStream++) = Endpoint_Read_Byte();\r
- Length--;\r
+ while (Length && Endpoint_BytesInEndpoint())\r
+ {\r
+ *(DataStream++) = Endpoint_Read_Byte();\r
+ Length--;\r
+ }\r
+ \r
+ Endpoint_ClearOUT();\r
}\r
- \r
- Endpoint_ClearOUT();\r
}\r
\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_IsOUTReceived()));\r
- \r
- while (Length && Endpoint_BytesInEndpoint())\r
+ if (Endpoint_IsOUTReceived())\r
{\r
- *(DataStream--) = Endpoint_Read_Byte();\r
- Length--;\r
+ while (Length && Endpoint_BytesInEndpoint())\r
+ {\r
+ *(DataStream--) = Endpoint_Read_Byte();\r
+ Length--;\r
+ }\r
+ \r
+ Endpoint_ClearOUT();\r
}\r
- \r
- Endpoint_ClearOUT();\r
}\r
\r
while (!(Endpoint_IsINReady()));\r
\r
- return ENDPOINT_RWCSTREAM_ERROR_NoError;\r
+ return ENDPOINT_RWCSTREAM_NoError;\r
}\r
\r
#endif\r