mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-10-25 19:50:01 +02:00 
			
		
		
		
	Oops - The DS1307 contains an unused "DayOfWeek" register that must be accounted for in the new unified DS1307 Time/Day read and write routines.
This commit is contained in:
		
							parent
							
								
									7776aa4e2e
								
							
						
					
					
						commit
						9c7594e7db
					
				| @ -13,26 +13,26 @@ void DS1307_SetTimeDate(const TimeDate_t* NewTimeDate) | |||||||
| 	return; | 	return; | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| 	DS1307_TimeRegs_t CurrentRTCTime; | 	DS1307_DateTimeRegs_t NewRegValues; | ||||||
| 	DS1307_DateRegs_t CurrentRTCDate; |  | ||||||
| 
 | 
 | ||||||
| 	// Convert new time data to the DS1307's time register layout
 | 	// Convert new time data to the DS1307's time register layout
 | ||||||
| 	CurrentRTCTime.Byte1.Fields.TenSec  = (NewTimeDate->Second / 10); | 	NewRegValues.Byte1.Fields.TenSec    = (NewTimeDate->Second / 10); | ||||||
| 	CurrentRTCTime.Byte1.Fields.Sec     = (NewTimeDate->Second % 10); | 	NewRegValues.Byte1.Fields.Sec       = (NewTimeDate->Second % 10); | ||||||
| 	CurrentRTCTime.Byte1.Fields.CH      = false; | 	NewRegValues.Byte1.Fields.CH        = false; | ||||||
| 	CurrentRTCTime.Byte2.Fields.TenMin  = (NewTimeDate->Minute / 10); | 	NewRegValues.Byte2.Fields.TenMin    = (NewTimeDate->Minute / 10); | ||||||
| 	CurrentRTCTime.Byte2.Fields.Min     = (NewTimeDate->Minute % 10); | 	NewRegValues.Byte2.Fields.Min       = (NewTimeDate->Minute % 10); | ||||||
| 	CurrentRTCTime.Byte3.Fields.TenHour = (NewTimeDate->Hour / 10); | 	NewRegValues.Byte3.Fields.TenHour   = (NewTimeDate->Hour / 10); | ||||||
| 	CurrentRTCTime.Byte3.Fields.Hour    = (NewTimeDate->Hour % 10); | 	NewRegValues.Byte3.Fields.Hour      = (NewTimeDate->Hour % 10); | ||||||
| 	CurrentRTCTime.Byte3.Fields.TwelveHourMode = false; | 	NewRegValues.Byte3.Fields.TwelveHourMode = false; | ||||||
| 
 | 
 | ||||||
| 	// Convert new date data to the DS1307's date register layout
 | 	// Convert new date data to the DS1307's date register layout
 | ||||||
