# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

### **ABSOLUTE MAXIMUM RATINGS**

Voltage Range on Any Pin Relative to GND......-0.3V to +6.0V Operating Temperature Range.....-40°C to +85°C Storage Temperature Range....-55°C to +125°C

| Junction Temperature            | +150°C    |
|---------------------------------|-----------|
| Lead Temperature (soldering, 10 | os)+300°C |
| Soldering Temperature (reflow)  | +260°C    |

Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of the specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

### PACKAGE THERMAL CHARACTERISTICS (Note 1)

SO

Junction-to-Ambient Thermal Resistance (0,1A) ...... 120°C/W

Note 1: Package thermal resistances were obtained using the method described in JEDEC specification JESD51-7, using a four-layer board. For detailed information on package thermal considerations, refer to <u>www.maximintegrated.com/thermal-tutorial</u>.

### **RECOMMENDED OPERATING CONDITIONS**

 $(T_A = -40^{\circ}C \text{ to } +85^{\circ}C, \text{ unless otherwise noted.})$  (Note 2)

| PARAMETER      | SYMBOL           | CONDITIONS | MIN                      | ΤΥΡ | MAX                      | UNITS |
|----------------|------------------|------------|--------------------------|-----|--------------------------|-------|
| Supply Voltage | V <sub>CC</sub>  |            | 2.3                      | 3.3 | 4.5                      | V     |
| Supply Voltage | V <sub>BAT</sub> |            | 2.3                      | 3.0 | 4.5                      | v     |
| Logic 1        | V <sub>IH</sub>  |            | 0.7 x<br>V <sub>CC</sub> |     | V <sub>CC</sub> +<br>0.3 | V     |
| Logic 0        | V <sub>IL</sub>  |            | -0.3                     |     | 0.3 x<br>V <sub>CC</sub> | V     |

### ELECTRICAL CHARACTERISTICS—FREQUENCY AND TIMEKEEPING

(V<sub>CC</sub> or V<sub>BAT</sub> = +3.3V, T<sub>A</sub> = -40°C to +85°C, unless otherwise noted. Typical values are at V<sub>CC</sub> = +3.3V, V<sub>BAT</sub> = +3.0V, and T<sub>A</sub> = +25°C, unless otherwise noted.) (Note 2)

| PARAMETER                                              | SYMBOL             | CONDITIONS                        | MIN | TYP | MAX    | UNITS           |
|--------------------------------------------------------|--------------------|-----------------------------------|-----|-----|--------|-----------------|
| 1Hz Frequency Tolerance                                | $\Delta f/f_{OUT}$ | Measured over $\geq$ 10s interval |     |     | ±5     | ppm             |
| 1Hz Frequency Stability vs. V <sub>CC</sub><br>Voltage | Δf/V               |                                   |     | ±1  |        | ppm/V           |
| Timekeeping Accuracy                                   | tK <sub>A</sub>    |                                   |     |     | ±0.432 | Seconds/<br>Day |
| 32kHz Frequency Tolerance                              | $\Delta f/f_{OUT}$ |                                   |     |     | ±2.5   | %               |

#### DC ELECTRICAL CHARACTERISTICS—GENERAL

(V<sub>CC</sub> = +2.3V to +4.5V, T<sub>A</sub> = -40°C to +85°C, unless otherwise noted. Typical values are at V<sub>CC</sub> = +3.3V, V<sub>BAT</sub> = +3.0V, and T<sub>A</sub> = +25°C, unless otherwise noted.) (Note 2)

| PARAMETER                                             | SYMBOL | CONDITIONS   | MIN | ТҮР | МАХ | UNITS |
|-------------------------------------------------------|--------|--------------|-----|-----|-----|-------|
| Active Supply Current<br>(I <sup>2</sup> C Active)    | ICCA   | (Note 3)     |     | 125 | 250 | μA    |
| Standby Supply Current<br>(I <sup>2</sup> C Inactive) | ICCS   | (Notes 3, 4) |     | 100 | 175 | μΑ    |

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

#### DC ELECTRICAL CHARACTERISTICS—GENERAL (continued)

(V<sub>CC</sub> = +2.3V to +4.5V,  $T_A$  = -40°C to +85°C, unless otherwise noted. Typical values are at V<sub>CC</sub> = +3.3V, V<sub>BAT</sub> = +3.0V, and  $T_A$  = +25°C, unless otherwise noted.) (Note 2)

| PARAMETER                                                  | SYMBOL   | CONDITIONS                             | MIN  | ТҮР   | МАХ  | UNITS |
|------------------------------------------------------------|----------|----------------------------------------|------|-------|------|-------|
| Temperature Conversion Current (I <sup>2</sup> C Inactive) | ICCSCONV |                                        |      | 200   | 350  | μA    |
| Power-Fail Voltage                                         | VPF      |                                        | 2.45 | 2.575 | 2.70 | V     |
| Logic 0 Output<br>(32KHZ, INT/SQW, SDA)                    | VOL      | IOL = 3mA                              |      |       | 0.4  | V     |
| Logic 0 Output (RST)                                       | VOL      | IOL = 1mA                              |      |       | 0.4  | V     |
|                                                            |          | Active supply $> 3.3V$ , IOH = $-1mA$  | 2.0  |       |      |       |
| Logic 1 Output (32KHZ)                                     | VOH      | Active supply > 2.7V, IOH = $-0.75$ mA | 2.0  |       |      | V     |
|                                                            |          | Active supply $> 2.3V$ , IOH = -0.14mA | 2.0  |       |      |       |
| Output Leakage<br>(32KHZ, INT/SQW, SDA)                    | ILO      |                                        | -0.1 |       | +0.1 | μA    |
| Input Leakage (SCL)                                        | ILI      |                                        | -0.1 |       | +0.1 | μA    |
| RST I/O Leakage                                            | IOL      |                                        | -200 |       | +10  | μA    |
| VBAT Leakage                                               | IBATLKG  | $TA = +25^{\circ}C$                    | -100 | 25    | +100 | nA    |
| Temperature Accuracy                                       | TEMPACC  | VCC or VBAT = $+3.3V$                  |      | ±3    |      | °C    |
| Temperature Conversion Time                                | tCONV    |                                        |      | 10    |      | ms    |
| Pushbutton Debounce                                        | PBDB     |                                        |      | 250   |      | ms    |
| Reset Active Time                                          | tRST     |                                        |      | 250   |      | ms    |
| Oscillator Stop Flag (OSF) Delay                           | tOSF     | (Note 5)                               |      | 25    | 100  | ms    |

