

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832

Email & Skype: info@chipsmall.com Web: www.chipsmall.com

Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China







# **PCA2125**

# SPI Real-time clock/calendar

Rev. 01 — 28 July 2008

**Product data sheet** 

# 1. General description

The PCA2125 is a CMOS real-time clock/calendar optimized for low-power consumption and an operating temperature up to 125 °C. Data is transferred via a Serial Peripheral Interface (SPI) bus with a maximum data rate of 6.0 Mbit/s. An alarm and timer function are also available with the possibility to generate a wake-up signal on an interrupt pin.

AEC Q100 qualified for automotive applications.

### 2. Features

- Provides year, month, day, weekday, hours, minutes and seconds based on 32.768 kHz quartz crystal
- Resolution: seconds to years
- Clock operating voltage: 1.3 V to 5.5 V
- Low backup current: typical 0.55  $\mu$ A at  $V_{DD} = 3.0 \text{ V}$  and  $T_{amb} = 25 \,^{\circ}\text{C}$
- 3-line SPI-bus with separate combinable data input and output
- Serial interface (at V<sub>DD</sub> = 1.6 V to 5.5 V)
- 1 second or 1 minute interrupt output
- Freely programmable timer with interrupt capability
- Freely programmable alarm function with interrupt capability
- Integrated oscillator capacitor
- Internal power-on reset
- Open-drain interrupt pin

# 3. Applications

- Automotive time keeping application
- Metering

# 4. Ordering information

Table 1. Ordering information

| Type number | Package |                                                                           |          |  |  |  |
|-------------|---------|---------------------------------------------------------------------------|----------|--|--|--|
|             | Name    | Description                                                               | Version  |  |  |  |
| PCA2125TS   | TSSOP14 | plastic thin shrink small outline package; 14 leads;<br>body width 4.4 mm | SOT402-1 |  |  |  |



#### SPI Real-time clock/calendar

# 5. Marking

Table 2. Marking codes

| Type number | Marking code |
|-------------|--------------|
| PCA2125TS   | PCA2125      |

# 6. Block diagram



SPI Real-time clock/calendar

# 7. Pinning information

# 7.1 Pinning



# 7.2 Pin description

Table 3. Pin description

|          |        | •                                                                                                                |
|----------|--------|------------------------------------------------------------------------------------------------------------------|
| Symbol   | Pin    | Description                                                                                                      |
| OSCI     | 1      | oscillator input                                                                                                 |
| osco     | 2      | oscillator output                                                                                                |
| n.c.     | 3, 4   | not connected; do not connect and do not use as feed through; connect to $V_DD$ if floating pins are not allowed |
| ĪNT      | 5      | interrupt output (open-drain; active LOW)                                                                        |
| CE       | 6      | chip enable input (active HIGH) with 200 $k\Omega$ pull-down resistor                                            |
| $V_{SS}$ | 7      | ground                                                                                                           |
| SDO      | 8      | serial data output, push-pull                                                                                    |
| SDI      | 9      | serial data input; might float when CE inactive                                                                  |
| SCL      | 10     | serial clock input; might float when CE inactive                                                                 |
| n.c.     | 11, 12 | not connected; do not connect and do not use as feed through; connect to $V_DD$ if floating pins are not allowed |
| CLKOUT   | 13     | clock output (open-drain)                                                                                        |
| $V_{DD}$ | 14     | supply voltage                                                                                                   |

# 8. Functional description

The PCA2125 contains sixteen 8-bit registers with an auto-incrementing address register, an on-chip 32.768 kHz oscillator with one integrated capacitor, a frequency divider which provides the source clock for the Real-Time Clock (RTC), a programmable clock output, and a 6 MHz SPI-bus.

All sixteen registers are designed as addressable 8-bit parallel registers although not all bits are implemented:

SPI Real-time clock/calendar

- The first two registers at addresses 00h and 01h (Control\_1 and Control\_2) are used as control registers.
- Registers at addresses 02h to 08h (Seconds, Minutes, Hours, Days, Weekdays, Months, Years) are used as counters for the clock function. Seconds, minutes, hours, days, months and years are all coded in Binary Coded Decimal (BCD) format. When one of the RTC registers is read the contents of all counters are frozen. Therefore, faulty reading of the clock/calendar during a carry condition is prevented.
- Registers at addresses 09h to 0Ch (Minute\_alarm, Hour\_alarm, Day\_alarm, Weekday alarm) define the alarm condition.
- Register at address 0Dh (CLKOUT\_control) defines the clock out mode.
- Registers at addresses 0Eh and 0Fh (Timer\_control and Countdown\_timer) are used for the countdown timer function. The countdown timer has four selectable source clocks allowing for countdown periods in the range from less than 1 ms to more than 4 hours. There are also two pre-defined timers which can be used to generate an interrupt once per second or once per minute. These are defined in register Control\_2 (01h).

# 8.1 Register overview

The time registers are encoded in BCD to simplify application use. Other registers are either bit-wise or standard binary.

Table 4. Register overview

Bits labeled '-' are not implemented and will return a logic 0 when read. Bit positions labeled '0' should always be written with logic 0.