| 	CurrentRTCDate.Byte1.Fields.TenDay   = (NewTimeDate->Day / 10); | 	NewRegValues.Byte4.Fields.DayOfWeek = 0; | ||||||
| 	CurrentRTCDate.Byte1.Fields.Day      = (NewTimeDate->Day % 10); | 	NewRegValues.Byte5.Fields.TenDay    = (NewTimeDate->Day / 10); | ||||||
| 	CurrentRTCDate.Byte2.Fields.TenMonth = (NewTimeDate->Month / 10); | 	NewRegValues.Byte5.Fields.Day       = (NewTimeDate->Day % 10); | ||||||
| 	CurrentRTCDate.Byte2.Fields.Month    = (NewTimeDate->Month % 10); | 	NewRegValues.Byte6.Fields.TenMonth  = (NewTimeDate->Month / 10); | ||||||
| 	CurrentRTCDate.Byte3.Fields.TenYear  = (NewTimeDate->Year / 10); | 	NewRegValues.Byte6.Fields.Month     = (NewTimeDate->Month % 10); | ||||||
| 	CurrentRTCDate.Byte3.Fields.Year     = (NewTimeDate->Year % 10); | 	NewRegValues.Byte7.Fields.TenYear   = (NewTimeDate->Year / 10); | ||||||
|  | 	NewRegValues.Byte7.Fields.Year      = (NewTimeDate->Year % 10); | ||||||
| 	 | 	 | ||||||
| 	if (TWI_StartTransmission(DS1307_ADDRESS_WRITE, 10)) | 	if (TWI_StartTransmission(DS1307_ADDRESS_WRITE, 10)) | ||||||
| 	{ | 	{ | ||||||
| @ -40,14 +40,15 @@ void DS1307_SetTimeDate(const TimeDate_t* NewTimeDate) | |||||||
| 		TWI_SendByte(0); | 		TWI_SendByte(0); | ||||||
| 
 | 
 | ||||||
| 		// Write time data to the first set of device registers
 | 		// Write time data to the first set of device registers
 | ||||||
| 		TWI_SendByte(CurrentRTCTime.Byte1.IntVal); | 		TWI_SendByte(NewRegValues.Byte1.IntVal); | ||||||
| 		TWI_SendByte(CurrentRTCTime.Byte2.IntVal); | 		TWI_SendByte(NewRegValues.Byte2.IntVal); | ||||||
| 		TWI_SendByte(CurrentRTCTime.Byte3.IntVal); | 		TWI_SendByte(NewRegValues.Byte3.IntVal); | ||||||
| 
 | 
 | ||||||
| 		// Write date data to the second set of device registers
 | 		// Write date data to the second set of device registers
 | ||||||
| 		TWI_SendByte(CurrentRTCDate.Byte1.IntVal); | 		TWI_SendByte(NewRegValues.Byte4.IntVal); | ||||||
| 		TWI_SendByte(CurrentRTCDate.Byte2.IntVal); | 		TWI_SendByte(NewRegValues.Byte5.IntVal); | ||||||
| 		TWI_SendByte(CurrentRTCDate.Byte3.IntVal); | 		TWI_SendByte(NewRegValues.Byte6.IntVal); | ||||||
|  | 		TWI_SendByte(NewRegValues.Byte7.IntVal); | ||||||
| 		 | 		 | ||||||
| 		TWI_StopTransmission(); | 		TWI_StopTransmission(); | ||||||
| 	} | 	} | ||||||
| @ -74,32 +75,32 @@ void DS1307_GetTimeDate(TimeDate_t* const TimeDate) | |||||||
| 		TWI_StopTransmission(); | 		TWI_StopTransmission(); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	DS1307_TimeRegs_t CurrentRTCTime; | 	DS1307_DateTimeRegs_t CurrentRegValues; | ||||||
| 	DS1307_DateRegs_t CurrentRTCDate; |  | ||||||
| 	 | 	 | ||||||
| 	if (TWI_StartTransmission(DS1307_ADDRESS_READ, 10)) | 	if (TWI_StartTransmission(DS1307_ADDRESS_READ, 10)) | ||||||
| 	{ | 	{ | ||||||
| 		// First set of registers store the current time
 | 		// First set of registers store the current time
 | ||||||
| 		TWI_ReceiveByte(&CurrentRTCTime.Byte1.IntVal, false); | 		TWI_ReceiveByte(&CurrentRegValues.Byte1.IntVal, false); | ||||||
| 		TWI_ReceiveByte(&CurrentRTCTime.Byte2.IntVal, false); | 		TWI_ReceiveByte(&CurrentRegValues.Byte2.IntVal, false); | ||||||
| 		TWI_ReceiveByte(&CurrentRTCTime.Byte3.IntVal, false); | 		TWI_ReceiveByte(&CurrentRegValues.Byte3.IntVal, false); | ||||||
| 
 | 
 | ||||||
| 		// Second set of registers store the current date
 | 		// Second set of registers store the current date
 | ||||||
| 		TWI_ReceiveByte(&CurrentRTCDate.Byte1.IntVal, false); | 		TWI_ReceiveByte(&CurrentRegValues.Byte4.IntVal, false); | ||||||
| 		TWI_ReceiveByte(&CurrentRTCDate.Byte2.IntVal, false); | 		TWI_ReceiveByte(&CurrentRegValues.Byte5.IntVal, false); | ||||||
| 		TWI_ReceiveByte(&CurrentRTCDate.Byte3.IntVal, true); | 		TWI_ReceiveByte(&CurrentRegValues.Byte6.IntVal, false); | ||||||
|  | 		TWI_ReceiveByte(&CurrentRegValues.Byte7.IntVal, true); | ||||||
| 		 | 		 | ||||||
| 		TWI_StopTransmission(); | 		TWI_StopTransmission(); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Convert stored time value into decimal
 | 	// Convert stored time value into decimal
 | ||||||
| 	TimeDate->Second  = (CurrentRTCTime.Byte1.Fields.TenSec  * 10) + CurrentRTCTime.Byte1.Fields.Sec; | 	TimeDate->Second  = (CurrentRegValues.Byte1.Fields.TenSec  * 10) + CurrentRegValues.Byte1.Fields.Sec; | ||||||
| 	TimeDate->Minute  = (CurrentRTCTime.Byte2.Fields.TenMin  * 10) + CurrentRTCTime.Byte2.Fields.Min; | 	TimeDate->Minute  = (CurrentRegValues.Byte2.Fields.TenMin  * 10) + CurrentRegValues.Byte2.Fields.Min; | ||||||
| 	TimeDate->Hour    = (CurrentRTCTime.Byte3.Fields.TenHour * 10) + CurrentRTCTime.Byte3.Fields.Hour; | 	TimeDate->Hour    = (CurrentRegValues.Byte3.Fields.TenHour * 10) + CurrentRegValues.Byte3.Fields.Hour; | ||||||
| 
 | 
 | ||||||
| 	// Convert stored date value into decimal
 | 	// Convert stored date value into decimal
 | ||||||
| 	TimeDate->Day    = (CurrentRTCDate.Byte1.Fields.TenDay   * 10) + CurrentRTCDate.Byte1.Fields.Day; | 	TimeDate->Day    = (CurrentRegValues.Byte5.Fields.TenDay   * 10) + CurrentRegValues.Byte5.Fields.Day; | ||||||
| 	TimeDate->Month  = (CurrentRTCDate.Byte2.Fields.TenMonth * 10) + CurrentRTCDate.Byte2.Fields.Month; | 	TimeDate->Month  = (CurrentRegValues.Byte6.Fields.TenMonth * 10) + CurrentRegValues.Byte6.Fields.Month; | ||||||
| 	TimeDate->Year   = (CurrentRTCDate.Byte3.Fields.TenYear  * 10) + CurrentRTCDate.Byte3.Fields.Year; | 	TimeDate->Year   = (CurrentRegValues.Byte7.Fields.TenYear  * 10) + CurrentRegValues.Byte7.Fields.Year; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -62,10 +62,18 @@ | |||||||
| 
 | 
 | ||||||
| 				uint8_t IntVal; | 				uint8_t IntVal; | ||||||
| 			} Byte3; | 			} Byte3; | ||||||
| 		} DS1307_TimeRegs_t; |  | ||||||
| 
 | 
 | ||||||