### DC ELECTRICAL CHARACTERISTICS—VBAT CURRENT CONSUMPTION

 $(V_{CC} = 0V, V_{BAT} = +2.3V \text{ to } +4.5V, T_A = -40^{\circ}\text{C} \text{ to } +85^{\circ}\text{C}, \text{ unless otherwise noted}. Typical values are at V_{CC} = 0V, V_{BAT} = +3.0V, \text{ and } T_A = +25^{\circ}\text{C}, \text{ unless otherwise noted}.)$  (Note 2)

| PARAMETER                                                                       | SYMBOL | CONDITIONS                      | MIN | ТҮР | МАХ | UNITS |
|---------------------------------------------------------------------------------|--------|---------------------------------|-----|-----|-----|-------|
| Active Battery Current<br>(I <sup>2</sup> C Active)                             | IBATA  | (Note 3)                        |     | 25  | 75  | μA    |
| Timekeeping Battery Current<br>(I <sup>2</sup> C Inactive)                      | IBATT  | EN32KHZ = 0, INTCN = 1 (Note 3) |     | 1.8 | 3.0 | μA    |
| Temperature Conversion Current<br>(I <sup>2</sup> C Inactive)                   | IBATTC |                                 |     | 200 | 350 | μA    |
| Data Retention Current<br>(Oscillator Stopped and I <sup>2</sup> C<br>Inactive) | IBATDR | TA = +25°C                      |     |     | 100 | nA    |

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

### AC ELECTRICAL CHARACTERISTICS—POWER SWITCH

 $(T_A = -40^{\circ}C \text{ to } +85^{\circ}C, \text{ unless otherwise noted.})$  (Note 2, Figure 2)

| PARAMETER                          | SYMBOL | CONDITIONS | MIN | ТҮР | МАХ | UNITS |
|------------------------------------|--------|------------|-----|-----|-----|-------|
| VCC Fall Time, VPFMAX to<br>VPFMIN | tVCCF  |            | 300 |     |     | μs    |
| VCC Rise Time, VPFMIN to<br>VPFMAX | tVCCR  |            | 0   |     |     | μs    |
| Recovery at Power-Up               | tREC   | (Note 6)   |     | 250 | 300 | ms    |

