Renamed all low level Endpoint_Read_*, Endpoint_Write_* and Endpoint_Discard_* functions to use the number of bits instead of a symbolic size (Byte, Word, DWord) so that the function names are applicable and correct across all architectures.

Renamed all low level Pipe_Read_*, Pipe_Write_* and Pipe_Discard_* functions to use the number of bits instead of a symbolic size (Byte, Word, DWord) so that the function names are applicable and correct across all architectures.
pull/1469/head
Dean Camera 14 years ago
parent 2efa79d3ec
commit 899df7d331

@ -301,7 +301,7 @@ static uint8_t FetchNextCommandByte(void)
} }
/* Fetch the next byte from the OUT endpoint */ /* Fetch the next byte from the OUT endpoint */
return Endpoint_Read_Byte(); return Endpoint_Read_8();
} }
/** Writes the next response byte to the CDC data IN endpoint, and sends the endpoint back if needed to free up the /** Writes the next response byte to the CDC data IN endpoint, and sends the endpoint back if needed to free up the
@ -327,7 +327,7 @@ static void WriteNextResponseByte(const uint8_t Response)
} }
/* Write the next byte to the IN endpoint */ /* Write the next byte to the IN endpoint */
Endpoint_Write_Byte(Response); Endpoint_Write_8(Response);
} }
/** Task to read in AVR910 commands from the CDC data OUT endpoint, process them, perform the required actions /** Task to read in AVR910 commands from the CDC data OUT endpoint, process them, perform the required actions

@ -203,7 +203,7 @@ void EVENT_USB_Device_ControlRequest(void)
} }
/* First byte of the data stage is the DNLOAD request's command */ /* First byte of the data stage is the DNLOAD request's command */
SentCommand.Command = Endpoint_Read_Byte(); SentCommand.Command = Endpoint_Read_8();
/* One byte of the data stage is the command, so subtract it from the total data bytes */ /* One byte of the data stage is the command, so subtract it from the total data bytes */
SentCommand.DataSize--; SentCommand.DataSize--;
@ -212,7 +212,7 @@ void EVENT_USB_Device_ControlRequest(void)
for (uint8_t DataByte = 0; (DataByte < sizeof(SentCommand.Data)) && for (uint8_t DataByte = 0; (DataByte < sizeof(SentCommand.Data)) &&
Endpoint_BytesInEndpoint(); DataByte++) Endpoint_BytesInEndpoint(); DataByte++)
{ {
SentCommand.Data[DataByte] = Endpoint_Read_Byte(); SentCommand.Data[DataByte] = Endpoint_Read_8();
SentCommand.DataSize--; SentCommand.DataSize--;
} }
@ -267,7 +267,7 @@ void EVENT_USB_Device_ControlRequest(void)
} }
/* Write the next word into the current flash page */ /* Write the next word into the current flash page */
boot_page_fill(CurrFlashAddress.Long, Endpoint_Read_Word_LE()); boot_page_fill(CurrFlashAddress.Long, Endpoint_Read_16_LE());
/* Adjust counters */ /* Adjust counters */
WordsInFlashPage += 1; WordsInFlashPage += 1;
@ -316,7 +316,7 @@ void EVENT_USB_Device_ControlRequest(void)
} }
/* Read the byte from the USB interface and write to to the EEPROM */ /* Read the byte from the USB interface and write to to the EEPROM */
eeprom_write_byte((uint8_t*)StartAddr, Endpoint_Read_Byte()); eeprom_write_byte((uint8_t*)StartAddr, Endpoint_Read_8());
/* Adjust counters */ /* Adjust counters */
StartAddr++; StartAddr++;
@ -348,12 +348,12 @@ void EVENT_USB_Device_ControlRequest(void)
{ {
/* Blank checking is performed in the DFU_DNLOAD request - if we get here we've told the host /* Blank checking is performed in the DFU_DNLOAD request - if we get here we've told the host
that the memory isn't blank, and the host is requesting the first non-blank address */ that the memory isn't blank, and the host is requesting the first non-blank address */
Endpoint_Write_Word_LE(StartAddr); Endpoint_Write_16_LE(StartAddr);
} }
else else
{ {
/* Idle state upload - send response to last issued command */ /* Idle state upload - send response to last issued command */
Endpoint_Write_Byte(ResponseByte); Endpoint_Write_8(ResponseByte);
} }
} }
else else
@ -388,9 +388,9 @@ void EVENT_USB_Device_ControlRequest(void)
/* Read the flash word and send it via USB to the host */ /* Read the flash word and send it via USB to the host */
#if (FLASHEND > 0xFFFF) #if (FLASHEND > 0xFFFF)
Endpoint_Write_Word_LE(pgm_read_word_far(CurrFlashAddress.Long)); Endpoint_Write_16_LE(pgm_read_word_far(CurrFlashAddress.Long));
#else #else
Endpoint_Write_Word_LE(pgm_read_word(CurrFlashAddress.Long)); Endpoint_Write_16_LE(pgm_read_word(CurrFlashAddress.Long));
#endif #endif
/* Adjust counters */ /* Adjust counters */
@ -417,7 +417,7 @@ void EVENT_USB_Device_ControlRequest(void)
} }
/* Read the EEPROM byte and send it via USB to the host */ /* Read the EEPROM byte and send it via USB to the host */
Endpoint_Write_Byte(eeprom_read_byte((uint8_t*)StartAddr)); Endpoint_Write_8(eeprom_read_byte((uint8_t*)StartAddr));
/* Adjust counters */ /* Adjust counters */
StartAddr++; StartAddr++;
@ -436,17 +436,17 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write 8-bit status value */ /* Write 8-bit status value */
Endpoint_Write_Byte(DFU_Status); Endpoint_Write_8(DFU_Status);
/* Write 24-bit poll timeout value */ /* Write 24-bit poll timeout value */
Endpoint_Write_Byte(0); Endpoint_Write_8(0);
Endpoint_Write_Word_LE(0); Endpoint_Write_16_LE(0);
/* Write 8-bit state value */ /* Write 8-bit state value */
Endpoint_Write_Byte(DFU_State); Endpoint_Write_8(DFU_State);
/* Write 8-bit state string ID number */ /* Write 8-bit state string ID number */
Endpoint_Write_Byte(0); Endpoint_Write_8(0);
Endpoint_ClearIN(); Endpoint_ClearIN();
@ -464,7 +464,7 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the current device state to the endpoint */ /* Write the current device state to the endpoint */
Endpoint_Write_Byte(DFU_State); Endpoint_Write_8(DFU_State);
Endpoint_ClearIN(); Endpoint_ClearIN();
@ -503,7 +503,7 @@ static void DiscardFillerBytes(uint8_t NumberOfBytes)
} }
else else
{ {
Endpoint_Discard_Byte(); Endpoint_Discard_8();
} }
} }
} }

@ -113,7 +113,7 @@ void EVENT_USB_Device_ControlRequest(void)
while (!(Endpoint_IsOUTReceived())); while (!(Endpoint_IsOUTReceived()));
/* Read in the write destination address */ /* Read in the write destination address */
uint16_t PageAddress = Endpoint_Read_Word_LE(); uint16_t PageAddress = Endpoint_Read_16_LE();
/* Check if the command is a program page command, or a start application command */ /* Check if the command is a program page command, or a start application command */
if (PageAddress == COMMAND_STARTAPPLICATION) if (PageAddress == COMMAND_STARTAPPLICATION)
@ -137,7 +137,7 @@ void EVENT_USB_Device_ControlRequest(void)
} }
/* Write the next data word to the FLASH page */ /* Write the next data word to the FLASH page */
boot_page_fill(PageAddress + ((uint16_t)PageWord << 1), Endpoint_Read_Word_LE()); boot_page_fill(PageAddress + ((uint16_t)PageWord << 1), Endpoint_Read_16_LE());
} }
/* Write the filled FLASH page to memory */ /* Write the filled FLASH page to memory */

@ -129,22 +129,22 @@ void DataflashManager_WriteBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceIn
} }
/* Write one 16-byte chunk of data to the Dataflash */ /* Write one 16-byte chunk of data to the Dataflash */
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;
@ -244,22 +244,22 @@ void DataflashManager_ReadBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceInf
} }
/* Read one 16-byte chunk of data from the Dataflash */ /* Read one 16-byte chunk of data from the Dataflash */
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;

@ -334,10 +334,10 @@ static bool SCSI_Command_ReadWrite_10(USB_ClassInfo_MS_Device_t* const MSInterfa
static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo) static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo)
{ {
/* Send an empty header response with the Write Protect flag status */ /* Send an empty header response with the Write Protect flag status */
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(DISK_READ_ONLY ? 0x80 : 0x00); Endpoint_Write_8(DISK_READ_ONLY ? 0x80 : 0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_ClearIN(); Endpoint_ClearIN();
/* Update the bytes transferred counter and succeed the command */ /* Update the bytes transferred counter and succeed the command */

@ -129,22 +129,22 @@ void DataflashManager_WriteBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceIn
} }
/* Write one 16-byte chunk of data to the Dataflash */ /* Write one 16-byte chunk of data to the Dataflash */
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;
@ -244,22 +244,22 @@ void DataflashManager_ReadBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceInf
} }
/* Read one 16-byte chunk of data from the Dataflash */ /* Read one 16-byte chunk of data from the Dataflash */
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;

@ -334,10 +334,10 @@ static bool SCSI_Command_ReadWrite_10(USB_ClassInfo_MS_Device_t* const MSInterfa
static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo) static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo)
{ {
/* Send an empty header response with the Write Protect flag status */ /* Send an empty header response with the Write Protect flag status */
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(DISK_READ_ONLY ? 0x80 : 0x00); Endpoint_Write_8(DISK_READ_ONLY ? 0x80 : 0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_ClearIN(); Endpoint_ClearIN();
/* Update the bytes transferred counter and succeed the command */ /* Update the bytes transferred counter and succeed the command */

@ -129,22 +129,22 @@ void DataflashManager_WriteBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceIn
} }
/* Write one 16-byte chunk of data to the Dataflash */ /* Write one 16-byte chunk of data to the Dataflash */
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;
@ -244,22 +244,22 @@ void DataflashManager_ReadBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceInf
} }
/* Read one 16-byte chunk of data from the Dataflash */ /* Read one 16-byte chunk of data from the Dataflash */
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;