| Address | Register name   |          |                 | Bit         |               |              |       |         |     |  |  |
|---------|-----------------|----------|-----------------|-------------|---------------|--------------|-------|---------|-----|--|--|
|         |                 | 7        | 6               | 5 4         |               | 3            | 2     | 1       | 0   |  |  |
| 00h     | Control_1       | EXT_TEST | 0               | STOP        | 0             | POR_OVRD     | 12_24 | 0       | 0   |  |  |
| 01h     | Control_2       | MI       | SI              | MSF         | TI_TP         | AF           | TF    | AIE     | TIE |  |  |
| 02h     | Seconds         | RF       |                 | SEC         | ONDS[1]       |              | SECON | os      |     |  |  |
| 03h     | Minutes         | -        |                 | MIN         | UTES[1]       | MINUTES      |       |         |     |  |  |
| 04h     | Hours           | -        | -               | AMPM        | HOURS[1]      |              | HOURS | 3       |     |  |  |
|         |                 | -        | - HOURS[2]      |             |               | HOURS        |       |         |     |  |  |
| 05h     | Days            | -        | -               |             | DAYS[1]       |              | DAYS  |         |     |  |  |
| 06h     | Weekdays        | -        | -               | -           | -             | - WEEKDAYS   |       | S       |     |  |  |
| 07h     | Months          | -        | -               | - MONTHS[1] |               | MONTHS       |       |         |     |  |  |
| 08h     | Years           |          | ١               | /EARS[1]    |               | YEARS        |       |         |     |  |  |
| 09h     | Minute_alarm    | AEN_M    |                 | MINUTE      | E_ALARM[1]    | MINUTE_ALARM |       |         |     |  |  |
| 0Ah     | Hour_alarm      | AEN_H    | -               | AMPM        | HOUR_ALARM[1] | HOUR_ALARM   |       |         |     |  |  |
|         |                 |          | -               | НС          | DUR_ALARM[2]  | HOUR_ALARM   |       |         |     |  |  |
| 0Bh     | Day_alarm       | AEN_D    | -               | D           | AY_ALARM[1]   | DAY_ALARM    |       |         |     |  |  |
| 0Ch     | Weekday_alarm   | AEN_W    | -               |             |               | -            | WEE   | KDAY_AL | ARM |  |  |
| 0Dh     | CLKOUT_control  | -        | -               | -           | -             | -            |       | COF     |     |  |  |
| 0Eh     | Timer_control   | TE       | -               | -           | -             | -            | -     | СТ      | D   |  |  |
| 0Fh     | Countdown_timer |          | COUNTDOWN_TIMER |             |               |              |       |         |     |  |  |

<sup>[1]</sup> Ten's place.

PCA2125\_1 © NXP B.V. 2008. All rights reserved.

SPI Real-time clock/calendar

[2] Ten's place in 24 h mode.

#### 8.2 Reset

The PCA2125 includes an internal reset circuit which is active whenever the oscillator is stopped; see <u>Figure 3</u>. The oscillator can be stopped, for example, by connecting one of the oscillator pins OSCI or OSCO to ground.



The oscillator is considered to be stopped during the time between power-up and stable crystal resonance; see <u>Figure 4</u>. This time can be in the range 200 ms to 2 s depending on crystal type, temperature and supply voltage. Whenever an internal reset occurs, the reset flag bit RF is set.



Table 5. Register reset value

Bits labeled '-' are not implemented and will return a '0' when read. Bits labeled 'X' are undefined at power-up and unchanged by subsequent resets.

| Address | Register name |   | Bit |   |   |   |   |   |   |  |
|---------|---------------|---|-----|---|---|---|---|---|---|--|
|         |               | 7 | 6   | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 00h     | Control_1     | 0 | 0   | 0 | - | 1 | 0 | - | - |  |
| 01h     | Control_2     | 0 | 0   | 0 | 0 | 0 | 0 | 0 | 0 |  |
| 02h     | Seconds       | 1 | Χ   | Χ | Χ | Χ | Χ | Χ | Χ |  |
| 03h     | Minutes       | - | Χ   | Χ | Χ | Χ | Χ | Χ | X |  |
| 04h     | Hours         | - | -   | Χ | Χ | Χ | Χ | Χ | Χ |  |
| 05h     | Days          | - | -   | Χ | Χ | Χ | Χ | Χ | Χ |  |
| 06h     | Weekdays      | - | -   | - | - | - | Χ | Χ | Χ |  |

#### SPI Real-time clock/calendar

 Table 5.
 Register reset value ...continued

Bits labeled '-' are not implemented and will return a '0' when read. Bits labeled 'X' are undefined at power-up and unchanged by subsequent resets.

| Address | Register name   | Bit |   |   |   |   |   |   |   |
|---------|-----------------|-----|---|---|---|---|---|---|---|
|         |                 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 07h     | Months          | -   | - | - | Χ | X | Χ | Χ | Χ |
| 08h     | Years           | Χ   | Χ | Χ | Χ | Χ | Χ | Χ | Χ |
| 09h     | Minute_alarm    | 1   | Χ | Χ | Χ | Χ | Χ | Χ | Χ |
| 0Ah     | Hour_alarm      | 1   | - | Χ | Χ | Χ | Χ | Χ | Χ |
| 0Bh     | Day_alarm       | 1   | - | Χ | Χ | Χ | Χ | Χ | Χ |
| 0Ch     | Weekday_alarm   | 1   | - | - | - | - | X | Χ | Χ |
| 0Dh     | CLKOUT_control  | -   | - | - | - | - | 0 | 0 | 0 |
| 0Eh     | Timer_control   | 0   | - | - | - | - | - | 1 | 1 |
| 0Fh     | Countdown_timer | Χ   | Χ | Х | Χ | Х | X | Χ | Χ |

After reset, the following mode is entered:

- 32.768 kHz on pin CLKOUT active
- Power-on reset override available to be set
- · 24 hour mode is selected

The SPI-bus is initialized whenever the chip enable pin CE is inactive (LOW).

#### 8.2.1 Power-on reset override

The Power-On Reset (POR) duration is directly related to the crystal oscillator start-up time. Due to the long start-up times experienced by these types of circuits, a mechanism has been built in to disable the POR and hence speed up the on-board test of the device.

The setting of this mode requires that bit POR\_OVRD be set to logic 1 and that the signals at the SPI-bus pins SDI and CE are toggled as illustrated in <u>Figure 5</u>. All timings are required minimums.

Once the override mode has been entered, the device immediately stops being reset and set-up operation can commence i.e. entry into the external clock test mode via the SPI-bus access. The override mode can be cleared by writing a logic 0 to bit POR\_OVRD. Bit POR\_OVRD must be set to logic 1 before a re-entry into the override mode is possible. Setting bit POR\_OVRD to logic 0 during normal operation has no effect except to prevent accidental entry into the POR override mode. This is the recommended setting.



### SPI Real-time clock/calendar

# 8.3 Control registers

Table 6. Control\_1 register (address 00h) bit description