| 		typedef struct | 			union | ||||||
| 			{ | 			{ | ||||||
|  | 				struct | ||||||
|  | 				{ | ||||||
|  | 					unsigned int DayOfWeek       : 3; | ||||||
|  | 					unsigned int Reserved        : 5; | ||||||
|  | 				} Fields; | ||||||
|  | 
 | ||||||
|  | 				uint8_t IntVal; | ||||||
|  | 			} Byte4; | ||||||
|  | 		 | ||||||
| 			union | 			union | ||||||
| 			{ | 			{ | ||||||
| 				struct | 				struct | ||||||
| @ -76,7 +84,7 @@ | |||||||
| 				} Fields; | 				} Fields; | ||||||
| 
 | 
 | ||||||
| 				uint8_t IntVal; | 				uint8_t IntVal; | ||||||
| 			} Byte1; | 			} Byte5; | ||||||
| 
 | 
 | ||||||
| 			union | 			union | ||||||
| 			{ | 			{ | ||||||
| @ -88,7 +96,7 @@ | |||||||
| 				} Fields; | 				} Fields; | ||||||
| 
 | 
 | ||||||
| 				uint8_t IntVal; | 				uint8_t IntVal; | ||||||
| 			} Byte2; | 			} Byte6; | ||||||
| 
 | 
 | ||||||
| 			union | 			union | ||||||
| 			{ | 			{ | ||||||
| @ -99,8 +107,8 @@ | |||||||
| 				} Fields; | 				} Fields; | ||||||
| 
 | 
 | ||||||
| 				uint8_t IntVal; | 				uint8_t IntVal; | ||||||
| 			} Byte3; | 			} Byte7; | ||||||
| 		} DS1307_DateRegs_t; | 		} DS1307_DateTimeRegs_t; | ||||||
| 
 | 
 | ||||||
| 	/* Macros: */ | 	/* Macros: */ | ||||||
| 		#define DS1307_ADDRESS_READ   (0xD0 | TWI_ADDRESS_READ) | 		#define DS1307_ADDRESS_READ   (0xD0 | TWI_ADDRESS_READ) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Dean Camera
						Dean Camera