diff mbox

[U-Boot,16/20] dm: net: rtc: Support using driver model for rtc in sntp

Message ID 1429555051-22335-17-git-send-email-sjg@chromium.org
State Accepted
Delegated to: Simon Glass
Headers show

Commit Message

Simon Glass April 20, 2015, 6:37 p.m. UTC
When setting the date, support driver model RTC also.

Signed-off-by: Simon Glass <sjg@chromium.org>
---

 net/sntp.c | 12 ++++++++++++
 1 file changed, 12 insertions(+)

Comments

Joe Hershberger April 20, 2015, 6:43 p.m. UTC | #1
Hi Simon,

On Mon, Apr 20, 2015 at 1:37 PM, Simon Glass <sjg@chromium.org> wrote:
> When setting the date, support driver model RTC also.
>
> Signed-off-by: Simon Glass <sjg@chromium.org>

Acked-by: Joe Hershberger <joe.hershberger@ni.com>
Simon Glass May 4, 2015, 2:20 p.m. UTC | #2
On 20 April 2015 at 12:43, Joe Hershberger <joe.hershberger@gmail.com> wrote:
> Hi Simon,
>
> On Mon, Apr 20, 2015 at 1:37 PM, Simon Glass <sjg@chromium.org> wrote:
>> When setting the date, support driver model RTC also.
>>
>> Signed-off-by: Simon Glass <sjg@chromium.org>
>
> Acked-by: Joe Hershberger <joe.hershberger@ni.com>

Applied to u-boot-dm.
diff mbox

Patch

diff --git a/net/sntp.c b/net/sntp.c
index d7b9e55..9c8ee34 100644
--- a/net/sntp.c
+++ b/net/sntp.c
@@ -7,6 +7,7 @@ 
 
 #include <common.h>
 #include <command.h>
+#include <dm.h>
 #include <net.h>
 #include <rtc.h>
 
@@ -70,7 +71,18 @@  static void sntp_handler(uchar *pkt, unsigned dest, struct in_addr sip,
 
 	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,