|        |          | 9.00  | (uuurooo ton) sit uooonption                                                                                                                                |               |
|--------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| Bit    | Symbol   | Value | Description                                                                                                                                                 | Reference     |
| 7      | EXT_TEST | 0     | normal mode                                                                                                                                                 | Section 8.9   |
|        |          | 1     | external clock test mode                                                                                                                                    |               |
| 6      | -        | 0     | unused                                                                                                                                                      |               |
| 5      | STOP     | 0     | RTC source clock runs                                                                                                                                       | Section 8.10  |
|        |          | 1     | RTC divider chain flip-flops are asynchronously set to logic 0; the RTC clock is stopped (CLKOUT at 32.768 kHz, 16.384 kHz or 8.192 kHz is still available) |               |
| 4      | -        | 0     | unused                                                                                                                                                      | -             |
| 3      | POR_OVRD | 0     | power-on reset override facility is disabled; <b>set to</b> logic 0 for normal operation                                                                    | Section 8.2.1 |
|        |          | 1     | power-on reset override is enabled                                                                                                                          |               |
| 2      | 12_24    | 0     | 24 hour mode is selected                                                                                                                                    | Table 11      |
|        |          | 1     | 12 hour mode is selected                                                                                                                                    |               |
| 1 to 0 | -        | 0     | unused                                                                                                                                                      | -             |
|        |          |       |                                                                                                                                                             |               |

Table 7. Control\_2 register (address 01h) bit description

| Bit | Symbol | Value | Description                                                                                 | Reference     |
|-----|--------|-------|---------------------------------------------------------------------------------------------|---------------|
| 7   | 7 MI 0 |       | minute interrupt is disabled                                                                | Section 8.6.1 |
|     |        | 1     | minute interrupt is enabled                                                                 | _             |
| 6   | SI     | 0     | second interrupt is disabled                                                                | _             |
|     |        | 1     | second interrupt is enabled                                                                 |               |
| 5   | MSF    | 0     | no minute or second interrupt generated                                                     | Section 8.6   |
|     |        | 1     | flag set when minute or second interrupt generated; flag must be cleared to clear interrupt |               |
| 4   | TI_TP  | 0     | interrupt pin follows timer flags                                                           | Section 8.7.2 |
| 1   |        | 1     | interrupt pin generates a pulse                                                             |               |
| 3   | 3 AF   | 0     | no alarm interrupt generated                                                                | Section 8.5.1 |
|     |        | 1     | flag set when alarm triggered; flag must be cleared to clear interrupt                      |               |
| 2   | TF     | 0     | no countdown timer interrupt generated                                                      | -             |
|     |        | 1     | flag set when countdown timer interrupt generated; flag must be cleared to clear interrupt  | -             |
| 1   | AIE    | 0     | no interrupt generated from the alarm flag                                                  | Section 8.7.3 |
|     |        | 1     | interrupt generated when alarm flag set                                                     |               |
| 0   | TIE    | 0     | no interrupt generated from the countdown timer flag                                        | Section 8.7   |
|     |        | 1     | interrupt generated when countdown timer flag set                                           |               |
|     |        |       |                                                                                             |               |

#### SPI Real-time clock/calendar

### 8.4 Time and date function

The majority of the registers are coded in the Binary Coded Decimal (BCD) format. BCD is used to simplify application use.

An example is shown for register Minutes in Table 8.

Table 8. BCD example

| Minutes value | Double                | -digit                |                |                       | Digit          | Digit          |                |       |  |
|---------------|-----------------------|-----------------------|----------------|-----------------------|----------------|----------------|----------------|-------|--|
| (decimal)     | Bit 7                 | Bit 6                 | Bit 5          | Bit 4                 | Bit 3          | Bit 2          | Bit 1          | Bit 0 |  |
|               | <b>2</b> <sup>3</sup> | <b>2</b> <sup>2</sup> | 2 <sup>1</sup> | <b>2</b> <sup>0</sup> | 2 <sup>3</sup> | 2 <sup>2</sup> | 2 <sup>1</sup> | 20    |  |
| 00            | 0                     | 0                     | 0              | 0                     | 0              | 0              | 0              | 0     |  |
| 01            | 0                     | 0                     | 0              | 0                     | 0              | 0              | 0              | 1     |  |
| 02            | 0                     | 0                     | 0              | 0                     | 0              | 0              | 1              | 0     |  |
| :             | :                     | :                     | :              | :                     | :              | :              | :              | :     |  |
| 09            | 0                     | 0                     | 0              | 0                     | 1              | 0              | 0              | 1     |  |
| 10            | 0                     | 0                     | 0              | 1                     | 0              | 0              | 0              | 0     |  |
| :             | :                     | :                     | :              | :                     | :              | :              | :              | :     |  |
| 58            | 0                     | 1                     | 0              | 1                     | 1              | 0              | 0              | 0     |  |
| 59            | 0                     | 1                     | 0              | 1                     | 1              | 0              | 0              | 1     |  |

Table 9. Register Seconds (address 02h) bit description

| Bit    | Symbol       | Value    | Description                                                                            |
|--------|--------------|----------|----------------------------------------------------------------------------------------|
| 7 RF   |              | 0        | clock integrity is guaranteed                                                          |
|        |              | 1        | clock integrity is not guaranteed; chip reset has occurred since flag was last cleared |
| 6 to 0 | SECONDS[6:0] | 00 to 59 | this register holds the current seconds value coded in BCD format                      |

Table 10. Register Minutes (address 03h) bit description

| Bit    | Symbol       | Value    | Description                                                       |
|--------|--------------|----------|-------------------------------------------------------------------|
| 7      | -            | 0        | unused                                                            |
| 6 to 0 | MINUTES[6:0] | 00 to 59 | this register holds the current minutes value coded in BCD format |

Table 11. Register Hours (address 04h) bit description

| Bit     | Symbol                     | Value    | Description                                                                      |
|---------|----------------------------|----------|----------------------------------------------------------------------------------|
| 6 and 7 | -                          | 0        | unused                                                                           |
| 12 hour | mode[1]                    |          |                                                                                  |
| 5       | AMPM                       | 0        | indicates AM                                                                     |
|         |                            | 1        | indicates PM                                                                     |
| 4 to 0  | HOURS[4:0]                 | 01 to 12 | this register holds the current hours value coded in BCD format for 12 hour mode |
| 24 hour | mode <u><sup>[1]</sup></u> |          |                                                                                  |
| 5 to 0  | HOURS[5:0]                 | 00 to 23 | this register holds the current hours value coded in BCD format for 24 hour mode |
|         |                            |          |                                                                                  |