#### AC ELECTRICAL CHARACTERISTICS—I<sup>2</sup>C INTERFACE

 $(V_{CC} \text{ or } V_{BAT} = +2.3V \text{ to } +4.5V, T_A = -40^{\circ}\text{C} \text{ to } +85^{\circ}\text{C}, \text{ unless otherwise noted. Typical values are at } V_{CC} = +3.3V, V_{BAT} = +3.0V, \text{ and } T_A = +25^{\circ}\text{C}, \text{ unless otherwise noted.}$  (Notes 2, 7, Figure 1)

| PARAMETER                                       | SYMBOL  | CONDITIONS | MIN           | ТҮР | MAX | UNITS |
|-------------------------------------------------|---------|------------|---------------|-----|-----|-------|
| SCL Clock Frequency                             | fSCL    |            | 0             |     | 400 | kHz   |
| Bus Free Time Between STOP and START Conditions | tBUF    |            | 1.3           |     |     | μs    |
| Hold Time (Repeated) START<br>Condition         | tHD:STA |            | 0.6           |     |     | μs    |
| Low Period of SCL                               | tLOW    |            | 1.3           |     |     | μs    |
| High Period of SCL                              | tHIGH   |            | 0.6           |     |     | μs    |
| Data Hold Time                                  | tHD:DAT |            | 0             |     | 0.9 | μs    |
| Data Set-Up Time                                | tSU:DAT |            | 100           |     |     | ns    |
| START Set-Up Time                               | tSU:STA |            | 0.6           |     |     | μs    |
| SDA and SCL Rise Time                           | tR      | (Note 8)   | 20 +<br>0.1CB |     | 300 | ns    |
| SDA and SCL Fall Time                           | tF      | (Note 8)   | 20 +<br>0.1CB |     | 300 | ns    |
| STOP Set-Up Time                                | tSU:STO |            | 0.6           |     |     | μs    |
| SDA, SCL Input Capacitance                      | CBIN    | (Note 9)   |               | 10  |     | pF    |

**Note 2:** Limits are 100% tested at  $T_A = +25^{\circ}C$  and  $T_A = +85^{\circ}C$ . Limits over the operating temperature range and relevant supply voltage range are guaranteed by design and characterization. Typical values are not guaranteed.

Note 3: Includes the temperature conversion current (averaged).

**Note 4:** Does not include  $\overline{RST}$  leakage if  $V_{CC} < V_{PF}$ .

Note 5: The parameter t<sub>OSF</sub> is the period of time the oscillator must be stopped for the OSF flag to be set.

**Note 6:** The state of  $\overline{RST}$  does not affect the I<sup>2</sup>C interface or RTC functions.

Note 7: Interface timing shown is for fast-mode (400kHz) operation. This device is also backward-compatible with standard mode I<sup>2</sup>C timing.

**Note 8:**  $C_B$  = total capacitance of one bus line in picofarads.

**Note 9:** Guaranteed by design and not 100% production tested.

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

## **Timing Diagrams**



Figure 1. I<sup>2</sup>C Timing



Figure 2. Power Switch Timing



Figure 3. Pushbutton Reset Timing

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM



## **Typical Operating Characteristics**

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM



### **Typical Operating Characteristics (continued)**

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

## **Pin Configuration**



### **Pin Description**

| PIN | NAME             | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | 32KHZ            | 32.768KHZ Output (Push-Pull Output, 50% Duty Cycle). If enabled (EN32KHZ = 1), the 32kHz output is active on V <sub>CC</sub> . If enabled for battery operation (BB32KHZ = 1), the output is also active on V <sub>BAT</sub> . When disabled, the output is forced low. This pin can be left unconnected if not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2   | V <sub>CC</sub>  | DC Power Pin for Primary Power Supply. This pin should be decoupled using a $0.1\mu$ F to $1.0\mu$ F capacitor. Connect to ground if not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3   | ĪNT/<br>SQW      | Active-Low Interrupt or 1Hz Square-Wave Output. This open-drain pin requires an external pullup resistor connected to a supply at 4.5V or less. It can be left open if not used. This multifunction pin is determined by the state of the INTCN bit in the Control register (0Eh). When INTCN is set to logic 0, this pin outputs a 1Hz square wave. When INTCN is set to logic 1, a match between the timekeeping registers and either of the alarm registers activates the INT/SQW pin (if the alarm is enabled). Because the INTCN bit is set to logic 1 when power is first applied, the pin defaults to an interrupt output with alarms disabled.                                                                                                                                                                              |
| 4   | RST              | Active-Low Reset. This pin is an open-drain input/output. It indicates the status of V <sub>CC</sub> relative to the V <sub>PF</sub> specification. As V <sub>CC</sub> falls below V <sub>PF</sub> , the $\overline{\text{RST}}$ pin is driven low. When V <sub>CC</sub> exceeds V <sub>PF</sub> , for t <sub>RST</sub> , the $\overline{\text{RST}}$ pin is pulled high by the internal pullup resistor. The active-low, open-drain output is combined with a debounced pushbutton input function. This pin can be activated by a pushbutton reset request. It has an internal 50k $\Omega$ (R <sub>PU</sub> ) nominal value pullup resistor to V <sub>CC</sub> . No external pullup resistors should be connected. If the oscillator is disabled, t <sub>REC</sub> is bypassed and $\overline{\text{RST}}$ immediately goes high. |
| 5   | GND              | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6   | V <sub>BAT</sub> | Backup Power-Supply Input. When using the device with the $V_{BAT}$ input as the primary power source, this pin should be decoupled using a $0.1\mu$ F to $1.0\mu$ F low-leakage capacitor. When using the device with the $V_{BAT}$ input as the backup power source, the capacitor is not required. If $V_{BAT}$ is not used, connect to ground. The device is UL recognized to ensure against reverse charging when used with a primary lithium battery. Go to www.maximintegrated.com/qa/info/ul for more information.                                                                                                                                                                                                                                                                                                          |
| 7   | SDA              | Serial-Data Input/Output. This pin is the data input/output for the $I^2C$ serial interface. This open-drain pin requires an external pullup resistor. The pullup voltage can be up to 4.5V, regardless of the voltage on $V_{CC}$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8   | SCL              | Serial-Clock Input. This pin is the clock input for the I <sup>2</sup> C serial interface and is used to synchronize data movement on the serial interface. The pullup voltage can be up to 4.5V, regardless of the voltage on $V_{CC}$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

### **Block Diagram**



#### **Detailed Description**

The DS3232M is a serial real-time clock (RTC) driven by an internal, temperature-compensated, microelectromechanical systems (MEMS) resonator. The oscillator provides a stable and accurate reference clock and maintains the RTC to within  $\pm 0.432$  seconds-per-day accuracy from -40°C to +85°C. The RTC is a low-power clock/ calendar with two programmable time-of-day alarms. INT/ SQW provides either an interrupt signal due to alarm conditions or a 1Hz square wave. The clock/calendar provides seconds, minutes, hours, day, date, month, and year information. The date at the end of the month is automatically adjusted for months with fewer than 31 days, including corrections for leap year. The clock operates in either the 24-hour or 12-hour format with an  $\overline{AM}$ /PM indicator. The internal registers are accessible though an I<sup>2</sup>C bus interface. A temperature-compensated voltage reference and comparator circuit monitors the level of V<sub>CC</sub> to detect power failures and to automatically switch to the backup supply when necessary. The RST pin provides an external pushbutton function and acts as an indicator of a power-fail event. Also available are 236 bytes of general-purpose battery-backed SRAM.

### **Operation**

The <u>Block Diagram</u> shows the device's main elements. Each of the major blocks is described separately in the following sections.

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM



Figure 4. Single Supply (V<sub>CC</sub> Only)



Figure 5. Single Supply (V<sub>BAT</sub> Only)



Figure 6. Dual Power Supply

#### **High-Accuracy Time Base**

The temperature sensor, oscillator, and digital adjustment controller logic form the highly accurate time base. The controller reads the output of the on-board temperature sensor and adjusts the final 1Hz output to maintain the required accuracy. The device is trimmed at the factory to maintain a tight accuracy over the operating temperature range. When the device is powered by V<sub>CC</sub>, the adjustment occurs once a second. When the device is powered by V<sub>BAT</sub>, the adjustment occurs once every 10s to conserve power. Adjusting the 1Hz time base less often does not affect the device's long-term timekeeping accuracy. The device also contains an Aging Offset register that allows a constant offset (positive or negative) to be added to the factory-trimmed adjustment value.

#### **Power-Supply Configurations**

The DS3232M can be configured to operate on a single power supply (using either  $V_{CC}$  or  $V_{BAT}$ ) or in a dualsupply configuration, which provides a backup supply source to keep the timekeeping circuits alive during absence of primary system power.

<u>Figure 4</u> illustrates a single-supply configuration using  $V_{CC}$  only, with the  $V_{BAT}$  input grounded. When  $V_{CC} < V_{PF}$ , the RST output is asserted (active low). Temperature conversions are executed once per second.

Figure 5 illustrates a single-supply configuration using  $V_{BAT}$  only, with the  $V_{CC}$  input grounded. The RST output is disabled and is held at ground through the connection of the internal pullup resistor. Temperature conversions are executed once every 10s.

Figure 6 illustrates a dual-supply configuration, using the V<sub>CC</sub> supply for normal system operation and the V<sub>BAT</sub> supply for backup power. In this configuration, the power-selection function is provided by a temperaturecompensated voltage reference and a comparator circuit that monitors the V<sub>CC</sub> level. When V<sub>CC</sub> is greater than V<sub>PF</sub>, the device is powered by V<sub>CC</sub>. When V<sub>CC</sub> is less than V<sub>PF</sub> but greater than V<sub>BAT</sub>, the device is powered by V<sub>CC</sub>. If V<sub>CC</sub> is less than V<sub>PF</sub> and is less than V<sub>BAT</sub>, the device is powered by V<sub>BAT</sub> (see Table 1).

When  $V_{CC} < V_{PF}$ , the  $\overline{RST}$  output is asserted (active low). When  $V_{CC}$  is the presently selected power source, temperature conversions are executed once per second. When  $V_{BAT}$  is the presently selected power source, temperature conversions are executed once every 10s.

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

| CONFIGURATION             | CONDITION                    | I/O AC             | TIVE              | I/O INA            | RST   |                 |  |                 |
|---------------------------|------------------------------|--------------------|-------------------|--------------------|-------|-----------------|--|-----------------|
| V <sub>CC</sub> Only      | $V_{CC} > V_{PF}$            |                    |                   |                    |       |                 |  | Inactive (High) |
| (Figure 4)                | $V_{CC} < V_{PF}$            | ICC                | CA                | IC                 | ICCS  |                 |  |                 |
| V <sub>BAT</sub> Only     | $\overline{\text{EOSC}} = 0$ |                    |                   | I <sub>BA</sub>    | ATT   | Disabled (Low)  |  |                 |
| (Figure 5)                | $\overline{\text{EOSC}} = 1$ | I IBA              | IA                | IBATDR             |       | Disabled (LOW)  |  |                 |
|                           | $V_{CC} > V_{PF}$            | Ico                | CA                | Iccs               |       | Inactive (High) |  |                 |
| Dual Supply<br>(Figure 6) |                              | $V_{CC} > V_{BAT}$ | I <sub>CCA</sub>  | $V_{CC} > V_{BAT}$ | Iccs  | Active (Low)    |  |                 |
|                           | $V_{CC} < V_{PF}$            | $V_{CC} < V_{BAT}$ | I <sub>BATA</sub> | $V_{CC} < V_{BAT}$ | IBATT |                 |  |                 |

#### **Table 1. Power Control**

To preserve the battery, the first time V<sub>BAT</sub> is applied to the device the oscillator does not start up until V<sub>CC</sub> exceeds V<sub>PF</sub> or until a valid I<sup>2</sup>C address is written to the device. Typical oscillator startup time is less than 1s. Approximately 2s after V<sub>CC</sub> is applied, or a valid I<sup>2</sup>C address is written, the device makes a temperature measurement and applies the calculated correction to the oscillator. Once the oscillator is running, it continues to run as long as a valid power source is available (V<sub>CC</sub> or V<sub>BAT</sub>), and the device continues to measure the temperature and correct the oscillator frequency. On the first application of V<sub>CC</sub> power, or (if V<sub>BAT</sub> powered) when a valid I<sup>2</sup>C address is written to the device, the time and date registers are reset to 01/01/00 01 00:00:00 (DD/MM/ YY DOW HH:MM:SS).

 $\label{eq:BAT} \begin{array}{l} \textit{PBAT} \textit{Operation} \\ \textit{There are several modes of operation that affect the amount of V_{BAT} current that is drawn. While the device is powered by V_{BAT} and the serial interface is active, the active battery current I_{BATA} is drawn. When the serial interface is inactive, the timekeeping current I_{BATT} (which includes the averaged temperature-conversion current I_{BATTC}) is used. The temperature-conversion current I_{BATTC} is specified since the system must be able to support the periodic higher current pulse and still maintain a valid voltage level. The data-retention current I_{BATDR} is the current drawn by the device when$ 

the oscillator is stopped ( $\overline{\text{EOSC}}$  = 1). This mode can be used to minimize battery requirements for periods when maintaining time and date information is not necessary, e.g., while the end system is waiting to be shipped to a customer.

#### **Pushbutton Reset Function**

The device provides for a pushbutton switch to be connected to the RST input/output pin. When the device is not in a reset cycle, it continuously monitors RST for a low-going edge. If an edge transition is detected, the device debounces the switch by pulling RST low. After the internal timer has expired (PBDB), the device continues to monitor the RST line. If the line is still low, the device continuously monitors the line looking for a rising edge. Upon detecting release, the device forces RST low and holds it low for t<sub>BST</sub>. RST is also used to indicate a power-fail condition. When  $V_{CC}$  is lower than  $V_{PF}$ , an internal power-fail signal is generated, which forces RST low. When V<sub>CC</sub> returns to a level above V<sub>PF</sub>, RST is held low for approximately 250ms (t<sub>BFC</sub>) to allow the power supply to stabilize. If the oscillator is not running when  $V_{CC}$  is applied,  $t_{RFC}$  is bypassed and  $\overline{RST}$  immediately goes high. Assertion of the RST output, whether by pushbutton or power-fail detection, does not affect the device's internal operation. RST output operation and pushbutton monitoring are only available if V<sub>CC</sub> power is available.

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

#### **Real-Time Clock (RTC)**

With the 1Hz source from the temperature-compensated oscillator, the RTC provides seconds, minutes, hours, day, date, month, and year information. The date at the end of the month is automatically adjusted for months with fewer than 31 days, including corrections for leap year. The clock operates in either the 24-hour or the 12-hour format with an AM/PM indicator. The clock provides two programmable time-of-day alarms. INT/SQW can be enabled to generate either an interrupt due to an alarm condition or a 1Hz square wave. This selection is controlled by the INTCN bit in the Control register.

#### **I<sup>2</sup>C** Interface

The I<sup>2</sup>C interface is accessible whenever either  $V_{CC}$  or V<sub>BAT</sub> is at a valid level. If a microcontroller connected to the device resets because of a loss of  $V_{CC}$  or other event, it is possible that the microcontroller and device's I<sup>2</sup>C communications could become unsynchronized, e.g., the microcontroller resets while reading data from the device. When the microcontroller resets, the device's I<sup>2</sup>C interface can be placed into a known state by toggling SCL until SDA is observed to be at a high level. At that point the microcontroller should pull SDA low while SCL is high, generating a START condition.

#### SRAM

The DS3232M provides 236 bytes of general-purpose battery-backed read/write memory. The I<sup>2</sup>C address ranges from 14h-FFh. The SRAM can be written or read whenever  $V_{CC}$  or  $V_{BAT}$  is greater than the minimum operating voltage.

Address Map Table 2 shows the address map for the device's timekeeping registers. During a multibyte access, when the address pointer reaches the end of the register space (12h), it wraps around to location 00h. On an I<sup>2</sup>C START or address pointer incrementing to location 00h, the current time is transferred to a second set of registers. The time information is read from these secondary registers, while the clock can continue to run. This eliminates the need to reread the registers in case the main registers update during a read.

#### **Clock and Calendar**

The time and calendar information is obtained by reading the appropriate register bytes. Table 2 shows the RTC registers. The time and calendar data are set or initialized by writing the appropriate register bytes. The contents of the time and calendar registers are in the binary-coded decimal (BCD) format. The device can be run in either 12-hour or 24-hour mode. Bit 6 of the Hours register is defined as the 12-hour or 24-hour mode select bit. When high, the 12-hour mode is selected. In the 12-hour mode, bit 5 is the AM/PM bit with logic-high being PM. In the 24-hour mode, bit 5 is the 20-hour bit (20-23 hours). The century bit (bit 7 of the Month register) is togaled when the Years register overflows from 99 to 00. The day-of-week register increments at midnight. Values that correspond to the day of week are user-defined but must be sequential (i.e., if 1 equals Sunday, then 2 equals Monday, and so on). Illogical time and date entries result in undefined operation. When reading or writing the time and date registers, secondary buffers are used to prevent errors when the internal registers update. When reading the time and date registers, the secondary buffers are synchronized to the internal registers on any I<sup>2</sup>C START and when the register pointer rolls over to zero. The time information is read from these secondary registers, while the clock continues to run. This eliminates the need to reread the registers in case the main registers update during a read. The countdown chain is reset whenever the seconds register is written. Write transfers occur on the acknowledge from the device. Once the countdown chain is reset, to avoid rollover issues the remaining time and date registers must be written within 1s.

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

| ADDRESS | BIT 7<br>MSB | BIT 6      | BIT 5                | BIT 4       | BIT 3   | BIT 2   | BIT 1         | BIT 0<br>LSB             | FUNCTION           | RANGE                    |
|---------|--------------|------------|----------------------|-------------|---------|---------|---------------|--------------------------|--------------------|--------------------------|
| 00h     | 0            | 10 Seconds |                      |             |         | Secor   | ids           |                          | Seconds            | 00–59                    |
| 01h     | 0            | 1          | 0 Minutes            |             |         | Minutes |               |                          | Minutes            | 00–59                    |
| 02h     | 0            | 12/24      | AM/PM<br>20<br>Hours | 10<br>Hours |         | Hou     | r             |                          | Hours              | 1–12 +<br>AM/PM<br>00–23 |
| 03h     | 0            | 0          | 0                    | 0           | 0       |         | Day           |                          | Day                | 1–7                      |
| 04h     | 0            | 0          | 10 E                 | Date        |         | Date    | e             |                          | Date               | 01–31                    |
| 05h     | Century      | 0          | 0                    | 10<br>Month |         | Mont    | th            |                          | Month/Century      | 01–12 +<br>Century       |
| 06h     |              | 10 Ye      | ear                  |             |         | Yea     | r             |                          | Year               | 00–99                    |
| 07h     | A1M1         | 10         | 0 Seconds            |             |         | Secor   | ıds           |                          | Alarm 1<br>Seconds | 00–59                    |
| 08h     | A1M2         | 1          | 0 Minutes            |             |         | Minutes |               | Alarm 1<br>Minutes       | 00–59              |                          |
| 09h     | A1M3         | 12/24      | AM/PM<br>20<br>Hours | 10<br>Hours | Hour    |         | Alarm 1 Hours | 1–12 +<br>AM/PM<br>00–23 |                    |                          |
| 0.41    |              |            | 10 5                 |             |         | Day     | Day           |                          | Alarm 1 Day        | 1–7                      |
| 0Ah     | A1M4         | DY/DT      | 10 E                 | Date        |         | Date    | Э             |                          | Alarm 1 Date       | 1–31                     |
| 0Bh     | A2M2         | 1          | 0 Minutes            |             | Minutes |         |               | Alarm 2<br>Minutes       | 00–59              |                          |
| 0Ch     | A2M3         | 12/24      | AM/PM<br>20<br>Hours | 10<br>Hours |         | Hou     | r             |                          | Alarm 2 Hours      | 1–12 +<br>AM/PM<br>00–23 |
| 0Dh     | A2M4         | DY/DT      | 10 E                 | )ato        |         | Day     | /             |                          | Alarm 2 Day        | 1–7                      |
|         |              |            |                      |             |         | Date    |               |                          | Alarm 2 Date       | 1–31                     |
| 0Eh     | EOSC         | BBSQW      | CONV                 | NA          | NA      | INTCN   | A2IE          | A1IE                     | Control            | —                        |
| 0Fh     | OSF          | BB32KHZ    | 0                    | 0           | EN32KHZ | BSY     | A2F           | A1F                      | Status             |                          |
| 10h     | SIGN         | DATA       | DATA                 | DATA        | DATA    | DATA    | DATA          | DATA                     | Aging Offset       | —                        |
| 11h     | SIGN         | DATA       | DATA                 | DATA        | DATA    | DATA    | DATA          | DATA                     | Temperature<br>MSB |                          |
| 12h     | DATA         | DATA       | 0                    | 0           | 0       | 0       | 0             | 0                        | Temperature<br>LSB | _                        |
| 13h     | SWRST        | 0          | 0                    | 0           | 0       | 0       | 0             | 0                        | Test               |                          |
| 14h–FFh | Х            | Х          | Х                    | Х           | Х       | Х       | Х             | Х                        | SRAM               | 00h–FFh                  |

## Table 2. Timekeeping Registers

*Note:* Unless otherwise specified, the registers' state is not defined when power is first applied.

## ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

#### Alarms

The device contains two time-of-day/date alarms. Alarm 1 can be set by writing to registers 07h–0Ah. Alarm 2 can be set by writing to registers 0Bh–0Dh. See <u>Table 2</u>. The alarms can be programmed (by the alarm enable and INTCN bits in the Control register) to activate the INT/SQW output on an alarm match condition. Bit 7 of each of the time-of-day/date alarm registers are mask bits (<u>Table 2</u>). When all the mask bits for each alarm are logic 0, an alarm only occurs when the values in the timekeeping registers match the corresponding values stored in the time-of-day/date alarm registers. The alarms can also be programmed to repeat every second, minute, hour, day, or date. <u>Table 3</u> shows the possible settings. Configurations not listed in the table result in illogical operation. The DY/DT bits (bit 6 of the alarm day/date registers) control whether the alarm value stored in bits 0–5 of that register reflects the day of the week or the date of the month. If DY/DT is written to logic 0, the alarm is the result of a match with date of the month. If DY/DT is written to logic 1, the alarm is the result of a match with date of the result of a match with date of the corresponding alarm flag A1F or A2F bit is set to logic 1. If the corresponding alarm flag A1F or A2F bit is set to logic 1. If the corresponding alarm interrupt enable A1IE or A2IE bit is also set to logic 1, the alarm condition activates the INT/SQW signal if the INTCN bit is set to logic 1. The match is tested on the once-per-second update of the time and date registers.

#### **Table 3. Alarm Mask Bits**

|       | ALARM 1 REGISTER MASK BITS (BIT 7) |      |      |      |                                                    |
|-------|------------------------------------|------|------|------|----------------------------------------------------|
| DY/DT | A1M4                               | A1M3 | A1M2 | A1M1 | ALARM RATE                                         |
| Х     | 1                                  | 1    | 1    | 1    | Alarm once a second                                |
| Х     | 1                                  | 1    | 1    | 0    | Alarm when seconds match                           |
| Х     | 1                                  | 1    | 0    | 0    | Alarm when minutes and seconds match               |
| Х     | 1                                  | 0    | 0    | 0    | Alarm when hours, minutes, and seconds match       |
| 0     | 0                                  | 0    | 0    | 0    | Alarm when date, hours, minutes, and seconds match |
| 1     | 0                                  | 0    | 0    | 0    | Alarm when day, hours, minutes, and seconds match  |

|       | ALARM 2 REGISTER MASK BITS (BIT 7)   A2M4 A2M3 A2M2 |   | BITS (BIT 7) | ALARM BATE                                         |  |
|-------|-----------------------------------------------------|---|--------------|----------------------------------------------------|--|
| DY/DI |                                                     |   | A2M2         |                                                    |  |
| Х     | 1                                                   | 1 | 1            | Alarm once per minute (00 seconds of every minute) |  |
| Х     | 1                                                   | 1 | 0            | Alarm when minutes match                           |  |
| Х     | 1                                                   | 0 | 0            | Alarm when hours and minutes match                 |  |
| 0     | 0                                                   | 0 | 0            | Alarm when date, hours, and minutes match          |  |
| 1     | 0                                                   | 0 | 0            | Alarm when day, hours, and minutes match           |  |

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

## **Control Register (0Eh)**

| BIT 7    | BIT 6                                                                          | BIT 5                                                                             | BIT 4                                                              | BIT 3                                                                  | BIT 2                                                                         | BIT 1                                                                                                                   | BIT 0                                                            |
|----------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| EOSC     | BBSQW                                                                          | CONV                                                                              | NA                                                                 | NA                                                                     | INTCN                                                                         | A2IE                                                                                                                    | A1IE                                                             |
| 0        | 0                                                                              | 0                                                                                 | 1                                                                  | 1                                                                      | 1                                                                             | 0                                                                                                                       | 0                                                                |
|          |                                                                                |                                                                                   |                                                                    |                                                                        |                                                                               | •                                                                                                                       |                                                                  |
| BIT 7    | stopped when t<br>device is power                                              | he device switch                                                                  | es to V <sub>BAT</sub> . Th<br>oscillator is alw                   | nis bit is clear (                                                     | logic 0) when po                                                              | et to logic 1, the<br>ower is first applie<br>of the $\overline{\text{EOSC}}$ bit.                                      | ed. When the                                                     |
| BIT 6    | enables the 1Hz                                                                |                                                                                   | Vhen BBSQW                                                         | is logic 0, INT/                                                       | SQW goes high i                                                               | N = 0 and V <sub>CC</sub> <<br>mpedance when                                                                            |                                                                  |
| BIT 5    | into digital code<br>device cannot to<br>user-initiated te<br>from the time it | e and execute the<br>be forced to exec<br>mperature conve<br>is written until the | e temperature<br>cute the tempe<br>ersion does no<br>e temperature | compensate a<br>erature-compen<br>t affect the inte<br>conversion is c | lgorithm to upda<br>sate algorithm fa<br>rnal update cycl<br>completed, at wh | or to convert the<br>te the oscillator's<br>aster than once p<br>e. The CONV bit<br>ich time both CC<br>ted conversion. | accuracy. The<br>er second. A<br>remains at a 1<br>NV and BSY go |
| BITS 4:3 | NA: Not applica                                                                | able. These bits I                                                                | nave no affect                                                     | on the device                                                          | and can be set t                                                              | o either 0 or 1.                                                                                                        |                                                                  |
| BIT 2    | 1Hz square way<br>ing registers an                                             | ve is output on $\overline{IN}$<br>d either of the al-<br>alarm flag is alwa      | IT/SQW. Wher arm registers a                                       | the INTCN bit activates the $\overline{IN}$                            | is set to logic 1,<br>IT/SQW output (i                                        | ne INTCN bit is so<br>a match betwee<br>f the alarm is also<br>it. The INTCN bit                                        | n the timekeep-<br>o enabled). The                               |
| BIT 1    | ister to assert IN                                                             | ਗ਼<br>√T/SQW (when IN                                                             | NTCN = 1). Wh                                                      | nen the A2IE bi                                                        | t is set to logic 0                                                           | 2 flag (A2F) bit i<br>or INTCN is set<br>when power is fir                                                              | to logic 0, the                                                  |
| BIT 0    | ister to assert IN                                                             | NT/SQW (when IN                                                                   | MTCN = 1). Wh                                                      | nen the A1IE bi                                                        | t is set to logic 0                                                           | 1 flag (A1F) bit i<br>or INTCN is set<br>when power is fir                                                              | to logic 0, the                                                  |



# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

Figure 7. CONV Control Bit and BSY Status Bit Operation

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

## **Status Register (0Fh)**

| BIT 7    | BIT 6                                                                                                                                                                                                                                                                                                                                             | BIT 5                                                                                                                   | BIT 4                                                                                                    | BIT 3                                                                                             | BIT 2                                   | BIT 1                                  | BIT 0         |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|-----------------------------------------|----------------------------------------|---------------|
| OSF      | BB32KHZ                                                                                                                                                                                                                                                                                                                                           | 0                                                                                                                       | 0                                                                                                        | EN32KHZ                                                                                           | BSY                                     | A2F                                    | A1F           |
| 1        | 1                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                       | 0                                                                                                        | 1                                                                                                 | Х                                       | Х                                      | Х             |
| BIT 7    | some period ar<br>that the oscillate<br>conditions that<br>1) The first time<br>2) The voltages<br>3) The EOSC b                                                                                                                                                                                                                                  | Ind could be used<br>or stops. This bin<br>can cause the C<br>power is applie<br>present on both<br>it is turned off in | d to judge the va<br>t remains at logic<br>DSF bit to be set:<br>d.<br>NVCC and VBAT a<br>battery-backed | licates that the os<br>lidity of the timeka<br>are insufficient to<br>mode.<br>e, leakage, etc.). | eeping data. This<br>logic 0. The follo | s bit is set to log<br>owing are examp | ic 1 any time |
| BIT 6    | ered from VBAT                                                                                                                                                                                                                                                                                                                                    | (provided the 3                                                                                                         |                                                                                                          | KHZ). This bit ena<br>nabled with the E<br>AT.                                                    |                                         |                                        |               |
| BITS 5:4 | Unused (0). The                                                                                                                                                                                                                                                                                                                                   | ese bits have no                                                                                                        | meaning and ar                                                                                           | e fixed at 0 when                                                                                 | read.                                   |                                        |               |
| BIT 3    | the 32KHZ outp                                                                                                                                                                                                                                                                                                                                    | out is high imped                                                                                                       | dance. On initial p                                                                                      | enables and disat<br>cower-up, this bit<br>re if the oscillator                                   | is set to a logic                       |                                        |               |
| BIT 2    | when the conve                                                                                                                                                                                                                                                                                                                                    | ersion signal to t                                                                                                      | he temperature s                                                                                         | vexecuting tempo<br>ensor is asserted<br>Block Diagram fo                                         | l, and then it is c                     |                                        |               |
| BIT 1    | A2F: Alarm 2 flag. A logic 1 in the alarm 2 flag bit indicates that the time matched the alarm 2 registers. If the A2IE bit is logic 1 and the INTCN bit is set to logic 1, INT/SQW is also asserted. A2F is cleared when written to logic 0. This bit can only be written to logic 0. Attempting to write to logic 1 leaves the value unchanged. |                                                                                                                         |                                                                                                          |                                                                                                   |                                         |                                        |               |
| BIT 0    | A1F: Alarm 1 flag. A logic 1 in the alarm 1 flag bit indicates that the time matched the alarm 1 registers. If the A1IE bit is logic 1 and the INTCN bit is set to logic 1, INT/SQW is also asserted. A1F is cleared when written to logic 0. This bit can only be written to logic 0. Attempting to write to logic 1 leaves the value unchanged. |                                                                                                                         |                                                                                                          |                                                                                                   |                                         |                                        |               |

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

| BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| SIGN  | DATA  |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

## Aging Offset Register (10h)

The Aging Offset register takes a user-provided value to add to or subtract from the factory-trimmed value that adjusts the accuracy of the time base. Use of the Aging Offset register is not needed to achieve the accuracy as defined in the *Electrical Characteristics* tables.

The Aging Offset code is encoded in two's complement, with bit 7 representing the SIGN bit. One LSB typically represents a 0.12ppm change in frequency. The change in ppm per LSB is the same over the operating temperature range. Positive offsets slow the time base and negative offsets quicken the time base.

### **Temperature Registers (11h–12h)**

#### Temperature Register (Upper Byte = 11h)

| BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| SIGN  | DATA  |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### Temperature Register (Lower Byte = 12h)

| BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| DATA  | DATA  | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Temperature is represented as a 10-bit code with a resolution of 0.25°C and is accessible at location 11h and 12h. The temperature is encoded in two's complement format. The upper 8 bits, the integer portion, are at location 11h and the lower 2 bits, the fractional portion, are at location 12h. For example, 00011001 01b = +25.25°C. Upon power reset, the registers are set to a default temperature of 0°C and the controller starts a temperature conversion. The temperature is read upon initial application of V<sub>CC</sub> or I<sup>2</sup>C access on V<sub>BAT</sub> and once every second afterwards with V<sub>CC</sub> power or once every 10s with V<sub>BAT</sub> power. The Temperature registers are also updated after each user-initiated conversion and are read only.

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

