From 9e013f2544fd1f576119bc861e4642353e3e7d04 Mon Sep 17 00:00:00 2001 From: thinkier <26728734+thinkier@users.noreply.github.com> Date: Thu, 15 Dec 2022 15:49:50 +1100 Subject: [PATCH] Fixed crash on cold RTC boot --- enviro/__init__.py | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/enviro/__init__.py b/enviro/__init__.py index 07b1633..3d2163e 100644 --- a/enviro/__init__.py +++ b/enviro/__init__.py @@ -127,12 +127,6 @@ def stop_activity_led(): # intialise the pcf85063a real time clock chip rtc = PCF85063A(i2c) -i2c.writeto_mem(0x51, 0x00, b'\x00') # ensure rtc is running (this should be default?) -rtc.enable_timer_interrupt(False) - -t = rtc.datetime() -# BUG ERRNO 22, EINVAL, when date read from RTC is invalid for the pico's RTC. -RTC().datetime((t[0], t[1], t[2], t[6], t[3], t[4], t[5], 0)) # synch PR2040 rtc too # jazz up that console! toot toot! print(" ___ ___ ___ ___ ___ ___ ") @@ -237,6 +231,19 @@ def sync_clock_from_ntp(): logging.info(" - rtc synched") return True +def init_rtc(): + i2c.writeto_mem(0x51, 0x00, b'\x00') # ensure rtc is running (this should be default?) + rtc.enable_timer_interrupt(False) + + if not is_clock_set(): + sync_clock_from_ntp() + + t = rtc.datetime() + RTC().datetime((t[0], t[1], t[2], t[6], t[3], t[4], t[5], 0)) # synch PR2040 rtc too + + +init_rtc() + # set the state of the warning led (off, on, blinking) def warn_led(state): if state == WARN_LED_OFF: @@ -498,3 +505,4 @@ def sleep(time_override=None): # reset the board machine.reset() +