X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=net%2Fsntp.c;h=9c8ee34a4ed7838ced1fa01eda84dcc1b9735bcf;hb=4c2cb115163caa7ff60f5bcb072d2ae20385f508;hp=6422eef72ef2b694177115a7634364b1fd05b34b;hpb=b939689c7b87773c44275a578ffc8674a867e39d;p=u-boot diff --git a/net/sntp.c b/net/sntp.c index 6422eef72e..9c8ee34a4e 100644 --- a/net/sntp.c +++ b/net/sntp.c @@ -7,6 +7,7 @@ #include #include +#include #include #include @@ -68,9 +69,20 @@ static void sntp_handler(uchar *pkt, unsigned dest, struct in_addr sip, */ memcpy(&seconds, &rpktp->transmit_timestamp, sizeof(ulong)); - to_tm(ntohl(seconds) - 2208988800UL + net_ntp_time_offset, &tm); + rtc_to_tm(ntohl(seconds) - 2208988800UL + net_ntp_time_offset, &tm); #if defined(CONFIG_CMD_DATE) +# ifdef CONFIG_DM_RTC + struct udevice *dev; + int ret; + + ret = uclass_get_device(UCLASS_RTC, 0, &dev); + if (ret) + printf("SNTP: cannot find RTC: err=%d\n", ret); + else + dm_rtc_set(dev, &tm); +# else rtc_set(&tm); +# endif #endif printf("Date: %4d-%02d-%02d Time: %2d:%02d:%02d\n", tm.tm_year, tm.tm_mon, tm.tm_mday,