## **Test Register (13h)**

|       | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0                                 |
|-------|-------|-------|-------|-------|-------|-------|-------|---------------------------------------|
| NAME: | SWRST | 0     | 0     | 0     | 0     | 0     | 0     | 0                                     |
| POR*: | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0                                     |
|       |       |       |       |       |       |       |       | · · · · · · · · · · · · · · · · · · · |

\*POR is defined as the first application of power to the device, either  $V_{BAT}$  or  $V_{CC}$ .

This register is used for factory test. Bits 6:0 are locked and always read as zeros. Writing to bit locations 6:0 has no affect on the device. If the SWRST bit is set to Logic 1, the device immediately resets all internal logic and registers (except the SRAM) to their factory-default POR state.

The device reset occurs during the normal acknowledge time slot following the receipt of the data byte carrying that SWRST instruction; a NACK occurs due to the resetting action (see Figure 8). The I/O master should terminate the I/O string with a normal STOP instruction (on the 28th SCL clock). The SWRST bit is automatically cleared to logic 0.



Figure 8. Software Reset I/O Execution

### SRAM (14h-FFh)

|       | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| NAME: | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |
| POR*: | Х     | Х     | Х     | Х     | Х     | Х     | Х     | Х     |

\*POR is defined as the first application of power to the device, either V<sub>BAT</sub> or V<sub>CC</sub>.

## ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

### **I<sup>2</sup>C Serial Port Operation**

#### I<sup>2</sup>C Slave Address

The device's slave address byte is D0h. The first byte sent to the device includes the device identifier, device address, and the  $R/\overline{W}$  bit (Figure 9). The device address sent by the I<sup>2</sup>C master must match the address assigned to the device.

#### I<sup>2</sup>C Definitions

The following terminology is commonly used to describe  $I^2C$  data transfers.

**Master Device:** The master device controls the slave devices on the bus. The master device generates SCL clock pulses and START and STOP conditions.

**Slave Devices:** Slave devices send and receive data at the master's request.

**Bus Idle or Not Busy:** Time between STOP and START conditions when both SDA and SCL are inactive and in their logic-high states. When the bus is idle, it often initiates a low-power mode for slave devices.

**START Condition:** A START condition is generated by the master to initiate a new data transfer with a slave. Transitioning SDA from high to low while SCL remains high generates a START condition. See Figure 1 for applicable timing.

**STOP Condition:** A STOP condition is generated by the master to end a data transfer with a slave. Transitioning SDA from low to high while SCL remains high generates a STOP condition. See <u>Figure 1</u> for applicable timing.

**Repeated START Condition:** The master can use a repeated START condition at the end of one data transfer to indicate that it immediately initiates a new data transfer following the current one. Repeated STARTs are commonly used during read operations to identify a specific memory address to begin a data