<sup>[1]</sup> Hour mode is set by bit 12\_24 in register Control\_1.

#### SPI Real-time clock/calendar

Table 12. Register Days (address 05h) bit description

| Bit    | Symbol    | Value    | Description                                                                              |
|--------|-----------|----------|------------------------------------------------------------------------------------------|
| 6, 7   | -         | 0        | unused                                                                                   |
| 5 to 0 | DAYS[5:0] | 01 to 31 | this register holds the current day value coded in BCD format $\[ \underline{^{[1]}} \]$ |

<sup>[1]</sup> The RTC compensates for leap years by adding a 29th day to February if the year counter contains a value which is exactly divisible by 4, including the year 00.

Table 13. Register Weekdays (address 06h) bit description

| Bit    | Symbol        | Value  | Description                                                 |
|--------|---------------|--------|-------------------------------------------------------------|
| 3 to 7 | -             | 0      | unused                                                      |
| 2 to 0 | WEEKDAYS[2:0] | 0 to 6 | this register holds the current weekday value; see Table 14 |

Table 14. Weekday assignments

| Day[1]    | Double-digit |       |       |       | Digit |       |       |       |
|-----------|--------------|-------|-------|-------|-------|-------|-------|-------|
|           | Bit 7        | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Sunday    | Χ            | Χ     | Χ     | Χ     | Х     | 0     | 0     | 0     |
| Monday    | Χ            | Χ     | Χ     | Χ     | Х     | 0     | 0     | 1     |
| Tuesday   | Χ            | Χ     | Χ     | Χ     | Х     | 0     | 1     | 0     |
| Wednesday | Χ            | Χ     | Χ     | Χ     | Х     | 0     | 1     | 1     |
| Thursday  | Χ            | Χ     | Χ     | Χ     | Х     | 1     | 0     | 0     |
| Friday    | Χ            | Χ     | Χ     | Χ     | Х     | 1     | 0     | 1     |
| Saturday  | Χ            | Χ     | Χ     | Χ     | Х     | 1     | 1     | 0     |

<sup>[1]</sup> The weekday assignments can be re-defined by the user.

Table 15. Register Months (address 07h) bit description

| Bit    | Symbol      | Value    | Description                                                                                        |
|--------|-------------|----------|----------------------------------------------------------------------------------------------------|
| 5 to 7 | -           | 0        | unused                                                                                             |
| 4 to 0 | MONTHS[4:0] | 01 to 12 | this register holds the current month value coded in BCD format; see $\underline{\text{Table 16}}$ |

Table 16. Month assignments

| Month     |       | Double | e-digit |       | Digit |       |       |       |  |
|-----------|-------|--------|---------|-------|-------|-------|-------|-------|--|
|           | Bit 7 | Bit 6  | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
| January   | Х     | Х      | Χ       | 0     | 0     | 0     | 0     | 1     |  |
| February  | Χ     | Χ      | Χ       | 0     | 0     | 0     | 1     | 0     |  |
| March     | Χ     | Χ      | Х       | 0     | 0     | 0     | 1     | 1     |  |
| April     | Χ     | Х      | Χ       | 0     | 0     | 1     | 0     | 0     |  |
| May       | Χ     | Χ      | Χ       | 0     | 0     | 1     | 0     | 1     |  |
| June      | Χ     | Χ      | Χ       | 0     | 0     | 1     | 1     | 0     |  |
| July      | Χ     | Х      | Χ       | 0     | 0     | 1     | 1     | 1     |  |
| August    | Χ     | Х      | Χ       | 0     | 1     | 0     | 0     | 0     |  |
| September | Χ     | Х      | Χ       | 0     | 1     | 0     | 0     | 1     |  |

#### SPI Real-time clock/calendar

Table 16. Month assignments ...continued

| Month    | Double-digit |       |       | Digit |       |       |       |       |
|----------|--------------|-------|-------|-------|-------|-------|-------|-------|
|          | Bit 7        | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| October  | Х            | Χ     | Χ     | 1     | 0     | 0     | 0     | 0     |
| November | Х            | Χ     | Χ     | 1     | 0     | 0     | 0     | 1     |
| December | Х            | Х     | Х     | 1     | 0     | 0     | 1     | 0     |

Table 17. Register Years (address 08h) bit description

| Bit    | Symbol     | Value    | Description                                                    |
|--------|------------|----------|----------------------------------------------------------------|
| 7 to 0 | YEARS[7:0] | 00 to 99 | this register holds the current year value coded in BCD format |

Figure 6 shows the data flow and data dependencies starting from the 1 Hz clock tick.



### 8.5 Alarm function

When one or several alarm registers are loaded with a valid minute, hour, day or weekday value and its corresponding alarm enable not bit (AENx) is logic 0, then that information is compared with the current minute, hour, day and weekday value.

Table 18. Register Minute\_alarm (address 09h) bit description

| Bit    | Symbol            | Value    | Description                                                    |
|--------|-------------------|----------|----------------------------------------------------------------|
| 7      | AEN_M             | 0        | minute alarm is enabled                                        |
|        |                   | 1        | minute alarm is disabled                                       |
| 6 to 0 | MINUTE_ALARM[6:0] | 00 to 59 | this register holds the minute alarm value coded in BCD format |

#### SPI Real-time clock/calendar

Table 19. Register Hour\_alarm (address 0Ah) bit description