@ -334,10 +334,10 @@ static bool SCSI_Command_ReadWrite_10(USB_ClassInfo_MS_Device_t* const MSInterfa
static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo) static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo)
{ {
/* Send an empty header response with the Write Protect flag status */ /* Send an empty header response with the Write Protect flag status */
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(DISK_READ_ONLY ? 0x80 : 0x00); Endpoint_Write_8(DISK_READ_ONLY ? 0x80 : 0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_ClearIN(); Endpoint_ClearIN();
/* Update the bytes transferred counter and succeed the command */ /* Update the bytes transferred counter and succeed the command */

@ -311,7 +311,7 @@ static void SideShow_GetApplicationOrder(SideShow_PacketHeader_t* const PacketHe
Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM);
Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL); Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);
Endpoint_Write_DWord_LE(TotalApplications); Endpoint_Write_32_LE(TotalApplications);
for (uint8_t App = 0; App < MAX_APPLICATIONS; App++) for (uint8_t App = 0; App < MAX_APPLICATIONS; App++)
{ {
@ -332,7 +332,7 @@ static void SideShow_GetSupportedEndpoints(SideShow_PacketHeader_t* const Packet
Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM); Endpoint_SelectEndpoint(SIDESHOW_IN_EPNUM);
Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL); Endpoint_Write_Stream_LE(PacketHeader, sizeof(SideShow_PacketHeader_t), NULL);
Endpoint_Write_DWord_LE(1); Endpoint_Write_32_LE(1);
Endpoint_Write_Stream_LE(&SupportedEndpointGUID, sizeof(GUID_t), NULL); Endpoint_Write_Stream_LE(&SupportedEndpointGUID, sizeof(GUID_t), NULL);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }

@ -169,7 +169,7 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the request response byte */ /* Write the request response byte */
Endpoint_Write_Byte(TMCRequestStatus); Endpoint_Write_8(TMCRequestStatus);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -190,9 +190,9 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the request response bytes */ /* Write the request response bytes */
Endpoint_Write_Byte(TMCRequestStatus); Endpoint_Write_8(TMCRequestStatus);
Endpoint_Write_Word_LE(0); Endpoint_Write_16_LE(0);
Endpoint_Write_DWord_LE(LastTransferLength); Endpoint_Write_32_LE(LastTransferLength);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -223,8 +223,8 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the request response bytes */ /* Write the request response bytes */
Endpoint_Write_Byte(TMCRequestStatus); Endpoint_Write_8(TMCRequestStatus);
Endpoint_Write_Byte(CurrentTransferTag); Endpoint_Write_8(CurrentTransferTag);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -245,9 +245,9 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the request response bytes */ /* Write the request response bytes */
Endpoint_Write_Byte(TMCRequestStatus); Endpoint_Write_8(TMCRequestStatus);
Endpoint_Write_Word_LE(0); Endpoint_Write_16_LE(0);
Endpoint_Write_DWord_LE(LastTransferLength); Endpoint_Write_32_LE(LastTransferLength);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -260,7 +260,7 @@ void EVENT_USB_Device_ControlRequest(void)
/* Check that no split transaction is already in progress */ /* Check that no split transaction is already in progress */
if (RequestInProgress != 0) if (RequestInProgress != 0)
{ {
Endpoint_Write_Byte(TMC_STATUS_SPLIT_IN_PROGRESS); Endpoint_Write_8(TMC_STATUS_SPLIT_IN_PROGRESS);
} }
else else
{ {
@ -275,7 +275,7 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the request response byte */ /* Write the request response byte */
Endpoint_Write_Byte(TMCRequestStatus); Endpoint_Write_8(TMCRequestStatus);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -296,8 +296,8 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the request response bytes */ /* Write the request response bytes */
Endpoint_Write_Byte(TMCRequestStatus); Endpoint_Write_8(TMCRequestStatus);
Endpoint_Write_Byte(0); Endpoint_Write_8(0);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();

@ -180,7 +180,7 @@ ISR(TIMER0_COMPA_vect, ISR_BLOCK)
#endif #endif
/* Write the sample to the buffer */ /* Write the sample to the buffer */
Endpoint_Write_Word_LE(AudioSample); Endpoint_Write_16_LE(AudioSample);
/* Check to see if the bank is now full */ /* Check to see if the bank is now full */
if (!(Endpoint_IsReadWriteAllowed())) if (!(Endpoint_IsReadWriteAllowed()))

@ -184,8 +184,8 @@ ISR(TIMER0_COMPA_vect, ISR_BLOCK)
if (Endpoint_IsOUTReceived() && StreamingAudioInterfaceSelected) if (Endpoint_IsOUTReceived() && StreamingAudioInterfaceSelected)
{ {
/* Retrieve the signed 16-bit left and right audio samples, convert to 8-bit */ /* Retrieve the signed 16-bit left and right audio samples, convert to 8-bit */
int8_t LeftSample_8Bit = ((int16_t)Endpoint_Read_Word_LE() >> 8); int8_t LeftSample_8Bit = ((int16_t)Endpoint_Read_16_LE() >> 8);
int8_t RightSample_8Bit = ((int16_t)Endpoint_Read_Word_LE() >> 8); int8_t RightSample_8Bit = ((int16_t)Endpoint_Read_16_LE() >> 8);
/* Mix the two channels together to produce a mono, 8-bit sample */ /* Mix the two channels together to produce a mono, 8-bit sample */
int8_t MixedSample_8Bit = (((int16_t)LeftSample_8Bit + (int16_t)RightSample_8Bit) >> 1); int8_t MixedSample_8Bit = (((int16_t)LeftSample_8Bit + (int16_t)RightSample_8Bit) >> 1);

@ -167,7 +167,7 @@ void EVENT_USB_Device_ControlRequest(void)
} }
/* Read in the LED report from the host */ /* Read in the LED report from the host */
uint8_t LEDStatus = Endpoint_Read_Byte(); uint8_t LEDStatus = Endpoint_Read_8();
Endpoint_ClearOUT(); Endpoint_ClearOUT();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -183,7 +183,7 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the current protocol flag to the host */ /* Write the current protocol flag to the host */
Endpoint_Write_Byte(UsingReportProtocol); Endpoint_Write_8(UsingReportProtocol);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -218,7 +218,7 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the current idle duration to the host, must be divided by 4 before sent to host */ /* Write the current idle duration to the host, must be divided by 4 before sent to host */
Endpoint_Write_Byte(IdleCount >> 2); Endpoint_Write_8(IdleCount >> 2);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -344,7 +344,7 @@ void ReceiveNextReport(void)
if (Endpoint_IsReadWriteAllowed()) if (Endpoint_IsReadWriteAllowed())
{ {
/* Read in the LED report from the host */ /* Read in the LED report from the host */
uint8_t LEDReport = Endpoint_Read_Byte(); uint8_t LEDReport = Endpoint_Read_8();
/* Process the read LED report from the host */ /* Process the read LED report from the host */
ProcessLEDReport(LEDReport); ProcessLEDReport(LEDReport);

@ -168,7 +168,7 @@ void EVENT_USB_Device_ControlRequest(void)
} }
/* Read in the LED report from the host */ /* Read in the LED report from the host */
uint8_t LEDStatus = Endpoint_Read_Byte(); uint8_t LEDStatus = Endpoint_Read_8();
Endpoint_ClearOUT(); Endpoint_ClearOUT();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -258,7 +258,7 @@ void Keyboard_HID_Task(void)
if (Endpoint_IsReadWriteAllowed()) if (Endpoint_IsReadWriteAllowed())
{ {
/* Read in and process the LED report from the host */ /* Read in and process the LED report from the host */
Keyboard_ProcessLEDReport(Endpoint_Read_Byte()); Keyboard_ProcessLEDReport(Endpoint_Read_8());
/* Handshake the OUT Endpoint - clear endpoint and ready for next report */ /* Handshake the OUT Endpoint - clear endpoint and ready for next report */
Endpoint_ClearOUT(); Endpoint_ClearOUT();

@ -127,22 +127,22 @@ void DataflashManager_WriteBlocks(const uint32_t BlockAddress,
} }
/* Write one 16-byte chunk of data to the Dataflash */ /* Write one 16-byte chunk of data to the Dataflash */
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;
@ -240,22 +240,22 @@ void DataflashManager_ReadBlocks(const uint32_t BlockAddress,
} }
/* Read one 16-byte chunk of data from the Dataflash */ /* Read one 16-byte chunk of data from the Dataflash */
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;

@ -212,10 +212,10 @@ static bool SCSI_Command_Request_Sense(void)
static bool SCSI_Command_Read_Capacity_10(void) static bool SCSI_Command_Read_Capacity_10(void)
{ {
/* Send the total number of logical blocks in the current LUN */ /* Send the total number of logical blocks in the current LUN */
Endpoint_Write_DWord_BE(LUN_MEDIA_BLOCKS - 1); Endpoint_Write_32_BE(LUN_MEDIA_BLOCKS - 1);
/* Send the logical block size of the device (must be 512 bytes) */ /* Send the logical block size of the device (must be 512 bytes) */
Endpoint_Write_DWord_BE(VIRTUAL_MEMORY_BLOCK_SIZE); Endpoint_Write_32_BE(VIRTUAL_MEMORY_BLOCK_SIZE);
/* Check if the current command is being aborted by the host */ /* Check if the current command is being aborted by the host */
if (IsMassStoreReset) if (IsMassStoreReset)
@ -329,10 +329,10 @@ static bool SCSI_Command_ReadWrite_10(const bool IsDataRead)
static bool SCSI_Command_ModeSense_6(void) static bool SCSI_Command_ModeSense_6(void)
{ {
/* Send an empty header response with the Write Protect flag status */ /* Send an empty header response with the Write Protect flag status */
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(DISK_READ_ONLY ? 0x80 : 0x00); Endpoint_Write_8(DISK_READ_ONLY ? 0x80 : 0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_ClearIN(); Endpoint_ClearIN();
/* Update the bytes transferred counter and succeed the command */ /* Update the bytes transferred counter and succeed the command */

@ -146,7 +146,7 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Indicate to the host the number of supported LUNs (virtual disks) on the device */ /* Indicate to the host the number of supported LUNs (virtual disks) on the device */
Endpoint_Write_Byte(TOTAL_LUNS - 1); Endpoint_Write_8(TOTAL_LUNS - 1);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();

@ -160,7 +160,7 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the current protocol flag to the host */ /* Write the current protocol flag to the host */
Endpoint_Write_Byte(UsingReportProtocol); Endpoint_Write_8(UsingReportProtocol);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -195,7 +195,7 @@ void EVENT_USB_Device_ControlRequest(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
/* Write the current idle duration to the host, must be divided by 4 before sent to host */ /* Write the current idle duration to the host, must be divided by 4 before sent to host */
Endpoint_Write_Byte(IdleCount >> 2); Endpoint_Write_8(IdleCount >> 2);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();

@ -198,7 +198,7 @@ void WriteNextReport(uint8_t* ReportOUTData,
/* If the report index is used, send it before the report data */ /* If the report index is used, send it before the report data */
if (ReportIndex) if (ReportIndex)
Pipe_Write_Byte(ReportIndex); Pipe_Write_8(ReportIndex);
/* Write out HID report data */ /* Write out HID report data */
Pipe_Write_Stream_LE(ReportOUTData, ReportLength, NULL); Pipe_Write_Stream_LE(ReportOUTData, ReportLength, NULL);

@ -203,7 +203,7 @@
(void)AudioInterfaceInfo; (void)AudioInterfaceInfo;
Sample = Endpoint_Read_Byte(); Sample = Endpoint_Read_8();
if (!(Endpoint_BytesInEndpoint())) if (!(Endpoint_BytesInEndpoint()))
Endpoint_ClearOUT(); Endpoint_ClearOUT();
@ -228,7 +228,7 @@
(void)AudioInterfaceInfo; (void)AudioInterfaceInfo;
Sample = (int16_t)Endpoint_Read_Word_LE(); Sample = (int16_t)Endpoint_Read_16_LE();
if (!(Endpoint_BytesInEndpoint())) if (!(Endpoint_BytesInEndpoint()))
Endpoint_ClearOUT(); Endpoint_ClearOUT();
@ -253,7 +253,7 @@
(void)AudioInterfaceInfo; (void)AudioInterfaceInfo;
Sample = (((uint32_t)Endpoint_Read_Byte() << 16) | Endpoint_Read_Word_LE()); Sample = (((uint32_t)Endpoint_Read_8() << 16) | Endpoint_Read_16_LE());
if (!(Endpoint_BytesInEndpoint())) if (!(Endpoint_BytesInEndpoint()))
Endpoint_ClearOUT(); Endpoint_ClearOUT();
@ -274,7 +274,7 @@
static inline void Audio_Device_WriteSample8(USB_ClassInfo_Audio_Device_t* const AudioInterfaceInfo, static inline void Audio_Device_WriteSample8(USB_ClassInfo_Audio_Device_t* const AudioInterfaceInfo,
const int8_t Sample) const int8_t Sample)
{ {
Endpoint_Write_Byte(Sample); Endpoint_Write_8(Sample);
if (Endpoint_BytesInEndpoint() == AudioInterfaceInfo->Config.DataINEndpointSize) if (Endpoint_BytesInEndpoint() == AudioInterfaceInfo->Config.DataINEndpointSize)
Endpoint_ClearIN(); Endpoint_ClearIN();
@ -293,7 +293,7 @@
static inline void Audio_Device_WriteSample16(USB_ClassInfo_Audio_Device_t* const AudioInterfaceInfo, static inline void Audio_Device_WriteSample16(USB_ClassInfo_Audio_Device_t* const AudioInterfaceInfo,
const int16_t Sample) const int16_t Sample)
{ {
Endpoint_Write_Word_LE(Sample); Endpoint_Write_16_LE(Sample);
if (Endpoint_BytesInEndpoint() == AudioInterfaceInfo->Config.DataINEndpointSize) if (Endpoint_BytesInEndpoint() == AudioInterfaceInfo->Config.DataINEndpointSize)
Endpoint_ClearIN(); Endpoint_ClearIN();
@ -312,8 +312,8 @@
static inline void Audio_Device_WriteSample24(USB_ClassInfo_Audio_Device_t* const AudioInterfaceInfo, static inline void Audio_Device_WriteSample24(USB_ClassInfo_Audio_Device_t* const AudioInterfaceInfo,
const int32_t Sample) const int32_t Sample)
{ {
Endpoint_Write_Word_LE(Sample); Endpoint_Write_16_LE(Sample);
Endpoint_Write_Byte(Sample >> 16); Endpoint_Write_8(Sample >> 16);
if (Endpoint_BytesInEndpoint() == AudioInterfaceInfo->Config.DataINEndpointSize) if (Endpoint_BytesInEndpoint() == AudioInterfaceInfo->Config.DataINEndpointSize)
Endpoint_ClearIN(); Endpoint_ClearIN();

@ -188,7 +188,7 @@ uint8_t CDC_Device_SendByte(USB_ClassInfo_CDC_Device_t* const CDCInterfaceInfo,
return ErrorCode; return ErrorCode;
} }
Endpoint_Write_Byte(Data); Endpoint_Write_8(Data);
return ENDPOINT_READYWAIT_NoError; return ENDPOINT_READYWAIT_NoError;
} }
@ -256,7 +256,7 @@ int16_t CDC_Device_ReceiveByte(USB_ClassInfo_CDC_Device_t* const CDCInterfaceInf
if (Endpoint_IsOUTReceived()) if (Endpoint_IsOUTReceived())
{ {
if (Endpoint_BytesInEndpoint()) if (Endpoint_BytesInEndpoint())
ReceivedByte = Endpoint_Read_Byte(); ReceivedByte = Endpoint_Read_8();
if (!(Endpoint_BytesInEndpoint())) if (!(Endpoint_BytesInEndpoint()))
Endpoint_ClearOUT(); Endpoint_ClearOUT();

@ -94,7 +94,7 @@ void HID_Device_ProcessControlRequest(USB_ClassInfo_HID_Device_t* const HIDInter
if (USB_ControlRequest.bmRequestType == (REQDIR_DEVICETOHOST | REQTYPE_CLASS | REQREC_INTERFACE)) if (USB_ControlRequest.bmRequestType == (REQDIR_DEVICETOHOST | REQTYPE_CLASS | REQREC_INTERFACE))
{ {
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
Endpoint_Write_Byte(HIDInterfaceInfo->State.UsingReportProtocol); Endpoint_Write_8(HIDInterfaceInfo->State.UsingReportProtocol);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
} }
@ -124,7 +124,7 @@ void HID_Device_ProcessControlRequest(USB_ClassInfo_HID_Device_t* const HIDInter
if (USB_ControlRequest.bmRequestType == (REQDIR_DEVICETOHOST | REQTYPE_CLASS | REQREC_INTERFACE)) if (USB_ControlRequest.bmRequestType == (REQDIR_DEVICETOHOST | REQTYPE_CLASS | REQREC_INTERFACE))
{ {
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
Endpoint_Write_Byte(HIDInterfaceInfo->State.IdleCount >> 2); Endpoint_Write_8(HIDInterfaceInfo->State.IdleCount >> 2);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
} }
@ -182,7 +182,7 @@ void HID_Device_USBTask(USB_ClassInfo_HID_Device_t* const HIDInterfaceInfo)
Endpoint_SelectEndpoint(HIDInterfaceInfo->Config.ReportINEndpointNumber); Endpoint_SelectEndpoint(HIDInterfaceInfo->Config.ReportINEndpointNumber);
if (ReportID) if (ReportID)
Endpoint_Write_Byte(ReportID); Endpoint_Write_8(ReportID);
Endpoint_Write_Stream_LE(ReportINData, ReportINSize, NULL); Endpoint_Write_Stream_LE(ReportINData, ReportINSize, NULL);

@ -61,7 +61,7 @@ void MS_Device_ProcessControlRequest(USB_ClassInfo_MS_Device_t* const MSInterfac
if (USB_ControlRequest.bmRequestType == (REQDIR_DEVICETOHOST | REQTYPE_CLASS | REQREC_INTERFACE)) if (USB_ControlRequest.bmRequestType == (REQDIR_DEVICETOHOST | REQTYPE_CLASS | REQREC_INTERFACE))
{ {
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
Endpoint_Write_Byte(MSInterfaceInfo->Config.TotalLUNs - 1); Endpoint_Write_8(MSInterfaceInfo->Config.TotalLUNs - 1);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
} }

@ -366,7 +366,7 @@ uint8_t CDC_Host_SendByte(USB_ClassInfo_CDC_Host_t* const CDCInterfaceInfo,
return ErrorCode; return ErrorCode;
} }
Pipe_Write_Byte(Data); Pipe_Write_8(Data);
Pipe_Freeze(); Pipe_Freeze();
return PIPE_READYWAIT_NoError; return PIPE_READYWAIT_NoError;
@ -415,7 +415,7 @@ int16_t CDC_Host_ReceiveByte(USB_ClassInfo_CDC_Host_t* const CDCInterfaceInfo)
if (Pipe_IsINReceived()) if (Pipe_IsINReceived())
{ {
if (Pipe_BytesInPipe()) if (Pipe_BytesInPipe())
ReceivedByte = Pipe_Read_Byte(); ReceivedByte = Pipe_Read_8();
if (!(Pipe_BytesInPipe())) if (!(Pipe_BytesInPipe()))
Pipe_ClearIN(); Pipe_ClearIN();

@ -240,7 +240,7 @@ uint8_t HID_Host_ReceiveReport(USB_ClassInfo_HID_Host_t* const HIDInterfaceInfo,
if (HIDInterfaceInfo->Config.HIDParserData->UsingReportIDs) if (HIDInterfaceInfo->Config.HIDParserData->UsingReportIDs)
{ {
ReportID = Pipe_Read_Byte(); ReportID = Pipe_Read_8();
*(BufferPos++) = ReportID; *(BufferPos++) = ReportID;
} }

@ -281,7 +281,7 @@ uint8_t PRNT_Host_SendByte(USB_ClassInfo_PRNT_Host_t* const PRNTInterfaceInfo,
return ErrorCode; return ErrorCode;
} }
Pipe_Write_Byte(Data); Pipe_Write_8(Data);
Pipe_Freeze(); Pipe_Freeze();
return PIPE_READYWAIT_NoError; return PIPE_READYWAIT_NoError;
@ -377,7 +377,7 @@ int16_t PRNT_Host_ReceiveByte(USB_ClassInfo_PRNT_Host_t* const PRNTInterfaceInfo
if (Pipe_IsINReceived()) if (Pipe_IsINReceived())
{ {
if (Pipe_BytesInPipe()) if (Pipe_BytesInPipe())
ReceivedByte = Pipe_Read_Byte(); ReceivedByte = Pipe_Read_8();
if (!(Pipe_BytesInPipe())) if (!(Pipe_BytesInPipe()))
Pipe_ClearIN(); Pipe_ClearIN();

@ -618,8 +618,8 @@
* *
* \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_8(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint8_t Endpoint_Read_Byte(void) static inline uint8_t Endpoint_Read_8(void)
{ {
return UEDATX; return UEDATX;
} }
@ -628,20 +628,20 @@
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
* *
* \param[in] Byte Next byte to write into the the currently selected endpoint's FIFO buffer. * \param[in] Data Data 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_8(const uint8_t Data) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Write_Byte(const uint8_t Byte) static inline void Endpoint_Write_8(const uint8_t Data)
{ {
UEDATX = Byte; UEDATX = Data;
} }
/** Discards one byte from the currently selected endpoint's bank, for OUT direction endpoints. /** Discards one byte from the currently selected endpoint's bank, for OUT direction endpoints.
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
*/ */
static inline void Endpoint_Discard_Byte(void) ATTR_ALWAYS_INLINE; static inline void Endpoint_Discard_8(void) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Discard_Byte(void) static inline void Endpoint_Discard_8(void)
{ {
uint8_t Dummy; uint8_t Dummy;
@ -653,21 +653,21 @@
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
* *
* \return Next word in the currently selected endpoint's FIFO buffer. * \return Next two bytes 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_16_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint16_t Endpoint_Read_Word_LE(void) static inline uint16_t Endpoint_Read_16_LE(void)
{ {
union union
{ {
uint16_t Word; uint16_t Value;
uint8_t Bytes[2]; uint8_t Bytes[2];
} Data; } Data;
Data.Bytes[0] = UEDATX; Data.Bytes[0] = UEDATX;
Data.Bytes[1] = UEDATX; Data.Bytes[1] = UEDATX;
return Data.Word; return Data.Value;
} }
/** Reads two bytes from the currently selected endpoint's bank in big endian format, for OUT /** Reads two bytes from the currently selected endpoint's bank in big endian format, for OUT
@ -675,21 +675,21 @@
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
* *
* \return Next word in the currently selected endpoint's FIFO buffer. * \return Next two bytes 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_16_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint16_t Endpoint_Read_Word_BE(void) static inline uint16_t Endpoint_Read_16_BE(void)
{ {
union union
{ {
uint16_t Word; uint16_t Value;
uint8_t Bytes[2]; uint8_t Bytes[2];
} Data; } Data;
Data.Bytes[1] = UEDATX; Data.Bytes[1] = UEDATX;
Data.Bytes[0] = UEDATX; Data.Bytes[0] = UEDATX;
return Data.Word; return Data.Value;
} }
/** Writes two bytes to the currently selected endpoint's bank in little endian format, for IN /** Writes two bytes to the currently selected endpoint's bank in little endian format, for IN
@ -697,13 +697,13 @@
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
* *
* \param[in] Word Next word to write to the currently selected endpoint's FIFO buffer. * \param[in] Data Data 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_16_LE(const uint16_t Data) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Write_Word_LE(const uint16_t Word) static inline void Endpoint_Write_16_LE(const uint16_t Data)
{ {
UEDATX = (Word & 0xFF); UEDATX = (Data & 0xFF);
UEDATX = (Word >> 8); UEDATX = (Data >> 8);
} }
/** Writes two bytes to the currently selected endpoint's bank in big endian format, for IN /** Writes two bytes to the currently selected endpoint's bank in big endian format, for IN
@ -711,21 +711,21 @@
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
* *
* \param[in] Word Next word to write to the currently selected endpoint's FIFO buffer. * \param[in] Data Data 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_16_BE(const uint16_t Data) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Write_Word_BE(const uint16_t Word) static inline void Endpoint_Write_16_BE(const uint16_t Data)
{ {
UEDATX = (Word >> 8); UEDATX = (Data >> 8);
UEDATX = (Word & 0xFF); UEDATX = (Data & 0xFF);
} }
/** Discards two bytes from the currently selected endpoint's bank, for OUT direction endpoints. /** Discards two bytes from the currently selected endpoint's bank, for OUT direction endpoints.
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
*/ */
static inline void Endpoint_Discard_Word(void) ATTR_ALWAYS_INLINE; static inline void Endpoint_Discard_16(void) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Discard_Word(void) static inline void Endpoint_Discard_16(void)
{ {
uint8_t Dummy; uint8_t Dummy;
@ -738,14 +738,14 @@
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
* *
* \return Next double word in the currently selected endpoint's FIFO buffer. * \return Next four bytes 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_32_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint32_t Endpoint_Read_DWord_LE(void) static inline uint32_t Endpoint_Read_32_LE(void)
{ {
union union
{ {
uint32_t DWord; uint32_t Value;
uint8_t Bytes[4]; uint8_t Bytes[4];
} Data; } Data;
@ -754,7 +754,7 @@
Data.Bytes[2] = UEDATX; Data.Bytes[2] = UEDATX;
Data.Bytes[3] = UEDATX; Data.Bytes[3] = UEDATX;
return Data.DWord; return Data.Value;
} }
/** Reads four bytes from the currently selected endpoint's bank in big endian format, for OUT /** Reads four bytes from the currently selected endpoint's bank in big endian format, for OUT
@ -762,14 +762,14 @@
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
* *
* \return Next double word in the currently selected endpoint's FIFO buffer. * \return Next four bytes 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_32_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint32_t Endpoint_Read_DWord_BE(void) static inline uint32_t Endpoint_Read_32_BE(void)
{ {
union union
{ {
uint32_t DWord; uint32_t Value;
uint8_t Bytes[4]; uint8_t Bytes[4];
} Data; } Data;
@ -778,7 +778,7 @@
Data.Bytes[1] = UEDATX; Data.Bytes[1] = UEDATX;
Data.Bytes[0] = UEDATX; Data.Bytes[0] = UEDATX;
return Data.DWord; return Data.Value;
} }
/** Writes four bytes to the currently selected endpoint's bank in little endian format, for IN /** Writes four bytes to the currently selected endpoint's bank in little endian format, for IN
@ -786,15 +786,15 @@
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
* *
* \param[in] DWord Next double word to write to the currently selected endpoint's FIFO buffer. * \param[in] Data Data 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_32_LE(const uint32_t Data) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Write_DWord_LE(const uint32_t DWord) static inline void Endpoint_Write_32_LE(const uint32_t Data)
{ {
UEDATX = (DWord & 0xFF); UEDATX = (Data & 0xFF);
UEDATX = (DWord >> 8); UEDATX = (Data >> 8);
UEDATX = (DWord >> 16); UEDATX = (Data >> 16);
UEDATX = (DWord >> 24); UEDATX = (Data >> 24);
} }
/** Writes four bytes to the currently selected endpoint's bank in big endian format, for IN /** Writes four bytes to the currently selected endpoint's bank in big endian format, for IN
@ -802,23 +802,23 @@
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
* *
* \param[in] DWord Next double word to write to the currently selected endpoint's FIFO buffer. * \param[in] Data Data 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_32_BE(const uint32_t Data) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Write_DWord_BE(const uint32_t DWord) static inline void Endpoint_Write_32_BE(const uint32_t Data)
{ {
UEDATX = (DWord >> 24); UEDATX = (Data >> 24);
UEDATX = (DWord >> 16); UEDATX = (Data >> 16);
UEDATX = (DWord >> 8); UEDATX = (Data >> 8);
UEDATX = (DWord & 0xFF); UEDATX = (Data & 0xFF);
} }
/** Discards four bytes from the currently selected endpoint's bank, for OUT direction endpoints. /** Discards four bytes from the currently selected endpoint's bank, for OUT direction endpoints.
* *
* \ingroup Group_EndpointPrimitiveRW_AVR8 * \ingroup Group_EndpointPrimitiveRW_AVR8
*/ */
static inline void Endpoint_Discard_DWord(void) ATTR_ALWAYS_INLINE; static inline void Endpoint_Discard_32(void) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Discard_DWord(void) static inline void Endpoint_Discard_32(void)
{ {
uint8_t Dummy; uint8_t Dummy;

@ -583,8 +583,8 @@
* *
* \return Next byte in the currently selected pipe's FIFO buffer. * \return Next byte in the currently selected pipe's FIFO buffer.
*/ */
static inline uint8_t Pipe_Read_Byte(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE; static inline uint8_t Pipe_Read_8(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint8_t Pipe_Read_Byte(void) static inline uint8_t Pipe_Read_8(void)
{ {
return UPDATX; return UPDATX;
} }
@ -593,10 +593,10 @@
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
* *
* \param[in] Byte Next byte to write into the the currently selected pipe's FIFO buffer. * \param[in] Data Data to write into the the currently selected pipe's FIFO buffer.
*/ */
static inline void Pipe_Write_Byte(const uint8_t Byte) ATTR_ALWAYS_INLINE; static inline void Pipe_Write_8(const uint8_t Data) ATTR_ALWAYS_INLINE;
static inline void Pipe_Write_Byte(const uint8_t Byte) static inline void Pipe_Write_8(const uint8_t Data)
{ {
UPDATX = Byte; UPDATX = Byte;
} }
@ -605,8 +605,8 @@
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
*/ */
static inline void Pipe_Discard_Byte(void) ATTR_ALWAYS_INLINE; static inline void Pipe_Discard_8(void) ATTR_ALWAYS_INLINE;
static inline void Pipe_Discard_Byte(void) static inline void Pipe_Discard_8(void)
{ {
uint8_t Dummy; uint8_t Dummy;
@ -618,21 +618,21 @@
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
* *
* \return Next word in the currently selected pipe's FIFO buffer. * \return Next two bytes in the currently selected pipe's FIFO buffer.
*/ */
static inline uint16_t Pipe_Read_Word_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE; static inline uint16_t Pipe_Read_16_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint16_t Pipe_Read_Word_LE(void) static inline uint16_t Pipe_Read_16_LE(void)
{ {
union union
{ {
uint16_t Word; uint16_t Value;
uint8_t Bytes[2]; uint8_t Bytes[2];
} Data; } Data;
Data.Bytes[0] = UPDATX; Data.Bytes[0] = UPDATX;
Data.Bytes[1] = UPDATX; Data.Bytes[1] = UPDATX;
return Data.Word; return Data.Value;
} }
/** Reads two bytes from the currently selected pipe's bank in big endian format, for OUT /** Reads two bytes from the currently selected pipe's bank in big endian format, for OUT
@ -640,21 +640,21 @@
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
* *
* \return Next word in the currently selected pipe's FIFO buffer. * \return Next two bytes in the currently selected pipe's FIFO buffer.
*/ */
static inline uint16_t Pipe_Read_Word_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE; static inline uint16_t Pipe_Read_16_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint16_t Pipe_Read_Word_BE(void) static inline uint16_t Pipe_Read_16_BE(void)
{ {
union union
{ {
uint16_t Word; uint16_t Value;
uint8_t Bytes[2]; uint8_t Bytes[2];
} Data; } Data;
Data.Bytes[1] = UPDATX; Data.Bytes[1] = UPDATX;
Data.Bytes[0] = UPDATX; Data.Bytes[0] = UPDATX;
return Data.Word; return Data.Value;
} }
/** Writes two bytes to the currently selected pipe's bank in little endian format, for IN /** Writes two bytes to the currently selected pipe's bank in little endian format, for IN
@ -662,13 +662,13 @@
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
* *
* \param[in] Word Next word to write to the currently selected pipe's FIFO buffer. * \param[in] Data Data to write to the currently selected pipe's FIFO buffer.
*/ */
static inline void Pipe_Write_Word_LE(const uint16_t Word) ATTR_ALWAYS_INLINE; static inline void Pipe_Write_16_LE(const uint16_t Data) ATTR_ALWAYS_INLINE;
static inline void Pipe_Write_Word_LE(const uint16_t Word) static inline void Pipe_Write_16_LE(const uint16_t Data)
{ {
UPDATX = (Word & 0xFF); UPDATX = (Data & 0xFF);
UPDATX = (Word >> 8); UPDATX = (Data >> 8);
} }
/** Writes two bytes to the currently selected pipe's bank in big endian format, for IN /** Writes two bytes to the currently selected pipe's bank in big endian format, for IN
@ -676,21 +676,21 @@
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
* *
* \param[in] Word Next word to write to the currently selected pipe's FIFO buffer. * \param[in] Data Data to write to the currently selected pipe's FIFO buffer.
*/ */
static inline void Pipe_Write_Word_BE(const uint16_t Word) ATTR_ALWAYS_INLINE; static inline void Pipe_Write_16_BE(const uint16_t Data) ATTR_ALWAYS_INLINE;
static inline void Pipe_Write_Word_BE(const uint16_t Word) static inline void Pipe_Write_16_BE(const uint16_t Data)
{ {
UPDATX = (Word >> 8); UPDATX = (Data >> 8);
UPDATX = (Word & 0xFF); UPDATX = (Data & 0xFF);
} }
/** Discards two bytes from the currently selected pipe's bank, for OUT direction pipes. /** Discards two bytes from the currently selected pipe's bank, for OUT direction pipes.
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
*/ */
static inline void Pipe_Discard_Word(void) ATTR_ALWAYS_INLINE; static inline void Pipe_Discard_16(void) ATTR_ALWAYS_INLINE;
static inline void Pipe_Discard_Word(void) static inline void Pipe_Discard_16(void)
{ {
uint8_t Dummy; uint8_t Dummy;
@ -703,14 +703,14 @@
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
* *
* \return Next double word in the currently selected pipe's FIFO buffer. * \return Next four bytes in the currently selected pipe's FIFO buffer.
*/ */
static inline uint32_t Pipe_Read_DWord_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE; static inline uint32_t Pipe_Read_32_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint32_t Pipe_Read_DWord_LE(void) static inline uint32_t Pipe_Read_32_LE(void)
{ {
union union
{ {
uint32_t DWord; uint32_t Value;
uint8_t Bytes[4]; uint8_t Bytes[4];
} Data; } Data;
@ -719,7 +719,7 @@
Data.Bytes[2] = UPDATX; Data.Bytes[2] = UPDATX;
Data.Bytes[3] = UPDATX; Data.Bytes[3] = UPDATX;
return Data.DWord; return Data.Value;
} }
/** Reads four bytes from the currently selected pipe's bank in big endian format, for OUT /** Reads four bytes from the currently selected pipe's bank in big endian format, for OUT
@ -727,10 +727,10 @@
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
* *
* \return Next double word in the currently selected pipe's FIFO buffer. * \return Next four bytes in the currently selected pipe's FIFO buffer.
*/ */
static inline uint32_t Pipe_Read_DWord_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE; static inline uint32_t Pipe_Read_32_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint32_t Pipe_Read_DWord_BE(void) static inline uint32_t Pipe_Read_32_BE(void)
{ {
union union
{ {
@ -751,15 +751,15 @@
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
* *
* \param[in] DWord Next double word to write to the currently selected pipe's FIFO buffer. * \param[in] Data Data to write to the currently selected pipe's FIFO buffer.
*/ */
static inline void Pipe_Write_DWord_LE(const uint32_t DWord) ATTR_ALWAYS_INLINE; static inline void Pipe_Write_32_LE(const uint32_t Data) ATTR_ALWAYS_INLINE;
static inline void Pipe_Write_DWord_LE(const uint32_t DWord) static inline void Pipe_Write_32_LE(const uint32_t Data)
{ {
UPDATX = (DWord & 0xFF); UPDATX = (Data & 0xFF);
UPDATX = (DWord >> 8); UPDATX = (Data >> 8);
UPDATX = (DWord >> 16); UPDATX = (Data >> 16);
UPDATX = (DWord >> 24); UPDATX = (Data >> 24);
} }
/** Writes four bytes to the currently selected pipe's bank in big endian format, for IN /** Writes four bytes to the currently selected pipe's bank in big endian format, for IN
@ -767,23 +767,23 @@
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
* *
* \param[in] DWord Next double word to write to the currently selected pipe's FIFO buffer. * \param[in] Data Data to write to the currently selected pipe's FIFO buffer.
*/ */
static inline void Pipe_Write_DWord_BE(const uint32_t DWord) ATTR_ALWAYS_INLINE; static inline void Pipe_Write_32_BE(const uint32_t Data) ATTR_ALWAYS_INLINE;
static inline void Pipe_Write_DWord_BE(const uint32_t DWord) static inline void Pipe_Write_32_BE(const uint32_t Data)
{ {
UPDATX = (DWord >> 24); UPDATX = (Data >> 24);
UPDATX = (DWord >> 16); UPDATX = (Data >> 16);
UPDATX = (DWord >> 8); UPDATX = (Data >> 8);
UPDATX = (DWord & 0xFF); UPDATX = (Data & 0xFF);
} }
/** Discards four bytes from the currently selected pipe's bank, for OUT direction pipes. /** Discards four bytes from the currently selected pipe's bank, for OUT direction pipes.
* *
* \ingroup Group_PipePrimitiveRW_AVR8 * \ingroup Group_PipePrimitiveRW_AVR8
*/ */
static inline void Pipe_Discard_DWord(void) ATTR_ALWAYS_INLINE; static inline void Pipe_Discard_32(void) ATTR_ALWAYS_INLINE;
static inline void Pipe_Discard_DWord(void) static inline void Pipe_Discard_32(void)
{ {
uint8_t Dummy; uint8_t Dummy;

@ -48,11 +48,11 @@ bool USB_RemoteWakeupEnabled;
void USB_Device_ProcessControlRequest(void) void USB_Device_ProcessControlRequest(void)
{ {
USB_ControlRequest.bmRequestType = Endpoint_Read_Byte(); USB_ControlRequest.bmRequestType = Endpoint_Read_8();
USB_ControlRequest.bRequest = Endpoint_Read_Byte(); USB_ControlRequest.bRequest = Endpoint_Read_8();
USB_ControlRequest.wValue = Endpoint_Read_Word_LE(); USB_ControlRequest.wValue = Endpoint_Read_16_LE();
USB_ControlRequest.wIndex = Endpoint_Read_Word_LE(); USB_ControlRequest.wIndex = Endpoint_Read_16_LE();
USB_ControlRequest.wLength = Endpoint_Read_Word_LE(); USB_ControlRequest.wLength = Endpoint_Read_16_LE();
EVENT_USB_Device_ControlRequest(); EVENT_USB_Device_ControlRequest();
@ -200,7 +200,7 @@ static void USB_Device_GetConfiguration(void)
{ {
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
Endpoint_Write_Byte(USB_ConfigurationNumber); Endpoint_Write_8(USB_ConfigurationNumber);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();
@ -311,7 +311,7 @@ static void USB_Device_GetStatus(void)
Endpoint_ClearSETUP(); Endpoint_ClearSETUP();
Endpoint_Write_Word_LE(CurrentStatus); Endpoint_Write_16_LE(CurrentStatus);
Endpoint_ClearIN(); Endpoint_ClearIN();
Endpoint_ClearStatusStage(); Endpoint_ClearStatusStage();

@ -65,7 +65,7 @@ uint8_t Endpoint_Discard_Stream(uint16_t Length,
} }
else else
{ {
Endpoint_Discard_Byte(); Endpoint_Discard_8();
Length--; Length--;
BytesInTransfer++; BytesInTransfer++;
@ -104,7 +104,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
} }
else else
{ {
Endpoint_Write_Byte(0); Endpoint_Write_8(0);
Length--; Length--;
BytesInTransfer++; BytesInTransfer++;
@ -119,7 +119,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN() #define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN()
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(*BufferPtr) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(*BufferPtr)
#include "Template/Template_Endpoint_RW.c" #include "Template/Template_Endpoint_RW.c"
#define TEMPLATE_FUNC_NAME Endpoint_Write_Stream_BE #define TEMPLATE_FUNC_NAME Endpoint_Write_Stream_BE
@ -127,7 +127,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN() #define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN()
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(*BufferPtr) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(*BufferPtr)
#include "Template/Template_Endpoint_RW.c" #include "Template/Template_Endpoint_RW.c"
#define TEMPLATE_FUNC_NAME Endpoint_Read_Stream_LE #define TEMPLATE_FUNC_NAME Endpoint_Read_Stream_LE
@ -135,7 +135,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearOUT() #define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearOUT()
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Endpoint_Read_Byte() #define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Endpoint_Read_8()
#include "Template/Template_Endpoint_RW.c" #include "Template/Template_Endpoint_RW.c"
#define TEMPLATE_FUNC_NAME Endpoint_Read_Stream_BE #define TEMPLATE_FUNC_NAME Endpoint_Read_Stream_BE
@ -143,7 +143,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearOUT() #define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearOUT()
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Endpoint_Read_Byte() #define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Endpoint_Read_8()
#include "Template/Template_Endpoint_RW.c" #include "Template/Template_Endpoint_RW.c"
#if defined(ARCH_HAS_FLASH_ADDRESS_SPACE) #if defined(ARCH_HAS_FLASH_ADDRESS_SPACE)
@ -152,7 +152,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN() #define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN()
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(pgm_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(pgm_read_byte(BufferPtr))
#include "Template/Template_Endpoint_RW.c" #include "Template/Template_Endpoint_RW.c"
#define TEMPLATE_FUNC_NAME Endpoint_Write_PStream_BE #define TEMPLATE_FUNC_NAME Endpoint_Write_PStream_BE
@ -160,7 +160,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN() #define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN()
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(pgm_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(pgm_read_byte(BufferPtr))
#include "Template/Template_Endpoint_RW.c" #include "Template/Template_Endpoint_RW.c"
#endif #endif
@ -170,7 +170,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN() #define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN()
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(eeprom_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(eeprom_read_byte(BufferPtr))
#include "Template/Template_Endpoint_RW.c" #include "Template/Template_Endpoint_RW.c"
#define TEMPLATE_FUNC_NAME Endpoint_Write_EStream_BE #define TEMPLATE_FUNC_NAME Endpoint_Write_EStream_BE
@ -178,7 +178,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN() #define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearIN()
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(eeprom_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(eeprom_read_byte(BufferPtr))
#include "Template/Template_Endpoint_RW.c" #include "Template/Template_Endpoint_RW.c"
#define TEMPLATE_FUNC_NAME Endpoint_Read_EStream_LE #define TEMPLATE_FUNC_NAME Endpoint_Read_EStream_LE
@ -186,7 +186,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearOUT() #define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearOUT()
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Endpoint_Read_Byte()) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Endpoint_Read_8())
#include "Template/Template_Endpoint_RW.c" #include "Template/Template_Endpoint_RW.c"
#define TEMPLATE_FUNC_NAME Endpoint_Read_EStream_BE #define TEMPLATE_FUNC_NAME Endpoint_Read_EStream_BE
@ -194,7 +194,7 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearOUT() #define TEMPLATE_CLEAR_ENDPOINT() Endpoint_ClearOUT()
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Endpoint_Read_Byte()) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Endpoint_Read_8())
#include "Template/Template_Endpoint_RW.c" #include "Template/Template_Endpoint_RW.c"
#endif #endif
@ -203,38 +203,38 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_FUNC_NAME Endpoint_Write_Control_Stream_LE #define TEMPLATE_FUNC_NAME Endpoint_Write_Control_Stream_LE
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(*BufferPtr) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(*BufferPtr)
#include "Template/Template_Endpoint_Control_W.c" #include "Template/Template_Endpoint_Control_W.c"
#define TEMPLATE_FUNC_NAME Endpoint_Write_Control_Stream_BE #define TEMPLATE_FUNC_NAME Endpoint_Write_Control_Stream_BE
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(*BufferPtr) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(*BufferPtr)
#include "Template/Template_Endpoint_Control_W.c" #include "Template/Template_Endpoint_Control_W.c"
#define TEMPLATE_FUNC_NAME Endpoint_Read_Control_Stream_LE #define TEMPLATE_FUNC_NAME Endpoint_Read_Control_Stream_LE
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Endpoint_Read_Byte() #define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Endpoint_Read_8()
#include "Template/Template_Endpoint_Control_R.c" #include "Template/Template_Endpoint_Control_R.c"
#define TEMPLATE_FUNC_NAME Endpoint_Read_Control_Stream_BE #define TEMPLATE_FUNC_NAME Endpoint_Read_Control_Stream_BE
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Endpoint_Read_Byte() #define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Endpoint_Read_8()
#include "Template/Template_Endpoint_Control_R.c" #include "Template/Template_Endpoint_Control_R.c"
#if defined(ARCH_HAS_FLASH_ADDRESS_SPACE) #if defined(ARCH_HAS_FLASH_ADDRESS_SPACE)
#define TEMPLATE_FUNC_NAME Endpoint_Write_Control_PStream_LE #define TEMPLATE_FUNC_NAME Endpoint_Write_Control_PStream_LE
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(pgm_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(pgm_read_byte(BufferPtr))
#include "Template/Template_Endpoint_Control_W.c" #include "Template/Template_Endpoint_Control_W.c"
#define TEMPLATE_FUNC_NAME Endpoint_Write_Control_PStream_BE #define TEMPLATE_FUNC_NAME Endpoint_Write_Control_PStream_BE
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(pgm_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(pgm_read_byte(BufferPtr))
#include "Template/Template_Endpoint_Control_W.c" #include "Template/Template_Endpoint_Control_W.c"
#endif #endif
@ -242,25 +242,25 @@ uint8_t Endpoint_Null_Stream(uint16_t Length,
#define TEMPLATE_FUNC_NAME Endpoint_Write_Control_EStream_LE #define TEMPLATE_FUNC_NAME Endpoint_Write_Control_EStream_LE
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(eeprom_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(eeprom_read_byte(BufferPtr))
#include "Template/Template_Endpoint_Control_W.c" #include "Template/Template_Endpoint_Control_W.c"
#define TEMPLATE_FUNC_NAME Endpoint_Write_Control_EStream_BE #define TEMPLATE_FUNC_NAME Endpoint_Write_Control_EStream_BE
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_Byte(eeprom_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Endpoint_Write_8(eeprom_read_byte(BufferPtr))
#include "Template/Template_Endpoint_Control_W.c" #include "Template/Template_Endpoint_Control_W.c"
#define TEMPLATE_FUNC_NAME Endpoint_Read_Control_EStream_LE #define TEMPLATE_FUNC_NAME Endpoint_Read_Control_EStream_LE
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Endpoint_Read_Byte()) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Endpoint_Read_8())
#include "Template/Template_Endpoint_Control_R.c" #include "Template/Template_Endpoint_Control_R.c"
#define TEMPLATE_FUNC_NAME Endpoint_Read_Control_EStream_BE #define TEMPLATE_FUNC_NAME Endpoint_Read_Control_EStream_BE
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) BufferPtr -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Endpoint_Read_Byte()) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Endpoint_Read_8())
#include "Template/Template_Endpoint_Control_R.c" #include "Template/Template_Endpoint_Control_R.c"
#endif #endif

@ -53,11 +53,11 @@ uint8_t USB_Host_SendControlRequest(void* const BufferPtr)
Pipe_Unfreeze(); Pipe_Unfreeze();
Pipe_Write_Byte(USB_ControlRequest.bmRequestType); Pipe_Write_8(USB_ControlRequest.bmRequestType);
Pipe_Write_Byte(USB_ControlRequest.bRequest); Pipe_Write_8(USB_ControlRequest.bRequest);
Pipe_Write_Word_LE(USB_ControlRequest.wValue); Pipe_Write_16_LE(USB_ControlRequest.wValue);
Pipe_Write_Word_LE(USB_ControlRequest.wIndex); Pipe_Write_16_LE(USB_ControlRequest.wIndex);
Pipe_Write_Word_LE(USB_ControlRequest.wLength); Pipe_Write_16_LE(USB_ControlRequest.wLength);
Pipe_ClearSETUP(); Pipe_ClearSETUP();
@ -87,7 +87,7 @@ uint8_t USB_Host_SendControlRequest(void* const BufferPtr)
while (Pipe_BytesInPipe() && DataLen) while (Pipe_BytesInPipe() && DataLen)
{ {
*(DataStream++) = Pipe_Read_Byte(); *(DataStream++) = Pipe_Read_8();
DataLen--; DataLen--;
} }
@ -121,7 +121,7 @@ uint8_t USB_Host_SendControlRequest(void* const BufferPtr)
while (DataLen && (Pipe_BytesInPipe() < USB_ControlPipeSize)) while (DataLen && (Pipe_BytesInPipe() < USB_ControlPipeSize))
{ {
Pipe_Write_Byte(*(DataStream++)); Pipe_Write_8(*(DataStream++));
DataLen--; DataLen--;
} }

@ -109,7 +109,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
} }
else else
{ {
Pipe_Write_Byte(0); Pipe_Write_8(0);
Length--; Length--;
BytesInTransfer++; BytesInTransfer++;
@ -128,7 +128,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT() #define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT()
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_Byte(*BufferPtr) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_8(*BufferPtr)
#include "Template/Template_Pipe_RW.c" #include "Template/Template_Pipe_RW.c"
#define TEMPLATE_FUNC_NAME Pipe_Write_Stream_BE #define TEMPLATE_FUNC_NAME Pipe_Write_Stream_BE
@ -137,7 +137,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT() #define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT()
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_Byte(*BufferPtr) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_8(*BufferPtr)
#include "Template/Template_Pipe_RW.c" #include "Template/Template_Pipe_RW.c"
#define TEMPLATE_FUNC_NAME Pipe_Read_Stream_LE #define TEMPLATE_FUNC_NAME Pipe_Read_Stream_LE
@ -146,7 +146,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_PIPE() Pipe_ClearIN() #define TEMPLATE_CLEAR_PIPE() Pipe_ClearIN()
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Pipe_Read_Byte() #define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Pipe_Read_8()
#include "Template/Template_Pipe_RW.c" #include "Template/Template_Pipe_RW.c"
#define TEMPLATE_FUNC_NAME Pipe_Read_Stream_BE #define TEMPLATE_FUNC_NAME Pipe_Read_Stream_BE
@ -155,7 +155,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_PIPE() Pipe_ClearIN() #define TEMPLATE_CLEAR_PIPE() Pipe_ClearIN()
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Pipe_Read_Byte() #define TEMPLATE_TRANSFER_BYTE(BufferPtr) *BufferPtr = Pipe_Read_8()
#include "Template/Template_Pipe_RW.c" #include "Template/Template_Pipe_RW.c"
#if defined(ARCH_HAS_FLASH_ADDRESS_SPACE) #if defined(ARCH_HAS_FLASH_ADDRESS_SPACE)
@ -165,7 +165,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT() #define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT()
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_Byte(pgm_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_8(pgm_read_byte(BufferPtr))
#include "Template/Template_Pipe_RW.c" #include "Template/Template_Pipe_RW.c"
#define TEMPLATE_FUNC_NAME Pipe_Write_PStream_BE #define TEMPLATE_FUNC_NAME Pipe_Write_PStream_BE
@ -174,7 +174,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT() #define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT()
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_Byte(pgm_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_8(pgm_read_byte(BufferPtr))
#include "Template/Template_Pipe_RW.c" #include "Template/Template_Pipe_RW.c"
#endif #endif
@ -185,7 +185,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT() #define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT()
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_Byte(eeprom_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_8(eeprom_read_byte(BufferPtr))
#include "Template/Template_Pipe_RW.c" #include "Template/Template_Pipe_RW.c"
#define TEMPLATE_FUNC_NAME Pipe_Write_EStream_BE #define TEMPLATE_FUNC_NAME Pipe_Write_EStream_BE
@ -194,7 +194,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT() #define TEMPLATE_CLEAR_PIPE() Pipe_ClearOUT()
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_Byte(eeprom_read_byte(BufferPtr)) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) Pipe_Write_8(eeprom_read_byte(BufferPtr))
#include "Template/Template_Pipe_RW.c" #include "Template/Template_Pipe_RW.c"
#define TEMPLATE_FUNC_NAME Pipe_Read_EStream_LE #define TEMPLATE_FUNC_NAME Pipe_Read_EStream_LE
@ -203,7 +203,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_PIPE() Pipe_ClearIN() #define TEMPLATE_CLEAR_PIPE() Pipe_ClearIN()
#define TEMPLATE_BUFFER_OFFSET(Length) 0 #define TEMPLATE_BUFFER_OFFSET(Length) 0
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream += Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream += Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Pipe_Read_Byte()) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Pipe_Read_8())
#include "Template/Template_Pipe_RW.c" #include "Template/Template_Pipe_RW.c"
#define TEMPLATE_FUNC_NAME Pipe_Read_EStream_BE #define TEMPLATE_FUNC_NAME Pipe_Read_EStream_BE
@ -212,7 +212,7 @@ uint8_t Pipe_Null_Stream(uint16_t Length,
#define TEMPLATE_CLEAR_PIPE() Pipe_ClearIN() #define TEMPLATE_CLEAR_PIPE() Pipe_ClearIN()
#define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1) #define TEMPLATE_BUFFER_OFFSET(Length) (Length - 1)
#define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream -= Amount #define TEMPLATE_BUFFER_MOVE(BufferPtr, Amount) DataStream -= Amount
#define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Pipe_Read_Byte()) #define TEMPLATE_TRANSFER_BYTE(BufferPtr) eeprom_update_byte(BufferPtr, Pipe_Read_8())
#include "Template/Template_Pipe_RW.c" #include "Template/Template_Pipe_RW.c"
#endif #endif

@ -130,6 +130,8 @@
#define ENDPOINT_DETAILS_EP6 256, 2 #define ENDPOINT_DETAILS_EP6 256, 2
#endif #endif
#define ENDPOINT_HSB_ADDRESS_SPACE_SIZE (64 * 1024UL)
/* Inline Functions: */ /* Inline Functions: */
static inline uint32_t Endpoint_BytesToEPSizeMask(const uint16_t Bytes) ATTR_WARN_UNUSED_RESULT ATTR_CONST static inline uint32_t Endpoint_BytesToEPSizeMask(const uint16_t Bytes) ATTR_WARN_UNUSED_RESULT ATTR_CONST
ATTR_ALWAYS_INLINE; ATTR_ALWAYS_INLINE;
@ -359,7 +361,7 @@
{ {
AVR32_USBB.uerst |= (AVR32_USBB_EPRST0_MASK << EndpointNumber); AVR32_USBB.uerst |= (AVR32_USBB_EPRST0_MASK << EndpointNumber);
AVR32_USBB.uerst &= ~(AVR32_USBB_EPRST0_MASK << EndpointNumber); AVR32_USBB.uerst &= ~(AVR32_USBB_EPRST0_MASK << EndpointNumber);
USB_EndpointFIFOPos[EndpointNumber] = &AVR32_USBB_SLAVE[EndpointNumber * 0x10000]; USB_EndpointFIFOPos[EndpointNumber] = &AVR32_USBB_SLAVE[EndpointNumber * ENDPOINT_HSB_ADDRESS_SPACE_SIZE];
} }
/** Enables the currently selected endpoint so that data can be sent and received through it to /** Enables the currently selected endpoint so that data can be sent and received through it to
@ -523,7 +525,7 @@
static inline void Endpoint_ClearSETUP(void) static inline void Endpoint_ClearSETUP(void)
{ {
(&AVR32_USBB.UESTA0CLR)[USB_SelectedEndpoint].rxstpic = true; (&AVR32_USBB.UESTA0CLR)[USB_SelectedEndpoint].rxstpic = true;
USB_EndpointFIFOPos[USB_SelectedEndpoint] = &AVR32_USBB_SLAVE[USB_SelectedEndpoint * 0x10000]; USB_EndpointFIFOPos[USB_SelectedEndpoint] = &AVR32_USBB_SLAVE[USB_SelectedEndpoint * ENDPOINT_HSB_ADDRESS_SPACE_SIZE];
} }
/** Sends an IN packet to the host on the currently selected endpoint, freeing up the endpoint for the /** Sends an IN packet to the host on the currently selected endpoint, freeing up the endpoint for the
@ -536,7 +538,7 @@
{ {
(&AVR32_USBB.UESTA0CLR)[USB_SelectedEndpoint].txinic = true; (&AVR32_USBB.UESTA0CLR)[USB_SelectedEndpoint].txinic = true;
(&AVR32_USBB.UECON0CLR)[USB_SelectedEndpoint].fifoconc = true; (&AVR32_USBB.UECON0CLR)[USB_SelectedEndpoint].fifoconc = true;
USB_EndpointFIFOPos[USB_SelectedEndpoint] = &AVR32_USBB_SLAVE[USB_SelectedEndpoint * 0x10000]; USB_EndpointFIFOPos[USB_SelectedEndpoint] = &AVR32_USBB_SLAVE[USB_SelectedEndpoint * ENDPOINT_HSB_ADDRESS_SPACE_SIZE];
} }
/** Acknowledges an OUT packet to the host on the currently selected endpoint, freeing up the endpoint /** Acknowledges an OUT packet to the host on the currently selected endpoint, freeing up the endpoint
@ -549,7 +551,7 @@
{ {
(&AVR32_USBB.UESTA0CLR)[USB_SelectedEndpoint].rxoutic = true; (&AVR32_USBB.UESTA0CLR)[USB_SelectedEndpoint].rxoutic = true;
(&AVR32_USBB.UECON0CLR)[USB_SelectedEndpoint].fifoconc = true; (&AVR32_USBB.UECON0CLR)[USB_SelectedEndpoint].fifoconc = true;
USB_EndpointFIFOPos[USB_SelectedEndpoint] = &AVR32_USBB_SLAVE[USB_SelectedEndpoint * 0x10000]; USB_EndpointFIFOPos[USB_SelectedEndpoint] = &AVR32_USBB_SLAVE[USB_SelectedEndpoint * ENDPOINT_HSB_ADDRESS_SPACE_SIZE];
} }
/** Stalls the current endpoint, indicating to the host that a logical problem occurred with the /** Stalls the current endpoint, indicating to the host that a logical problem occurred with the
@ -620,34 +622,34 @@
/** Reads one byte from the currently selected endpoint's bank, for OUT direction endpoints. /** Reads one byte from the currently selected endpoint's bank, for OUT direction endpoints.
* *
* \ingroup Group_EndpointPrimitiveRW_AVR32 * \ingroup Group_EndpointPrimitiveRW_UC3
* *
* \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_8(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint8_t Endpoint_Read_Byte(void) static inline uint8_t Endpoint_Read_8(void)
{ {
return *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++); return *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++);
} }
/** Writes one byte from the currently selected endpoint's bank, for IN direction endpoints. /** Writes one byte from the currently selected endpoint's bank, for IN direction endpoints.
* *
* \ingroup Group_EndpointPrimitiveRW_AVR32 * \ingroup Group_EndpointPrimitiveRW_UC3
* *
* \param[in] Byte Next byte to write into the the currently selected endpoint's FIFO buffer. * \param[in] Data Data 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_8(const uint8_t Data) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Write_Byte(const uint8_t Byte) static inline void Endpoint_Write_8(const uint8_t Data)
{ {
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = Byte; *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = Data;
} }
/** Discards one byte from the currently selected endpoint's bank, for OUT direction endpoints. /** Discards one byte from the currently selected endpoint's bank, for OUT direction endpoints.
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
*/ */
static inline void Endpoint_Discard_Byte(void) ATTR_ALWAYS_INLINE; static inline void Endpoint_Discard_8(void) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Discard_Byte(void) static inline void Endpoint_Discard_8(void)
{ {
uint8_t Dummy; uint8_t Dummy;
@ -659,10 +661,10 @@
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
* *
* \return Next word in the currently selected endpoint's FIFO buffer. * \return Next two bytes 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_16_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint16_t Endpoint_Read_Word_LE(void) static inline uint16_t Endpoint_Read_16_LE(void)
{ {
uint16_t Byte1 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++); uint16_t Byte1 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++);
uint16_t Byte0 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++); uint16_t Byte0 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++);
@ -675,10 +677,10 @@
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
* *
* \return Next word in the currently selected endpoint's FIFO buffer. * \return Next two bytes 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_16_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint16_t Endpoint_Read_Word_BE(void) static inline uint16_t Endpoint_Read_16_BE(void)
{ {
uint16_t Byte0 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++); uint16_t Byte0 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++);
uint16_t Byte1 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++); uint16_t Byte1 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++);
@ -691,13 +693,13 @@
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
* *
* \param[in] Word Next word to write to the currently selected endpoint's FIFO buffer. * \param[in] Data Data 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_16_LE(const uint16_t Data) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Write_Word_LE(const uint16_t Word) static inline void Endpoint_Write_16_LE(const uint16_t Data)
{ {
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Word >> 8); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data >> 8);
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Word & 0xFF); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data & 0xFF);
} }
/** Writes two bytes to the currently selected endpoint's bank in big endian format, for IN /** Writes two bytes to the currently selected endpoint's bank in big endian format, for IN
@ -705,21 +707,21 @@
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
* *
* \param[in] Word Next word to write to the currently selected endpoint's FIFO buffer. * \param[in] Data Data 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_16_BE(const uint16_t Data) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Write_Word_BE(const uint16_t Word) static inline void Endpoint_Write_16_BE(const uint16_t Data)
{ {
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Word & 0xFF); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data & 0xFF);
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Word >> 8); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data >> 8);
} }
/** Discards two bytes from the currently selected endpoint's bank, for OUT direction endpoints. /** Discards two bytes from the currently selected endpoint's bank, for OUT direction endpoints.
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
*/ */
static inline void Endpoint_Discard_Word(void) ATTR_ALWAYS_INLINE; static inline void Endpoint_Discard_16(void) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Discard_Word(void) static inline void Endpoint_Discard_16(void)
{ {
uint8_t Dummy; uint8_t Dummy;
@ -732,10 +734,10 @@
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
* *
* \return Next double word in the currently selected endpoint's FIFO buffer. * \return Next four bytes 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_32_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint32_t Endpoint_Read_DWord_LE(void) static inline uint32_t Endpoint_Read_32_LE(void)
{ {
uint32_t Byte3 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++); uint32_t Byte3 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++);
uint32_t Byte2 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++); uint32_t Byte2 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++);
@ -750,10 +752,10 @@
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
* *
* \return Next double word in the currently selected endpoint's FIFO buffer. * \return Next four bytes 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_32_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint32_t Endpoint_Read_DWord_BE(void) static inline uint32_t Endpoint_Read_32_BE(void)
{ {
uint32_t Byte0 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++); uint32_t Byte0 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++);
uint32_t Byte1 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++); uint32_t Byte1 = *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++);
@ -768,15 +770,15 @@
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
* *
* \param[in] DWord Next double word to write to the currently selected endpoint's FIFO buffer. * \param[in] Data Data 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_32_LE(const uint32_t Data) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Write_DWord_LE(const uint32_t DWord) static inline void Endpoint_Write_32_LE(const uint32_t Data)
{ {
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (DWord >> 24); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data >> 24);
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (DWord >> 16); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data >> 16);
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (DWord >> 8); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data >> 8);
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (DWord & 0xFF); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data & 0xFF);
} }
/** Writes four bytes to the currently selected endpoint's bank in big endian format, for IN /** Writes four bytes to the currently selected endpoint's bank in big endian format, for IN
@ -784,23 +786,23 @@
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
* *
* \param[in] DWord Next double word to write to the currently selected endpoint's FIFO buffer. * \param[in] Data Data 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_32_BE(const uint32_t Data) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Write_DWord_BE(const uint32_t DWord) static inline void Endpoint_Write_32_BE(const uint32_t Data)
{ {
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (DWord & 0xFF); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data & 0xFF);
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (DWord >> 8); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data >> 8);
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (DWord >> 16); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data >> 16);
*(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (DWord >> 24); *(USB_EndpointFIFOPos[USB_SelectedEndpoint]++) = (Data >> 24);
} }
/** Discards four bytes from the currently selected endpoint's bank, for OUT direction endpoints. /** Discards four bytes from the currently selected endpoint's bank, for OUT direction endpoints.
* *
* \ingroup Group_EndpointPrimitiveRW_UC3 * \ingroup Group_EndpointPrimitiveRW_UC3
*/ */
static inline void Endpoint_Discard_DWord(void) ATTR_ALWAYS_INLINE; static inline void Endpoint_Discard_32(void) ATTR_ALWAYS_INLINE;
static inline void Endpoint_Discard_DWord(void) static inline void Endpoint_Discard_32(void)
{ {
uint8_t Dummy; uint8_t Dummy;

@ -98,6 +98,9 @@
/* Private Interface - For use in library only: */ /* Private Interface - For use in library only: */
#if !defined(__DOXYGEN__) #if !defined(__DOXYGEN__)
/* Macros: */
#define PIPE_HSB_ADDRESS_SPACE_SIZE (64 * 1024UL)
/* External Variables: */ /* External Variables: */
extern volatile uint8_t USB_SelectedPipe; extern volatile uint8_t USB_SelectedPipe;
extern volatile uint8_t* USB_PipeFIFOPos[]; extern volatile uint8_t* USB_PipeFIFOPos[];
@ -158,13 +161,6 @@
* bank. * bank.
*/ */
#define PIPE_BANK_DOUBLE AVR32_USBB_UPCFG0_PBK_DOUBLE #define PIPE_BANK_DOUBLE AVR32_USBB_UPCFG0_PBK_DOUBLE
/** Mask for the bank mode selection for the \ref Pipe_ConfigurePipe() macro. This indicates that the pipe
* should have three banks, which requires more USB FIFO memory but results in faster transfers as one
* USB device (the AVR or the attached device) can access one bank while the other accesses the remaining
* banks.
*/
#define PIPE_BANK_TRIPLE AVR32_USBB_UPCFG0_PBK_TRIPLE
//@} //@}
/** Default size of the default control pipe's bank, until altered by the Endpoint0Size value /** Default size of the default control pipe's bank, until altered by the Endpoint0Size value
@ -251,7 +247,7 @@
{ {
AVR32_USBB.uprst |= (AVR32_USBB_PRST0_MASK << PipeNumber); AVR32_USBB.uprst |= (AVR32_USBB_PRST0_MASK << PipeNumber);
AVR32_USBB.uprst &= ~(AVR32_USBB_PRST0_MASK << PipeNumber); AVR32_USBB.uprst &= ~(AVR32_USBB_PRST0_MASK << PipeNumber);
USB_PipeFIFOPos[USB_SelectedPipe] = &AVR32_USBB_SLAVE[USB_SelectedPipe * 0x10000]; USB_PipeFIFOPos[USB_SelectedPipe] = &AVR32_USBB_SLAVE[USB_SelectedPipe * PIPE_HSB_ADDRESS_SPACE_SIZE];
} }
/** Enables the currently selected pipe so that data can be sent and received through it to and from /** Enables the currently selected pipe so that data can be sent and received through it to and from
@ -524,7 +520,7 @@
static inline void Pipe_ClearSETUP(void) static inline void Pipe_ClearSETUP(void)
{ {
(&AVR32_USBB.UPSTA0CLR)[USB_SelectedPipe].txstpic = true; (&AVR32_USBB.UPSTA0CLR)[USB_SelectedPipe].txstpic = true;
USB_PipeFIFOPos[USB_SelectedPipe] = &AVR32_USBB_SLAVE[USB_SelectedPipe * 0x10000]; USB_PipeFIFOPos[USB_SelectedPipe] = &AVR32_USBB_SLAVE[USB_SelectedPipe * PIPE_HSB_ADDRESS_SPACE_SIZE];
} }
/** Acknowledges the reception of a setup IN request from the attached device on the currently selected /** Acknowledges the reception of a setup IN request from the attached device on the currently selected
@ -537,7 +533,7 @@
{ {
(&AVR32_USBB.UPSTA0CLR)[USB_SelectedPipe].rxinic = true; (&AVR32_USBB.UPSTA0CLR)[USB_SelectedPipe].rxinic = true;
(&AVR32_USBB.UPCON0CLR)[USB_SelectedPipe].fifoconc = true; (&AVR32_USBB.UPCON0CLR)[USB_SelectedPipe].fifoconc = true;
USB_PipeFIFOPos[USB_SelectedPipe] = &AVR32_USBB_SLAVE[USB_SelectedPipe * 0x10000]; USB_PipeFIFOPos[USB_SelectedPipe] = &AVR32_USBB_SLAVE[USB_SelectedPipe * PIPE_HSB_ADDRESS_SPACE_SIZE];
} }
/** Sends the currently selected pipe's contents to the device as an OUT packet on the selected pipe, freeing /** Sends the currently selected pipe's contents to the device as an OUT packet on the selected pipe, freeing
@ -550,7 +546,7 @@
{ {
(&AVR32_USBB.UPSTA0CLR)[USB_SelectedPipe].txoutic = true; (&AVR32_USBB.UPSTA0CLR)[USB_SelectedPipe].txoutic = true;
(&AVR32_USBB.UPCON0CLR)[USB_SelectedPipe].fifoconc = true; (&AVR32_USBB.UPCON0CLR)[USB_SelectedPipe].fifoconc = true;
USB_PipeFIFOPos[USB_SelectedPipe] = &AVR32_USBB_SLAVE[USB_SelectedPipe * 0x10000]; USB_PipeFIFOPos[USB_SelectedPipe] = &AVR32_USBB_SLAVE[USB_SelectedPipe * PIPE_HSB_ADDRESS_SPACE_SIZE];
} }
/** Determines if the device sent a NAK (Negative Acknowledge) in response to the last sent packet on /** Determines if the device sent a NAK (Negative Acknowledge) in response to the last sent packet on
@ -602,7 +598,7 @@
static inline void Pipe_ClearStall(void) static inline void Pipe_ClearStall(void)
{ {
(&AVR32_USBB.UPSTA0CLR)[USB_SelectedPipe].rxstalldic = true; (&AVR32_USBB.UPSTA0CLR)[USB_SelectedPipe].rxstalldic = true;
USB_PipeFIFOPos[USB_SelectedPipe] = &AVR32_USBB_SLAVE[USB_SelectedPipe * 0x10000]; USB_PipeFIFOPos[USB_SelectedPipe] = &AVR32_USBB_SLAVE[USB_SelectedPipe * PIPE_HSB_ADDRESS_SPACE_SIZE];
} }
/** Reads one byte from the currently selected pipe's bank, for OUT direction pipes. /** Reads one byte from the currently selected pipe's bank, for OUT direction pipes.
@ -611,8 +607,8 @@
* *
* \return Next byte in the currently selected pipe's FIFO buffer. * \return Next byte in the currently selected pipe's FIFO buffer.
*/ */
static inline uint8_t Pipe_Read_Byte(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE; static inline uint8_t Pipe_Read_8(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint8_t Pipe_Read_Byte(void) static inline uint8_t Pipe_Read_8(void)
{ {
return *(USB_PipeFIFOPos[USB_SelectedPipe]++); return *(USB_PipeFIFOPos[USB_SelectedPipe]++);
} }
@ -621,20 +617,20 @@
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
* *
* \param[in] Byte Next byte to write into the the currently selected pipe's FIFO buffer. * \param[in] Data Data to write into the the currently selected pipe's FIFO buffer.
*/ */
static inline void Pipe_Write_Byte(const uint8_t Byte) ATTR_ALWAYS_INLINE; static inline void Pipe_Write_8(const uint8_t Data) ATTR_ALWAYS_INLINE;
static inline void Pipe_Write_Byte(const uint8_t Byte) static inline void Pipe_Write_8(const uint8_t Data)
{ {
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = Byte; *(USB_PipeFIFOPos[USB_SelectedPipe]++) = Data;
} }
/** Discards one byte from the currently selected pipe's bank, for OUT direction pipes. /** Discards one byte from the currently selected pipe's bank, for OUT direction pipes.
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
*/ */
static inline void Pipe_Discard_Byte(void) ATTR_ALWAYS_INLINE; static inline void Pipe_Discard_8(void) ATTR_ALWAYS_INLINE;
static inline void Pipe_Discard_Byte(void) static inline void Pipe_Discard_8(void)
{ {
uint8_t Dummy; uint8_t Dummy;
@ -646,10 +642,10 @@
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
* *
* \return Next word in the currently selected pipe's FIFO buffer. * \return Next two bytes in the currently selected pipe's FIFO buffer.
*/ */
static inline uint16_t Pipe_Read_Word_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE; static inline uint16_t Pipe_Read_16_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint16_t Pipe_Read_Word_LE(void) static inline uint16_t Pipe_Read_16_LE(void)
{ {
uint16_t Byte1 = *(USB_PipeFIFOPos[USB_SelectedPipe]++); uint16_t Byte1 = *(USB_PipeFIFOPos[USB_SelectedPipe]++);
uint16_t Byte0 = *(USB_PipeFIFOPos[USB_SelectedPipe]++); uint16_t Byte0 = *(USB_PipeFIFOPos[USB_SelectedPipe]++);
@ -662,10 +658,10 @@
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
* *
* \return Next word in the currently selected pipe's FIFO buffer. * \return Next two bytes in the currently selected pipe's FIFO buffer.
*/ */
static inline uint16_t Pipe_Read_Word_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE; static inline uint16_t Pipe_Read_16_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint16_t Pipe_Read_Word_BE(void) static inline uint16_t Pipe_Read_16_BE(void)
{ {
uint16_t Byte0 = *(USB_PipeFIFOPos[USB_SelectedPipe]++); uint16_t Byte0 = *(USB_PipeFIFOPos[USB_SelectedPipe]++);
uint16_t Byte1 = *(USB_PipeFIFOPos[USB_SelectedPipe]++); uint16_t Byte1 = *(USB_PipeFIFOPos[USB_SelectedPipe]++);
@ -678,13 +674,13 @@
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
* *
* \param[in] Word Next word to write to the currently selected pipe's FIFO buffer. * \param[in] Data Data to write to the currently selected pipe's FIFO buffer.
*/ */
static inline void Pipe_Write_Word_LE(const uint16_t Word) ATTR_ALWAYS_INLINE; static inline void Pipe_Write_16_LE(const uint16_t Data) ATTR_ALWAYS_INLINE;
static inline void Pipe_Write_Word_LE(const uint16_t Word) static inline void Pipe_Write_16_LE(const uint16_t Data)
{ {
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Word >> 8); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data >> 8);
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Word & 0xFF); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data & 0xFF);
} }
/** Writes two bytes to the currently selected pipe's bank in big endian format, for IN /** Writes two bytes to the currently selected pipe's bank in big endian format, for IN
@ -692,21 +688,21 @@
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
* *
* \param[in] Word Next word to write to the currently selected pipe's FIFO buffer. * \param[in] Data Data to write to the currently selected pipe's FIFO buffer.
*/ */
static inline void Pipe_Write_Word_BE(const uint16_t Word) ATTR_ALWAYS_INLINE; static inline void Pipe_Write_16_BE(const uint16_t Data) ATTR_ALWAYS_INLINE;
static inline void Pipe_Write_Word_BE(const uint16_t Word) static inline void Pipe_Write_16_BE(const uint16_t Data)
{ {
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Word & 0xFF); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data & 0xFF);
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Word >> 8); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data >> 8);
} }
/** Discards two bytes from the currently selected pipe's bank, for OUT direction pipes. /** Discards two bytes from the currently selected pipe's bank, for OUT direction pipes.
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
*/ */
static inline void Pipe_Discard_Word(void) ATTR_ALWAYS_INLINE; static inline void Pipe_Discard_16(void) ATTR_ALWAYS_INLINE;
static inline void Pipe_Discard_Word(void) static inline void Pipe_Discard_16(void)
{ {
uint8_t Dummy; uint8_t Dummy;
@ -719,10 +715,10 @@
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
* *
* \return Next double word in the currently selected pipe's FIFO buffer. * \return Next four bytes in the currently selected pipe's FIFO buffer.
*/ */
static inline uint32_t Pipe_Read_DWord_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE; static inline uint32_t Pipe_Read_32_LE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint32_t Pipe_Read_DWord_LE(void) static inline uint32_t Pipe_Read_32_LE(void)
{ {
uint32_t Byte3 = *(USB_PipeFIFOPos[USB_SelectedPipe]++); uint32_t Byte3 = *(USB_PipeFIFOPos[USB_SelectedPipe]++);
uint32_t Byte2 = *(USB_PipeFIFOPos[USB_SelectedPipe]++); uint32_t Byte2 = *(USB_PipeFIFOPos[USB_SelectedPipe]++);
@ -737,10 +733,10 @@
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
* *
* \return Next double word in the currently selected pipe's FIFO buffer. * \return Next four bytes in the currently selected pipe's FIFO buffer.
*/ */
static inline uint32_t Pipe_Read_DWord_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE; static inline uint32_t Pipe_Read_32_BE(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
static inline uint32_t Pipe_Read_DWord_BE(void) static inline uint32_t Pipe_Read_32_BE(void)
{ {
uint32_t Byte0 = *(USB_PipeFIFOPos[USB_SelectedPipe]++); uint32_t Byte0 = *(USB_PipeFIFOPos[USB_SelectedPipe]++);
uint32_t Byte1 = *(USB_PipeFIFOPos[USB_SelectedPipe]++); uint32_t Byte1 = *(USB_PipeFIFOPos[USB_SelectedPipe]++);
@ -755,15 +751,15 @@
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
* *
* \param[in] DWord Next double word to write to the currently selected pipe's FIFO buffer. * \param[in] Data Data to write to the currently selected pipe's FIFO buffer.
*/ */
static inline void Pipe_Write_DWord_LE(const uint32_t DWord) ATTR_ALWAYS_INLINE; static inline void Pipe_Write_32_LE(const uint32_t Data) ATTR_ALWAYS_INLINE;
static inline void Pipe_Write_DWord_LE(const uint32_t DWord) static inline void Pipe_Write_32_LE(const uint32_t Data)
{ {
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (DWord >> 24); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data >> 24);
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (DWord >> 16); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data >> 16);
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (DWord >> 8); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data >> 8);
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (DWord & 0xFF); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data & 0xFF);
} }
/** Writes four bytes to the currently selected pipe's bank in big endian format, for IN /** Writes four bytes to the currently selected pipe's bank in big endian format, for IN
@ -771,23 +767,23 @@
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
* *
* \param[in] DWord Next double word to write to the currently selected pipe's FIFO buffer. * \param[in] Data Data to write to the currently selected pipe's FIFO buffer.
*/ */
static inline void Pipe_Write_DWord_BE(const uint32_t DWord) ATTR_ALWAYS_INLINE; static inline void Pipe_Write_32_BE(const uint32_t Data) ATTR_ALWAYS_INLINE;
static inline void Pipe_Write_DWord_BE(const uint32_t DWord) static inline void Pipe_Write_32_BE(const uint32_t Data)
{ {
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (DWord & 0xFF); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data & 0xFF);
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (DWord >> 8); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data >> 8);
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (DWord >> 16); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data >> 16);
*(USB_PipeFIFOPos[USB_SelectedPipe]++) = (DWord >> 24); *(USB_PipeFIFOPos[USB_SelectedPipe]++) = (Data >> 24);
} }
/** Discards four bytes from the currently selected pipe's bank, for OUT direction pipes. /** Discards four bytes from the currently selected pipe's bank, for OUT direction pipes.
* *
* \ingroup Group_PipePrimitiveRW_UC3 * \ingroup Group_PipePrimitiveRW_UC3
*/ */
static inline void Pipe_Discard_DWord(void) ATTR_ALWAYS_INLINE; static inline void Pipe_Discard_32(void) ATTR_ALWAYS_INLINE;
static inline void Pipe_Discard_DWord(void) static inline void Pipe_Discard_32(void)
{ {
uint8_t Dummy; uint8_t Dummy;

@ -61,6 +61,10 @@
* - Endpoint_ResetFIFO() renamed to Endpoint_ResetEndpoint(), to be consistent with the Pipe_ResetPipe() function name * - Endpoint_ResetFIFO() renamed to Endpoint_ResetEndpoint(), to be consistent with the Pipe_ResetPipe() function name
* - Implemented on-demand PLL clock generation for the U4, U6 and U7 series USB AVRs when automatic PLL mode is specified * - Implemented on-demand PLL clock generation for the U4, U6 and U7 series USB AVRs when automatic PLL mode is specified
* - F_CLOCK changed to F_USB to be more descriptive, and applicable on future architecture ports * - F_CLOCK changed to F_USB to be more descriptive, and applicable on future architecture ports
* - Renamed all low level Endpoint_Read_*, Endpoint_Write_* and Endpoint_Discard_* functions to use the number of bits instead of
* a symbolic size (Byte, Word, DWord) so that the function names are applicable and correct across all architectures
* - Renamed all low level Pipe_Read_*, Pipe_Write_* and Pipe_Discard_* functions to use the number of bits instead of
* a symbolic size (Byte, Word, DWord) so that the function names are applicable and correct across all architectures
* - Library Applications: * - Library Applications:
* - Changed the XPLAINBridge software UART to use the regular timer CTC mode instead of the alternative CTC mode * - Changed the XPLAINBridge software UART to use the regular timer CTC mode instead of the alternative CTC mode
* via the Input Capture register, to reduce user confusion * via the Input Capture register, to reduce user confusion

@ -45,6 +45,12 @@
* should use the new \ref CDC_Device_SendData() function, or remove the length parameter from the function call. * should use the new \ref CDC_Device_SendData() function, or remove the length parameter from the function call.
* - The Endpoint_ResetFIFO() function has been renamed to \ref Endpoint_ResetEndpoint(), to make the API function names more * - The Endpoint_ResetFIFO() function has been renamed to \ref Endpoint_ResetEndpoint(), to make the API function names more
* consistent. Existing applications using the old function name should simply replace it with a call to the new function name. * consistent. Existing applications using the old function name should simply replace it with a call to the new function name.
* - The Endpoint_*_Byte() functions have been renamed Endpoint_*_8() to ensure they are correct across all architectures. Existing
* code using these functions should replace the previous function names with the new function names.
* - The Endpoint_*_Word() functions have been renamed Endpoint_*_16() to ensure they are correct across all architectures. Existing
* code using these functions should replace the previous function names with the new function names.
* - The Endpoint_*_DWord() functions have been renamed Endpoint_*_32() to ensure they are correct across all architectures. Existing
* code using these functions should replace the previous function names with the new function names.
* *
* <b>Host Mode</b> * <b>Host Mode</b>
* - The Pipe stream functions now all require a \c BytesProcessed parameter instead of the previous callback parameter. * - The Pipe stream functions now all require a \c BytesProcessed parameter instead of the previous callback parameter.
@ -57,6 +63,12 @@
* length parameter from the function call. * length parameter from the function call.
* - The Pipe_ClearErrorFlags() function has been removed, as the pipe error flags are now automatically cleared when the * - The Pipe_ClearErrorFlags() function has been removed, as the pipe error flags are now automatically cleared when the
* \ref Pipe_ClearError() function is called. * \ref Pipe_ClearError() function is called.
* - The Pipe_*_Byte() functions have been renamed Pipe_*_8() to ensure they are correct across all architectures. Existing code using
* these functions should replace the previous function names with the new function names.
* - The Pipe_*_Word() functions have been renamed Pipe_*_16() to ensure they are correct across all architectures. Existing code using
* these functions should replace the previous function names with the new function names.
* - The Pipe_*_DWord() functions have been renamed Pipe_*_32() to ensure they are correct across all architectures. Existing code using
* these functions should replace the previous function names with the new function names.
* *
* \section Sec_Migration101122 Migrating from 100807 to 101122 * \section Sec_Migration101122 Migrating from 100807 to 101122
* <b>USB Core</b> * <b>USB Core</b>
@ -354,7 +366,7 @@
* - All pipe read/write/discard aliases which did not have an explicitly endianness specifier (such as \c Pipe_Read_Word()) have * - All pipe read/write/discard aliases which did not have an explicitly endianness specifier (such as \c Pipe_Read_Word()) have
* been removed for clarity. Existing projects should use the \c _LE suffix on such calls to use the explicit Little Endian versions. * been removed for clarity. Existing projects should use the \c _LE suffix on such calls to use the explicit Little Endian versions.
* - The \c Host_IsResetBusDone() macro has been renamed to \c Host_IsBusResetComplete(). * - The \c Host_IsResetBusDone() macro has been renamed to \c Host_IsBusResetComplete().
* - The \c Pipe_Ignore_Word() and \c Pipe_Ignore_DWord() functions have been renamed to \ref Pipe_Discard_Word() and \ref Pipe_Discard_DWord() * - The \c Pipe_Ignore_Word() and \c Pipe_Ignore_DWord() functions have been renamed to \c Pipe_Discard_Word() and \c Pipe_Discard_DWord()
* to remain consistent with the rest of the pipe API. * to remain consistent with the rest of the pipe API.
* - It is no longer needed to manually include the headers from \c LUFA/Drivers/USB/Class, as they are now included along with the rest * - It is no longer needed to manually include the headers from \c LUFA/Drivers/USB/Class, as they are now included along with the rest
* of the USB headers when \c LUFA/Drivers/USB/USB.h is included. * of the USB headers when \c LUFA/Drivers/USB/USB.h is included.

@ -95,8 +95,8 @@ void ISPProtocol_EnterISPMode(void)
} }
} }
Endpoint_Write_Byte(CMD_ENTER_PROGMODE_ISP); Endpoint_Write_8(CMD_ENTER_PROGMODE_ISP);
Endpoint_Write_Byte(ResponseStatus); Endpoint_Write_8(ResponseStatus);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -121,8 +121,8 @@ void ISPProtocol_LeaveISPMode(void)
ISPTarget_DisableTargetISP(); ISPTarget_DisableTargetISP();
ISPProtocol_DelayMS(Leave_ISP_Params.PostDelayMS); ISPProtocol_DelayMS(Leave_ISP_Params.PostDelayMS);
Endpoint_Write_Byte(CMD_LEAVE_PROGMODE_ISP); Endpoint_Write_8(CMD_LEAVE_PROGMODE_ISP);
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -154,8 +154,8 @@ void ISPProtocol_ProgramMemory(uint8_t V2Command)
Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM); Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM);
Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN); Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN);
Endpoint_Write_Byte(V2Command); Endpoint_Write_8(V2Command);
Endpoint_Write_Byte(STATUS_CMD_FAILED); Endpoint_Write_8(STATUS_CMD_FAILED);
Endpoint_ClearIN(); Endpoint_ClearIN();
return; return;
} }
@ -270,8 +270,8 @@ void ISPProtocol_ProgramMemory(uint8_t V2Command)
MustLoadExtendedAddress = true; MustLoadExtendedAddress = true;
} }
Endpoint_Write_Byte(V2Command); Endpoint_Write_8(V2Command);
Endpoint_Write_Byte(ProgrammingStatus); Endpoint_Write_8(ProgrammingStatus);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -295,8 +295,8 @@ void ISPProtocol_ReadMemory(uint8_t V2Command)
Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM); Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM);
Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN); Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN);
Endpoint_Write_Byte(V2Command); Endpoint_Write_8(V2Command);
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
/* Read each byte from the device and write them to the packet for the host */ /* Read each byte from the device and write them to the packet for the host */
for (uint16_t CurrentByte = 0; CurrentByte < Read_Memory_Params.BytesToRead; CurrentByte++) for (uint16_t CurrentByte = 0; CurrentByte < Read_Memory_Params.BytesToRead; CurrentByte++)
@ -312,7 +312,7 @@ void ISPProtocol_ReadMemory(uint8_t V2Command)
ISPTarget_SendByte(Read_Memory_Params.ReadMemoryCommand); ISPTarget_SendByte(Read_Memory_Params.ReadMemoryCommand);
ISPTarget_SendByte(CurrentAddress >> 8); ISPTarget_SendByte(CurrentAddress >> 8);
ISPTarget_SendByte(CurrentAddress & 0xFF); ISPTarget_SendByte(CurrentAddress & 0xFF);
Endpoint_Write_Byte(ISPTarget_ReceiveByte()); Endpoint_Write_8(ISPTarget_ReceiveByte());
/* Check if the endpoint bank is currently full, if so send the packet */ /* Check if the endpoint bank is currently full, if so send the packet */
if (!(Endpoint_IsReadWriteAllowed())) if (!(Endpoint_IsReadWriteAllowed()))
@ -338,7 +338,7 @@ void ISPProtocol_ReadMemory(uint8_t V2Command)
} }
} }
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
bool IsEndpointFull = !(Endpoint_IsReadWriteAllowed()); bool IsEndpointFull = !(Endpoint_IsReadWriteAllowed());
Endpoint_ClearIN(); Endpoint_ClearIN();
@ -380,8 +380,8 @@ void ISPProtocol_ChipErase(void)
else else
ResponseStatus = ISPTarget_WaitWhileTargetBusy(); ResponseStatus = ISPTarget_WaitWhileTargetBusy();
Endpoint_Write_Byte(CMD_CHIP_ERASE_ISP); Endpoint_Write_8(CMD_CHIP_ERASE_ISP);
Endpoint_Write_Byte(ResponseStatus); Endpoint_Write_8(ResponseStatus);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -410,10 +410,10 @@ void ISPProtocol_ReadFuseLockSigOSCCAL(uint8_t V2Command)
for (uint8_t RByte = 0; RByte < sizeof(ResponseBytes); RByte++) for (uint8_t RByte = 0; RByte < sizeof(ResponseBytes); RByte++)
ResponseBytes[RByte] = ISPTarget_TransferByte(Read_FuseLockSigOSCCAL_Params.ReadCommandBytes[RByte]); ResponseBytes[RByte] = ISPTarget_TransferByte(Read_FuseLockSigOSCCAL_Params.ReadCommandBytes[RByte]);
Endpoint_Write_Byte(V2Command); Endpoint_Write_8(V2Command);
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
Endpoint_Write_Byte(ResponseBytes[Read_FuseLockSigOSCCAL_Params.RetByte - 1]); Endpoint_Write_8(ResponseBytes[Read_FuseLockSigOSCCAL_Params.RetByte - 1]);
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -439,9 +439,9 @@ void ISPProtocol_WriteFuseLock(uint8_t V2Command)
for (uint8_t SByte = 0; SByte < sizeof(Write_FuseLockSig_Params.WriteCommandBytes); SByte++) for (uint8_t SByte = 0; SByte < sizeof(Write_FuseLockSig_Params.WriteCommandBytes); SByte++)
ISPTarget_SendByte(Write_FuseLockSig_Params.WriteCommandBytes[SByte]); ISPTarget_SendByte(Write_FuseLockSig_Params.WriteCommandBytes[SByte]);
Endpoint_Write_Byte(V2Command); Endpoint_Write_8(V2Command);
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -463,8 +463,8 @@ void ISPProtocol_SPIMulti(void)
Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM); Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM);
Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN); Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN);
Endpoint_Write_Byte(CMD_SPI_MULTI); Endpoint_Write_8(CMD_SPI_MULTI);
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
uint8_t CurrTxPos = 0; uint8_t CurrTxPos = 0;
uint8_t CurrRxPos = 0; uint8_t CurrRxPos = 0;
@ -484,9 +484,9 @@ void ISPProtocol_SPIMulti(void)
while (CurrRxPos < SPI_Multi_Params.RxBytes) while (CurrRxPos < SPI_Multi_Params.RxBytes)
{ {
if (CurrTxPos < SPI_Multi_Params.TxBytes) if (CurrTxPos < SPI_Multi_Params.TxBytes)
Endpoint_Write_Byte(ISPTarget_TransferByte(SPI_Multi_Params.TxData[CurrTxPos++])); Endpoint_Write_8(ISPTarget_TransferByte(SPI_Multi_Params.TxData[CurrTxPos++]));
else else
Endpoint_Write_Byte(ISPTarget_ReceiveByte()); Endpoint_Write_8(ISPTarget_ReceiveByte());
/* Check to see if we have filled the endpoint bank and need to send the packet */ /* Check to see if we have filled the endpoint bank and need to send the packet */
if (!(Endpoint_IsReadWriteAllowed())) if (!(Endpoint_IsReadWriteAllowed()))
@ -498,7 +498,7 @@ void ISPProtocol_SPIMulti(void)
CurrRxPos++; CurrRxPos++;
} }
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
bool IsEndpointFull = !(Endpoint_IsReadWriteAllowed()); bool IsEndpointFull = !(Endpoint_IsReadWriteAllowed());
Endpoint_ClearIN(); Endpoint_ClearIN();

@ -73,7 +73,7 @@ void V2Protocol_Init(void)
*/ */
void V2Protocol_ProcessCommand(void) void V2Protocol_ProcessCommand(void)
{ {
uint8_t V2Command = Endpoint_Read_Byte(); uint8_t V2Command = Endpoint_Read_8();
/* Start the watchdog with timeout interrupt enabled to manage the timeout */ /* Start the watchdog with timeout interrupt enabled to manage the timeout */
TimeoutExpired = false; TimeoutExpired = false;
@ -166,8 +166,8 @@ static void V2Protocol_UnknownCommand(const uint8_t V2Command)
Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM); Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM);
Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN); Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN);
Endpoint_Write_Byte(V2Command); Endpoint_Write_8(V2Command);
Endpoint_Write_Byte(STATUS_CMD_UNKNOWN); Endpoint_Write_8(STATUS_CMD_UNKNOWN);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -178,9 +178,9 @@ static void V2Protocol_SignOn(void)
Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM); Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM);
Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN); Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN);
Endpoint_Write_Byte(CMD_SIGN_ON); Endpoint_Write_8(CMD_SIGN_ON);
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
Endpoint_Write_Byte(sizeof(PROGRAMMER_ID) - 1); Endpoint_Write_8(sizeof(PROGRAMMER_ID) - 1);
Endpoint_Write_Stream_LE(PROGRAMMER_ID, (sizeof(PROGRAMMER_ID) - 1), NULL); Endpoint_Write_Stream_LE(PROGRAMMER_ID, (sizeof(PROGRAMMER_ID) - 1), NULL);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -194,8 +194,8 @@ static void V2Protocol_ResetProtection(void)
Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM); Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM);
Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN); Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN);
Endpoint_Write_Byte(CMD_RESET_PROTECTION); Endpoint_Write_8(CMD_RESET_PROTECTION);
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -207,33 +207,33 @@ static void V2Protocol_ResetProtection(void)
*/ */
static void V2Protocol_GetSetParam(const uint8_t V2Command) static void V2Protocol_GetSetParam(const uint8_t V2Command)
{ {
uint8_t ParamID = Endpoint_Read_Byte(); uint8_t ParamID = Endpoint_Read_8();
uint8_t ParamValue; uint8_t ParamValue;
if (V2Command == CMD_SET_PARAMETER) if (V2Command == CMD_SET_PARAMETER)
ParamValue = Endpoint_Read_Byte(); ParamValue = Endpoint_Read_8();
Endpoint_ClearOUT(); Endpoint_ClearOUT();
Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM); Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM);
Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN); Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN);
Endpoint_Write_Byte(V2Command); Endpoint_Write_8(V2Command);
uint8_t ParamPrivs = V2Params_GetParameterPrivileges(ParamID); uint8_t ParamPrivs = V2Params_GetParameterPrivileges(ParamID);
if ((V2Command == CMD_SET_PARAMETER) && (ParamPrivs & PARAM_PRIV_WRITE)) if ((V2Command == CMD_SET_PARAMETER) && (ParamPrivs & PARAM_PRIV_WRITE))
{ {
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
V2Params_SetParameterValue(ParamID, ParamValue); V2Params_SetParameterValue(ParamID, ParamValue);
} }
else if ((V2Command == CMD_GET_PARAMETER) && (ParamPrivs & PARAM_PRIV_READ)) else if ((V2Command == CMD_GET_PARAMETER) && (ParamPrivs & PARAM_PRIV_READ))
{ {
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
Endpoint_Write_Byte(V2Params_GetParameterValue(ParamID)); Endpoint_Write_8(V2Params_GetParameterValue(ParamID));
} }
else else
{ {
Endpoint_Write_Byte(STATUS_CMD_FAILED); Endpoint_Write_8(STATUS_CMD_FAILED);
} }
Endpoint_ClearIN(); Endpoint_ClearIN();
@ -254,8 +254,8 @@ static void V2Protocol_LoadAddress(void)
if (CurrentAddress & (1UL << 31)) if (CurrentAddress & (1UL << 31))
MustLoadExtendedAddress = true; MustLoadExtendedAddress = true;
Endpoint_Write_Byte(CMD_LOAD_ADDRESS); Endpoint_Write_8(CMD_LOAD_ADDRESS);
Endpoint_Write_Byte(STATUS_CMD_OK); Endpoint_Write_8(STATUS_CMD_OK);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }

@ -70,8 +70,8 @@ void XPROGProtocol_SetMode(void)
XPROG_SelectedProtocol = SetMode_XPROG_Params.Protocol; XPROG_SelectedProtocol = SetMode_XPROG_Params.Protocol;
Endpoint_Write_Byte(CMD_XPROG_SETMODE); Endpoint_Write_8(CMD_XPROG_SETMODE);
Endpoint_Write_Byte((SetMode_XPROG_Params.Protocol != XPRG_PROTOCOL_JTAG) ? STATUS_CMD_OK : STATUS_CMD_FAILED); Endpoint_Write_8((SetMode_XPROG_Params.Protocol != XPRG_PROTOCOL_JTAG) ? STATUS_CMD_OK : STATUS_CMD_FAILED);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -80,7 +80,7 @@ void XPROGProtocol_SetMode(void)
*/ */
void XPROGProtocol_Command(void) void XPROGProtocol_Command(void)
{ {
uint8_t XPROGCommand = Endpoint_Read_Byte(); uint8_t XPROGCommand = Endpoint_Read_8();
switch (XPROGCommand) switch (XPROGCommand)
{ {
@ -122,9 +122,9 @@ static void XPROGProtocol_EnterXPROGMode(void)
else if (XPROG_SelectedProtocol == XPRG_PROTOCOL_TPI) else if (XPROG_SelectedProtocol == XPRG_PROTOCOL_TPI)
NVMBusEnabled = TINYNVM_EnableTPI(); NVMBusEnabled = TINYNVM_EnableTPI();
Endpoint_Write_Byte(CMD_XPROG); Endpoint_Write_8(CMD_XPROG);
Endpoint_Write_Byte(XPRG_CMD_ENTER_PROGMODE); Endpoint_Write_8(XPRG_CMD_ENTER_PROGMODE);
Endpoint_Write_Byte(NVMBusEnabled ? XPRG_ERR_OK : XPRG_ERR_FAILED); Endpoint_Write_8(NVMBusEnabled ? XPRG_ERR_OK : XPRG_ERR_FAILED);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -148,9 +148,9 @@ static void XPROGProtocol_LeaveXPROGMode(void)
ISPTarget_ConfigureRescueClock(); ISPTarget_ConfigureRescueClock();
#endif #endif
Endpoint_Write_Byte(CMD_XPROG); Endpoint_Write_8(CMD_XPROG);
Endpoint_Write_Byte(XPRG_CMD_LEAVE_PROGMODE); Endpoint_Write_8(XPRG_CMD_LEAVE_PROGMODE);
Endpoint_Write_Byte(XPRG_ERR_OK); Endpoint_Write_8(XPRG_ERR_OK);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -224,9 +224,9 @@ static void XPROGProtocol_Erase(void)
ReturnStatus = XPRG_ERR_TIMEOUT; ReturnStatus = XPRG_ERR_TIMEOUT;
} }
Endpoint_Write_Byte(CMD_XPROG); Endpoint_Write_8(CMD_XPROG);
Endpoint_Write_Byte(XPRG_CMD_ERASE); Endpoint_Write_8(XPRG_CMD_ERASE);
Endpoint_Write_Byte(ReturnStatus); Endpoint_Write_8(ReturnStatus);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -317,9 +317,9 @@ static void XPROGProtocol_WriteMemory(void)
} }
} }
Endpoint_Write_Byte(CMD_XPROG); Endpoint_Write_8(CMD_XPROG);
Endpoint_Write_Byte(XPRG_CMD_WRITE_MEM); Endpoint_Write_8(XPRG_CMD_WRITE_MEM);
Endpoint_Write_Byte(ReturnStatus); Endpoint_Write_8(ReturnStatus);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }
@ -360,9 +360,9 @@ static void XPROGProtocol_ReadMemory(void)
ReturnStatus = XPRG_ERR_TIMEOUT; ReturnStatus = XPRG_ERR_TIMEOUT;
} }
Endpoint_Write_Byte(CMD_XPROG); Endpoint_Write_8(CMD_XPROG);
Endpoint_Write_Byte(XPRG_CMD_READ_MEM); Endpoint_Write_8(XPRG_CMD_READ_MEM);
Endpoint_Write_Byte(ReturnStatus); Endpoint_Write_8(ReturnStatus);
if (ReturnStatus == XPRG_ERR_OK) if (ReturnStatus == XPRG_ERR_OK)
Endpoint_Write_Stream_LE(ReadBuffer, ReadMemory_XPROG_Params.Length, NULL); Endpoint_Write_Stream_LE(ReadBuffer, ReadMemory_XPROG_Params.Length, NULL);
@ -418,14 +418,14 @@ static void XPROGProtocol_ReadCRC(void)
ReturnStatus = XPRG_ERR_FAILED; ReturnStatus = XPRG_ERR_FAILED;
} }
Endpoint_Write_Byte(CMD_XPROG); Endpoint_Write_8(CMD_XPROG);
Endpoint_Write_Byte(XPRG_CMD_CRC); Endpoint_Write_8(XPRG_CMD_CRC);
Endpoint_Write_Byte(ReturnStatus); Endpoint_Write_8(ReturnStatus);
if (ReturnStatus == XPRG_ERR_OK) if (ReturnStatus == XPRG_ERR_OK)
{ {
Endpoint_Write_Byte(MemoryCRC >> 16); Endpoint_Write_8(MemoryCRC >> 16);
Endpoint_Write_Word_LE(MemoryCRC & 0xFFFF); Endpoint_Write_16_LE(MemoryCRC & 0xFFFF);
} }
Endpoint_ClearIN(); Endpoint_ClearIN();
@ -438,22 +438,22 @@ static void XPROGProtocol_SetParam(void)
{ {
uint8_t ReturnStatus = XPRG_ERR_OK; uint8_t ReturnStatus = XPRG_ERR_OK;
uint8_t XPROGParam = Endpoint_Read_Byte(); uint8_t XPROGParam = Endpoint_Read_8();
/* Determine which parameter is being set, store the new parameter value */ /* Determine which parameter is being set, store the new parameter value */
switch (XPROGParam) switch (XPROGParam)
{ {
case XPRG_PARAM_NVMBASE: case XPRG_PARAM_NVMBASE:
XPROG_Param_NVMBase = Endpoint_Read_DWord_BE(); XPROG_Param_NVMBase = Endpoint_Read_32_BE();
break; break;
case XPRG_PARAM_EEPPAGESIZE: case XPRG_PARAM_EEPPAGESIZE:
XPROG_Param_EEPageSize = Endpoint_Read_Word_BE(); XPROG_Param_EEPageSize = Endpoint_Read_16_BE();
break; break;
case XPRG_PARAM_NVMCMD_REG: case XPRG_PARAM_NVMCMD_REG:
XPROG_Param_NVMCMDRegAddr = Endpoint_Read_Byte(); XPROG_Param_NVMCMDRegAddr = Endpoint_Read_8();
break; break;
case XPRG_PARAM_NVMCSR_REG: case XPRG_PARAM_NVMCSR_REG:
XPROG_Param_NVMCSRRegAddr = Endpoint_Read_Byte(); XPROG_Param_NVMCSRRegAddr = Endpoint_Read_8();
break; break;
default: default:
ReturnStatus = XPRG_ERR_FAILED; ReturnStatus = XPRG_ERR_FAILED;
@ -464,9 +464,9 @@ static void XPROGProtocol_SetParam(void)
Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM); Endpoint_SelectEndpoint(AVRISP_DATA_IN_EPNUM);
Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN); Endpoint_SetEndpointDirection(ENDPOINT_DIR_IN);
Endpoint_Write_Byte(CMD_XPROG); Endpoint_Write_8(CMD_XPROG);
Endpoint_Write_Byte(XPRG_CMD_SET_PARAM); Endpoint_Write_8(XPRG_CMD_SET_PARAM);
Endpoint_Write_Byte(ReturnStatus); Endpoint_Write_8(ReturnStatus);
Endpoint_ClearIN(); Endpoint_ClearIN();
} }