Figure 9. I<sup>2</sup>C Slave Address Byte

Maxim Integrated

transfer. A repeated START condition is issued identically to a normal START condition. See Figure 1 for applicable timing.

**Bit Write:** Transitions of SDA must occur during the low state of SCL. The data on SDA must remain valid and unchanged during the entire high pulse of SCL plus the setup and hold time requirements (see Figure 1). Data is shifted into the device during the rising edge of the SCL.

**Bit Read:** At the end of a write operation, the master must release the SDA bus line for the proper amount of setup time (see Figure 1) before the next rising edge of SCL during a bit read. The device shifts out each bit of data on SDA at the falling edge of the previous SCL pulse and the data bit is valid at the rising edge of the current SCL pulse. Remember that the master generates all SCL clock pulses including when it is reading bits from the slave.

Acknowledge (ACK and NACK): An acknowledge (ACK) or not acknowledge (NACK) is always the ninth bit transmitted during a byte transfer. The device receiving data (the master during a read or the slave during a write operation) performs an ACK by transmitting a 0 during the ninth bit. A device performs a NACK by transmitting a 1 during the ninth bit. Timing for the ACK and NACK is identical to all other bit writes. An ACK is the acknowledgment that the device is properly receiving data. A NACK is used to terminate a read sequence or as an indication that the device is not receiving data.

**Byte Write:** A byte write consists of 8 bits of information transferred from the master to the slave (most significant bit first) plus a 1-bit acknowledgment from the slave to the master. The 8 bits transmitted by the master are done according to the bit write definition and the acknowledgment is read using the bit read definition.