|           | _          | -        | · · · · · · · · · · · · · · · · · · ·                                             |
|-----------|------------|----------|-----------------------------------------------------------------------------------|
| Bit       | Symbol     | Value    | Description                                                                       |
| 7         | AEN_H      | 0        | hour alarm is enabled                                                             |
|           |            | 1        | hour alarm is disabled                                                            |
| 6         | -          | 0        | unused                                                                            |
| 12 hour r | mode       |          |                                                                                   |
| 5         | AMPM       | 0        | indicates AM                                                                      |
|           |            | 1        | indicates PM                                                                      |
| 4 to 0    | HOUR_ALARM | 01 to 12 | this register holds the hour alarm value coded in BCD format when in 12 hour mode |
| 24 hour r | mode       |          |                                                                                   |
| 5 to 0    | HOUR_ALARM | 00 to 23 | this register holds the hour alarm value coded in BCD format when in 24 hour mode |

## Table 20. Register Day\_alarm (address 0Bh) bit description

| Bit    | Symbol    | Value    | Description                                                 |
|--------|-----------|----------|-------------------------------------------------------------|
| 7      | AEN_D     | 0        | day alarm is enabled                                        |
|        |           | 1        | day alarm is disabled                                       |
| 6      | -         | 0        | unused                                                      |
| 5 to 0 | DAY_ALARM | 01 to 31 | this register holds the day alarm value coded in BCD format |

#### Table 21. Register Weekday alarm (address 0Ch) bit description

| Bit    | Symbol        | Value  | Description                                 |
|--------|---------------|--------|---------------------------------------------|
| 7      | AEN_W         | 0      | weekday alarm is enabled                    |
|        |               | 1      | weekday alarm is disabled                   |
| 3 to 6 | -             | 0      | unused                                      |
| 2 to 0 | WEEKDAY_ALARM | 0 to 6 | this register holds the weekday alarm value |

SPI Real-time clock/calendar



Generation of interrupts from the alarm function is described in Section 8.7.3.

### 8.5.1 Alarm flag

When all enabled comparisons first match, the alarm flag bit AF is set. Bit AF will remain set until cleared by software. Once bit AF has been cleared it will only be set again when the time increments once more to match the alarm condition.

Alarm registers which have their bit AENx at logic 1 are ignored.

<u>Figure 8</u> shows an example for clearing bit AF, but leaving bit MSF and bit TF unaffected. The flags are cleared by a write command, therefore bits 7, 6, 4, 1 and 0 must be written with their previous values. Repeatedly re-writing these bits has no influence on the functional behavior.



#### SPI Real-time clock/calendar

To prevent the timer flags being overwritten while clearing bit AF, a logic AND is performed during a write access. The flag is reset by writing a logic 0 but its value is not affected by writing a logic 1.

Table 22. Flag location in register Control 2

| Register  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| Control_2 | -     | -     | MSF   | -     | AF    | TF    | -     | -     |

Table 23 shows what instruction must be sent to clear bit AF. In this example, bit MSF and bit TF are unaffected.

Table 23. Example to clear only AF (bit 3) in register Control\_2

| Register  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| Control_2 | -     | -     | 1     | -     | 0     | 1     | -     | -     |

#### 8.6 Timer functions

The countdown timer has four selectable source clocks allowing for countdown periods in the range from less than 1 ms to more than 4 hours. There are also two pre-defined timers which can be used to generate an interrupt once per second or once per minute.

Registers Control\_2 (01h), Timer\_control (0Eh) and Countdown\_timer (0Fh) are used to control the timer function and output.

Table 24. Register Timer\_control (address 0Eh) bit description

| Bit                | Symbol | Value                             | Description                          | Reference     |
|--------------------|--------|-----------------------------------|--------------------------------------|---------------|
| 7                  | TE     | 0                                 | countdown timer is disabled          | Section 8.6.2 |
|                    |        | 1                                 | countdown timer is enabled           |               |
| 6 to 2             | -      | 0                                 | unused                               |               |
| 1 to 0 CTD[1:0] 00 |        | 00                                | 4096 Hz countdown timer source clock |               |
|                    |        | 01                                | 64 Hz countdown timer source clock   |               |
|                    | 10     | 1 Hz countdown timer source clock |                                      |               |
|                    |        | 11                                | 1/60 Hz countdown timer source clock |               |

Table 25. Register Countdown timer (address 0Fh) bit description

| Bit    | Symbol               | Value      | Description                                        | Reference     |
|--------|----------------------|------------|----------------------------------------------------|---------------|
| 7 to 0 | COUNTDOWN_TIMER[7:0] | 00h to FFh | countdown value = n.                               | Section 8.6.2 |
|        |                      |            | $CountdownPeriod = \frac{n}{SourceClockFrequency}$ |               |

# 8.6.1 Second and minute interrupt

The second and minute interrupts (bits SI and MI) are pre-defined timers for generating periodic interrupts. The timers can be enabled independently of one another, however a minute interrupt enabled on top of a second interrupt will not be distinguishable since it will occur at the same time; see Figure 9.

#### SPI Real-time clock/calendar



Table 26. Effect of bits MI and SI on INT generation

| Minute interrupt (bit MI) | Second interrupt (bit SI) | Result                       |
|---------------------------|---------------------------|------------------------------|
| 0                         | 0                         | no interrupt generated       |
| 1                         | 0                         | an interrupt once per minute |
| 0                         | 1                         | an interrupt once per second |
| 1                         | 1                         | an interrupt once per second |

The minute and second flag (bit MSF) is set to logic 1 when either the seconds or the minutes counter increments according to the currently enabled interrupt. The flag can be read and cleared by the interface. The status of bit MSF does not affect the  $\overline{\text{INT}}$  pulse generation. If the MSF flag is not cleared prior to the next coming interrupt period, an  $\overline{\text{INT}}$  pulse will still be generated.

The purpose of the flag is to allow the controlling system to interrogate the PCA2125 and identify the source of the interrupt such as the minute/second or countdown timer.

#### SPI Real-time clock/calendar

Table 27. Effect of bits MI and SI on bit MSF

| Minute interrupt (bit MI) | Second interrupt (bit SI) | Result                                            |
|---------------------------|---------------------------|---------------------------------------------------|
| 0                         | 0                         | MSF never set                                     |
| 1                         | 0                         | MSF set when <b>minutes</b> counter increments[1] |
| 0                         | 1                         | MSF set when <b>seconds</b> counter increments    |
| 1                         | 1                         | MSF set when <b>seconds</b> counter increments    |

