1
0
Fork 0
wasp-os/wasp/drivers/nrf_rtc.py

84 lines
2.2 KiB
Python
Raw Normal View History

# SPDX-License-Identifier: LGPL-3.0-or-later
# Copyright (C) 2020 Daniel Thompson
""" Real Time Clock based on the nRF-family low power counter """
import machine
import time
#class Stim(object):
# def __init__(self):
# self(0)
#
# def __call__(self, v):
# self.c = v
#
# def counter(self):
# return self.c
class RTC(object):
"""Real Time Clock based on the nRF-family low power counter."""
def __init__(self, counter):
self.counter = counter
if machine.mem32[0x200039c0] == 0x1abe11ed and \
machine.mem32[0x200039dc] == 0x10adab1e:
self.lastcount = self.counter.counter()
self.offset = machine.mem32[0x200039c4]
self._uptime = machine.mem32[0x200039c8] // 125
else:
machine.mem32[0x200039c0] = 0x1abe11ed
machine.mem32[0x200039dc] = 0x10adab1e
self._uptime = 0
self.set_localtime((2020, 3, 1, 3, 0, 0, 0, 0))
def update(self):
newcount = self.counter.counter()
split = newcount - self.lastcount
if split == 0:
return False
if split < 0:
split += (1 << 24)
self.lastcount += split
self.lastcount &= (1 << 24) - 1
self._uptime += split
machine.mem32[0x200039c8] = self._uptime * 125
return True
def set_localtime(self, t):
self.lastcount = self.counter.counter()
if len(t) < 8:
yyyy = t[0]
mm = t[1]
dd = t[2]
HH = t[3]
MM = t[4]
SS = t[5]
t = (yyyy, mm, dd, HH, MM, SS, 0, 0)
lt = time.mktime(t)
self.offset = lt - (self._uptime >> 3)
machine.mem32[0x200039c4] = self.offset
def get_localtime(self):
self.update()
return time.localtime(self.offset + (self._uptime >> 3))
def get_time(self):
localtime = self.get_localtime()
return localtime[3:6]
@property
def uptime(self):
"""Provide the current uptime in seconds."""
return self._uptime // 8
def get_uptime_ms(self):
"""Return the current uptime in milliseconds."""
return self._uptime * 125