xref: /freebsd/share/man/man4/ds3231.4 (revision b64c5a0ace59af62eff52bfe110a521dc73c937b)
1.\"
2.\" Copyright (c) 2014 Luiz Otavio O Souza <loos@freebsd.org>
3.\" All rights reserved.
4.\"
5.\" Redistribution and use in source and binary forms, with or without
6.\" modification, are permitted provided that the following conditions
7.\" are met:
8.\" 1. Redistributions of source code must retain the above copyright
9.\"    notice, this list of conditions and the following disclaimer.
10.\" 2. Redistributions in binary form must reproduce the above copyright
11.\"    notice, this list of conditions and the following disclaimer in the
12.\"    documentation and/or other materials provided with the distribution.
13.\"
14.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
15.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
16.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
17.\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
18.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
19.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24.\"
25.Dd December 10, 2024
26.Dt DS3231 4
27.Os
28.Sh NAME
29.Nm ds3231
30.Nd Extremely Accurate i2c-integrated real-time clock (RTC)/TCXO/Crystal
31.Sh SYNOPSIS
32.Cd "device iic"
33.Cd "device iicbus"
34.Cd "device ds3231"
35.Sh DESCRIPTION
36The
37.Nm
38is a low-cost, extremely accurate I2C realtime clock (RTC) with an
39integrated temperature-compensated crystal oscillator (TCXO) and crystal.
40.Pp
41The device incorporates a battery input and maintains accurate timekeeping
42when main power to the device is interrupted.
43.Pp
44Access to
45.Nm
46data is made with the
47.Xr sysctl 8
48interface:
49.Bd -literal
50dev.ds3231.0.%desc: Maxim DS3231 RTC
51dev.ds3231.0.%driver: ds3231
52dev.ds3231.0.%location: addr=0xd0
53dev.ds3231.0.%pnpinfo: name=rtc compat=maxim,ds3231
54dev.ds3231.0.%parent: iicbus1
55dev.ds3231.0.temperature: 23.2C
56dev.ds3231.0.temp_conv: 0
57dev.ds3231.0.bbsqw: 0
58dev.ds3231.0.sqw_freq: 8192
59dev.ds3231.0.sqw_mode: interrupt
60dev.ds3231.0.32khz_enable: 1
61.Ed
62.Bl -tag -width ".Va dev.ds3231.%d.temperature"
63.It Va dev.ds3231.%d.temperature
64The read-only value of the current temperature read by the RTC.
65.It Va dev.ds3231.%d.temp_conv
66Start a new temperature conversion.
67When read as 1, a temperature conversion is in progress.
68When read as 0 and then set to 1, a temperature conversion is started.
69The temperature conversion runs automatically on power up and once every 64
70seconds afterward.
71.It Va dev.ds3231.%d.bbsqw
72If set to 1 and
73.Va dev.ds3231.%d.sqw_mode
74is set to square-wave, battery-backed square-wave output is enabled.
75If set to 0, the SQW pin will be set to high impendance when the RTC is
76being powered by battery.
77.It Va dev.ds3231.%d.sqw_freq
78Select the frequency of the SQW pin when the square-wave output is enabled on
79.Va dev.ds3231.%d.sqw_mode .
80It can be set to 1, 1024, 4096, and 8192.
81.It Va dev.ds3231.%d.sqw_mode
82Set the operation mode for the SQW pin.
83It can be set to 'interrupt' (default) or 'square-wave'.
84In interrupt mode, the SQW pin is used to generate interrupts for the RTC
85alarms.
86In square-wave mode, the SQW pin drives a square-wave of
87.Va dev.ds3231.%d.sqw_freq
88frequency.
89.It Va dev.ds3231.%d.32khz_enable
90Enable the 32kHz output.
91.El
92.Pp
93Please check the
94.Nm
95datasheet for more details.
96.Pp
97On a
98.Xr device.hints 5
99based system, such as
100.Li MIPS ,
101these values are configurable for
102.Nm :
103.Bl -tag -width ".Va hint.ds3231.%d.addr"
104.It Va hint.ds3231.%d.at
105The
106.Xr iicbus 4
107that the
108.Nm
109is connected to.
110.It Va hint.ds3231.%d.addr
111The 8-bit i2c address of
112.Nm .
113The default 8-bit address for
114.Nm
115is 0xd0.
116.El
117.Pp
118On a
119.Xr FDT 4
120based system the following properties must be set:
121.Bl -tag -width ".Va compatible"
122.It Va compatible
123Must always be set to "maxim,ds3231".
124.It Va reg
125The 7-bit i2c address of
126.Nm .
127The default 7-bit address for
128.Nm
129is 0x68.
130.El
131.Sh SEE ALSO
132.Xr fdt 4 ,
133.Xr iic 4 ,
134.Xr iicbus 4 ,
135.Xr sysctl 8
136.Sh HISTORY
137The
138.Nm
139driver first appeared in
140.Fx 11.0 .
141.Sh AUTHORS
142.An -nosplit
143The
144.Nm
145driver and this manual page were written by
146.An Luiz Otavio O Souza Aq Mt loos@FreeBSD.org .
147