<sup>[1]</sup> In the case of bit MI = 1 and bit SI = 0, bit MSF will be cleared automatically after 1 second.

#### 8.6.2 Countdown timer function

The 8-bit countdown timer at address 0Fh is controlled by the timer control register at address 0Eh. The timer control register determines one of 4 source clock frequencies for the timer (4096 Hz, 64 Hz, 1 Hz, or  $\frac{1}{60}$  Hz), and enables or disables the timer.

Table 28. Bits CTD1 and CTD0 for timer frequency selection and countdown timer durations

| Bits CTD[1:0] | Timer source clock  | Delay                        |                                |  |  |
|---------------|---------------------|------------------------------|--------------------------------|--|--|
|               | frequency           | Minimum timer duration n = 1 | Maximum timer duration n = 255 |  |  |
| 00            | 4096 Hz             | 244 μs                       | 62.256 ms                      |  |  |
| 01            | 64 Hz               | 15.625 ms                    | 3.984 s                        |  |  |
| 10            | 1 Hz                | 1 s                          | 255 s                          |  |  |
| 11            | ¹⁄ <sub>60</sub> Hz | 60 s <sup>[1]</sup>          | 4 h 15 min                     |  |  |

<sup>[1]</sup> When not in use, bits CTD[1:0] must be set to  $\frac{1}{60}$  Hz for power saving.

**Remark:** Note that all timings which are generated from the 32.768 kHz oscillator are based on the assumption that there is 0 ppm deviation. Deviation in oscillator frequency will result in a corresponding deviation in timings. This is not applicable to interface timing.

The timer counts down from a software-loaded 8-bit binary value n. Loading the counter with 0 effectively stops the timer. Values from 1 to 255 are valid. When the counter reaches 1, the countdown timer flag (bit TF) will be set and the counter automatically re-loads and starts the next timer period. Reading the timer will return the current value of the countdown counter; see <a href="Figure 10">Figure 10</a>.

SPI Real-time clock/calendar



If a new value of n is written before the end of the current timer period, then this value will take immediate effect. NXP Semiconductors does not recommend changing n without first disabling the counter (by setting bit TE=0). The update of n is asynchronous with the timer clock, therefore changing it without setting bit TE=0 will result in a corrupted value loaded into the countdown counter which results in an undetermined countdown period for the first period. The countdown value n will however be correctly stored and correctly loaded on subsequent timer periods.

When the countdown timer flag is set, an interrupt signal on  $\overline{\text{INT}}$  will be generated provided that this mode is enabled. See Section 8.7.2 for details on how the interrupt can be controlled.

When starting the timer for the first time, the first period will have an uncertainty which is a result of the enable instruction being generated from the interface clock which is asynchronous with the timer source clock. Subsequent timer periods will have no such delay. The amount of delay for the first timer period will depend on the chosen source clock; see <a href="Table 29">Table 29</a>.

Table 29. First period delay for timer counter value n

| Timer source clock  | Minimum timer period      | Maximum timer period                |
|---------------------|---------------------------|-------------------------------------|
| 4096 Hz             | n                         | n + 1                               |
| 64 Hz               | n                         | n + 1                               |
| 1 Hz                | $(n-1) + \frac{1}{64}$ Hz | n + <sup>1</sup> / <sub>64</sub> Hz |
| ¹⁄ <sub>60</sub> Hz | $(n-1) + \frac{1}{64}$ Hz | n + <sup>1</sup> / <sub>64</sub> Hz |

At the end of every countdown, the timer sets the countdown timer flag (bit TF). Bit TF can only be cleared by software. The asserted bit TF can be used to generate an interrupt (INT). The interrupt can be generated as a pulsed signal every countdown period or as a permanently active signal which follows the condition of bit TF. Bit TI\_TP is used to control this mode selection and the interrupt output can be disabled with bit TIE.

#### SPI Real-time clock/calendar

When reading the timer, the current countdown value is returned and **not** the initial value n. For accurate read back of the countdown value, the SPI-bus clock (SCL) must be operating at a frequency of at least twice the selected timer clock. Since it is not possible to freeze the countdown timer counter during read back, it is recommended to read the register twice and check for consistent results.

### 8.6.3 Timer flags

When a minute or second interrupt occurs, bit MSF is set to logic 1. Similarly, at the end of a timer countdown, bit TF is set to logic 1. These bits maintain their value until overwritten by software. If both countdown timer and minute/second interrupts are required in the application, the source of the interrupt can be determined by reading these bits. To prevent one flag being overwritten while clearing another, a logic AND is performed during a write access. The flag is reset by writing a logic 0 but its value is not affected by writing a logic 1.

Three examples are given for clearing the flags. Flags MSF and TF are cleared by a write command, therefore bits 7, 6, 4, 1 and 0 must be written with their previous values. Repeatedly re-writing these bits has no influence on the functional behavior.

Table 30. Flag location in register Control 2

| Register  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| Control_2 | -     | -     | MSF   | -     | AF    | TF    | -     | -     |

<u>Table 31</u>, <u>Table 32</u> and <u>Table 33</u> show what instruction must be sent to clear the appropriate flag.

Table 31. Example to clear only TF (bit 2) in register Control\_2

| Register  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| Control_2 | -     | -     | 1     | -     | 1     | 0     | -     | -     |

Table 32. Example to clear only MSF (bit 5) in register Control 2

| Register  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| Control_2 | -     | -     | 0     | -     | 1     | 1     | -     | -     |

Table 33. Example to clear both TF and MSF (bits 2 and 5) in register Control 2

| Register  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| Control_2 | -     | -     | 0     | -     | 1     | 0     | -     | -     |

Clearing the alarm flag (bit AF) operates in exactly the same way; see Section 8.5.1.

# 8.7 Interrupt output

An active LOW interrupt signal is available at pin  $\overline{\text{INT}}$ . Operation is controlled via the bits of control register 2. Interrupts can be sourced from three places: second/minute timer, countdown timer and alarm function.

Bit TI\_TP configures the timer generated interrupts to be either a pulse or to follow the status of the interrupt flags (bits TF and MSF).

SPI Real-time clock/calendar



