This commit is contained in:
PoliEcho 2025-09-13 11:07:46 +02:00
parent d6c8082338
commit 5010544ba9

View File

@ -29,39 +29,62 @@
#define PIN_MOSI 19
extern "C" void sync_system_time(unsigned int sec, unsigned int usec) {
printf("SNTP callback received: %lu\n", (unsigned long)sec);
time_t unix_time = (time_t)sec;
if (sec == 0) {
printf("SNTP: Invalid timestamp received\n");
return;
}
u16_t timezone_offset = 7200;
printf("SNTP callback received: %lu\n", (unsigned long)sec);
// Apply timezone offset for local time
unix_time += timezone_offset;
// Convert NTP timestamp to Unix timestamp
#define NTP_DELTA 2208988800UL
time_t unix_time = (time_t)(sec - NTP_DELTA);
struct tm *time_info = gmtime(&unix_time);
if (time_info == NULL) {
printf("SNTP: Invalid timestamp %lu\n", (unsigned long)sec);
return;
}
u16_t timezone_offset = 7200;
unix_time += timezone_offset;
struct tm *time_info = gmtime(&unix_time);
if (time_info == NULL) {
printf("SNTP: Invalid timestamp %lu\n", (unsigned long)sec);
return;
}
printf("Got SNTP response: %02d/%02d/%04d %02d:%02d:%02d\n",
time_info->tm_mday, time_info->tm_mon + 1, time_info->tm_year + 1900,
time_info->tm_hour, time_info->tm_min, time_info->tm_sec);
datetime_t dt = {
.year = static_cast<int16_t>(time_info->tm_year + 1900),
.month = static_cast<int8_t>(time_info->tm_mon + 1),
.day = static_cast<int8_t>(time_info->tm_mday),
.dotw = static_cast<int8_t>(time_info->tm_wday),
.hour = static_cast<int8_t>(time_info->tm_hour),
.min = static_cast<int8_t>(time_info->tm_min),
.sec = static_cast<int8_t>(time_info->tm_sec)
};
// Set RTC
if (rtc_set_datetime(&dt)) {
printf("SNTP: Time synchronized to %04d-%02d-%02d %02d:%02d:%02d %s\n",
dt.year, dt.month, dt.day, dt.hour, dt.min, dt.sec,
(timezone_offset == 0) ? "UTC" : "Local");
} else {
printf("SNTP: Failed to set RTC\n");
}
datetime_t dt = {.year = static_cast<int16_t>(time_info->tm_year + 1900),
.month = static_cast<int8_t>(time_info->tm_mon + 1),
.day = static_cast<int8_t>(time_info->tm_mday),
.dotw = static_cast<int8_t>(time_info->tm_wday),
.hour = static_cast<int8_t>(time_info->tm_hour),
.min = static_cast<int8_t>(time_info->tm_min),
.sec = static_cast<int8_t>(time_info->tm_sec)};
// Sanity checks
if (dt.year < 2020 || dt.year > 2100 || dt.month < 1 || dt.month > 12 ||
dt.day < 1 || dt.day > 31 || dt.hour > 23 || dt.min > 59 || dt.sec > 59) {
printf("SNTP: Invalid date/time components\n");
return;
}
}
// Set RTC
// Set RTC with error handling
if (rtc_set_datetime(&dt)) {
printf("SNTP: Time set to %04d-%02d-%02d %02d:%02d:%02d %s\n", dt.year,
dt.month, dt.day, dt.hour, dt.min, dt.sec,
printf("SNTP: Time synchronized to %04d-%02d-%02d %02d:%02d:%02d %s\n",
dt.year, dt.month, dt.day, dt.hour, dt.min, dt.sec,
(timezone_offset == 0) ? "UTC" : "Local");
} else {
printf("SNTP: Failed to set RTC\n");