A NTP Server with LTC Input and Offsetting Options
Find a file
John Rogers fb8088c704 test: add missing milliseconds field to TimeturnerOffset init
Co-authored-by: aider (gemini/gemini-2.5-pro-preview-05-06) <aider@aider.chat>
2025-07-29 11:44:59 +01:00
.github actually you do effectively build them twice 2025-07-21 21:36:58 +01:00
docs docs: add API documentation 2025-07-21 17:00:58 +01:00
firmware Add files via upload 2025-07-22 13:34:13 +01:00
src test: add missing milliseconds field to TimeturnerOffset init 2025-07-29 11:44:59 +01:00
static feat: Allow millisecond offset for timeturner 2025-07-29 11:39:46 +01:00
.gitattributes Add .gitattributes, .gitignore, and README.md. 2024-07-27 20:16:00 +01:00
.gitignore Merge branch 'master' into withmergeresolve 2025-07-21 14:25:00 +01:00
Cargo.toml fix: Enable std feature for log and remove clock history 2025-07-28 23:39:01 +01:00
config.yml feat: add timeturner for time offsets and migrate config to YAML 2025-07-21 19:16:06 +01:00
LICENSE Create LICENSE 2025-07-22 13:40:18 +01:00
README.md Update README.md 2025-07-21 22:38:45 +01:00
setup.sh fix: Conditionally compile systemd features for Linux only 2025-07-21 19:46:16 +01:00
splash.png Rename wallpaper.png to splash.png 2025-06-24 22:29:29 +01:00
test_ltc_serial.py final test_ltc_serial.py 2025-07-07 20:23:28 +01:00
timeturner.py final python script version - moving to RUST 2025-07-08 18:50:12 +01:00

🕰️ NTP Timeturner (alpha)

An LTC-driven NTP server for Raspberry Pi, built with broadcast precision and a hint of magic.

Inspired by the TimeTurner in the Harry Potter series, this project synchronises timecode-locked systems by decoding incoming LTC (Linear Time Code) and broadcasting it as NTP — with precision as Hermione would insist upon.

Created by Chris Frankland-Wright and John Rogers


📦 Hardware Requirements


🛠️ Software Features

  • Reads SMPTE LTC from Audio Interface (3.5mm TRS but adaptable to BNC/XLR)
  • Converts LTC into NTP-synced time
  • Broadcasts time via local NTP server
  • Supports configurable time offsets (hours, minutes, seconds, milliseconds) - NOT AVAILABLE
  • Systemd service support for headless operation

🚀 Installation (to update)

For Rust install you can do

cargo install --git https://github.com/cjfranko/NTP-Timeturner

Clone and run the installer:

wget https://raw.githubusercontent.com/cjfranko/NTP-Timeturner/master/setup.sh
chmod +x setup.sh
./setup.sh

🕰️ Chrony NTP

chronyc sources | Checks Source
chronyc tracking | NTP Tracking
sudo nano /etc/chrony/chrony.conf | Default Chrony Conf File

Add to top:
# Serve the system clock as a reference at stratum10
server 127.127.1.0
allow 127.0.0.0/8
local stratum 10

Add to bottom:
# Allow LAN clients
allow 0.0.0.0/0

# comment out:
pool 2.debian.pool.ntp.org iburst
sourcedir /run/chrony-dhcp