**Remark:** Note that the interrupts from the three groups are wired-OR, meaning they will mask one another; see Figure 11.

## 8.7.1 Minute and second interrupts

The pulse generator for the minute/second interrupt operates from an internal 64 Hz clock and consequently generates a pulse of  $\frac{1}{64}$  second duration.

If the MSF flag is clear before the end of the  $\overline{\text{INT}}$  pulse, then the  $\overline{\text{INT}}$  pulse is shortened. This allows the source of a system interrupt to be cleared immediately it is serviced i.e. the system does not have to wait for the completion of the pulse before continuing; see Figure 12. Instructions for clearing MSF are given in Section 8.6.3.

SPI Real-time clock/calendar



The timing shown for clearing bit MSF in <u>Figure 12</u> is also valid for the non-pulsed interrupt mode i.e. when bit  $TI_TP = 0$ , where the pulse can be shortened by setting both bits MI and SI to logic 0.

### 8.7.2 Countdown timer interrupts

Generation of interrupts from the countdown timer is controlled via bit TIE; see Table 7.

The pulse generator for the countdown timer interrupt also uses an internal clock which is dependent on the selected source clock for the countdown timer and on the countdown value n. As a consequence, the width of the interrupt pulse varies; see Table 34.

Table 34. INT operation (bit TI\_TP = 1)

| Source clock (Hz) | INT period (s) |        |  |  |  |  |
|-------------------|----------------|--------|--|--|--|--|
|                   | n = 1[1]       | n > 1  |  |  |  |  |
| 4096              | 1/8192         | 1/4096 |  |  |  |  |
| 64                | 1/128          | 1/64   |  |  |  |  |
| 1                 | 1/64           | 1/64   |  |  |  |  |
| 1/60              | 1/64           | 1/64   |  |  |  |  |

<sup>[1]</sup> n = loaded countdown value. Timer stopped when n = 0.

If the TF flag is clear before the end of the  $\overline{\text{INT}}$  pulse, then the  $\overline{\text{INT}}$  pulse is shortened. This allows the source of a system interrupt to be cleared immediately it is serviced i.e. the system does not have to wait for the completion of the pulse before continuing; see Figure 13. Instructions for clearing TF are given in Section 8.6.3.

#### SPI Real-time clock/calendar



The timing shown for clearing bit TF in  $\frac{\text{Figure } 13}{\text{Figure } 13}$  is also valid for the non-pulsed interrupt mode i.e. when bit TI\_TP = 0, where the pulse can be shortened by setting bit TIE = 0.

### 8.7.3 Alarm interrupts

Generation of interrupts from the alarm function is controlled via bit AIE. If bit AIE is enabled, the  $\overline{\text{INT}}$  pin follows the status of bit AF. Clearing bit AF will immediately clear  $\overline{\text{INT}}$ . No pulse generation is possible for alarm interrupts; see Figure 14.



SPI Real-time clock/calendar

### 8.8 Clock output

A programmable square wave is available at pin CLKOUT. Operation is controlled by control bits COF[2:0] in register CLKOUT\_control (0Dh). Frequencies of 32.768 kHz (default) down to 1 Hz can be generated for use as a system clock, microcontroller clock, input to a charge pump, or for calibration of the oscillator.

Pin CLKOUT is an open-drain output and enabled at power-on. When disabled the output is LOW.

The duty cycle of the selected clock is not controlled, but due to the nature of the clock generation, all clock frequencies, except 32.768 kHz, have a duty cycle of 50:50.

The 'stop' function can also affect the CLKOUT signal, depending on the selected frequency. When 'stop' is active, the CLKOUT pin will generate a continuous LOW for those frequencies that can be stopped. For more details, see Section 8.10.

Table 35. CLKOUT frequency selection

| Bits COF[2:0] | CLKOUT frequency (Hz) | Typical duty cycle[1] (%) | Effect of 'stop' |
|---------------|-----------------------|---------------------------|------------------|
| 000           | 32768                 | 60:40 to 40:60            | no effect        |
| 001           | 16384                 | 50 : 50                   | no effect        |
| 010           | 8192                  | 50 : 50                   | no effect        |
| 011           | 4096                  | 50 : 50                   | CLKOUT = LOW     |
| 100           | 2048                  | 50 : 50                   | CLKOUT = LOW     |
| 101           | 1024                  | 50 : 50                   | CLKOUT = LOW     |
| 110           | 1                     | 50 : 50                   | CLKOUT = LOW     |
| 111           | CLKOUT = LOW          |                           |                  |

<sup>[1]</sup> Duty cycle definition: HIGH-level time (%): LOW-level time (%).

#### 8.9 External clock test mode

A test mode is available which allows for on-board testing. In this mode it is possible to set up test conditions and control the operation of the RTC.

The test mode is entered by setting bit EXT\_TEST in register Control\_1 making pin CLKOUT an input. The test mode replaces the internal signal with the signal applied to pin CLKOUT. Every 64 positive edges applied to pin CLKOUT generates an increment of one second.

The signal applied to pin CLKOUT should have a minimum HIGH width of 300 ns and a minimum period of 1000 ns. The internal clock, now sourced from pin CLKOUT, is divided down to 1 Hz by a 2<sup>6</sup> divide chain called a prescaler; see Section 8.10. The prescaler can be set into a known state by using bit STOP. When bit STOP is set, the prescaler is reset to 0. STOP must be cleared before the prescaler can operate again.

From a stop condition, the first 1 second increment will take place after 32 positive edges on pin CLKOUT. Thereafter, every 64 positive edges will cause a 1 second increment.

**Remark:** Entry into test mode is not synchronized to the internal 64 Hz clock. When entering the test mode, no assumption as to the state of the prescaler can be made.

Operation example:

SPI Real-time clock/calendar

- 1. Set EXT\_TEST test mode (register Control\_1, bit EXT\_TEST = 1).
- 2. Set STOP (register Control 1, bit STOP = 1).
- 3. Clear STOP (register Control 1, bit STOP = 0).
- 4. Set time registers to desired value.
- 5. Apply 32 clock pulses to pin CLKOUT.
- 6. Read time registers to see the first change.
- 7. Apply 64 clock pulses to pin CLKOUT.
- 8. Read time registers to see the second change.

