Как стать автором
Обновить

RTC: Обзор микросхемы часов DS3231

Уровень сложностиПростой
Время на прочтение4 мин
Количество просмотров15K

В один тестирующий стенд понадобилось добавить источник автономного точного времени для логов. В коробке с неотсортированными примочками каким-то образом оказался только чип DS3231.

Это чип часов реального времени. Причем необычный RTC. Внутри него есть собственный кварцевый резонатор, а ещё датчик температуры и регистры конфигураций. В спеке написано, что за год ошибка не превысит 2 минуты. Внутри DS3231 всего-навсего 33k транзисторов. Попробуем разобраться, что это за ASIC такой и как с ним работать.

Распиновка корпуса DS3231:

https://docs.google.com/spreadsheets/d/1HU7AiqZ2NBZyWqT0Ura-tjRy0CjZiKvkRfyBWxorrsQ/edit#gid=0

Схема подключения микросхемы:

А это габариты модуля.

3 отверстия по 2 мм
3 отверстия по 2 мм

Программная часть

С точки зрения программиста чип выглядит так.

Чип программируется через 2х проводной синхронный интерфейс I2C. На шине I2C чип обладает адресом 0x68=0b1101000=104. Вот так отображается карта I2C адресов когда к шине подключен DS3231 и еще какая то eeprom.

У любого I2C устройства 2 адреса. На чтение и на запись. Для DS3231 это:

Адрес

Значение

тип

bin

hex

main

0110_1000

0x68

read

1101_0001

0xD1

write

1101_0000

0xD0

Байты передаются старшим битом вперед. У него 19 регистров конфигураций по 8 бит каждый. Всего 152 бита конфигов. Вот полная карта регистров.

Заметьте, что на год выделено всего‑навсего 8 бит. То есть можно отсчитывать только 256 лет, а если учитывать, что под десятки только 4 бита, то получается что 159 лет. Как же закодировать 2023 год? Можно в регистре year (0×06) хранить только десятки и единицы от значения годов. Столетия прибавлять или вычитать как константу.

Часы RTC DS3231 не такие уж и хорошие как написано в спеке. Из коробки при работе на улице летом за две недели работы они ушли в сторону на 20 минут вперед от точного времени из интернета. Если посмотреть осциллографом, что выдаёт пин 32kHz на выходе кварца, то там прямоугольный сигнал не 32 768 Hz а 32 776Hz.

Чтобы окончательно в этом убедиться можно выводить на улицу частоту кварца делёную на четыре. Тут становится совсем явно, что желаемая частота 8192 Hz даже ни разу не появилась.

Это значит, что часы надо подстраивать, варьируя регистр Aging Offset с адресом 10h.

Согласно спеке положительные значения Aging Offset замедляют кварцевый резонатор. Это мне как раз и надо. Попробуем поставить максимальное замедление +127. Частота кварца поделенная на 4 приняла значение из диапазона 8193....8194. Это лучше 8194...8197, но на 4...8 Hz больше нужного значения.

В часах также есть термо‑компенсация. И термо‑компенсация не происходит сама собой. Без термо компенсации часы будут работать совсем плохо и показывать каждый день на 2 минуты больше. Поэтому надо периодически брать регистр Control (0Eh) и выставлять в 1 бит пятый бит CONV.

Плюсы DS3231

1--интерфейс I2C

2--возможность посмотреть реальную частоту кварца

3--есть датчик температуры внутри

4--есть прерывания по совпадению с датой и временем

5--есть подстройка

6--есть термо компенсация

7--автоматическое просчитывание календаря на аппаратном уровне

Недостатки DS3231

1--Не хватает read-only регистра с ID микросхемы

2--Нет возможности заменить кварц так как он внутри микросхемы

3--накапливают ошибку 10 минут в неделю. Но это скорее всего бракованный экземпляр. 

4--Много лишних NC пинов на чипе

Идеи проектов на RTC

  • Часы, будильники, календари.

  • Устройство которое напоминает что‑то сделать.

  • Телематические блоки, источник TimeStamp(ов).

  • Навигационные системы.

Несмотря на то, что сам драйвер часов реального времени это сравнительно простая микросхема однако для работы с часами реального времени надо целая куча разнообразных служебных функций для работы с датой и временем. Это сравнение дат. Вычисление порядкового номера дня в году, преобразование даты в строки разных национальный форматов, синтаксический разбор времени‑даты из строчек, проверка структуры данных времени на валидность, вычисление разницы между двумя датами в секундах и прочее и прочее. При этом для всего для этого необходимы модульные тесты.

Как инициализировать часы реального времени?

Понятно что время надо как-то синхронизировать. Тут есть минимум 4 варианта:

1--Получить точное время из GNSS модуля.

2--задавать по какому‑н интерфейсу, например по UART‑CLI вручную.

3--прошивка может также распарсить время прямо из дирректив препроцессора __TIME__ __DATE__. Таким образом время будет отличатся только на длительность компиляции.

4--Если вы живете в нормальной стране, то скорее всего в вашем городе FM радиостанции передают точное время по бинарному протоколу RDS (Radio Data System). Тогда вы можете синхронизироваться при помощи дешевых микросхем FM тюнеров, например Si4703
https://habr.com/ru/articles/687898/

Вывод

DS3231 не оправдал ожиданий. Спешит на 4...8 Hz или мне просто попался бракованный экземпляр микросхемы. Другой экземпляр DS3231, кстати, оказался заметно стабильнее. Надо поискать что‑то другое. Одно из двух: чип DS3231 реально спешит, либо логический анализатор Saleae Pro бракованный.

Если Вам известны другие варианты проверенных RTC модулей со встроенным батарейным отсеком, то напишите в комментариях.

Словарь

Акроним

Расшифровка

RTC

Real-Time Clock

ASIC

application-specific integrated circuit

RST

Reset

MSB

most significant bit

SQW

square-wave output

AM

After Morning

BCD

binary-coded decimal

PM

post meridiem

INT

Interrupt

I2C

Inter-Integrated Circuit

GPS

Global Positioning System

TCXO

temperature compensated crystal oscillator

VCC

Voltage Collector Collector

DS

Dallas

Links

DS3231: высокоточная микросхема RTC

Часы на DS3231 и AVR-микроконтроллере

DS3231 – подключение часов реального времени

Сайт точного времени https://timesles.com/ru/time/timezones/abbr/utc-317/

Контрольные вопросы:

— Почему часовые кварцы делают с частотой ровно 32 768 Hz?

Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
Вы программировали RTC?
67.78% да61
32.22% нет29
Проголосовали 90 пользователей. Воздержались 4 пользователя.
Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
Вы программировали чип DS3231?
39.56% да36
60.44% нет55
Проголосовал 91 пользователь. Воздержались 3 пользователя.
Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.
Вы программировали другие RTC (не DS3231)?
58.24% да53
41.76% нет38
Проголосовал 91 пользователь. Воздержались 3 пользователя.
Теги:
Хабы:
Всего голосов 19: ↑14 и ↓5+14
Комментарии32

Публикации

Истории

Ближайшие события

28 ноября
Конференция «TechRec: ITHR CAMPUS»
МоскваОнлайн
2 – 18 декабря
Yandex DataLens Festival 2024
МоскваОнлайн
11 – 13 декабря
Международная конференция по AI/ML «AI Journey»
МоскваОнлайн
25 – 26 апреля
IT-конференция Merge Tatarstan 2025
Казань