

# Very Low Power 8-Bit 32 kHz RTC Module with Digital Trimming, User RAM and Battery Switch-over

## Description

The V3025 is a low power CMOS real time clock with an integrated battery switch-over. The standby current is typically 2.5  $\mu A$  and the access time is 50 ns. The interface is a multiplexed address and data 8 bits bus. Multiplexing of address and data is handled by the input line  $\overline{A}$  /D. There are no busy flags in the V3025, internal time update cycles are invisible to the user's software. Time data can be read from the V3025 in 12 or 24 hour data formats. An external signal puts the V3025 in standby mode. Even in standby, the V3025 pulls the  $\overline{IRQ}$ pin active low on an internal alarm interrupt. Calendar functions include leap year correction and week number calculation. The V3025 can be synchronized to an external 50 Hz signal or to the nearest second or minute. The integrated battery switch-over supply the real time clock part by  $V_{DD}$  as long as  $V_{DD}$  is higher than  $V_{BAT}$ . When  $V_{DD}$  decreases under  $V_{BAT}$ , the output  $\overline{PFO}$  comes active and the real clock is supplied by the battery or the supercap.

#### Applications

- Industrial controllers
- □ Alarm systems with periodic wake up
- □ PABX and telephone systems
- Point of sale terminals
- □ Automotive electronics
- Personal computers

#### **Typical Operating Configuration** V<sub>QD</sub> $V_{DD}$ Data Bus Peripherals Address Bus CPU Decoder Other IRQ WR or R/W -0 RD or DS RD WR S ress Data 6 S WR A D Q Addr RAM FO V3025 in SO -28 Vol VBAT V. 3.6 V 100 nF =100 nF Fig. 1

#### Features

- Built-in quartz with digital trimming and temperature compensation facilities
- □ INTEL and MOTOROLA interface compatibility
- □ 15 ns typical access time at 5.0V
- □ 1.2 µA typical standby current at 3.0V
- □ Wide supply voltage range,  $2.0 \le V_{DD} \le 5.5V$
- □ Integrated battery switch-over
- □ Battery voltage range, 2.0  $\leq$  V<sub>BAT</sub>  $\leq$  4.0V
- No busy state
- No external components required
- BCD format
- □ Frequency measurements
- Time set lock mode
- Week number calculation
- Clock counts up to 99 years
- Leap year correction
- □ 12 or 24 hour data format
- Output programmable interrupts
- □ Alarm interrupt, programmable up to one month
- □ Timer interrupt, programmable up to 24 hours
- □ Time to 1/100 of a second
- To external time reference synchronisation
- □ 50 Hz or nearest s/min synchronisation
- Dever fail input PFI
- Power fail output or Reset output PFO
- **\Box** Tri-state bus capability when power fail ( $\overline{PFI} = 0$ )
- User RAM
- □ Temperature range -40 to +85°C
- Package SO28

#### **Pin Assignment**

| SO28             |       |                  |
|------------------|-------|------------------|
| SYNC 🗌 🌒         |       | V <sub>BAT</sub> |
| PFI              | -     | AD7              |
| AD0              |       | AD6              |
| AD1 📃            |       | AD5              |
| AD2 📃            |       | AD4              |
| AD3 🔛            | V3025 | RD               |
| Ā/D              |       | WR               |
|                  |       | CS               |
| V <sub>OUT</sub> |       | PFO              |
| V <sub>ss</sub>  |       | V <sub>DD</sub>  |
| V <sub>ss</sub>  |       |                  |
|                  |       | Fig. 2           |



#### **Absolute Maximum Ratings**

| Parameter                                                                                  | Symbol              | Conditions               |
|--------------------------------------------------------------------------------------------|---------------------|--------------------------|
| Maximum voltage at $V_{\text{DD}}$ and $V_{\text{BAT}}$                                    | V <sub>SUPmax</sub> | V <sub>SS</sub> + 7.0V   |
| Max. voltage at remaining pins                                                             | V <sub>SUP</sub>    | V <sub>DD</sub> + 0.3V   |
| Min. voltage on all pins                                                                   | V <sub>min</sub>    | $V_{SS} - 0.3V$          |
| Maximum storage temperature                                                                | T <sub>STOmax</sub> | +125°C                   |
| Minimum storage temperature                                                                | T <sub>STOmin</sub> | -55°C                    |
| Maximum electrostatic discharge to MIL-STD-883C method 3015.7 with ref. to V <sub>SS</sub> | V <sub>Smax</sub>   | 1000V                    |
| Maximum soldering conditions                                                               | T <sub>Smax</sub>   | 250°C x 10s              |
| Shock resistance                                                                           |                     | 5000 g.<br>0.3ms, ½ sine |
|                                                                                            |                     | Table 1                  |

Stresses above these listed maximum ratings may cause permanent damages to the device. Exposure beyond specified operating conditions may affect device reliability or cause malfunction.

#### **Handling Procedures**

This device has built-in protection against high static voltages or electric fields; however, anti-static precautions must be taken as for any other CMOS component. Unless otherwise specified, proper operation can only occur when all terminal voltages are kept within the voltage range. Unused inputs must always be tied to a defined logic voltage level.