Repeat steps 7 and 8 for additional increments.

### 8.10 STOP bit function

The STOP bit function allows the accurate starting of the time circuits. The stop function will cause the upper part of the prescaler ( $F_2$  to  $F_{14}$ ) to be held at reset, thus no 1 Hz ticks will be generated. The time circuits can then be set and will not increment until the stop is released; see Figure 15.

Stop will not affect the output of 32768 Hz, 16384 Hz or 8192 Hz; see Section 8.8.



The lower two stages of the prescaler ( $F_0$  and  $F_1$ ) are not reset and because the SPI-bus is asynchronous to the crystal oscillator, the accuracy of re-starting the time circuits will be between 0 and one 8192 Hz cycle; see Figure 16.



PCA2125\_1 © NXP B.V. 2008. All rights reserved.

#### SPI Real-time clock/calendar

The first increment of the time circuits is between 0.499888 s and 0.500000 s after stop is released. The uncertainty is caused by prescaler bits F0 and F1 not being reset; see Table 36.

Table 36. Example: first increment of time circuits after stop release

| Bit STOP    | Prescaler bits                 | 1 Hz tick       | Time          | Comment                                               |
|-------------|--------------------------------|-----------------|---------------|-------------------------------------------------------|
| BIL STOP    |                                | I HZ LICK       |               | Comment                                               |
|             | $F_0F_1-F_2$ to $F_{14}^{[1]}$ |                 | hh:mm:ss      |                                                       |
| Clock is ru | inning normally                |                 |               |                                                       |
| 0           | 01-0 0001 1101 0100            |                 | 12:45:12      | prescaler counting normally                           |
| Stop is ac  | tivated by user. F0F1 a        | re not reset ar | nd values can | not be predicted externally                           |
| 1           | XX-0 0000 0000 0000            |                 | 12:45:12      | prescaler is reset; time circuits are frozen          |
| New time i  | is set by user                 |                 |               |                                                       |
| 1           | XX-0 0000 0000 0000            |                 | 08:00:00      | prescaler is reset; time circuits are frozen          |
| Stop is rel | eased by user                  |                 |               |                                                       |
| 0           | XX-0 0000 0000 0000            |                 | 08:00:00      | prescaler is now running                              |
|             | XX-1 0000 0000 0000            |                 | 08:00:00      |                                                       |
|             | XX-0 1000 0000 0000            |                 | 08:00:00      |                                                       |
|             | XX-1 1000 0000 0000            |                 | 08:00:00      |                                                       |
|             | :                              |                 | :             |                                                       |
|             | 11-1 1111 1111 1110            |                 | 08:00:00      |                                                       |
|             | 00-0 0000 0000 0001            |                 | 08:00:01      | 0 to 1 transition of F14 increments the time circuits |
|             | 10-0 0000 0000 0001            |                 | 08:00:01      |                                                       |
|             | :                              |                 | :             |                                                       |
|             | 11-1 1111 1111 1111            |                 | 08:00:01      |                                                       |
|             | 00-0 0000 0000 0000            |                 | 08:00:01      |                                                       |
|             | 10-0 0000 0000 0000            |                 | 08:00:01      |                                                       |
|             | :                              |                 | :             |                                                       |
|             | 11-1 1111 1111 1110            |                 | 08:00:01      |                                                       |
|             | 00-0 0000 0000 0001            |                 | 08:00:02      | 0 to 1 transition of F14 increments the time circuits |
|             |                                |                 |               |                                                       |

<sup>[1]</sup> F<sub>0</sub> is clocked at 32.768 kHz.



SPI Real-time clock/calendar

#### 8.11 3-line SPI

Data transfer to and from the device is made via a 3-wire SPI-bus; see <u>Table 37</u>. The data lines for input and output are split. The data input and output lines can be connected together to facilitate a bidirectional data bus. The chip enable signal is used to identify the transmitted data. Each data transfer is a byte, with the Most Significant Bit (MSB) sent first; see Figure 18.

Table 37. Serial interface

| Pin | Function           | Description                                                                                                                                             |
|-----|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| CE  | chip enable input  | when LOW, the interface is reset; pull-down resistor included; active input can be higher than $V_{\text{DD}}$ , but must not be wired HIGH permanently |
| SCL | serial clock input | when pin CE = LOW, this input might float; input can be higher than $V_{\text{DD}}$                                                                     |
| SDI | serial data input  | when pin CE = LOW, this input might float; input can be higher than $V_{\text{DD}}$ ; input data is sampled on the rising edge of SCL                   |
| SDO | serial data output | push-pull output; drives from $V_{\text{SS}}$ to $V_{\text{DD}};$ output data is changed on the falling edge of SCL                                     |

The transmission is controlled by the active HIGH chip enable signal CE. The first byte transmitted is the command byte. Subsequent bytes will be either data to be written or data to be read. Data is captured on the rising edge of the clock and transferred internally on the falling edge.



The command byte defines the address of the first register to be accessed and the read/write mode. The address counter will auto increment after every access and will reset to zero after the last valid register is accessed. The read/write bit  $(R/\overline{W})$  defines if the following bytes will be read or write information.

Table 38. Command byte definition

| Symbol           | Value      | Description                                                           |
|------------------|------------|-----------------------------------------------------------------------|
| $R/\overline{W}$ |            | data read or data write selection                                     |
|                  | 0          | write data                                                            |
|                  | 1          | read data                                                             |
| SA               | 001        | subaddress; other codes will cause the device to ignore data transfer |
| RA               | 00h to 0Fh | register address range                                                |
|                  | R/W        | R/W 0 1 SA 001                                                        |

In <u>Figure 19</u> the Seconds register is set to 45 seconds and the Minutes register to 10 minutes.

SPI Real-time clock/calendar



In <u>Figure 20</u> the Months and Years registers are read. In this example, pins SDI and SDO are not connected together. In this configuration, it is important that pin SDI is never left floating: it must always be driven either HIGH or LOW. If pin SDI is left open, high  $I_{DD}$  currents will result.