@ -130,22 +130,22 @@ void DataflashManager_WriteBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceIn
} }
/* Write one 16-byte chunk of data to the Dataflash */ /* Write one 16-byte chunk of data to the Dataflash */
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;
@ -245,22 +245,22 @@ void DataflashManager_ReadBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceInf
} }
/* Read one 16-byte chunk of data from the Dataflash */ /* Read one 16-byte chunk of data from the Dataflash */
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;

@ -330,10 +330,10 @@ static bool SCSI_Command_ReadWrite_10(USB_ClassInfo_MS_Device_t* const MSInterfa
static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo) static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo)
{ {
/* Send an empty header response with the Write Protect flag status */ /* Send an empty header response with the Write Protect flag status */
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(DISK_READ_ONLY ? 0x80 : 0x00); Endpoint_Write_8(DISK_READ_ONLY ? 0x80 : 0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_ClearIN(); Endpoint_ClearIN();
/* Update the bytes transferred counter and succeed the command */ /* Update the bytes transferred counter and succeed the command */

@ -129,22 +129,22 @@ void DataflashManager_WriteBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceIn
} }
/* Write one 16-byte chunk of data to the Dataflash */ /* Write one 16-byte chunk of data to the Dataflash */
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;
@ -244,22 +244,22 @@ void DataflashManager_ReadBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceInf
} }
/* Read one 16-byte chunk of data from the Dataflash */ /* Read one 16-byte chunk of data from the Dataflash */
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;

