diff options
Diffstat (limited to 'Demos/Device')
28 files changed, 155 insertions, 180 deletions
| diff --git a/Demos/Device/ClassDriver/MassStorage/Lib/SCSI.c b/Demos/Device/ClassDriver/MassStorage/Lib/SCSI.c index f9cf9146f..be6a7903a 100644 --- a/Demos/Device/ClassDriver/MassStorage/Lib/SCSI.c +++ b/Demos/Device/ClassDriver/MassStorage/Lib/SCSI.c @@ -169,12 +169,10 @@ static bool SCSI_Command_Inquiry(USB_ClassInfo_MS_Device_t* const MSInterfaceInf  		return false;  	} -	Endpoint_Write_Stream_LE(&InquiryData, BytesTransferred, NO_STREAM_CALLBACK); - -	uint8_t PadBytes[AllocationLength - BytesTransferred]; +	Endpoint_Write_Stream_LE(&InquiryData, BytesTransferred, NULL);  	/* Pad out remaining bytes with 0x00 */ -	Endpoint_Write_Stream_LE(&PadBytes, sizeof(PadBytes), NO_STREAM_CALLBACK); +	Endpoint_Null_Stream((AllocationLength - BytesTransferred), NULL);  	/* Finalize the stream transfer to send the last packet */  	Endpoint_ClearIN(); @@ -197,10 +195,8 @@ static bool SCSI_Command_Request_Sense(USB_ClassInfo_MS_Device_t* const MSInterf  	uint8_t  AllocationLength = MSInterfaceInfo->State.CommandBlock.SCSICommandData[4];  	uint8_t  BytesTransferred = (AllocationLength < sizeof(SenseData))? AllocationLength : sizeof(SenseData); -	uint8_t PadBytes[AllocationLength - BytesTransferred]; - -	Endpoint_Write_Stream_LE(&SenseData, BytesTransferred, NO_STREAM_CALLBACK); -	Endpoint_Write_Stream_LE(&PadBytes, sizeof(PadBytes), NO_STREAM_CALLBACK); +	Endpoint_Write_Stream_LE(&SenseData, BytesTransferred, NULL); +	Endpoint_Null_Stream((AllocationLength - BytesTransferred), NULL);  	Endpoint_ClearIN();  	/* Succeed the command and update the bytes transferred counter */ @@ -221,8 +217,8 @@ static bool SCSI_Command_Read_Capacity_10(USB_ClassInfo_MS_Device_t* const MSInt  	uint32_t LastBlockAddressInLUN = (LUN_MEDIA_BLOCKS - 1);  	uint32_t MediaBlockSize        = VIRTUAL_MEMORY_BLOCK_SIZE; -	Endpoint_Write_Stream_BE(&LastBlockAddressInLUN, sizeof(LastBlockAddressInLUN), NO_STREAM_CALLBACK); -	Endpoint_Write_Stream_BE(&MediaBlockSize, sizeof(MediaBlockSize), NO_STREAM_CALLBACK); +	Endpoint_Write_Stream_BE(&LastBlockAddressInLUN, sizeof(LastBlockAddressInLUN), NULL); +	Endpoint_Write_Stream_BE(&MediaBlockSize, sizeof(MediaBlockSize), NULL);  	Endpoint_ClearIN();  	/* Succeed the command and update the bytes transferred counter */ diff --git a/Demos/Device/ClassDriver/MassStorageKeyboard/Lib/SCSI.c b/Demos/Device/ClassDriver/MassStorageKeyboard/Lib/SCSI.c index 73a938cbc..83719bf78 100644 --- a/Demos/Device/ClassDriver/MassStorageKeyboard/Lib/SCSI.c +++ b/Demos/Device/ClassDriver/MassStorageKeyboard/Lib/SCSI.c @@ -169,12 +169,10 @@ static bool SCSI_Command_Inquiry(USB_ClassInfo_MS_Device_t* const MSInterfaceInf  		return false;  	} -	Endpoint_Write_Stream_LE(&InquiryData, BytesTransferred, NO_STREAM_CALLBACK); - -	uint8_t PadBytes[AllocationLength - BytesTransferred]; +	Endpoint_Write_Stream_LE(&InquiryData, BytesTransferred, NULL);  	/* Pad out remaining bytes with 0x00 */ -	Endpoint_Write_Stream_LE(&PadBytes, sizeof(PadBytes), NO_STREAM_CALLBACK); +	Endpoint_Null_Stream((AllocationLength - BytesTransferred), NULL);  	/* Finalize the stream transfer to send the last packet */  	Endpoint_ClearIN(); @@ -197,10 +195,8 @@ static bool SCSI_Command_Request_Sense(USB_ClassInfo_MS_Device_t* const MSInterf  	uint8_t  AllocationLength = MSInterfaceInfo->State.CommandBlock.SCSICommandData[4];  	uint8_t  BytesTransferred = (AllocationLength < sizeof(SenseData))? AllocationLength : sizeof(SenseData); -	uint8_t PadBytes[AllocationLength - BytesTransferred]; - -	Endpoint_Write_Stream_LE(&SenseData, BytesTransferred, NO_STREAM_CALLBACK); -	Endpoint_Write_Stream_LE(&PadBytes, sizeof(PadBytes), NO_STREAM_CALLBACK); +	Endpoint_Write_Stream_LE(&SenseData, BytesTransferred, NULL); +	Endpoint_Null_Stream((AllocationLength - BytesTransferred), NULL);  	Endpoint_ClearIN();  	/* Succeed the command and update the bytes transferred counter */ @@ -221,8 +217,8 @@ static bool SCSI_Command_Read_Capacity_10(USB_ClassInfo_MS_Device_t* const MSInt  	uint32_t LastBlockAddressInLUN = (LUN_MEDIA_BLOCKS - 1);  	uint32_t MediaBlockSize        = VIRTUAL_MEMORY_BLOCK_SIZE; -	Endpoint_Write_Stream_BE(&LastBlockAddressInLUN, sizeof(LastBlockAddressInLUN), NO_STREAM_CALLBACK); -	Endpoint_Write_Stream_BE(&MediaBlockSize, sizeof(MediaBlockSize), NO_STREAM_CALLBACK); +	Endpoint_Write_Stream_BE(&LastBlockAddressInLUN, sizeof(LastBlockAddressInLUN), NULL); +	Endpoint_Write_Stream_BE(&MediaBlockSize, sizeof(MediaBlockSize), NULL);  	Endpoint_ClearIN();  	/* Succeed the command and update the bytes transferred counter */ diff --git a/Demos/Device/Incomplete/Sideshow/Lib/SideshowCommands.c b/Demos/Device/Incomplete/Sideshow/Lib/SideshowCommands.c index 5e713cb39..3aa00957f 100644 --- a/Demos/Device/Incomplete/Sideshow/Lib/SideshowCommands.c +++ b/Demos/Device/Incomplete/Sideshow/Lib/SideshowCommands.c @@ -48,7 +48,7 @@ void Sideshow_ProcessCommandPacket(void)  	SideShow_PacketHeader_t PacketHeader;  	Endpoint_SelectEndpoint(SIDESHOW_OUT_EPNUM); -	Endpoint_Read_Stream_LE(&PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Read_Stream_LE(&PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	PacketHeader.Type.TypeFields.Response = true; @@ -104,14 +104,14 @@ void Sideshow_ProcessCommandPacket(void)  		default:  			PacketHeader.Length -= sizeof(SideShow_PacketHeader_t); -			Endpoint_Discard_Stream(PacketHeader.Length); +			Endpoint_Discard_Stream(PacketHeader.Length, NULL);  			Endpoint_ClearOUT();  			PacketHeader.Length   = sizeof(SideShow_PacketHeader_t);  			PacketHeader.Type.TypeFields.NAK = true;  			Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -			Endpoint_Write_Stream_LE(&PacketHeader, sizeof(SideShow_PacketHeader_t)); +			Endpoint_Write_Stream_LE(&PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  			Endpoint_ClearIN();  			printf(" UNK"); @@ -123,7 +123,7 @@ static void SideShow_Ping(SideShow_PacketHeader_t* const PacketHeader)  	Endpoint_ClearOUT();  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	Endpoint_ClearIN();  } @@ -131,15 +131,15 @@ static void SideShow_Sync(SideShow_PacketHeader_t* const PacketHeader)  {  	GUID_t ProtocolGUID; -	Endpoint_Read_Stream_LE(&ProtocolGUID, sizeof(GUID_t)); +	Endpoint_Read_Stream_LE(&ProtocolGUID, sizeof(GUID_t), NULL);  	Endpoint_ClearOUT();  	if (!(GUID_COMPARE(&ProtocolGUID, (uint32_t[])STANDARD_PROTOCOL_GUID)))  	  PacketHeader->Type.TypeFields.NAK = true;  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); -	Endpoint_Write_Stream_LE(&ProtocolGUID, sizeof(GUID_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL); +	Endpoint_Write_Stream_LE(&ProtocolGUID, sizeof(GUID_t), NULL);  	Endpoint_ClearIN();  } @@ -150,7 +150,7 @@ static void SideShow_GetCurrentUser(SideShow_PacketHeader_t* const PacketHeader)  	PacketHeader->Length = sizeof(SideShow_PacketHeader_t) + sizeof(uint32_t) + UserSID.LengthInBytes;  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	SideShow_Write_Unicode_String(&UserSID);  	Endpoint_ClearIN();  } @@ -163,7 +163,7 @@ static void SideShow_SetCurrentUser(SideShow_PacketHeader_t* const PacketHeader)  	PacketHeader->Length = sizeof(SideShow_PacketHeader_t);  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	Endpoint_ClearIN();  } @@ -172,7 +172,7 @@ static void SideShow_GetCapabilities(SideShow_PacketHeader_t* const PacketHeader  	SideShow_PropertyKey_t  Property;  	SideShow_PropertyData_t PropertyData; -	Endpoint_Read_Stream_LE(&Property, sizeof(SideShow_PropertyKey_t)); +	Endpoint_Read_Stream_LE(&Property, sizeof(SideShow_PropertyKey_t), NULL);  	Endpoint_ClearOUT();  	printf(" ID: %lu", Property.PropertyID); @@ -255,7 +255,7 @@ static void SideShow_GetCapabilities(SideShow_PacketHeader_t* const PacketHeader  	}  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	if (!(PacketHeader->Type.TypeFields.NAK))  	{ @@ -263,12 +263,12 @@ static void SideShow_GetCapabilities(SideShow_PacketHeader_t* const PacketHeader  		{  			case VT_UI4:  			case VT_I4: -				Endpoint_Write_Stream_LE(&PropertyData.Data.Data32, sizeof(uint32_t)); +				Endpoint_Write_Stream_LE(&PropertyData.Data.Data32, sizeof(uint32_t), NULL);  				break;  			case VT_UI2:  			case VT_I2:  			case VT_BOOL: -				Endpoint_Write_Stream_LE(&PropertyData.Data.Data16, sizeof(uint16_t)); +				Endpoint_Write_Stream_LE(&PropertyData.Data.Data16, sizeof(uint16_t), NULL);  				break;  			case VT_LPWSTR:  				SideShow_Write_Unicode_String((Unicode_String_t*)PropertyData.Data.Data16); @@ -289,7 +289,7 @@ static void SideShow_GetString(SideShow_PacketHeader_t* const PacketHeader,  	                       sizeof(uint32_t) + ((Unicode_String_t*)UnicodeStruct)->LengthInBytes;  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	SideShow_Write_Unicode_String(UnicodeStruct);  	Endpoint_ClearIN();  } @@ -310,13 +310,13 @@ static void SideShow_GetApplicationOrder(SideShow_PacketHeader_t* const PacketHe  	                       sizeof(uint32_t) + (TotalApplications * sizeof(GUID_t));  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	Endpoint_Write_DWord_LE(TotalApplications);  	for (uint8_t App = 0; App < MAX_APPLICATIONS; App++)  	{  		if (InstalledApplications[App].InUse) -		  Endpoint_Write_Stream_LE(&InstalledApplications[App].ApplicationID, sizeof(GUID_t)); +		  Endpoint_Write_Stream_LE(&InstalledApplications[App].ApplicationID, sizeof(GUID_t), NULL);  	}  	Endpoint_ClearIN(); @@ -331,9 +331,9 @@ static void SideShow_GetSupportedEndpoints(SideShow_PacketHeader_t* const Packet  	PacketHeader->Length = sizeof(SideShow_PacketHeader_t) + sizeof(uint32_t) + sizeof(GUID_t);  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	Endpoint_Write_DWord_LE(1); -	Endpoint_Write_Stream_LE(&SupportedEndpointGUID, sizeof(GUID_t)); +	Endpoint_Write_Stream_LE(&SupportedEndpointGUID, sizeof(GUID_t), NULL);  	Endpoint_ClearIN();  } @@ -342,7 +342,7 @@ static void SideShow_AddApplication(SideShow_PacketHeader_t* const PacketHeader)  	SideShow_Application_t* CurrApp;  	GUID_t                  ApplicationID; -	Endpoint_Read_Stream_LE(&ApplicationID, sizeof(GUID_t)); +	Endpoint_Read_Stream_LE(&ApplicationID, sizeof(GUID_t), NULL);  	CurrApp = SideShow_GetApplicationFromGUID(&ApplicationID); @@ -353,7 +353,7 @@ static void SideShow_AddApplication(SideShow_PacketHeader_t* const PacketHeader)  	{  		PacketHeader->Length -= sizeof(SideShow_PacketHeader_t) + sizeof(GUID_t); -		Endpoint_Discard_Stream(PacketHeader->Length); +		Endpoint_Discard_Stream(PacketHeader->Length, NULL);  		Endpoint_ClearOUT();  		PacketHeader->Type.TypeFields.NAK = true; @@ -361,10 +361,10 @@ static void SideShow_AddApplication(SideShow_PacketHeader_t* const PacketHeader)  	else  	{  		CurrApp->ApplicationID = ApplicationID; -		Endpoint_Read_Stream_LE(&CurrApp->EndpointID, sizeof(GUID_t)); +		Endpoint_Read_Stream_LE(&CurrApp->EndpointID, sizeof(GUID_t), NULL);  		SideShow_Read_Unicode_String(&CurrApp->ApplicationName, sizeof(CurrApp->ApplicationName.UnicodeString)); -		Endpoint_Read_Stream_LE(&CurrApp->CachePolicy, sizeof(uint32_t)); -		Endpoint_Read_Stream_LE(&CurrApp->OnlineOnly, sizeof(uint32_t)); +		Endpoint_Read_Stream_LE(&CurrApp->CachePolicy, sizeof(uint32_t), NULL); +		Endpoint_Read_Stream_LE(&CurrApp->OnlineOnly, sizeof(uint32_t), NULL);  		SideShow_Discard_Byte_Stream();  		SideShow_Discard_Byte_Stream();  		SideShow_Discard_Byte_Stream(); @@ -378,7 +378,7 @@ static void SideShow_AddApplication(SideShow_PacketHeader_t* const PacketHeader)  	PacketHeader->Length = sizeof(SideShow_PacketHeader_t);  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	Endpoint_ClearIN();  } @@ -386,7 +386,7 @@ static void SideShow_DeleteApplication(SideShow_PacketHeader_t* const PacketHead  {  	GUID_t ApplicationGUID; -	Endpoint_Read_Stream_LE(&ApplicationGUID, sizeof(GUID_t)); +	Endpoint_Read_Stream_LE(&ApplicationGUID, sizeof(GUID_t), NULL);  	Endpoint_ClearOUT();  	SideShow_Application_t* AppToDelete = SideShow_GetApplicationFromGUID(&ApplicationGUID); @@ -399,7 +399,7 @@ static void SideShow_DeleteApplication(SideShow_PacketHeader_t* const PacketHead  	PacketHeader->Length = sizeof(SideShow_PacketHeader_t);  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	Endpoint_ClearIN();  } @@ -411,7 +411,7 @@ static void SideShow_DeleteAllApplications(SideShow_PacketHeader_t* const Packet  	  InstalledApplications[App].InUse = false;  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	Endpoint_ClearIN();  } @@ -421,8 +421,8 @@ static void SideShow_AddContent(SideShow_PacketHeader_t* const PacketHeader)  	GUID_t EndpointID;  	SideShow_Application_t* Application; -	Endpoint_Read_Stream_LE(&ApplicationID, sizeof(GUID_t)); -	Endpoint_Read_Stream_LE(&EndpointID, sizeof(GUID_t)); +	Endpoint_Read_Stream_LE(&ApplicationID, sizeof(GUID_t), NULL); +	Endpoint_Read_Stream_LE(&EndpointID, sizeof(GUID_t), NULL);  	Application = SideShow_GetApplicationFromGUID(&ApplicationID); @@ -441,7 +441,7 @@ static void SideShow_AddContent(SideShow_PacketHeader_t* const PacketHeader)  	PacketHeader->Length = sizeof(SideShow_PacketHeader_t);  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	Endpoint_ClearIN();  } @@ -451,9 +451,9 @@ static void SideShow_DeleteContent(SideShow_PacketHeader_t* const PacketHeader)  	GUID_t   EndpointID;  	uint32_t ContentID; -	Endpoint_Read_Stream_LE(&ApplicationID, sizeof(GUID_t)); -	Endpoint_Read_Stream_LE(&EndpointID, sizeof(GUID_t)); -	Endpoint_Read_Stream_LE(&ContentID, sizeof(uint32_t)); +	Endpoint_Read_Stream_LE(&ApplicationID, sizeof(GUID_t), NULL); +	Endpoint_Read_Stream_LE(&EndpointID, sizeof(GUID_t), NULL); +	Endpoint_Read_Stream_LE(&ContentID, sizeof(uint32_t), NULL);  	Endpoint_ClearOUT();  	SideShow_Application_t* Application = SideShow_GetApplicationFromGUID(&ApplicationID); @@ -466,7 +466,7 @@ static void SideShow_DeleteContent(SideShow_PacketHeader_t* const PacketHeader)  	PacketHeader->Length = sizeof(SideShow_PacketHeader_t);  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	Endpoint_ClearIN();  } @@ -475,8 +475,8 @@ static void SideShow_DeleteAllContent(SideShow_PacketHeader_t* const PacketHeade  	GUID_t ApplicationID;  	GUID_t EndpointID; -	Endpoint_Read_Stream_LE(&ApplicationID, sizeof(GUID_t)); -	Endpoint_Read_Stream_LE(&EndpointID, sizeof(GUID_t)); +	Endpoint_Read_Stream_LE(&ApplicationID, sizeof(GUID_t), NULL); +	Endpoint_Read_Stream_LE(&EndpointID, sizeof(GUID_t), NULL);  	Endpoint_ClearOUT();  	SideShow_Application_t* Application = SideShow_GetApplicationFromGUID(&ApplicationID); @@ -489,7 +489,7 @@ static void SideShow_DeleteAllContent(SideShow_PacketHeader_t* const PacketHeade  	PacketHeader->Length = sizeof(SideShow_PacketHeader_t);  	Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); -	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t)); +	Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);  	Endpoint_ClearIN();  } diff --git a/Demos/Device/Incomplete/Sideshow/Lib/SideshowCommon.c b/Demos/Device/Incomplete/Sideshow/Lib/SideshowCommon.c index 78de4937a..982df292a 100644 --- a/Demos/Device/Incomplete/Sideshow/Lib/SideshowCommon.c +++ b/Demos/Device/Incomplete/Sideshow/Lib/SideshowCommon.c @@ -36,13 +36,13 @@ uint16_t SideShow_Read_Unicode_String(void* const UnicodeString,  	Unicode_String_t* const UnicodeStruct = (Unicode_String_t*)UnicodeString;  	uint32_t                UnicodeCharsToRead; -	Endpoint_Read_Stream_LE(&UnicodeCharsToRead, sizeof(uint32_t)); +	Endpoint_Read_Stream_LE(&UnicodeCharsToRead, sizeof(uint32_t), NULL);  	int UnicodeData[UnicodeCharsToRead];  	UnicodeStruct->LengthInBytes = (UnicodeCharsToRead << 1); -	Endpoint_Read_Stream_LE(&UnicodeData, UnicodeStruct->LengthInBytes); +	Endpoint_Read_Stream_LE(&UnicodeData, UnicodeStruct->LengthInBytes, NULL);  	if (UnicodeStruct->LengthInBytes > MaxBytes)  	  UnicodeStruct->LengthInBytes = MaxBytes; @@ -58,15 +58,15 @@ void SideShow_Write_Unicode_String(void* const UnicodeString)  	uint32_t StringSizeInCharacters = (UnicodeStruct->LengthInBytes >> 1); -	Endpoint_Write_Stream_LE(&StringSizeInCharacters, sizeof(uint32_t)); -	Endpoint_Write_Stream_LE(&UnicodeStruct->UnicodeString, UnicodeStruct->LengthInBytes); +	Endpoint_Write_Stream_LE(&StringSizeInCharacters, sizeof(uint32_t), NULL); +	Endpoint_Write_Stream_LE(&UnicodeStruct->UnicodeString, UnicodeStruct->LengthInBytes, NULL);  }  void SideShow_Discard_Byte_Stream(void)  {  	uint32_t StreamSize; -	Endpoint_Read_Stream_LE(&StreamSize, sizeof(uint32_t)); -	Endpoint_Discard_Stream(StreamSize); +	Endpoint_Read_Stream_LE(&StreamSize, sizeof(uint32_t), NULL); +	Endpoint_Discard_Stream(StreamSize, NULL);  } diff --git a/Demos/Device/Incomplete/Sideshow/Lib/SideshowContent.c b/Demos/Device/Incomplete/Sideshow/Lib/SideshowContent.c index 60fdf1e94..1159f4f49 100644 --- a/Demos/Device/Incomplete/Sideshow/Lib/SideshowContent.c +++ b/Demos/Device/Incomplete/Sideshow/Lib/SideshowContent.c @@ -37,19 +37,19 @@ bool SideShow_AddSimpleContent(SideShow_PacketHeader_t* const PacketHeader,  	uint32_t ContentSize;  	uint32_t ContentID; -	Endpoint_Read_Stream_LE(&ContentID, sizeof(uint32_t)); +	Endpoint_Read_Stream_LE(&ContentID, sizeof(uint32_t), NULL);  	PacketHeader->Length -= sizeof(uint32_t);  	if (Application->CurrentContentID != ContentID)  	{ -		Endpoint_Discard_Stream(PacketHeader->Length); +		Endpoint_Discard_Stream(PacketHeader->Length, NULL);  		return false;  	} -	Endpoint_Read_Stream_LE(&ContentSize, sizeof(uint32_t)); -	Endpoint_Read_Stream_LE(&Application->CurrentContent, sizeof(XML_START_TAG) - 1); +	Endpoint_Read_Stream_LE(&ContentSize, sizeof(uint32_t), NULL); +	Endpoint_Read_Stream_LE(&Application->CurrentContent, (sizeof(XML_START_TAG) - 1), NULL);  	PacketHeader->Length -= sizeof(uint32_t) + (sizeof(XML_START_TAG) - 1); @@ -57,14 +57,14 @@ bool SideShow_AddSimpleContent(SideShow_PacketHeader_t* const PacketHeader,  	{  		SideShow_ProcessXMLContent(&Application->CurrentContent, (ContentSize - (sizeof(XML_END_TAG) - 1))); -		Endpoint_Discard_Stream(sizeof(XML_END_TAG) - 1); +		Endpoint_Discard_Stream((sizeof(XML_END_TAG) - 1), NULL);  		Application->HaveContent = true;  	}  	else  	{  		printf(" BINARY"); -		Endpoint_Discard_Stream(ContentSize); +		Endpoint_Discard_Stream(ContentSize, NULL);  	}  	return true; @@ -74,6 +74,6 @@ static void SideShow_ProcessXMLContent(void* ContentData,                                         uint32_t ContentSize)  {  	printf(" XML"); -	Endpoint_Discard_Stream(ContentSize); +	Endpoint_Discard_Stream(ContentSize, NULL);  } diff --git a/Demos/Device/Incomplete/Sideshow/makefile b/Demos/Device/Incomplete/Sideshow/makefile index 6da7dd700..81756c12b 100644 --- a/Demos/Device/Incomplete/Sideshow/makefile +++ b/Demos/Device/Incomplete/Sideshow/makefile @@ -121,7 +121,6 @@ LUFA_OPTS += -D FIXED_CONTROL_ENDPOINT_SIZE=8  LUFA_OPTS += -D FIXED_NUM_CONFIGURATIONS=1  LUFA_OPTS += -D USE_FLASH_DESCRIPTORS  LUFA_OPTS += -D USE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" -LUFA_OPTS += -D NO_STREAM_CALLBACKS  # Create the LUFA source path variables by including the LUFA root makefile diff --git a/Demos/Device/Incomplete/TestAndMeasurement/TestAndMeasurement.c b/Demos/Device/Incomplete/TestAndMeasurement/TestAndMeasurement.c index a23521e16..3c5cf47d5 100644 --- a/Demos/Device/Incomplete/TestAndMeasurement/TestAndMeasurement.c +++ b/Demos/Device/Incomplete/TestAndMeasurement/TestAndMeasurement.c @@ -64,6 +64,8 @@ bool IsTMCBulkOUTReset = false;  /** Last used tag value for data transfers */
  uint8_t CurrentTransferTag = 0;
 +/** Length of last data transfer, for reporting to the host in case an in-progress tranfer is aborted */
 +uint32_t LastTransferLength = 0;
  /** Main program entry point. This routine contains the overall program flow, including initial
   *  setup of all components and the main program loop.
 @@ -190,7 +192,7 @@ void EVENT_USB_Device_ControlRequest(void)  				/* Write the request response bytes */
  				Endpoint_Write_Byte(TMCRequestStatus);
  				Endpoint_Write_Word_LE(0);
 -				Endpoint_Write_DWord_LE(0); // TODO - Last transfer length
 +				Endpoint_Write_DWord_LE(LastTransferLength);
  				Endpoint_ClearIN();
  				Endpoint_ClearStatusStage();				
 @@ -245,7 +247,7 @@ void EVENT_USB_Device_ControlRequest(void)  				/* Write the request response bytes */
  				Endpoint_Write_Byte(TMCRequestStatus);
  				Endpoint_Write_Word_LE(0);
 -				Endpoint_Write_DWord_LE(0); // TODO - Last transfer length
 +				Endpoint_Write_DWord_LE(LastTransferLength);
  				Endpoint_ClearIN();
  				Endpoint_ClearStatusStage();
 @@ -324,6 +326,7 @@ void TMC_Task(void)  	  return;
  	TMC_MessageHeader_t MessageHeader;
 +	uint16_t            BytesTransferred;
  	/* Try to read in a TMC message from the interface, process if one is available */
  	if (ReadTMCHeader(&MessageHeader))
 @@ -334,16 +337,33 @@ void TMC_Task(void)  		switch (MessageHeader.MessageID)
  		{
  			case TMC_MESSAGEID_DEV_DEP_MSG_OUT:
 -				Endpoint_Discard_Stream(MessageHeader.TransferSize, StreamCallback_AbortOUTOnRequest);
 +				BytesTransferred = 0;
 +				while (Endpoint_Discard_Stream(MessageHeader.TransferSize, &BytesTransferred) ==
 +				       ENDPOINT_RWSTREAM_IncompleteTransfer)
 +				{
 +					if (IsTMCBulkOUTReset)
 +					  break;
 +				}
 +				LastTransferLength = BytesTransferred;
 +				
  				Endpoint_ClearOUT();
  				break;
  			case TMC_MESSAGEID_DEV_DEP_MSG_IN:
  				Endpoint_ClearOUT();
  				MessageHeader.TransferSize = 3;
 +				MessageHeader.MessageIDSpecific.DeviceOUT.LastMessageTransaction = true;
  				WriteTMCHeader(&MessageHeader);
 -				Endpoint_Write_Stream_LE("TMC", 3, StreamCallback_AbortINOnRequest);
 +				BytesTransferred = 0;
 +				while (Endpoint_Write_Stream_LE("TMC", MessageHeader.TransferSize, &BytesTransferred) ==
 +				       ENDPOINT_RWSTREAM_IncompleteTransfer)
 +				{
 +					if (IsTMCBulkINReset)
 +					  break;
 +				}
 +				LastTransferLength = BytesTransferred;
 +
  				Endpoint_ClearIN();
  				break;
  			default:
 @@ -367,6 +387,8 @@ void TMC_Task(void)   */
  bool ReadTMCHeader(TMC_MessageHeader_t* const MessageHeader)
  {
 +	uint16_t BytesTransferred;
 +
  	/* Select the Data Out endpoint */
  	Endpoint_SelectEndpoint(TMC_OUT_EPNUM);
 @@ -375,7 +397,13 @@ bool ReadTMCHeader(TMC_MessageHeader_t* const MessageHeader)  	  return false;
  	/* Read in the header of the command from the host */
 -	Endpoint_Read_Stream_LE(MessageHeader, sizeof(TMC_MessageHeader_t), StreamCallback_AbortOUTOnRequest);
 +	BytesTransferred = 0;
 +	while (Endpoint_Read_Stream_LE(MessageHeader, sizeof(TMC_MessageHeader_t), &BytesTransferred) ==
 +	       ENDPOINT_RWSTREAM_IncompleteTransfer)
 +	{
 +		if (IsTMCBulkOUTReset)
 +		  break;
 +	}
  	/* Store the new command tag value for later use */
  	CurrentTransferTag = MessageHeader->Tag;
 @@ -386,9 +414,7 @@ bool ReadTMCHeader(TMC_MessageHeader_t* const MessageHeader)  bool WriteTMCHeader(TMC_MessageHeader_t* const MessageHeader)
  {
 -	/* Compute the next transfer tag value, must be between 1 and 254 */
 -	if (++CurrentTransferTag == 0xFF)
 -	  CurrentTransferTag = 1;
 +	uint16_t BytesTransferred;
  	/* Set the message tag of the command header */
  	MessageHeader->Tag        =  CurrentTransferTag;
 @@ -398,35 +424,14 @@ bool WriteTMCHeader(TMC_MessageHeader_t* const MessageHeader)  	Endpoint_SelectEndpoint(TMC_IN_EPNUM);
  	/* Send the command header to the host */
 -	Endpoint_Write_Stream_LE(MessageHeader, sizeof(TMC_MessageHeader_t), StreamCallback_AbortINOnRequest);
 +	BytesTransferred = 0;
 +	while (Endpoint_Write_Stream_LE(MessageHeader, sizeof(TMC_MessageHeader_t), &BytesTransferred) ==
 +	       ENDPOINT_RWSTREAM_IncompleteTransfer)
 +	{
 +		if (IsTMCBulkINReset)
 +		  break;
 +	}
  	/* Indicate if the command has been aborted or not */
  	return !(IsTMCBulkINReset);
  }
 -
 -/** Stream callback function for the Endpoint stream write functions. This callback will abort the current stream transfer
 - *  if a TMC Abort Bulk IN request has been issued to the control endpoint.
 - */
 -uint8_t StreamCallback_AbortINOnRequest(void)
 -{	
 -	/* Abort if a TMC Bulk Data IN abort was received */
 -	if (IsTMCBulkINReset)
 -	  return STREAMCALLBACK_Abort;
 -	
 -	/* Continue with the current stream operation */
 -	return STREAMCALLBACK_Continue;
 -}
 -
 -/** Stream callback function for the Endpoint stream read functions. This callback will abort the current stream transfer
 - *  if a TMC Abort Bulk OUT request has been issued to the control endpoint.
 - */
 -uint8_t StreamCallback_AbortOUTOnRequest(void)
 -{	
 -	/* Abort if a TMC Bulk Data IN abort was received */
 -	if (IsTMCBulkOUTReset)
 -	  return STREAMCALLBACK_Abort;
 -	
 -	/* Continue with the current stream operation */
 -	return STREAMCALLBACK_Continue;
 -}
 - diff --git a/Demos/Device/Incomplete/TestAndMeasurement/TestAndMeasurement.h b/Demos/Device/Incomplete/TestAndMeasurement/TestAndMeasurement.h index a163df66f..42e659882 100644 --- a/Demos/Device/Incomplete/TestAndMeasurement/TestAndMeasurement.h +++ b/Demos/Device/Incomplete/TestAndMeasurement/TestAndMeasurement.h @@ -150,8 +150,5 @@  		void EVENT_USB_Device_ConfigurationChanged(void);
  		void EVENT_USB_Device_ControlRequest(void);
 -		uint8_t StreamCallback_AbortINOnRequest(void);
 -		uint8_t StreamCallback_AbortOUTOnRequest(void);
 -
  #endif
 diff --git a/Demos/Device/LowLevel/DualVirtualSerial/DualVirtualSerial.c b/Demos/Device/LowLevel/DualVirtualSerial/DualVirtualSerial.c index bf8074971..14aa0be71 100644 --- a/Demos/Device/LowLevel/DualVirtualSerial/DualVirtualSerial.c +++ b/Demos/Device/LowLevel/DualVirtualSerial/DualVirtualSerial.c @@ -227,7 +227,7 @@ void CDC1_Task(void)  		Endpoint_SelectEndpoint(CDC1_TX_EPNUM);  		/* Write the String to the Endpoint */ -		Endpoint_Write_Stream_LE(ReportString, strlen(ReportString)); +		Endpoint_Write_Stream_LE(ReportString, strlen(ReportString), NULL);  		/* Finalize the stream transfer to send the last packet */  		Endpoint_ClearIN(); @@ -269,7 +269,7 @@ void CDC2_Task(void)  		uint16_t DataLength = Endpoint_BytesInEndpoint();  		/* Read in the incoming packet into the buffer */ -		Endpoint_Read_Stream_LE(&Buffer, DataLength); +		Endpoint_Read_Stream_LE(&Buffer, DataLength, NULL);  		/* Finalize the stream transfer to send the last packet */  		Endpoint_ClearOUT(); @@ -278,7 +278,7 @@ void CDC2_Task(void)  		Endpoint_SelectEndpoint(CDC2_TX_EPNUM);  		/* Write the received data to the endpoint */ -		Endpoint_Write_Stream_LE(&Buffer, DataLength); +		Endpoint_Write_Stream_LE(&Buffer, DataLength, NULL);  		/* Finalize the stream transfer to send the last packet */  		Endpoint_ClearIN(); diff --git a/Demos/Device/LowLevel/DualVirtualSerial/makefile b/Demos/Device/LowLevel/DualVirtualSerial/makefile index 7eb6bb44e..4daadb2a3 100644 --- a/Demos/Device/LowLevel/DualVirtualSerial/makefile +++ b/Demos/Device/LowLevel/DualVirtualSerial/makefile @@ -121,7 +121,6 @@ LUFA_OPTS += -D FIXED_CONTROL_ENDPOINT_SIZE=8  LUFA_OPTS += -D FIXED_NUM_CONFIGURATIONS=1  LUFA_OPTS += -D USE_FLASH_DESCRIPTORS  LUFA_OPTS += -D USE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" -LUFA_OPTS += -D NO_STREAM_CALLBACKS  # Create the LUFA source path variables by including the LUFA root makefile diff --git a/Demos/Device/LowLevel/GenericHID/GenericHID.c b/Demos/Device/LowLevel/GenericHID/GenericHID.c index 2d1e2dd0f..e8d0e41d2 100644 --- a/Demos/Device/LowLevel/GenericHID/GenericHID.c +++ b/Demos/Device/LowLevel/GenericHID/GenericHID.c @@ -198,7 +198,7 @@ void HID_Task(void)  			uint8_t GenericData[GENERIC_REPORT_SIZE];  			/* Read Generic Report Data */ -			Endpoint_Read_Stream_LE(&GenericData, sizeof(GenericData)); +			Endpoint_Read_Stream_LE(&GenericData, sizeof(GenericData), NULL);  			/* Process Generic Report Data */  			ProcessGenericHIDReport(GenericData); @@ -220,7 +220,7 @@ void HID_Task(void)  		CreateGenericHIDReport(GenericData);  		/* Write Generic Report Data */ -		Endpoint_Write_Stream_LE(&GenericData, sizeof(GenericData)); +		Endpoint_Write_Stream_LE(&GenericData, sizeof(GenericData), NULL);  		/* Finalize the stream transfer to send the last packet */  		Endpoint_ClearIN(); diff --git a/Demos/Device/LowLevel/GenericHID/makefile b/Demos/Device/LowLevel/GenericHID/makefile index bbcc74160..ae6c300ca 100644 --- a/Demos/Device/LowLevel/GenericHID/makefile +++ b/Demos/Device/LowLevel/GenericHID/makefile @@ -121,7 +121,6 @@ LUFA_OPTS += -D FIXED_CONTROL_ENDPOINT_SIZE=8  LUFA_OPTS += -D FIXED_NUM_CONFIGURATIONS=1  LUFA_OPTS += -D USE_FLASH_DESCRIPTORS  LUFA_OPTS += -D USE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" -LUFA_OPTS += -D NO_STREAM_CALLBACKS  # Create the LUFA source path variables by including the LUFA root makefile diff --git a/Demos/Device/LowLevel/Joystick/Joystick.c b/Demos/Device/LowLevel/Joystick/Joystick.c index e4f76ec13..df1a884b6 100644 --- a/Demos/Device/LowLevel/Joystick/Joystick.c +++ b/Demos/Device/LowLevel/Joystick/Joystick.c @@ -194,7 +194,7 @@ void HID_Task(void)  		GetNextReport(&JoystickReportData);  		/* Write Joystick Report Data */ -		Endpoint_Write_Stream_LE(&JoystickReportData, sizeof(JoystickReportData)); +		Endpoint_Write_Stream_LE(&JoystickReportData, sizeof(JoystickReportData), NULL);  		/* Finalize the stream transfer to send the last packet */  		Endpoint_ClearIN(); diff --git a/Demos/Device/LowLevel/Joystick/makefile b/Demos/Device/LowLevel/Joystick/makefile index e253c56d7..e22d511e9 100644 --- a/Demos/Device/LowLevel/Joystick/makefile +++ b/Demos/Device/LowLevel/Joystick/makefile @@ -121,7 +121,6 @@ LUFA_OPTS += -D FIXED_CONTROL_ENDPOINT_SIZE=8  LUFA_OPTS += -D FIXED_NUM_CONFIGURATIONS=1  LUFA_OPTS += -D USE_FLASH_DESCRIPTORS  LUFA_OPTS += -D USE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" -LUFA_OPTS += -D NO_STREAM_CALLBACKS  # Create the LUFA source path variables by including the LUFA root makefile diff --git a/Demos/Device/LowLevel/Keyboard/Keyboard.c b/Demos/Device/LowLevel/Keyboard/Keyboard.c index 7a1734996..94f0f7deb 100644 --- a/Demos/Device/LowLevel/Keyboard/Keyboard.c +++ b/Demos/Device/LowLevel/Keyboard/Keyboard.c @@ -324,7 +324,7 @@ void SendNextReport(void)  		PrevKeyboardReportData = KeyboardReportData;  		/* Write Keyboard Report Data */ -		Endpoint_Write_Stream_LE(&KeyboardReportData, sizeof(KeyboardReportData)); +		Endpoint_Write_Stream_LE(&KeyboardReportData, sizeof(KeyboardReportData), NULL);  		/* Finalize the stream transfer to send the last packet */  		Endpoint_ClearIN(); diff --git a/Demos/Device/LowLevel/Keyboard/makefile b/Demos/Device/LowLevel/Keyboard/makefile index c78388099..2c1e31fca 100644 --- a/Demos/Device/LowLevel/Keyboard/makefile +++ b/Demos/Device/LowLevel/Keyboard/makefile @@ -121,7 +121,6 @@ LUFA_OPTS += -D FIXED_CONTROL_ENDPOINT_SIZE=8  LUFA_OPTS += -D FIXED_NUM_CONFIGURATIONS=1  LUFA_OPTS += -D USE_FLASH_DESCRIPTORS  LUFA_OPTS += -D USE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" -LUFA_OPTS += -D NO_STREAM_CALLBACKS  # Create the LUFA source path variables by including the LUFA root makefile diff --git a/Demos/Device/LowLevel/KeyboardMouse/KeyboardMouse.c b/Demos/Device/LowLevel/KeyboardMouse/KeyboardMouse.c index 0263093c7..058887971 100644 --- a/Demos/Device/LowLevel/KeyboardMouse/KeyboardMouse.c +++ b/Demos/Device/LowLevel/KeyboardMouse/KeyboardMouse.c @@ -41,7 +41,7 @@  USB_KeyboardReport_Data_t KeyboardReportData;  /** Global structure to hold the current mouse interface HID report, for transmission to the host */ -USB_MouseReport_Data_t    MouseReportData; +USB_MouseReport_Data_t MouseReportData;  /** Main program entry point. This routine configures the hardware required by the application, then @@ -242,7 +242,7 @@ void Keyboard_HID_Task(void)  	if (Endpoint_IsReadWriteAllowed())  	{  		/* Write Keyboard Report Data */ -		Endpoint_Write_Stream_LE(&KeyboardReportData, sizeof(KeyboardReportData)); +		Endpoint_Write_Stream_LE(&KeyboardReportData, sizeof(KeyboardReportData), NULL);  		/* Finalize the stream transfer to send the last packet */  		Endpoint_ClearIN(); @@ -300,7 +300,7 @@ void Mouse_HID_Task(void)  	if (Endpoint_IsReadWriteAllowed())  	{  		/* Write Mouse Report Data */ -		Endpoint_Write_Stream_LE(&MouseReportData, sizeof(MouseReportData)); +		Endpoint_Write_Stream_LE(&MouseReportData, sizeof(MouseReportData), NULL);  		/* Finalize the stream transfer to send the last packet */  		Endpoint_ClearIN(); diff --git a/Demos/Device/LowLevel/KeyboardMouse/makefile b/Demos/Device/LowLevel/KeyboardMouse/makefile index d3527c790..f1a16e1e1 100644 --- a/Demos/Device/LowLevel/KeyboardMouse/makefile +++ b/Demos/Device/LowLevel/KeyboardMouse/makefile @@ -121,7 +121,6 @@ LUFA_OPTS += -D FIXED_CONTROL_ENDPOINT_SIZE=8  LUFA_OPTS += -D FIXED_NUM_CONFIGURATIONS=1  LUFA_OPTS += -D USE_FLASH_DESCRIPTORS  LUFA_OPTS += -D USE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" -LUFA_OPTS += -D NO_STREAM_CALLBACKS  # Create the LUFA source path variables by including the LUFA root makefile diff --git a/Demos/Device/LowLevel/MIDI/MIDI.c b/Demos/Device/LowLevel/MIDI/MIDI.c index 697a00ca2..bd2ffa995 100644 --- a/Demos/Device/LowLevel/MIDI/MIDI.c +++ b/Demos/Device/LowLevel/MIDI/MIDI.c @@ -171,7 +171,7 @@ void MIDI_Task(void)  				};  			/* Write the MIDI event packet to the endpoint */ -			Endpoint_Write_Stream_LE(&MIDIEvent, sizeof(MIDIEvent)); +			Endpoint_Write_Stream_LE(&MIDIEvent, sizeof(MIDIEvent), NULL);  			/* Send the data in the endpoint to the host */  			Endpoint_ClearIN(); @@ -190,7 +190,7 @@ void MIDI_Task(void)  		MIDI_EventPacket_t MIDIEvent;  		/* Read the MIDI event packet from the endpoint */ -		Endpoint_Read_Stream_LE(&MIDIEvent, sizeof(MIDIEvent)); +		Endpoint_Read_Stream_LE(&MIDIEvent, sizeof(MIDIEvent), NULL);  		/* Check to see if the sent command is a note on message with a non-zero velocity */  		if ((MIDIEvent.Command == (MIDI_COMMAND_NOTE_ON >> 4)) && (MIDIEvent.Data3 > 0)) diff --git a/Demos/Device/LowLevel/MIDI/makefile b/Demos/Device/LowLevel/MIDI/makefile index 6cc229ddb..40c028328 100644 --- a/Demos/Device/LowLevel/MIDI/makefile +++ b/Demos/Device/LowLevel/MIDI/makefile @@ -121,7 +121,6 @@ LUFA_OPTS += -D FIXED_CONTROL_ENDPOINT_SIZE=8  LUFA_OPTS += -D FIXED_NUM_CONFIGURATIONS=1  LUFA_OPTS += -D USE_FLASH_DESCRIPTORS  LUFA_OPTS += -D USE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" -LUFA_OPTS += -D NO_STREAM_CALLBACKS  # Create the LUFA source path variables by including the LUFA root makefile diff --git a/Demos/Device/LowLevel/MassStorage/Lib/SCSI.c b/Demos/Device/LowLevel/MassStorage/Lib/SCSI.c index 9073aa34b..0400cc2c6 100644 --- a/Demos/Device/LowLevel/MassStorage/Lib/SCSI.c +++ b/Demos/Device/LowLevel/MassStorage/Lib/SCSI.c @@ -166,12 +166,10 @@ static bool SCSI_Command_Inquiry(void)  	}  	/* Write the INQUIRY data to the endpoint */ -	Endpoint_Write_Stream_LE(&InquiryData, BytesTransferred, StreamCallback_AbortOnMassStoreReset); - -	uint8_t PadBytes[AllocationLength - BytesTransferred]; +	Endpoint_Write_Stream_LE(&InquiryData, BytesTransferred, NULL);  	/* Pad out remaining bytes with 0x00 */ -	Endpoint_Write_Stream_LE(&PadBytes, sizeof(PadBytes), StreamCallback_AbortOnMassStoreReset); +	Endpoint_Null_Stream((AllocationLength - BytesTransferred), NULL);  	/* Finalize the stream transfer to send the last packet */  	Endpoint_ClearIN(); @@ -193,12 +191,10 @@ static bool SCSI_Command_Request_Sense(void)  	uint8_t  BytesTransferred = (AllocationLength < sizeof(SenseData))? AllocationLength : sizeof(SenseData);  	/* Send the SENSE data - this indicates to the host the status of the last command */ -	Endpoint_Write_Stream_LE(&SenseData, BytesTransferred, StreamCallback_AbortOnMassStoreReset); - -	uint8_t PadBytes[AllocationLength - BytesTransferred]; +	Endpoint_Write_Stream_LE(&SenseData, BytesTransferred, NULL);  	/* Pad out remaining bytes with 0x00 */ -	Endpoint_Write_Stream_LE(&PadBytes, sizeof(PadBytes), StreamCallback_AbortOnMassStoreReset); +	Endpoint_Null_Stream((AllocationLength - BytesTransferred), NULL);  	/* Finalize the stream transfer to send the last packet */  	Endpoint_ClearIN(); diff --git a/Demos/Device/LowLevel/MassStorage/MassStorage.c b/Demos/Device/LowLevel/MassStorage/MassStorage.c index fe8a3f7a0..cbfef0fbf 100644 --- a/Demos/Device/LowLevel/MassStorage/MassStorage.c +++ b/Demos/Device/LowLevel/MassStorage/MassStorage.c @@ -221,6 +221,8 @@ void MassStorage_Task(void)   */  static bool ReadInCommandBlock(void)  { +	uint16_t BytesTransferred; +  	/* Select the Data Out endpoint */  	Endpoint_SelectEndpoint(MASS_STORAGE_OUT_EPNUM); @@ -229,12 +231,14 @@ static bool ReadInCommandBlock(void)  	  return false;  	/* Read in command block header */ -	Endpoint_Read_Stream_LE(&CommandBlock, (sizeof(CommandBlock) - sizeof(CommandBlock.SCSICommandData)), -	                        StreamCallback_AbortOnMassStoreReset); - -	/* Check if the current command is being aborted by the host */ -	if (IsMassStoreReset) -	  return false; +	BytesTransferred = 0; +	while (Endpoint_Read_Stream_LE(&CommandBlock, (sizeof(CommandBlock) - sizeof(CommandBlock.SCSICommandData)), +	                               &BytesTransferred) == ENDPOINT_RWSTREAM_IncompleteTransfer) +	{ +		/* Check if the current command is being aborted by the host */ +		if (IsMassStoreReset) +		  return false; +	}  	/* Verify the command block - abort if invalid */  	if ((CommandBlock.Signature         != MS_CBW_SIGNATURE) || @@ -252,13 +256,14 @@ static bool ReadInCommandBlock(void)  	}  	/* Read in command block command data */ -	Endpoint_Read_Stream_LE(&CommandBlock.SCSICommandData, -	                        CommandBlock.SCSICommandLength, -	                        StreamCallback_AbortOnMassStoreReset); - -	/* Check if the current command is being aborted by the host */ -	if (IsMassStoreReset) -	  return false; +	BytesTransferred = 0; +	while (Endpoint_Read_Stream_LE(&CommandBlock.SCSICommandData, CommandBlock.SCSICommandLength, +	                               &BytesTransferred) == ENDPOINT_RWSTREAM_IncompleteTransfer) +	{ +		/* Check if the current command is being aborted by the host */ +		if (IsMassStoreReset) +		  return false; +	}  	/* Finalize the stream transfer to send the last packet */  	Endpoint_ClearOUT(); @@ -271,6 +276,8 @@ static bool ReadInCommandBlock(void)   */  static void ReturnCommandStatus(void)  { +	uint16_t BytesTransferred; +  	/* Select the Data Out endpoint */  	Endpoint_SelectEndpoint(MASS_STORAGE_OUT_EPNUM); @@ -294,27 +301,15 @@ static void ReturnCommandStatus(void)  	}  	/* Write the CSW to the endpoint */ -	Endpoint_Write_Stream_LE(&CommandStatus, sizeof(CommandStatus), -	                          StreamCallback_AbortOnMassStoreReset); - -	/* Check if the current command is being aborted by the host */ -	if (IsMassStoreReset) -	  return; - +	BytesTransferred = 0; +	while (Endpoint_Write_Stream_LE(&CommandStatus, sizeof(CommandStatus), +	                                &BytesTransferred) == ENDPOINT_RWSTREAM_IncompleteTransfer) +	{ +		/* Check if the current command is being aborted by the host */ +		if (IsMassStoreReset) +		  return; +	} +	  	/* Finalize the stream transfer to send the last packet */  	Endpoint_ClearIN();  } - -/** Stream callback function for the Endpoint stream read and write functions. This callback will abort the current stream transfer - *  if a Mass Storage Reset request has been issued to the control endpoint. - */ -uint8_t StreamCallback_AbortOnMassStoreReset(void) -{ -	/* Abort if a Mass Storage reset command was received */ -	if (IsMassStoreReset) -	  return STREAMCALLBACK_Abort; - -	/* Continue with the current stream operation */ -	return STREAMCALLBACK_Continue; -} - diff --git a/Demos/Device/LowLevel/Mouse/Mouse.c b/Demos/Device/LowLevel/Mouse/Mouse.c index 4df986cef..40ec25a86 100644 --- a/Demos/Device/LowLevel/Mouse/Mouse.c +++ b/Demos/Device/LowLevel/Mouse/Mouse.c @@ -280,7 +280,7 @@ void SendNextReport(void)  		PrevMouseReportData = MouseReportData;  		/* Write Mouse Report Data */ -		Endpoint_Write_Stream_LE(&MouseReportData, sizeof(MouseReportData)); +		Endpoint_Write_Stream_LE(&MouseReportData, sizeof(MouseReportData), NULL);  		/* Finalize the stream transfer to send the last packet */  		Endpoint_ClearIN(); diff --git a/Demos/Device/LowLevel/Mouse/makefile b/Demos/Device/LowLevel/Mouse/makefile index 4c5b510ea..9041e5cf6 100644 --- a/Demos/Device/LowLevel/Mouse/makefile +++ b/Demos/Device/LowLevel/Mouse/makefile @@ -121,7 +121,6 @@ LUFA_OPTS += -D FIXED_CONTROL_ENDPOINT_SIZE=8  LUFA_OPTS += -D FIXED_NUM_CONFIGURATIONS=1  LUFA_OPTS += -D USE_FLASH_DESCRIPTORS  LUFA_OPTS += -D USE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" -LUFA_OPTS += -D NO_STREAM_CALLBACKS  # Create the LUFA source path variables by including the LUFA root makefile diff --git a/Demos/Device/LowLevel/RNDISEthernet/RNDISEthernet.c b/Demos/Device/LowLevel/RNDISEthernet/RNDISEthernet.c index fdf23ecab..9796d4ebc 100644 --- a/Demos/Device/LowLevel/RNDISEthernet/RNDISEthernet.c +++ b/Demos/Device/LowLevel/RNDISEthernet/RNDISEthernet.c @@ -182,7 +182,7 @@ void RNDIS_Task(void)  			};  		/* Indicate that a message response is ready for the host */ -		Endpoint_Write_Stream_LE(&Notification, sizeof(Notification)); +		Endpoint_Write_Stream_LE(&Notification, sizeof(Notification), NULL);  		/* Finalize the stream transfer to send the last packet */  		Endpoint_ClearIN(); @@ -204,7 +204,7 @@ void RNDIS_Task(void)  		if (Endpoint_IsOUTReceived() && !(FrameIN.FrameInBuffer))  		{  			/* Read in the packet message header */ -			Endpoint_Read_Stream_LE(&RNDISPacketHeader, sizeof(RNDIS_Packet_Message_t)); +			Endpoint_Read_Stream_LE(&RNDISPacketHeader, sizeof(RNDIS_Packet_Message_t), NULL);  			/* Stall the request if the data is too large */  			if (RNDISPacketHeader.DataLength > ETHERNET_FRAME_SIZE_MAX) @@ -214,7 +214,7 @@ void RNDIS_Task(void)  			}  			/* Read in the Ethernet frame into the buffer */ -			Endpoint_Read_Stream_LE(FrameIN.FrameData, RNDISPacketHeader.DataLength); +			Endpoint_Read_Stream_LE(FrameIN.FrameData, RNDISPacketHeader.DataLength, NULL);  			/* Finalize the stream transfer to send the last packet */  			Endpoint_ClearOUT(); @@ -242,10 +242,10 @@ void RNDIS_Task(void)  			RNDISPacketHeader.DataLength    = FrameOUT.FrameLength;  			/* Send the packet header to the host */ -			Endpoint_Write_Stream_LE(&RNDISPacketHeader, sizeof(RNDIS_Packet_Message_t)); +			Endpoint_Write_Stream_LE(&RNDISPacketHeader, sizeof(RNDIS_Packet_Message_t), NULL);  			/* Send the Ethernet frame data to the host */ -			Endpoint_Write_Stream_LE(FrameOUT.FrameData, RNDISPacketHeader.DataLength); +			Endpoint_Write_Stream_LE(FrameOUT.FrameData, RNDISPacketHeader.DataLength, NULL);  			/* Finalize the stream transfer to send the last packet */  			Endpoint_ClearIN(); diff --git a/Demos/Device/LowLevel/RNDISEthernet/makefile b/Demos/Device/LowLevel/RNDISEthernet/makefile index 9695916c5..53f678b86 100644 --- a/Demos/Device/LowLevel/RNDISEthernet/makefile +++ b/Demos/Device/LowLevel/RNDISEthernet/makefile @@ -121,7 +121,6 @@ LUFA_OPTS += -D FIXED_CONTROL_ENDPOINT_SIZE=8  LUFA_OPTS += -D FIXED_NUM_CONFIGURATIONS=1  LUFA_OPTS += -D USE_FLASH_DESCRIPTORS  LUFA_OPTS += -D USE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" -LUFA_OPTS += -D NO_STREAM_CALLBACKS  LUFA_OPTS += -D NO_DECODE_ETHERNET  LUFA_OPTS += -D NO_DECODE_ARP diff --git a/Demos/Device/LowLevel/VirtualSerial/VirtualSerial.c b/Demos/Device/LowLevel/VirtualSerial/VirtualSerial.c index bc2f0ec0d..e841ab530 100644 --- a/Demos/Device/LowLevel/VirtualSerial/VirtualSerial.c +++ b/Demos/Device/LowLevel/VirtualSerial/VirtualSerial.c @@ -203,7 +203,7 @@ void CDC_Task(void)  		Endpoint_SelectEndpoint(CDC_TX_EPNUM);  		/* Write the String to the Endpoint */ -		Endpoint_Write_Stream_LE(ReportString, strlen(ReportString)); +		Endpoint_Write_Stream_LE(ReportString, strlen(ReportString), NULL);  		/* Remember if the packet to send completely fills the endpoint */  		bool IsFull = (Endpoint_BytesInEndpoint() == CDC_TXRX_EPSIZE); diff --git a/Demos/Device/LowLevel/VirtualSerial/makefile b/Demos/Device/LowLevel/VirtualSerial/makefile index b556a3b78..0488b71d5 100644 --- a/Demos/Device/LowLevel/VirtualSerial/makefile +++ b/Demos/Device/LowLevel/VirtualSerial/makefile @@ -121,7 +121,6 @@ LUFA_OPTS += -D FIXED_CONTROL_ENDPOINT_SIZE=8  LUFA_OPTS += -D FIXED_NUM_CONFIGURATIONS=1  LUFA_OPTS += -D USE_FLASH_DESCRIPTORS  LUFA_OPTS += -D USE_STATIC_OPTIONS="(USB_DEVICE_OPT_FULLSPEED | USB_OPT_REG_ENABLED | USB_OPT_AUTO_PLL)" -LUFA_OPTS += -D NO_STREAM_CALLBACKS  # Create the LUFA source path variables by including the LUFA root makefile | 
