Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add ESP32SPI support #32

Merged
merged 4 commits into from
May 8, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 6 additions & 10 deletions README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -59,21 +59,17 @@ Usage Example

.. code-block:: python

import adafruit_connection_manager
import adafruit_ntp
import socketpool
import os
import time
import wifi

# Get wifi details and more from a secrets.py file
try:
from secrets import secrets
except ImportError:
print("WiFi secrets are kept in secrets.py, please add them there!")
raise
wifi_ssid = os.getenv("CIRCUITPY_WIFI_SSID")
wifi_password = os.getenv("CIRCUITPY_WIFI_PASSWORD")
wifi.radio.connect(wifi_ssid, wifi_password)

wifi.radio.connect(secrets["ssid"], secrets["password"])

pool = socketpool.SocketPool(wifi.radio)
pool = adafruit_connection_manager.get_radio_socketpool(wifi.radio)
ntp = adafruit_ntp.NTP(pool, tz_offset=0)

while True:
Expand Down
27 changes: 18 additions & 9 deletions adafruit_ntp.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,10 +22,14 @@
import struct
import time

from micropython import const


__version__ = "0.0.0+auto.0"
__repo__ = "https://github.com/adafruit/Adafruit_CircuitPython_NTP.git"

NTP_TO_UNIX_EPOCH = 2208988800 # 1970-01-01 00:00:00
PACKET_SIZE = const(48)


class NTP:
Expand Down Expand Up @@ -53,9 +57,8 @@ def __init__(
:param int socket_timeout: UDP socket timeout, in seconds.
"""
self._pool = socketpool
self._server = server
self._port = port
self._packet = bytearray(48)
self._socket_address = self._pool.getaddrinfo(server, port)[0][4]
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@anecdata good call out on the init. I'll move this to the datetime property:

if self._socket_address is None:
   self._socket_address = self._pool.getaddrinfo(server, port)[0][4]

Will hold on other reviews first

self._packet = bytearray(PACKET_SIZE)
self._tz_offset = int(tz_offset * 60 * 60)
self._socket_timeout = socket_timeout

Expand All @@ -72,20 +75,26 @@ def datetime(self) -> time.struct_time:
is received within socket_timeout seconds"""
if time.monotonic_ns() > self.next_sync:
self._packet[0] = 0b00100011 # Not leap second, NTP version 4, Client mode
for i in range(1, len(self._packet)):
for i in range(1, PACKET_SIZE):
self._packet[i] = 0
with self._pool.socket(self._pool.AF_INET, self._pool.SOCK_DGRAM) as sock:
sock.settimeout(self._socket_timeout)
sock.sendto(self._packet, (self._server, self._port))
sock.recvfrom_into(self._packet)
if hasattr(sock, "sendto"):
sock.sendto(self._packet, self._socket_address)
sock.recvfrom_into(self._packet)
else:
sock.connect(
self._socket_address,
conntype=self._pool._interface.UDP_MODE, # pylint: disable=protected-access
)
sock.send(self._packet)
self._packet[:PACKET_SIZE] = sock.recv(PACKET_SIZE)
# Get the time in the context to minimize the difference between it and receiving
# the packet.
destination = time.monotonic_ns()
poll = struct.unpack_from("!B", self._packet, offset=2)[0]
self.next_sync = destination + (2**poll) * 1_000_000_000
seconds = struct.unpack_from(
"!I", self._packet, offset=len(self._packet) - 8
)[0]
seconds = struct.unpack_from("!I", self._packet, offset=PACKET_SIZE - 8)[0]
self._monotonic_start = (
seconds
+ self._tz_offset
Expand Down
Loading