@ -329,10 +329,10 @@ static bool SCSI_Command_ReadWrite_10(USB_ClassInfo_MS_Device_t* const MSInterfa
static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo) static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo)
{ {
/* Send an empty header response with the Write Protect flag status */ /* Send an empty header response with the Write Protect flag status */
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(DISK_READ_ONLY ? 0x80 : 0x00); Endpoint_Write_8(DISK_READ_ONLY ? 0x80 : 0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_ClearIN(); Endpoint_ClearIN();
/* Update the bytes transferred counter and succeed the command */ /* Update the bytes transferred counter and succeed the command */

@ -129,22 +129,22 @@ void DataflashManager_WriteBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceIn
} }
/* Write one 16-byte chunk of data to the Dataflash */ /* Write one 16-byte chunk of data to the Dataflash */
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
Dataflash_SendByte(Endpoint_Read_Byte()); Dataflash_SendByte(Endpoint_Read_8());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;
@ -244,22 +244,22 @@ void DataflashManager_ReadBlocks(USB_ClassInfo_MS_Device_t* const MSInterfaceInf
} }
/* Read one 16-byte chunk of data from the Dataflash */ /* Read one 16-byte chunk of data from the Dataflash */
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
Endpoint_Write_Byte(Dataflash_ReceiveByte()); Endpoint_Write_8(Dataflash_ReceiveByte());
/* Increment the Dataflash page 16 byte block counter */ /* Increment the Dataflash page 16 byte block counter */
CurrDFPageByteDiv16++; CurrDFPageByteDiv16++;

@ -329,10 +329,10 @@ static bool SCSI_Command_ReadWrite_10(USB_ClassInfo_MS_Device_t* const MSInterfa
static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo) static bool SCSI_Command_ModeSense_6(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo)
{ {
/* Send an empty header response with the Write Protect flag status */ /* Send an empty header response with the Write Protect flag status */
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_Write_Byte(DISK_READ_ONLY ? 0x80 : 0x00); Endpoint_Write_8(DISK_READ_ONLY ? 0x80 : 0x00);
Endpoint_Write_Byte(0x00); Endpoint_Write_8(0x00);
Endpoint_ClearIN(); Endpoint_ClearIN();
/* Update the bytes transferred counter and succeed the command */ /* Update the bytes transferred counter and succeed the command */

Loading…
Cancel
Save