|  |  | @ -75,7 +75,7 @@ bool XMEGANVM_WaitWhileNVMBusBusy(void) | 
			
		
	
		
		
			
				
					
					|  |  |  | 	for (;;) |  |  |  | 	for (;;) | 
			
		
	
		
		
			
				
					
					|  |  |  | 	{ |  |  |  | 	{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the LDCS command to read the PDI STATUS register to see the NVM bus is active */ |  |  |  | 		/* Send the LDCS command to read the PDI STATUS register to see the NVM bus is active */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_LDCS | PDI_STATUS_REG); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_LDCS(PDI_REG_STATUS)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		uint8_t StatusRegister = XPROGTarget_ReceiveByte(); |  |  |  | 		uint8_t StatusRegister = XPROGTarget_ReceiveByte(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -97,14 +97,14 @@ bool XMEGANVM_WaitWhileNVMBusBusy(void) | 
			
		
	
		
		
			
				
					
					|  |  |  | bool XMEGANVM_WaitWhileNVMControllerBusy(void) |  |  |  | bool XMEGANVM_WaitWhileNVMControllerBusy(void) | 
			
		
	
		
		
			
				
					
					|  |  |  | { |  |  |  | { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Preload the pointer register with the NVM STATUS register address to check the BUSY flag */ |  |  |  | 	/* Preload the pointer register with the NVM STATUS register address to check the BUSY flag */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_ST | (PDI_POINTER_DIRECT << 2) | PDI_DATSIZE_4BYTES); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_ST(PDI_POINTER_DIRECT, PDI_DATSIZE_4BYTES)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_STATUS); |  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_STATUS); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Poll the NVM STATUS register while the NVM controller is busy */ |  |  |  | 	/* Poll the NVM STATUS register while the NVM controller is busy */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	for (;;) |  |  |  | 	for (;;) | 
			
		
	
		
		
			
				
					
					|  |  |  | 	{ |  |  |  | 	{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Fetch the current status value via the pointer register (without auto-increment afterwards) */ |  |  |  | 		/* Fetch the current status value via the pointer register (without auto-increment afterwards) */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_LD | (PDI_POINTER_INDIRECT << 2) | PDI_DATSIZE_1BYTE); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_LD(PDI_POINTER_INDIRECT, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		uint8_t StatusRegister = XPROGTarget_ReceiveByte(); |  |  |  | 		uint8_t StatusRegister = XPROGTarget_ReceiveByte(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -128,11 +128,11 @@ bool XMEGANVM_EnablePDI(void) | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_EnableTargetPDI(); |  |  |  | 	XPROGTarget_EnableTargetPDI(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Store the RESET key into the RESET PDI register to keep the XMEGA in reset */ |  |  |  | 	/* Store the RESET key into the RESET PDI register to keep the XMEGA in reset */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STCS | PDI_RESET_REG); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STCS(PDI_REG_RESET)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_RESET_KEY); |  |  |  | 	XPROGTarget_SendByte(PDI_RESET_KEY); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Lower direction change guard time to 32 USART bits */ |  |  |  | 	/* Lower direction change guard time to 32 USART bits */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STCS | PDI_CTRL_REG); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STCS(PDI_REG_CTRL)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(0x02); |  |  |  | 	XPROGTarget_SendByte(0x02); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Enable access to the XPROG NVM bus by sending the documented NVM access key to the device */ |  |  |  | 	/* Enable access to the XPROG NVM bus by sending the documented NVM access key to the device */ | 
			
		
	
	
		
		
			
				
					|  |  | @ -155,11 +155,11 @@ void XMEGANVM_DisablePDI(void) | 
			
		
	
		
		
			
				
					
					|  |  |  | 	do |  |  |  | 	do | 
			
		
	
		
		
			
				
					
					|  |  |  | 	{ |  |  |  | 	{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Clear reset register */ |  |  |  | 		/* Clear reset register */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STCS | PDI_RESET_REG); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STCS(PDI_REG_RESET)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(0x00); |  |  |  | 		XPROGTarget_SendByte(0x00); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Read back the reset register, check to see if it took effect */ |  |  |  | 		/* Read back the reset register, check to see if it took effect */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_LDCS | PDI_RESET_REG); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_LDCS(PDI_REG_RESET)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	} while (XPROGTarget_ReceiveByte() != 0x00); |  |  |  | 	} while (XPROGTarget_ReceiveByte() != 0x00); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_DisableTargetPDI(); |  |  |  | 	XPROGTarget_DisableTargetPDI(); | 
			
		
	
	
		
		
			
				
					|  |  | @ -182,12 +182,12 @@ bool XMEGANVM_GetMemoryCRC(const uint8_t CRCCommand, | 
			
		
	
		
		
			
				
					
					|  |  |  | 	  return false; |  |  |  | 	  return false; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Set the NVM command to the correct CRC read command */ |  |  |  | 	/* Set the NVM command to the correct CRC read command */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(CRCCommand); |  |  |  | 	XPROGTarget_SendByte(CRCCommand); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Set CMDEX bit in NVM CTRLA register to start the CRC generation */ |  |  |  | 	/* Set CMDEX bit in NVM CTRLA register to start the CRC generation */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CTRLA); |  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CTRLA); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(XMEGA_NVM_BIT_CTRLA_CMDEX); |  |  |  | 	XPROGTarget_SendByte(XMEGA_NVM_BIT_CTRLA_CMDEX); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -200,15 +200,15 @@ bool XMEGANVM_GetMemoryCRC(const uint8_t CRCCommand, | 
			
		
	
		
		
			
				
					
					|  |  |  | 	  return false; |  |  |  | 	  return false; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Load the PDI pointer register with the DAT0 register start address */ |  |  |  | 	/* Load the PDI pointer register with the DAT0 register start address */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_ST | (PDI_POINTER_DIRECT << 2) | PDI_DATSIZE_4BYTES); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_ST(PDI_POINTER_DIRECT, PDI_DATSIZE_4BYTES)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_DAT0); |  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_DAT0); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Send the REPEAT command to grab the CRC bytes */ |  |  |  | 	/* Send the REPEAT command to grab the CRC bytes */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_REPEAT | PDI_DATSIZE_1BYTE); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_REPEAT(PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(XMEGA_CRC_LENGTH_BYTES - 1); |  |  |  | 	XPROGTarget_SendByte(XMEGA_CRC_LENGTH_BYTES - 1); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Read in the CRC bytes from the target */ |  |  |  | 	/* Read in the CRC bytes from the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_LD | (PDI_POINTER_INDIRECT_PI << 2) | PDI_DATSIZE_1BYTE); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_LD(PDI_POINTER_INDIRECT_PI, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	for (uint8_t i = 0; i < XMEGA_CRC_LENGTH_BYTES; i++) |  |  |  | 	for (uint8_t i = 0; i < XMEGA_CRC_LENGTH_BYTES; i++) | 
			
		
	
		
		
			
				
					
					|  |  |  | 	  ((uint8_t*)CRCDest)[i] = XPROGTarget_ReceiveByte(); |  |  |  | 	  ((uint8_t*)CRCDest)[i] = XPROGTarget_ReceiveByte(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -232,29 +232,29 @@ bool XMEGANVM_ReadMemory(const uint32_t ReadAddress, | 
			
		
	
		
		
			
				
					
					|  |  |  | 	  return false; |  |  |  | 	  return false; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Send the READNVM command to the NVM controller for reading of an arbitrary location */ |  |  |  | 	/* Send the READNVM command to the NVM controller for reading of an arbitrary location */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(XMEGA_NVM_CMD_READNVM); |  |  |  | 	XPROGTarget_SendByte(XMEGA_NVM_CMD_READNVM); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	if (ReadSize > 1) |  |  |  | 	if (ReadSize > 1) | 
			
		
	
		
		
			
				
					
					|  |  |  | 	{ |  |  |  | 	{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Load the PDI pointer register with the start address we want to read from */ |  |  |  | 		/* Load the PDI pointer register with the start address we want to read from */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_ST | (PDI_POINTER_DIRECT << 2) | PDI_DATSIZE_4BYTES); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_ST(PDI_POINTER_DIRECT, PDI_DATSIZE_4BYTES)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendAddress(ReadAddress); |  |  |  | 		XMEGANVM_SendAddress(ReadAddress); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the REPEAT command with the specified number of bytes to read */ |  |  |  | 		/* Send the REPEAT command with the specified number of bytes to read */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_REPEAT | PDI_DATSIZE_1BYTE); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_REPEAT(PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(ReadSize - 1); |  |  |  | 		XPROGTarget_SendByte(ReadSize - 1); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send a LD command with indirect access and post-increment to read out the bytes */ |  |  |  | 		/* Send a LD command with indirect access and post-increment to read out the bytes */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_LD | (PDI_POINTER_INDIRECT_PI << 2) | PDI_DATSIZE_1BYTE); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_LD(PDI_POINTER_INDIRECT_PI, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		while (ReadSize-- && TimeoutTicksRemaining) |  |  |  | 		while (ReadSize-- && TimeoutTicksRemaining) | 
			
		
	
		
		
			
				
					
					|  |  |  | 		  *(ReadBuffer++) = XPROGTarget_ReceiveByte(); |  |  |  | 		  *(ReadBuffer++) = XPROGTarget_ReceiveByte(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
		
		
			
				
					
					|  |  |  | 	else |  |  |  | 	else | 
			
		
	
		
		
			
				
					
					|  |  |  | 	{ |  |  |  | 	{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send a LDS command with the read address to read out the requested byte */ |  |  |  | 		/* Send a LDS command with the read address to read out the requested byte */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_LDS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_LDS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendAddress(ReadAddress); |  |  |  | 		XMEGANVM_SendAddress(ReadAddress); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		*(ReadBuffer++) = XPROGTarget_ReceiveByte(); |  |  |  | 		*(ReadBuffer++) = XPROGTarget_ReceiveByte(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
	
		
		
			
				
					|  |  | @ -279,12 +279,12 @@ bool XMEGANVM_WriteByteMemory(const uint8_t WriteCommand, | 
			
		
	
		
		
			
				
					
					|  |  |  | 	  return false; |  |  |  | 	  return false; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Send the memory write command to the target */ |  |  |  | 	/* Send the memory write command to the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 	XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(WriteCommand); |  |  |  | 	XPROGTarget_SendByte(WriteCommand); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	/* Send new memory byte to the memory of the target */ |  |  |  | 	/* Send new memory byte to the memory of the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 	XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 	XMEGANVM_SendAddress(WriteAddress); |  |  |  | 	XMEGANVM_SendAddress(WriteAddress); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	XPROGTarget_SendByte(Byte); |  |  |  | 	XPROGTarget_SendByte(Byte); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -318,12 +318,12 @@ bool XMEGANVM_WritePageMemory(const uint8_t WriteBuffCommand, | 
			
		
	
		
		
			
				
					
					|  |  |  | 		  return false; |  |  |  | 		  return false; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the memory buffer erase command to the target */ |  |  |  | 		/* Send the memory buffer erase command to the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(EraseBuffCommand); |  |  |  | 		XPROGTarget_SendByte(EraseBuffCommand); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Set CMDEX bit in NVM CTRLA register to start the buffer erase */ |  |  |  | 		/* Set CMDEX bit in NVM CTRLA register to start the buffer erase */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CTRLA); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CTRLA); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_BIT_CTRLA_CMDEX); |  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_BIT_CTRLA_CMDEX); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
	
		
		
			
				
					|  |  | @ -335,20 +335,20 @@ bool XMEGANVM_WritePageMemory(const uint8_t WriteBuffCommand, | 
			
		
	
		
		
			
				
					
					|  |  |  | 		  return false; |  |  |  | 		  return false; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the memory buffer write command to the target */ |  |  |  | 		/* Send the memory buffer write command to the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(WriteBuffCommand); |  |  |  | 		XPROGTarget_SendByte(WriteBuffCommand); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Load the PDI pointer register with the start address we want to write to */ |  |  |  | 		/* Load the PDI pointer register with the start address we want to write to */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_ST | (PDI_POINTER_DIRECT << 2) | PDI_DATSIZE_4BYTES); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_ST(PDI_POINTER_DIRECT, PDI_DATSIZE_4BYTES)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendAddress(WriteAddress); |  |  |  | 		XMEGANVM_SendAddress(WriteAddress); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the REPEAT command with the specified number of bytes to write */ |  |  |  | 		/* Send the REPEAT command with the specified number of bytes to write */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_REPEAT | PDI_DATSIZE_1BYTE); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_REPEAT(PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(WriteSize - 1); |  |  |  | 		XPROGTarget_SendByte(WriteSize - 1); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send a ST command with indirect access and post-increment to write the bytes */ |  |  |  | 		/* Send a ST command with indirect access and post-increment to write the bytes */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_ST | (PDI_POINTER_INDIRECT_PI << 2) | PDI_DATSIZE_1BYTE); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_ST(PDI_POINTER_INDIRECT_PI, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		while (WriteSize--) |  |  |  | 		while (WriteSize--) | 
			
		
	
		
		
			
				
					
					|  |  |  | 		  XPROGTarget_SendByte(*(WriteBuffer++)); |  |  |  | 		  XPROGTarget_SendByte(*(WriteBuffer++)); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
	
		
		
			
				
					|  |  | @ -360,12 +360,12 @@ bool XMEGANVM_WritePageMemory(const uint8_t WriteBuffCommand, | 
			
		
	
		
		
			
				
					
					|  |  |  | 		  return false; |  |  |  | 		  return false; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the memory write command to the target */ |  |  |  | 		/* Send the memory write command to the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(WritePageCommand); |  |  |  | 		XPROGTarget_SendByte(WritePageCommand); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the address of the first page location to write the memory page */ |  |  |  | 		/* Send the address of the first page location to write the memory page */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendAddress(WriteAddress); |  |  |  | 		XMEGANVM_SendAddress(WriteAddress); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(0x00); |  |  |  | 		XPROGTarget_SendByte(0x00); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
	
		
		
			
				
					|  |  | @ -391,24 +391,24 @@ bool XMEGANVM_EraseMemory(const uint8_t EraseCommand, | 
			
		
	
		
		
			
				
					
					|  |  |  | 	if (EraseCommand == XMEGA_NVM_CMD_CHIPERASE) |  |  |  | 	if (EraseCommand == XMEGA_NVM_CMD_CHIPERASE) | 
			
		
	
		
		
			
				
					
					|  |  |  | 	{ |  |  |  | 	{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the memory erase command to the target */ |  |  |  | 		/* Send the memory erase command to the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(EraseCommand); |  |  |  | 		XPROGTarget_SendByte(EraseCommand); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Set CMDEX bit in NVM CTRLA register to start the erase sequence */ |  |  |  | 		/* Set CMDEX bit in NVM CTRLA register to start the erase sequence */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CTRLA); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CTRLA); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_BIT_CTRLA_CMDEX); |  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_BIT_CTRLA_CMDEX); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
		
		
			
				
					
					|  |  |  | 	else if (EraseCommand == XMEGA_NVM_CMD_ERASEEEPROM) |  |  |  | 	else if (EraseCommand == XMEGA_NVM_CMD_ERASEEEPROM) | 
			
		
	
		
		
			
				
					
					|  |  |  | 	{ |  |  |  | 	{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the EEPROM page buffer erase command to the target */ |  |  |  | 		/* Send the EEPROM page buffer erase command to the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_CMD_ERASEEEPROMPAGEBUFF); |  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_CMD_ERASEEEPROMPAGEBUFF); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Set CMDEX bit in NVM CTRLA register to start the buffer erase */ |  |  |  | 		/* Set CMDEX bit in NVM CTRLA register to start the buffer erase */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CTRLA); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CTRLA); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_BIT_CTRLA_CMDEX); |  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_BIT_CTRLA_CMDEX); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -417,42 +417,42 @@ bool XMEGANVM_EraseMemory(const uint8_t EraseCommand, | 
			
		
	
		
		
			
				
					
					|  |  |  | 		  return false; |  |  |  | 		  return false; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the EEPROM memory buffer write command to the target */ |  |  |  | 		/* Send the EEPROM memory buffer write command to the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_CMD_LOADEEPROMPAGEBUFF); |  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_CMD_LOADEEPROMPAGEBUFF); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Load the PDI pointer register with the EEPROM page start address */ |  |  |  | 		/* Load the PDI pointer register with the EEPROM page start address */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_ST | (PDI_POINTER_DIRECT << 2) | PDI_DATSIZE_4BYTES); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_ST(PDI_POINTER_DIRECT, PDI_DATSIZE_4BYTES)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendAddress(Address); |  |  |  | 		XMEGANVM_SendAddress(Address); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the REPEAT command with the specified number of bytes to write */ |  |  |  | 		/* Send the REPEAT command with the specified number of bytes to write */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_REPEAT | PDI_DATSIZE_1BYTE); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_REPEAT(PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(XPROG_Param_EEPageSize - 1); |  |  |  | 		XPROGTarget_SendByte(XPROG_Param_EEPageSize - 1); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send a ST command with indirect access and post-increment to tag each byte in the EEPROM page buffer */ |  |  |  | 		/* Send a ST command with indirect access and post-increment to tag each byte in the EEPROM page buffer */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_ST | (PDI_POINTER_INDIRECT_PI << 2) | PDI_DATSIZE_1BYTE); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_ST(PDI_POINTER_INDIRECT_PI, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		for (uint8_t PageByte = 0; PageByte < XPROG_Param_EEPageSize; PageByte++) |  |  |  | 		for (uint8_t PageByte = 0; PageByte < XPROG_Param_EEPageSize; PageByte++) | 
			
		
	
		
		
			
				
					
					|  |  |  | 		  XPROGTarget_SendByte(0x00); |  |  |  | 		  XPROGTarget_SendByte(0x00); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the memory erase command to the target */ |  |  |  | 		/* Send the memory erase command to the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(EraseCommand); |  |  |  | 		XPROGTarget_SendByte(EraseCommand); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Set CMDEX bit in NVM CTRLA register to start the EEPROM erase sequence */ |  |  |  | 		/* Set CMDEX bit in NVM CTRLA register to start the EEPROM erase sequence */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CTRLA); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CTRLA); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_BIT_CTRLA_CMDEX); |  |  |  | 		XPROGTarget_SendByte(XMEGA_NVM_BIT_CTRLA_CMDEX); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
		
		
			
				
					
					|  |  |  | 	else |  |  |  | 	else | 
			
		
	
		
		
			
				
					
					|  |  |  | 	{ |  |  |  | 	{ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Send the memory erase command to the target */ |  |  |  | 		/* Send the memory erase command to the target */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); |  |  |  | 		XMEGANVM_SendNVMRegAddress(XMEGA_NVM_REG_CMD); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(EraseCommand); |  |  |  | 		XPROGTarget_SendByte(EraseCommand); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		/* Other erase modes just need us to address a byte within the target memory space */ |  |  |  | 		/* Other erase modes just need us to address a byte within the target memory space */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS | (PDI_DATSIZE_4BYTES << 2)); |  |  |  | 		XPROGTarget_SendByte(PDI_CMD_STS(PDI_DATSIZE_4BYTES, PDI_DATSIZE_1BYTE)); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		XMEGANVM_SendAddress(Address); |  |  |  | 		XMEGANVM_SendAddress(Address); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XPROGTarget_SendByte(0x00); |  |  |  | 		XPROGTarget_SendByte(0x00); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
	
		
		
			
				
					|  |  | 
 |