| Operating Conditions  |        |     |  |  |
|-----------------------|--------|-----|--|--|
| Parameter             | Symbol | Mi  |  |  |
| Operating temperature | TA     | -4( |  |  |

| Parameter                                 | Symbol           | Min | Тур | Max | Unit   |
|-------------------------------------------|------------------|-----|-----|-----|--------|
| Operating temperature                     | T <sub>A</sub>   | -40 |     | +85 | °C     |
| Main supply voltage                       | V <sub>DD</sub>  | 2   |     | 5.5 | V      |
| Battery supply voltage                    | V <sub>BAT</sub> | 2   |     | 4   | V      |
| Logic supply voltage                      | V <sub>SUP</sub> | 2.0 | 5.0 | 5.5 | V      |
| Supply voltage dv/dt<br>(power-up & down) | dv/dt            |     |     | 6   | V/µs   |
| Decoupling capacitor                      |                  |     | 100 |     | nF     |
|                                           |                  |     |     | Та  | able 2 |

## **Electrical Characteristics**

. . . 10.1. . 0.5%

| Parameter                         | Symbol           | Test Conditions                                                               | Min                  | Тур             | Max           | Unit    |
|-----------------------------------|------------------|-------------------------------------------------------------------------------|----------------------|-----------------|---------------|---------|
| Standby current (note 1)          | I <sub>DD1</sub> | $V_{DD} = 3 V, V_{BAT} = 0V, \overline{PFI} = 0$                              |                      | 1.2             | 10            | μA      |
|                                   | I <sub>DD2</sub> | $V_{DD} = 5.5 V, \overline{PFI} = 0$                                          |                      | 2.5             | 15            | μA      |
| Standby current (note 1)          | I <sub>BAT</sub> | $V_{DD} = 0 V$ , $\overline{PFI} = 0$                                         |                      | 1.3             | 10            | μA      |
| Dynamic current (note 2)          | I <sub>DYN</sub> | $\overline{CS} = 4 \text{ MHz}, \overline{RD} = V_{SS}$                       |                      |                 | 1.5           | mA      |
|                                   |                  | $\overline{WR} = V_{DD}$                                                      |                      |                 |               |         |
| IRQ (open drain)                  |                  |                                                                               |                      | 1               |               |         |
| Output low voltage                | V <sub>OL</sub>  | I <sub>OL</sub> = 6 mA                                                        |                      |                 | 0.4           | V       |
| Output low voltage                | V <sub>OL</sub>  | $I_{OL} = 1 \text{ mA}, V_{DD} = 2 \text{ V}$                                 |                      |                 | 0.4           | V       |
| Inputs and Outputs                | •                |                                                                               |                      |                 |               |         |
| Input logic low                   | VIL              | T <sub>A</sub> = +25°C                                                        |                      |                 | $0.2 V_{SUP}$ | V       |
| Input logic high                  | VIH              | $T_{A} = +25^{\circ}C$                                                        | 0.8 V <sub>SUP</sub> |                 |               | V       |
| Output logic low                  | V <sub>OL</sub>  | I <sub>OL</sub> = 6 mA                                                        |                      |                 | 0.4           | V       |
| Output logic high                 | V <sub>OH</sub>  | I <sub>ОН</sub> = 6 mA                                                        | 2.4                  |                 |               | V       |
| PFI activation voltage            | V <sub>PFL</sub> |                                                                               |                      | $0.5 V_{DD}$    |               | V       |
| PFI hysteresis                    | V <sub>H</sub>   | $T_A = +25^{\circ}C$                                                          |                      | 100             |               | mV      |
| Pullup on SYNC                    | I <sub>LS</sub>  | V <sub>ILS</sub> = 0.8 V                                                      | 20                   | 40              |               | μA      |
| Input leakage                     | I <sub>IN</sub>  | $V_{SS} < V_{IN} < V_{DD}$                                                    |                      | 5               | 1000          | nA      |
| Output tri-state leakage          | I <sub>TS</sub>  | <u>CS</u> = 1                                                                 |                      | 5               | 1000          | nA      |
| <b>Oscillator Characteristics</b> |                  |                                                                               |                      |                 |               |         |
| Starting voltage                  | V <sub>STA</sub> | T <sub>A</sub> ≥ +25°C                                                        | 2                    |                 |               | V       |
|                                   | V <sub>STA</sub> |                                                                               |                      | 2.5             |               | V       |
| Frequency Characteristics         | 5                |                                                                               |                      |                 |               |         |
| Start-up time                     | T <sub>STA</sub> |                                                                               |                      | 1               |               | S       |
| Frequency tolerance               | ∆f/f             | $T_A$ = +25°C addr. 10 hex = 00 hex                                           | 150                  | 210<br>(note 4) | 251           | ppm     |
| Frequency stability               | f <sub>sta</sub> | $2.0 \le V_{DD} \le 5.5 \text{ V} \text{ (note 3)}$                           |                      | 1               | 5             | ppm/V   |
| Temperature stability             | t <sub>sta</sub> | addr. 10 hex = 00 hex                                                         |                      | see Fig.6       |               | ppm     |
| Aging                             | t <sub>aq</sub>  | $T_A = +25^{\circ}C$ , first year                                             |                      | Ŭ               | ±5            | ppm/yea |
| Accuracy versus switch-<br>over   | A <sub>sw</sub>  | $V_{BAT}$ = 3V, 10 pulses of $V_{DD}$<br>switching between 2 to 5V in<br>70ms |                      | 0.2             |               | ppm     |

**Note 1**: With  $\overline{PFO} = 0$  (V<sub>SS</sub>) all I/O pads can be tri-state, tested.

With  $\overline{PFO} = 1$  (V<sub>SUP</sub>),  $\overline{CS} = 1$  (V<sub>DD</sub>) and all other I/O pads fixed to V<sub>SUP</sub> or V<sub>SS</sub>: same standby current, not tested. Note 2: All other inputs to V<sub>DD</sub> and all outputs open.

Note 3: At a given temperature.

Note 4: See Fig. 5



## **Switch-over Electrical Characteristics**

 $T_A$  = -40 to +85°C, inputs to V<sub>DD</sub>, outputs not connected, unless otherwise specified

| Parameter                                                    | Symbol           | Test Conditions                                 | Min  | Тур  | Max  | Unit  |
|--------------------------------------------------------------|------------------|-------------------------------------------------|------|------|------|-------|
| ON resistance of V <sub>DD</sub> to V <sub>OUT</sub>         | R <sub>VDD</sub> | $V_{DD} = 3V, V_{BAT} = 0V, I_{OUT} = 100mA$    |      | 4    | 8    | Ω     |
| ON resistance of V <sub>BAT</sub> to V <sub>OUT</sub>        | R <sub>BAT</sub> | $V_{DD} = 0V, V_{BAT} = 3V, I_{OUT} = 20mA$     |      | 24   | 40   | Ω     |
| $V_{DD}$ voltage over $V_{BAT}$ for switching                | $V_{SVDD}$       | $V_{BAT} = 3V, V_{OUT}$ open                    | 3.00 | 3.21 | 3.45 | V     |
| $V_{\text{DD}}$ voltage under $V_{\text{BAT}}$ for switching | $V_{SBAT}$       | $V_{BAT} = 3V, V_{OUT}$ open                    | 2.98 | 3.08 | 3.18 | V     |
| V <sub>DD</sub> rising edge switching                        | T <sub>RDD</sub> | $V_{BAT}$ = 3V, $V_{DD}$ rise from 2.8V to 3.5V |      | 14   | 100  | μs    |
| delay to PFO and VOUT                                        |                  |                                                 |      |      |      |       |
| VDD falling edge switching                                   | T <sub>FDD</sub> | $V_{BAT}$ = 3V, $V_{DD}$ falling from 3.5V to   |      | 8    | 60   | μs    |
| delay to PFO and VOUT                                        |                  | 2.8V                                            |      |      |      |       |
|                                                              |                  |                                                 |      |      |      | Table |

## **Timing Characteristics**

 $V_{DD} = 5.0V \pm 10\%$ ,  $V_{BAT} = 0V$ ,  $V_{SS} = 0V$  and  $T_A = -40$  to  $+85^{\circ}C$ 

| Parameter                                                            | Symbol           | Test Conditions          | Min | Тур | Max | Unit    |
|----------------------------------------------------------------------|------------------|--------------------------|-----|-----|-----|---------|
| Chip select duration, write cycle                                    | t <sub>cs</sub>  |                          | 50  |     |     | ns      |
| Write pulse duration                                                 | t <sub>WR</sub>  |                          | 50  |     |     | ns      |
| Time between two transfers                                           | t <sub>w</sub>   |                          | 100 |     |     | ns      |
| RAM access time (note 1)                                             | t <sub>ACC</sub> | C <sub>LOAD</sub> = 50pF |     | 50  | 60  | ns      |
| Data valid to Hi-impedance (note 2)                                  | t <sub>DF</sub>  |                          | 10  | 30  | 40  | ns      |
| Write data settle time (note 3)                                      | t <sub>DW</sub>  |                          | 50  |     |     | ns      |
| Data hold time (note 4)                                              | t <sub>DH</sub>  |                          | 10  |     |     | ns      |
| Advance write time                                                   | t <sub>ADW</sub> |                          | 10  |     |     | ns      |
| PF response delay                                                    | t <sub>PF</sub>  |                          |     |     | 100 | ns      |
| Rise time (all inputs)                                               | t <sub>R</sub>   |                          |     |     | 200 | ns      |
| Fall time (all inputs)                                               | t⊨               |                          |     |     | 200 | ns      |
| $\overline{\text{CS}}$ delay after $\overline{\text{A}}$ /D (note 5) | tĀ /Ds           |                          | 5   |     |     | ns      |
| $\overline{\text{CS}}$ delay to $\overline{\text{A}}$ /D             | tĀ /Dt           |                          | 10  |     |     | ns      |
|                                                                      |                  | -                        | •   | •   | •   | Table 4 |

Note 1:  $t_{ACC}$  starts from  $\overline{RD}$  (  $\overline{DS}$  ) or  $\overline{CS}$  , whichever activates last

Typically,  $t_{ACC}$  = 5 + 0.9 C<sub>EXT</sub> in ns; where C<sub>EXT</sub> (external parasitic capacitance) is in pF

Note 2:  $t_{DF}$  starts from  $\overline{RD}$  (  $\overline{DS}$  ) or  $\overline{CS}$  , whichever deactivates first

Note 3:  $t_{DW}$  ends at  $\overline{WR}$  (R/ $\overline{W}$ ) or  $\overline{CS}$ , whichever deactivates first

Note 4:  $t_{DH}$  starts from  $~\overline{WR}~~(R/~\overline{W}$  ) or  $~\overline{CS}$  , whichever deactivates first

**Note 5**:  $\overline{A}$  /D must come before a  $\overline{CS}$  and  $\overline{RD}$  or a  $\overline{CS}$  and  $\overline{WR}$  combination. The user has to guarantee this.



# Typical V<sub>DD</sub> Current vs. Temperature



# Typical V<sub>BAT</sub> Current vs. Temperature



# Typical Frequency on IRQ



Fig. 5



## **Module Characteristic**



## Typical V<sub>DD</sub> Switch Resistance vs. Temperature



Fig. 7

## Typical Battery Switch Resistance vs. Temperature



Fig. 8



## **Timing Waveforms**

Read Timing for Intel ( $\overline{RD}$  and  $\overline{WR}$  Pulse) and Motorola ( $\overline{DS}$  or  $\overline{RD}$  pin tied to  $\overline{CS}$  and  $R/\overline{W}$ )





#### Intel Interface Write Timing













Fig. 9d



#### Motorola Interface Motorola Write



Write





Read



Fig. 9g



## General Block Diagram





## Pin Description SO28 Package

| Pin   | Name            | Description                          |         |
|-------|-----------------|--------------------------------------|---------|
| 1     | SYNC            | Time synchronization                 | I       |
| 2     | PFI             | Power fail                           | I       |
| 3     | AD0             | Bit 0 from MUX address /<br>data bus | I/O     |
| 4     | AD1             | Bit 1 from MUX address /<br>data bus | I/O     |
| 5     | AD2             | Bit 2 from MUX address /<br>data bus | I/O     |
| 6     | AD3             | Bit 3 from MUX address /<br>data bus | I/O     |
| 7     | Ā /D            | Address / data decode                | I       |
| 8     | ĪRQ             | Interrupt request                    | 0       |
| 9     | Vout            | Switch-over output                   | 0       |
| 10-14 | V <sub>SS</sub> | Supply ground (substrate)            | GND     |
| 15-19 | V <sub>DD</sub> | Positive supply terminal             | PWR     |
| 20    | PFO             | Power fail output                    | 0       |
| 21    | CS              | Chip select                          | I       |
| 22    | WR              | WR (Intel) or R/W<br>(Motorola)      | I       |
| 23    | RD              | RD (Intel) or DS (Motorola)          | I.      |
| 24    | AD4             | Bit 4 from MUX address /<br>data bus | I/O     |
| 25    | AD5             | Bit 5 from MUX address /<br>data bus | I/O     |
| 26    | AD6             | Bit 6 from MUX address /<br>data bus | I/O     |
| 27    | AD7             | Bit 7 from MUX address /<br>data bus | I/O     |
| 28    | VBAT            | Battery supply                       | PWR     |
|       |                 |                                      | Table 5 |

#### Functional Description Power Supply, Data Retention and Standby

The V3025 is put in standby mode by activating the  $\overline{PFI}$  input. When pulled logic low,  $\overline{PFI}$  will disable the input lines, and immediately take to high impedance the lines AD 0-7. Input states must be under control whenever  $\overline{PFI}$  is deactivated. If no specific power fail signal can be provided,  $\overline{PFI}$  can be tied to the system  $\overline{RESET}$ . Even in standby the interrupt request pin  $\overline{IRQ}$  will pull to ground upon an unmasked alarm interrupt occurring.

## Switch-over

The switch-over supplies the core of the RTC. The I/O pads are supplied by V<sub>DD</sub>, except for  $\overline{IRQ}$  and  $\overline{SYNC}$ . The  $\overline{SYNC}$  input is internally pulled-up to V<sub>OUT</sub>,  $\overline{IRQ}$  can be externally pulled-up between 2 and 5.5V. The switch-over circuitry works in recovery mode. During switching, both transistors (V<sub>DD</sub> to V<sub>OUT</sub> and V<sub>BAT</sub> to V<sub>OUT</sub>) are ON. This is to guarantee that the RTC is always supplied. The power fail signal becomes active ( $\overline{PFO}$  = 0) when V<sub>DD</sub> < V<sub>BAT</sub> (see Table 4).

## Initialisation

When power is first applied to the V3025 all registers have a random value.

To initialise the V3025, software must first write a 1 to the initialisation bit (addr. 2 bit 4) and then a 0. This sets the Frequency Tuning bit and clears all other status bits.

The time and date parameters should then be loaded into the RAM (addr. 20 to 28 hex) and then transferred to the reserved clock area using the clock command followed by a write.

The digital trimming register must then be initialised by writing 210 (D2 hex) to it, if Frequency Tuning is not required. After having written a value to the digital trimming register the frequency tuning mode bit can be cleared.

## **RAM Configuration**

The RAM area of the V3025 has a reserved clock and time area, a data space, user RAM and an address command space (see Table 10 or Fig. 10). The reserved clock and timer area is not directly accessible to the user, it is used for internal time keeping and contains the current time and date plus the timer parameters.

## **Data Space**

All locations in the data space are Read/Write. The data space is directly accessible to the user and is divided into five areas:

**Status Registers** – three registers used for status and control data for the device (see Table 7, 8 and 9). Reserved bits must be set to 0.

**Digital Trimming Register** – a special function described under "Frequency Tuning".

**Time and Date Registers** – 9 time and date locations which are loaded with, either the current time and date parameters from the reserved clock area or the time and date parameters to be transferred to the reserved clock area.

**Alarm Registers** – 5 locations used for setting the alarm parameters.

**Timer Registers** – 4 locations which are loaded with either the timer parameters from the reserved timer area or the timer parameters to be transferred to the reserved timer area.

## User RAM

The V3025 has 16 bytes of general purpose RAM available for the users applications. This RAM block is located at addresses 50 to 5F hex and is maintained even in the standby mode ( $\overline{PFI}$  active). The commands, or the time set lock bit, have no effect on the user RAM block. Reading or writing to the user RAM is similar to reading or writing to any system RAM address.



#### **Status Words**









## Address Command Space

This space contains the three commands used for carrying out the transfers between the Time and Data Register and / or the Timer Registers and the reserved clock and timer area.

| Address   |     | Parameter                | Range |
|-----------|-----|--------------------------|-------|
| Dec       | Hex |                          |       |
|           |     | Data Space               |       |
| Status    |     |                          | 1     |
| 00        | 00  | status 0                 |       |
| 01        | 01  | status 1                 |       |
| 02        | 02  | status 2                 |       |
| Special p |     |                          |       |
| 16        | 10  | digital trimming         | 0-255 |
| Clock     | 1   |                          |       |
| 32        | 20  | 1/100 second             | 00-99 |
| 33        | 21  | seconds                  | 00-59 |
| 34        | 22  | minutes                  | 00-59 |
| 35        | 23  | hours (note 1)           | 00-23 |
| 36        | 24  | date                     | 01-31 |
| 37        | 25  | month                    | 01-12 |
| 38        | 26  | year                     | 00-99 |
| 39        | 27  | week day                 | 01-07 |
| 40        | 28  | week number              | 00-53 |
| Alarm     |     |                          |       |
| 48        | 30  | 1/100 second             | 00-99 |
| 49        | 31  | seconds                  | 00-59 |
| 50        | 32  | minutes                  | 00-59 |
| 51        | 33  | hours (note 1 & 2)       | 00-23 |
| 52        | 34  | date                     | 01-31 |
| Timer     | 1   |                          |       |
| 64        | 40  | 1/100 second             | 00-99 |
| 65        | 41  | seconds                  | 00-59 |
| 66        | 42  | minutes                  | 00-59 |
| 67        | 43  | hours                    | 00-23 |
| User RAM  |     |                          |       |
| 80        | 50  | user RAM, byte 0         | ļ     |
| 81        | 51  | user RAM, byte 1         | ļ     |
| 82        | 52  | user RAM, byte 2         |       |
| 83        | 53  | user RAM, byte 3         | ļ     |
| 84        | 54  | user RAM, byte 4         | ļ     |
| 85        | 55  | user RAM, byte 5         |       |
| 86        | 56  | user RAM, byte 6         |       |
| 87        | 57  | user RAM, byte 7         | ļ     |
| 88        | 58  | user RAM, byte 8         | ļ     |
| 89        | 59  | user RAM, byte 9         |       |
| 90        | 5A  | user RAM, byte 10        |       |
| 91        | 5B  | user RAM, byte 11        |       |
| 92        | 5C  | user RAM, byte 12        |       |
| 93        | 5D  | user RAM, byte 13        |       |
| 94        | 5E  | user RAM, byte 14        |       |
| 95        | 5F  | user RAM, byte 15        |       |
|           |     | ress Command Space       | 1     |
| 240       | F0  | clock and timer transfer |       |
| 241       | F1  | clock transfer           |       |
| 242       | F2  | timer transfer           | Table |

Table 10

- Note 1: The MSB (bit 7) of the hours byte (addr. 23 hex for the clock and 33 hex for the alarm) are used as AM/PM indicators in the 12 hour time data format and reading of the hours byte must be preceded by masking of the AM/PM bit. A set AM/PM bit indicates PM. In the 24 hour time data format the bit will always be zero.
- **Note 2**: The alarm hours, addr. 33 hex, must always be rewritten after a change between 12 and 24 hour modes.



## Communication

Data transfer is in 8 bit parallel form. All time data is in packed BCD format with tens data on lines AD7-4 and units on lines AD3-0. To access information within the RAM (see Fig.10) first write the RAM address, then read or write from or to this location. Fig.11 shows the two steps needed.

The lines AD0-7 will be treated as an address when pin  $\overline{A}$  /D is low, and as data when  $\overline{A}$  /D is high. Pin  $\overline{A}$  /D must not change state during any single read or write access. One line of the address bus (e.g. A0) can be used to implement the  $\overline{A}$  /D signal (see "Typical Operating Configuration", Fig.1). Until a new address is written, data accesses ( $\overline{A}$  /D high) will always be to the same RAM address.

## **Communication Sequence**



## Fig. 11

## Access Considerations

The communication sequence shown in Fig.11 is reentrant. When the address is written to the V3025 (ie. first step of the communication sequence) it is stored in an internal address latch. Software can read the internal address latch at any time by holding the  $\overline{A}$  /D line low during a read from the V3025. So, for example, an interrupt routine can read the address latch and push it on to a stack, popping it when finished to restore the V3025.

N.B. Alarm and timer interrupt routines can reprogram the alarm and timer without it being necessary to read or reprogram the clock.

## Commands

The commands allow software to transfer the clock and timer parameters in a sequence (eg. seconds, minutes, hours, etc.) without any danger of an internal time update with carry over corrupting the data. They also avoid delaying internal time updates while using the V3025, as updates occurring in the reserved clock and timer area are invisible to software. Software writes or reads parameters to or from the RAM only.

There are three commands that occupy the command address space in the RAM. The function of these commands is to transfer data from the reserved clock and timer area to the RAM or to transfer data in the opposite direction, from the RAM to the reserved clock and timer area.

The commands take place in two steps as do all other communications. The command address is sent with  $\overline{A}$  /D low. This is followed by either a read ( $\overline{RD}$ ) or a write ( $\overline{WR}$ ), with  $\overline{A}$  /D high, to determine the direction of the transfer. If the second step is a read then the data is transferred from the reserved clock and timer area to the RAM and if the second step is a write then the data that has already been loaded into the RAM clock and/or timer

locations is transferred to the reserved clock and/or timer area.

#### **Clock and Calendar**

The time and date locations in RAM (see Table 10) provide access to the 1/100 seconds, seconds, minutes, hours, date, month, year, week day and week number. These parameters have the ranges indicated in Table 10. The V3025 may be programmed for 12 or 24 hour time format (see section "12/24 Data Format"). If a parameter is found to be out of range, it will be cleared when the units value on its being next incremented is equal to or greater than 9 eg. B2 will be set to 00 after the units have incremented to 9 (ie. B9 to 00). The device incorporates leap year correction and week number calculation at the beginning of a year. If the first day of the year is day 05, 06 or 07 of the week, then it is given a zero week number, otherwise it becomes week 1. Week days are numbered from 1 to 7 with Monday as day 1.

Reading of the current time and date must be preceded by a clock command. The time and date from the last clock command is held unchanged in RAM.

When transferring data to the reserved clock and timer area remember to clear the time set lock bit first.

#### Timer

The timer can be used either for counting elapsed time, or for giving an interrupt ( $\overline{IRQ}$ ) on being incremented from 23:59:59:99 to 00:00:00:00. The timer counts up with a resolution of 1/100 second in the timer reserved areas. The timer enable/disable bit (addr. 00 hex, bit 3) must be set by software to allow the timer to be incremented. The timer is incremented in the reserved timer area, every internal time update (10 ms). The timer flag (addr. 01 hex, bit 6) is set when the timer rolls over from 23:59:59:99 to 00:00:00:00 and the  $\overline{IRQ}$  becomes active if the timer mask bit (addr. 01, bit 2) is set. The  $\overline{IRQ}$  will remain active until software acknowledges the interrupt by clearing the timer flag. The timer is incremented in the standby mode, however it will not cause  $\overline{IRQ}$  to become active until power (V<sub>DD</sub>) has been restored.

**Note**: The user should ensure that a time lapse of at least 60 microseconds exists between the falling edge of the  $\overline{IRQ}$  and the clearing of the timer flag.



#### Reading the Clock



#### Setting the Timer (Time Set Lock Bit = 0)



**Note**: Commands are only valid as commands when the  $\overline{A}$  /D line is low. Writing F2 hex with the  $\overline{A}$  /D line high, as in the last box of Fig. 11, serves only to activate the V3025 write pin which determines the direction of transfer.

#### Alarm

An alarm date and time may be preset in RAM addresses 30 to 34 hex. The alarm function can be activated by setting the alarm enable / disable bit (addr. 00 hex, bit 2). Once enabled the preset alarm time and date are compared, every internal time update cycle (10 ms), with the clock parameters in the reserved clock area. When the clock parameters equal the alarm parameters the alarm flag (addr. 01 hex, bit 5) is set. If the alarm mask bit (addr. 01 hex, bit 1) is set, the IRQ pin goes active. The alarm flag indicates to software the source of the interrupt. IRQ will remain active until software acknowledges the interrupt by clearing the alarm flag. If the alarm is enabled, and an alarm address set to FF hex, this parameters is not compared with the associated clock

parameter. Thus it is possible to achieve a repeat feature where an alarm occurs every programmed number of seconds, or seconds and minutes, or seconds, minutes and hours. The V3025 pulls the open drain  $\overline{IRQ}$  line active low during standby when an alarm interrupt occurs. If the 12/24 hour mode is changed then the alarm hours must be re-initialised.

**Note**: The user should ensure that a time lapse of at least 60 microseconds exists between the falling edge of the  $\overline{IRQ}$  and the clearing of the alarm flag.



# IRQ

The  $\overline{\text{IRQ}}$  output is used by 4 of the V3025's features. These are:

- 1. Pulse, to provide periodic interrupts to the microprocessors at pre-programmed intervals;
- 2. Alarm to provide an interrupt to the microprocessor at a pre-programmed time and date;
- 3. Timer, to provide an interrupt to the microprocessor when the time rolls over from 23:59:59:99 to 00:00:00:00; and
- 4. Frequency trimming (see section "Frequency Trimming").

The first 3 features listed are similar in the way they provide interrupts to the microprocessor. Each of the 3 has an enable / disable bit, a flag bit, and an interrupt mask bit. The enable / disable bit allows software to select a feature or not. A set flag bit indicates that an enable feature has reached its interrupt condition. Software must clear the flag bit. The interrupt mask bit allows or disallows the IRQ output to become active when the flag bit is se. The  $\overline{IRQ}$  output becomes active whenever any interrupt flag is set which also has its mask bit set. For all sources of maskable interrupts within the V3025, the IRQ output will remain active until software clears the interrupt flag. The IRQ output is the logical OR of all the unmasked interrupt flags. The IRQ output is open drain so an external pullup to  $V_{\text{DD}}$  is needed. In standby (PF active) the IRQ output will be active if the alarm mask bit (addr, 01 hex, bit 1) is set and the alarm flag is also set. The timer or the pulse feature cannot cause the  $\overline{IRQ}$  output to become active while in standby.

## Snychronization

There are 3 ways to synchronize the V3025. It can be synchronized to 50 Hz, the nearest second, or the nearest minute. Synchronization mode is selected by setting one of the bits 5 to 7 at addr. 02 hex, in accordance with Table 8. If more than one bit is set then all the synchronization bits are disabled. If the SYNC input is set low for longer than 200  $\mu$ s, while in the synchronization mode, the clock will synchronize to the falling edge of the signal. Synchronization to the nearest second implies that the 1/100 seconds are cleared to zero and if the contents were > 50, the seconds register is incremented. Synchronization to the nearest minute implies that the seconds are cleared to zero and if the contents were > 30, the minutes register is incremented. Fractions of seconds are cleared.

#### Pulse

There are 4 programmable pulse frequencies available on the V3025, these are every 10 ms, 100 ms, second or minute. The pulse feature is activated by setting the pulse enable / disable bit at address 00, bit 1. The pulse frequency is selected by setting one of the bit 0 to 3 at address 02 hex (see Table 9). If more than one of the pulse bits is set then the feature is disabled. At the selected interval the pulse flag bit (addr. 01 hex, bit 4) is set. If the pulse mask bit (addr. 01 hex, bit 0) is set then the IRQ pin goes active. The pulse flag indicates to software the source of the interrupt. IRQ will remain active until software acknowledges the interrupt by clearing the pulse flag. The pulse feature is disabled while in standby. Upon power restoration the pulse feature is enabled if enabled prior to standby. See also the section "Frequency Tuning".

Note: The user should ensure that a time lapse of at least 60 microseconds exists between the falling edge of the  $\overline{IRQ}$  and the clearing of the pulse flag.

#### Time Set Lock

The time set lock control bit is located at address 00 hex, bit 5 (see Table 7). When set by software, this bit disables any transfer from the RAM to the reserved clock and timer area as well as inhibiting any write to the digital trimming register at address 10 hex. When the time set lock bit is set the following transfer operations are disabled:

The clock command followed by write, the timer command followed by write, the clock and timer command followed by write, and writing to the digital trimming register

A set bit prevents unauthorized overwriting of the reserved clock and timer area. Reading of the reserved clock and timer area, using the commands, is not affected by the time set lock bit. Clearing the time set lock bit by software will re-enable the above listed commands. On initialisation the time set lock bit is cleared. The time set lock bit does not affect the user RAM (addr. 50 to 5F hex).

#### **Frequency Tuning**

The V3025 offers a key feature called "Digital Trimming", which is used for the clock accuracy adjustment. Unlike the traditional capacitor trimming method which tunes the crystal oscillator, the digital trimming acts on the divider chain, allowing the clock adjustment by software. The oscillator frequency itself is not affected.

## The Principle of Digital Trimming

With the digital trimming disabled (ie. digital trimming register set to 00 hex), the oscillator and the first stages of the divider chain will run slightly too fast (typ. 210 ppm: ppm = parts per million), and will generate a 100 Hz signal with a frequency of typically 100.021 Hz. To correct this frequency, the digital trimming logic will inhibit every 31 seconds, a number of clock pulses, as set in the digital trimming register. Since the duration of 31 seconds corresponds to 1'015'808 oscillator cycles, the digital trimming has a resolution of 0.984 ppm. In other words every increment by 1 of the digital trimming value will slow down the clock by 0.984 ppm, which permits the accuracy of ± 0.5 ppm to be reached. Note that a 1 ppm error will result in a 1 second difference after 11.5 days, or a 1 minute difference after 694 days ! The trimming range of the V3025 is from 0 to 251 ppm. The 251 ppm correction is obtained by writing 255 (FFhex) into the digital trimming reaister.



#### How to Determine the Digital Trimming Value

The value to write into the digital trimming register has to be determined by the following procedure:

- Initialise the V3025 by writing a 1 and then a 0 into the "Initialisation Bit" of the status register 2 (addr. 02 hex, bit 4). This activates the frequency tuning mode in status register 0 (addr. 00 hex, bit 1) and clears the other status bits.
- 2. Write the value 00 hex into the digital trimming register (addr 10 hex). From now, the IRQ output (open drain) will deliver the 100 Hz signal, which has a 20% duty cycle.
- 3. Measure the duration of 21 pulses at the IRQ output, with the trigger set for the falling edge. It is possible also to divide the IRQ frequency by 21, using a TTL or CMOS external circuit.
- 4. Compute the frequency error in ppm: freq. error =  $\frac{210\text{ms} - \text{measured value in ms}}{210\text{ms}} \times 10^6$
- 5. Compute the corrective value to write into the digital trimming register.

Digital trimming value = frequency error / 0.984

- 6. Write this value into the digital trimming register.
- 7. Switch off the frequency tuning mode in status 0 (addr. 00 hex, bit 0 set to 0).

The Real Time Clock circuit will now run accurately at an operating temperature equal to the calibration temperature. If the operating temperature differs from the one at calibration time, the graphs shown on Fig. 5 and 6 will help in determining the definitive value. If the mean operating temperature of the equipment is not known at calibration time, the equipment user will do the final correction with a software provided by the system designer. To avoid the calibration procedure, it is possible also to set the digital trimming register to 210 (D2 hex) as a standard starting value, and let the final equipment user perform the final adjustment on site, which will take the real temperature into account.

## **Time Correction at Room Temperature**

Let us consider that the duration of 21 pulses of the  $\overline{IRQ}$  signal is 209.97 ms at room temperature.

The frequency error is: (210 – 209.97) / 210 x 1E + 06 = 142.857 ppm

The value for the digital trimming register is: 142.857 / 0.984 = 145.18, rounded up to 145 ppm (91 hex)

#### **Time Correction with Change of Temperature**

If the mean temperature on site is known to be 45°C, the frequency error determined at room temperature has to be modified using the graphs or the equation of Fig. 6

$$\Delta f/f = -0.038 \text{ x} (45-25)^2 = 15.2 \text{ ppm}$$

The trimming value for 45°C will be:

(142.857 ppm – 15.2 ppm) / 0.984 = 129.73, rounded to 130 (82 hex)

#### 12 / 24 Hour Data Format

The V3025 can run in 12 hour data format. On initialisation the 12/24 hour bit addr. 00 bit 4 is cleared putting the V3025 in 24 hour data format. If the 12 hour data format is required then bit 4 at addr. 00 must be set. In the 12 hour data format the AM/PM indicator is the MSB of the hours register addr. 23 bit 7. A set bit indicates PM. When reading the hours in the 12 hour data format software should mask the MSB of the hours register. In the 24 hour data format the MSB is always zero.

The internal clock registers change automatically between 12 and 24 hour mode when the 24/12 hour bit is changed. **The alarm hours however must be rewritten.** 

#### Test

From the various test features added to the V3025 some may be activated by the user. Table 7 shows the test bits. Table 11 shows the three available modes and how they may be activated.

The first accelerates the incrementing of the parameters in the reserved clock and timer area by 32.

The second causes all clock and timer parameters, in the reserved clock and timer area, to be incremented in parallel at 100 Hz with no carry over, ie. independently of each other.

The third test mode combines the previous two resulting in parallel incrementing at 3.2 kHz.

While test bit 1 is set (addr. 00 hex, bit 7) the digital trimming action is disabled and no pulses are removed from the divider chain. Test bit 0 (addr. 00 hex, bit 6) can be combined with digital trimming (see section "Frequency Tuning").

To leave test, the test bits (addr 00 hex, bits 6 and 7) must be cleared by software. Test corrupts the clock and timer parameters and so all parameters should be re-initialised after a test session.

#### **Test Modes**

| Addr.<br>00hex bit 7 | Addr.<br>00hex bit 6 | Function                                                                                                                                           |
|----------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                    | 0                    | Normal operation                                                                                                                                   |
| 0                    | 1                    | Acceleration by 32                                                                                                                                 |
| 1                    | 0                    | Parallel increment of all clock<br>and timer parameters at 100<br>Hz with no carry over;<br>dependent on the status of bit<br>3 at address 00 hex  |
| 1                    | 1                    | Parallel increment of all clock<br>and timer parameters at 3.2<br>kHz with no carry over;<br>dependent on the status of bit<br>3 at address 00 hex |

Table 11



# **Typical Operating Configuration**







- The formula in Fig. 5 is used by software to continually update the digital trimming register and so compensate the V3025 for the ambient temperature.
- The timer is used to measure the duration the valve is on.
- The alarm feature is used to turn the controller power on and off at the time programmed by software. The V3025 pulls IRQ active low on an alarm even in standby and thus can control the power on/off switch for the controller.

# **Typical Applications**

V3025 Interfaced with Intel CPU (RD and WR pulse)





## V3025 Interfaced with Motorola CPU ( $\overline{DS}$ or $\overline{RD}$ pin tied to $\overline{CS}$ , and R/ $\overline{W}$ )



## Ordering and Package Information Dimensions of 28-pin SOIC Package



Fig. 18

## **Ordering Information**

When ordering, please specify the complete part number.

| Part Number | Package     | Delivery Form | Package Marking<br>(first line) |
|-------------|-------------|---------------|---------------------------------|
| V3025SO28B  | 28-pin SOIC | Tape & Reel   | V3025 28SI                      |
| V3025SO28A  | 28-pin SOIC | Stick         | V3025 28SI                      |

EM Microelectronic-Marin SA cannot assume responsibility for use of any circuitry described other than circuitry entirely embodied in an EM Microelectronic-Marin SA product. EM Microelectronic-Marin SA reserves the right to change the circuitry and specifications without notice at any time. You are strongly urged to ensure that the information given has not been superseded by a more up-to-date version.

© EM Microelectronic-Marin SA, 09/04, Rev. F