forked from mfulz_github/qmk_firmware
		
	Minor changes to the AVRISP project for code clarity.
This commit is contained in:
		
							parent
							
								
									8bb007f80b
								
							
						
					
					
						commit
						c647c27639
					
				| @ -120,11 +120,11 @@ void Process_AVRISP_Commands(void) | ||||
| 
 | ||||
| 	Endpoint_SelectEndpoint(AVRISP_DATA_EPNUM); | ||||
| 	 | ||||
| 	/* Check to see if a V2 Protocol command has been received - if not, abort */ | ||||
| 	if (!(Endpoint_IsOUTReceived())) | ||||
| 	  return; | ||||
| 
 | ||||
| 	/* Check to see if a V2 Protocol command has been received */ | ||||
| 	if (Endpoint_IsOUTReceived()) | ||||
| 	{ | ||||
| 		/* Pass off processing of the V2 Protocol command to the V2 Protocol handler */ | ||||
| 		V2Protocol_ProcessCommand(); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -301,10 +301,8 @@ static void V2Protocol_Command_ProgramMemory(uint8_t V2Command) | ||||
| 		uint8_t  ProgrammingCommands[3]; | ||||
| 		uint8_t  PollValue1; | ||||
| 		uint8_t  PollValue2; | ||||
| 		uint8_t  ProgData[256]; | ||||
| 	} Write_Memory_Params; | ||||
| 	 | ||||
| 	uint8_t* NextWriteByte = Write_Memory_Params.ProgData; | ||||
| 		uint8_t  ProgData[256]; // Note, the Jungo driver has a very short ACK timeout period, need to buffer the
 | ||||
| 	} Write_Memory_Params;      // whole page and ACK the packet as fast as possible to prevent it from aborting
 | ||||
| 	 | ||||
| 	Endpoint_Read_Stream_LE(&Write_Memory_Params, sizeof(Write_Memory_Params) - sizeof(Write_Memory_Params.ProgData)); | ||||
| 	Write_Memory_Params.BytesToWrite = SwapEndian_16(Write_Memory_Params.BytesToWrite); | ||||
| @ -329,6 +327,8 @@ static void V2Protocol_Command_ProgramMemory(uint8_t V2Command) | ||||
| 	uint16_t PollAddress       = 0; | ||||
| 	uint8_t  PollValue         = (V2Command == CMD_PROGRAM_FLASH_ISP) ? Write_Memory_Params.PollValue1 : | ||||
| 	                                                                    Write_Memory_Params.PollValue2; | ||||
| 	uint8_t* NextWriteByte = Write_Memory_Params.ProgData; | ||||
| 
 | ||||
| 	if (Write_Memory_Params.ProgrammingMode & PROG_MODE_PAGED_WRITES_MASK) | ||||
| 	{ | ||||
| 		uint16_t StartAddress = (CurrentAddress & 0xFFFF); | ||||
|  | ||||
| @ -132,7 +132,7 @@ uint8_t V2Params_GetParameterValue(uint8_t ParamID) | ||||
| { | ||||
| 	ParameterItem_t* ParamInfo = V2Params_GetParamFromTable(ParamID); | ||||
| 	 | ||||
| 	if (ParamInfo == NULL) | ||||
| 	if ((ParamInfo == NULL) || !(ParamInfo->ParamPrivellages & PARAM_PRIV_READ)) | ||||
| 	  return 0; | ||||
| 	 | ||||
| 	return ParamInfo->ParamValue; | ||||
| @ -149,7 +149,7 @@ void V2Params_SetParameterValue(uint8_t ParamID, uint8_t Value) | ||||
| { | ||||
| 	ParameterItem_t* ParamInfo = V2Params_GetParamFromTable(ParamID); | ||||
| 
 | ||||
| 	if (ParamInfo == NULL) | ||||
| 	if ((ParamInfo == NULL) || !(ParamInfo->ParamPrivellages & PARAM_PRIV_WRITE)) | ||||
| 	  return; | ||||
| 
 | ||||
| 	ParamInfo->ParamValue = Value; | ||||
|  | ||||
| @ -155,17 +155,14 @@ uint8_t V2Protocol_WaitWhileTargetBusy(void) | ||||
| { | ||||
| 	TCNT0 = 0; | ||||
| 	 | ||||
| 	bool DeviceBusy; | ||||
| 	 | ||||
| 	do | ||||
| 	{ | ||||
| 		SPI_SendByte(0xF0); | ||||
| 		SPI_SendByte(0x00); | ||||
| 
 | ||||
| 		SPI_SendByte(0x00); | ||||
| 		DeviceBusy = (SPI_ReceiveByte() & 0x01); | ||||
| 	} | ||||
| 	while (DeviceBusy && (TCNT0 < TARGET_BUSY_TIMEOUT_MS)); | ||||
| 	while ((SPI_ReceiveByte() & 0x01) && (TCNT0 < TARGET_BUSY_TIMEOUT_MS)); | ||||
| 
 | ||||
| 	if (TCNT0 >= TARGET_BUSY_TIMEOUT_MS) | ||||
| 	  return STATUS_RDY_BSY_TOUT; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Dean Camera
						Dean Camera