**Byte Read:** A byte read is an 8-bit information transfer from the slave to the master plus a 1-bit ACK or NACK from the master to the slave. The 8 bits of information that are transferred (most significant bit first) from the slave to the master are read by the master using the bit read definition, and the master transmits an ACK using the bit write definition to receive additional data bytes. The master must NACK the last byte read to terminate communication so the slave returns control of SDA to the master.

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

**Slave Address Byte:** Each slave on the I<sup>2</sup>C bus responds to a slave address byte sent immediately following a START condition. The slave address byte contains the slave address in the most significant 7 bits and the R/W bit in the least significant bit. The device's slave address is D0h and cannot be modified by the user. When the R/W bit is 0 (such as in D0h), the master is indicating it writes data to the slave. If R/W = 1 (D1h in this case), the master is indicating it wants to read from the slave. If an incorrect slave address is written, the device assumes the master is communicating with another I<sup>2</sup>C device and ignore the communication until the next START condition is sent.

**Memory Address:** During an I<sup>2</sup>C write operation, the master must transmit a memory address to identify the memory location where the slave is to store the data. The memory address is always the second byte transmitted during a write operation following the slave address byte.

#### **I<sup>2</sup>C** Communication

See Figure 10 for an I<sup>2</sup>C communication example.

Writing a Single Byte to a Slave: The master must generate a START condition, write the slave address byte ( $R/\overline{W} = 0$ ), write the memory address, write the byte of data, and generate a STOP condition. Remember the master must read the slave's acknowledgment during all byte write operations.

Writing Multiple Bytes to a Slave: To write multiple bytes to a slave, the master generates a START condition, writes the slave address byte ( $R\overline{W} = 0$ ), writes the starting memory address, writes multiple data bytes, and generates a STOP condition.

**Reading a Single Byte from a Slave:** Unlike the write operation that uses the specified memory address byte to define where the data is to be written, the read operation occurs at the present value of the memory address counter. To read a single byte from the slave, the master generates a START condition, writes the



Figure 10. I<sup>2</sup>C Transactions

## ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

slave address byte with  $R/\overline{W} = 1$ , reads the data byte with a NACK to indicate the end of the transfer, and generates a STOP condition. However, since requiring the master to keep track of the memory address counter is impractical, use the method for manipulating the address counter for reads.

**Manipulating the Address Counter for Reads:** A dummy write cycle can be used to force the address counter to a particular value. To do this the master generates a START condition, writes the slave address byte ( $R\overline{W} = 0$ ), writes the memory address where it desires to read, generates a repeated START condition, writes the slave address byte ( $R\overline{W} = 1$ ), reads data with ACK or NACK as applicable, and generates a STOP condition. See Figure 6 for a read example using the repeated START condition to specify the starting memory location.

**Reading Multiple Bytes from a Slave:** The read operation can be used to read multiple bytes with a single transfer. When reading bytes from the slave, the master simply ACKs the data byte if it desires to read another byte before terminating the transaction. After the master reads the last byte it must NACK to indicate the end of the transfer and then it generates a STOP condition.

### **Applications Information**

#### **Power-Supply Decoupling**

To achieve the best results when using the DS3232M, decouple the V<sub>CC</sub> and/or V<sub>BAT</sub> power supplies with 0.1µF and/or 1.0µF capacitors. Use a high-quality, ceramic, surface-mount capacitor if possible. Surface-mount components minimize lead inductance, which improves performance, and ceramic capacitors tend to have adequate high-frequency response for decoupling applications.

If communications during battery operation are not required, the  $V_{BAT}$  decoupling capacitor can be omitted.

#### **Using Open-Drain Outputs**

The  $\overline{INT}/SQW$  output is open drain and requires an external pullup resistor to realize logic-high output level. Pullup resistor values between 1k $\Omega$  and 10M $\Omega$  are typical.

The  $\overline{\text{RST}}$  output is also open drain, but is provided with an internal 50k $\Omega$  pullup resistor (RPU) to V<sub>CC</sub>. External pullup resistors should not be added.

#### **SDA and SCL Pullup Resistors**

SDA is an open-drain output and requires an external pullup resistor to realize a logic-high level.

Because the device does not use clock cycle stretching, a master using either an open-drain output with a pullup resistor or CMOS output driver (push-pull) could be used for SCL.

#### **Battery Charge Protection**

The device contains Maxim's redundant battery-charge protection circuit to prevent any charging of the external battery.

### **Ordering Information**

| PART        | TEMP RANGE     | PIN-PACKAGE |
|-------------|----------------|-------------|
| DS3232MZ+   | -40°C to +85°C | 8 SO        |
| DS3232MZ/V+ | -40°C to +85°C | 8 SO        |

+Denotes a lead(Pb)-free/RoHS-compliant package. /V denotes an automotive qualified part.

#### **Package Information**

For the latest package outline information and land patterns (footprints), go to <u>www.maximintegrated.com/packages</u>. Note that a "+", "#", or "-" in the package code indicates RoHS status only. Package drawings may show a different suffix character, but the drawing pertains to the package regardless of RoHS status.

| PACKAGE | PACKAGE | OUTLINE        | LAND           |
|---------|---------|----------------|----------------|
| TYPE    | CODE    | NO.            | PATTERN NO.    |
| 8 SO    | S8MK+1  | <u>21-0041</u> | <u>90-0096</u> |

# ±5ppm, I<sup>2</sup>C Real-Time Clock with SRAM

### **Revision History**

| REVISION<br>NUMBER | REVISION<br>DATE | DESCRIPTION                                                                                                                                                                                 | PAGES<br>CHANGED |
|--------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0                  | 3/12             | Initial release                                                                                                                                                                             |                  |
| 1                  | 8/12             | Added an automotive qualified part option to the Ordering Information table                                                                                                                 | 22               |
| 2                  | 7/13             | Added the junction temperature to the <i>Absolute Maximum Ratings</i> section; added the <i>Package Thermal Characteristics</i> section and renumbered the electrical characteristics notes | 2, 3, 4          |



Maxim Integrated cannot assume responsibility for use of any circuitry other than circuitry entirely embodied in a Maxim Integrated product. No circuit patent licenses are implied. Maxim Integrated reserves the right to change the circuitry and specifications without notice at any time. The parametric values (min and max limits) shown in the Electrical Characteristics table are guaranteed. Other parametric values quoted in this data sheet are provided for guidance.

#### Maxim Integrated 160 Rio Robles, San Jose, CA 95134 USA 1-408-601-1000

© 2013 Maxim Integrated Products, Inc.

Maxim Integrated and the Maxim Integrated logo are trademarks of Maxim Integrated Products, Inc.

23