

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









# **MCP7940M**

### Low-Cost I<sup>2</sup>C<sup>TM</sup> Real-Time Clock/Calendar with SRAM

#### **Timekeeping Features:**

- Real-Time Clock/Calendar (RTCC):
  - Hours, Minutes, Seconds, Day of Week, Day, Month, Year
  - Leap year compensated to 2399
  - 12/24 hour modes
- · Oscillator for 32.768 kHz Crystals:
  - Optimized for 6-9 pF crystals
- On-Chip Digital Trimming/Calibration:
  - ±1 PPM resolution
  - ±129 PPM range
- · Dual Programmable Alarms
- · Versatile Output Pin:
  - Clock output with selectable frequency
  - Alarm output
  - General purpose output

#### Low-Power Features:

- · Wide Voltage Range:
  - Operating voltage range of 1.8V to 5.5V
- · Low Typical Timekeeping Current:
  - Operating from Vcc: 1.2 µA at 3.3V

#### **User Memory:**

· 64-byte SRAM

#### **Operating Ranges:**

- 2-Wire Serial Interface, I<sup>2</sup>C<sup>™</sup> Compatible
  - I<sup>2</sup>C clock rate up to 400 kHz
- · Temperature Range:
  - Industrial (I): -40°C to +85°C

#### Packages:

 8-Lead SOIC, MSOP, TSSOP, PDIP and 2x3 TDFN

#### **General Description:**

The MCP7940M Real-Time Clock/Calendar (RTCC) tracks time using internal counters for hours, minutes, seconds, days, months, years, and day of week. Alarms can be configured on all counters up to and including months. For usage and configuration, the MCP7940M supports I<sup>2</sup>C communications up to 400 kHz.

The open-drain, multi-functional output can be configured to assert on an alarm match, to output a selectable frequency square wave, or as a general purpose output.

The MCP7940M is designed to operate using a 32.768 kHz tuning fork crystal with external crystal load capacitors. On-chip digital trimming can be used to adjust for frequency variance caused by crystal tolerance and temperature.

#### **Package Types**



FIGURE 1-1: TYPICAL APPLICATION SCHEMATIC



#### FIGURE 1-2: BLOCK DIAGRAM



#### 1.0 ELECTRICAL CHARACTERISTICS

### Absolute Maximum Ratings (†)

| Vcc                                                    | 6.5V              |
|--------------------------------------------------------|-------------------|
| All inputs and outputs (except SDA and SCL) w.r.t. Vss | 0.6V to Vcc +1.0V |
| SDA and SCL w.r.t. Vss                                 | 0.6V to 6.5V      |
| Storage temperature                                    | 65°C to +150°C    |
| Ambient temperature with power applied                 | 40°C to +125°C    |
| ESD protection on all pins                             | ≥ 4 kV            |

<sup>†</sup> NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

#### TABLE 1-1: DC CHARACTERISTICS

| DC CHA        | RACTERI      | STICS                                                      | Electrica<br>Industrial |                     | teristics:<br>Vcc = +1 |        | 5V TA = -40°C to +85°C                                 |
|---------------|--------------|------------------------------------------------------------|-------------------------|---------------------|------------------------|--------|--------------------------------------------------------|
| Param.<br>No. | Sym.         | Characteristic                                             | Min.                    | Typ. <sup>(2)</sup> | Max.                   | Units  | Conditions                                             |
| D1            | VIH          | High-level input voltage                                   | 0.7 Vcc                 | _                   | _                      | V      | _                                                      |
| D2            | VIL          | Low-level input voltage                                    | _                       | _                   | 0.3 Vcc<br>0.2 Vcc     | V<br>V | Vcc ≥ 2.5V<br>Vcc < 2.5V                               |
| D3            | VHYS         | Hysteresis of Schmitt<br>Trigger inputs<br>(SDA, SCL pins) | 0.05<br>Vcc             | _                   | _                      | V      | (Note 1)                                               |
| D4            | Vol          | Low-level output voltage (MFP, SDA pins)                   | _                       | _                   | 0.40                   | V      | IOL = 3.0 mA @ Vcc = 4.5V<br>IOL = 2.1 mA @ Vcc = 2.5V |
| D5            | ILI          | Input leakage current                                      | _                       | _                   | ±1                     | μΑ     | VIN = Vss or Vcc                                       |
| D6            | ILO          | Output leakage current                                     | _                       | _                   | ±1                     | μΑ     | Vout = Vss or Vcc                                      |
| D7            | CIN,<br>COUT | Pin capacitance<br>(SDA, SCL, MFP pins)                    | _                       | _                   | 10                     | pF     | Vcc = 5.0V <b>(Note 1)</b><br>TA = 25°C, f = 1 MHz     |
| D8            | Cosc         | Oscillator pin capacitance (X1, X2 pins)                   | _                       | 3                   | _                      | pF     | (Note 1)                                               |
| D9            | ICCREAD      | SRAM/RTCC register                                         | _                       | _                   | 300                    | μΑ     | Vcc = 5.5V, SCL = 400 kHz                              |
|               | ICCWRITE     | operating current                                          | _                       |                     | 400                    | μΑ     | Vcc = 5.5V, SCL = 400 kHz                              |
| D10           | ICCDAT       | Vcc data-retention current (oscillator off)                | _                       | _                   | 1                      | μΑ     | SCL, SDA, Vcc = 5.5V                                   |
| D11           | Ісст         | Timekeeping current                                        | _                       | 1.2                 |                        | μΑ     | Vcc = 3.3V (Note 1)                                    |

Note 1: This parameter is not tested but ensured by characterization.

<sup>2:</sup> Typical measurements taken at room temperature.

## **MCP7940M**

TABLE 1-2: AC CHARACTERISTICS

|               |         |                                                                                    | Electrical Ch   | aracteris | tics:       |       |                                              |
|---------------|---------|------------------------------------------------------------------------------------|-----------------|-----------|-------------|-------|----------------------------------------------|
| AC CHA        | RACTER  | ISTICS                                                                             | Industrial (I): |           | = +1.8V to  | 5.5V  | $TA = -40^{\circ}C \text{ to } +85^{\circ}C$ |
| Param.<br>No. | Symbol  | Characteristic                                                                     | Min.            | Тур.      | Max.        | Units | Conditions                                   |
| 1             | FCLK    | Clock frequency                                                                    |                 |           | 100<br>400  | kHz   | 1.8V ≤ VCC < 2.5V<br>2.5V ≤ VCC ≤ 5.5V       |
| 2             | THIGH   | Clock high time                                                                    | 4000<br>600     |           | _           | ns    | 1.8V ≤ VCC < 2.5V<br>2.5V ≤ VCC ≤ 5.5V       |
| 3             | TLOW    | Clock low time                                                                     | 4700<br>1300    |           | _           | ns    | 1.8V ≤ VCC < 2.5V<br>2.5V ≤ VCC ≤ 5.5V       |
| 4             | TR      | SDA and SCL rise time (Note 1)                                                     |                 |           | 1000<br>300 | ns    | 1.8V ≤ VCC < 2.5V<br>2.5V ≤ VCC ≤ 5.5V       |
| 5             | TF      | SDA and SCL fall time (Note 1)                                                     |                 |           | 1000<br>300 | ns    | 1.8V ≤ VCC < 2.5V<br>2.5V ≤ VCC ≤ 5.5V       |
| 6             | THD:STA | Start condition hold time                                                          | 4000<br>600     |           | _           | ns    | 1.8V ≤ VCC < 2.5V<br>2.5V ≤ VCC ≤ 5.5V       |
| 7             | Tsu:sta | Start condition setup time                                                         | 4700<br>600     | _         | _           | ns    | 1.8V ≤ VCC < 2.5V<br>2.5V ≤ VCC ≤ 5.5V       |
| 8             | THD:DAT | Data input hold time                                                               | 0               | _         | _           | ns    | (Note 2)                                     |
| 9             | TSU:DAT | Data input setup time                                                              | 250<br>100      |           | _           | ns    | 1.8V ≤ VCC < 2.5V<br>2.5V ≤ VCC ≤ 5.5V       |
| 10            | Tsu:sto | Stop condition setup time                                                          | 4000<br>600     |           | _           | ns    | 1.8V ≤ VCC < 2.5V<br>2.5V ≤ VCC ≤ 5.5V       |
| 11            | Таа     | Output valid from clock                                                            | _               | _         | 3500<br>900 | ns    | 1.8V ≤ VCC < 2.5V<br>2.5V ≤ VCC ≤ 5.5V       |
| 12            | TBUF    | Bus free time: Time the bus<br>must be free before a new<br>transmission can start | 4700<br>1300    |           | _<br>_      | ns    | 1.8V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V       |
| 13            | TSP     | Input filter spike suppression (SDA and SCL pins)                                  | _               | _         | 50          | ns    | (Note 1)                                     |
| 14            | Fosc    | Oscillator frequency                                                               | _               | 32.768    |             | kHz   | _                                            |
| 15            | Tosf    | Oscillator timeout period                                                          | 1               |           | _           | ms    | (Note 1)                                     |

Note 1: Not 100% tested.

<sup>2:</sup> As a transmitter, the device must provide an internal minimum delay time to bridge the undefined region (minimum 300 ns) of the falling edge of SCL to avoid unintended generation of Start or Stop conditions.

FIGURE 1-3: I<sup>2</sup>C BUS TIMING DATA



#### 2.0 PIN DESCRIPTIONS

The descriptions of the pins are listed in Table 2-1.

TABLE 2-1: PIN FUNCTION TABLE

| Name | 8-pin<br>SOIC | 8-pin<br>MSOP | 8-pin<br>TSSOP | 8-pin<br>TDFN | 8-pin<br>PDIP | Function                                        |
|------|---------------|---------------|----------------|---------------|---------------|-------------------------------------------------|
| X1   | 1             | 1             | 1              | 1             | 1             | Quartz Crystal Input, External Oscillator Input |
| X2   | 2             | 2             | 2              | 2             | 2             | Quartz Crystal Output                           |
| NC   | 3             | 3             | 3              | 3             | 3             | Not Connected                                   |
| Vss  | 4             | 4             | 4              | 4             | 4             | Ground                                          |
| SDA  | 5             | 5             | 5              | 5             | 5             | Bidirectional Serial Data (I <sup>2</sup> C™)   |
| SCL  | 6             | 6             | 6              | 6             | 6             | Serial Clock (I <sup>2</sup> C)                 |
| MFP  | 7             | 7             | 7              | 7             | 7             | Multifunction Pin                               |
| Vcc  | 8             | 8             | 8              | 8             | 8             | Primary Power Supply                            |

Note: Exposed pad on TFDN can be connected to Vss or left floating.

#### 2.1 Serial Data (SDA)

This is a bidirectional pin used to transfer addresses and data into and out of the device. It is an open-drain terminal. Therefore, the SDA bus requires a pull-up resistor to Vcc (typically 10  $k\Omega$  for 100 kHz, 2  $k\Omega$  for 400 kHz). For normal data transfer, SDA is allowed to change only during SCL low. Changes during SCL high are reserved for indicating the Start and Stop conditions.

### 2.2 Serial Clock (SCL)

This input is used to synchronize the data transfer to and from the device.

#### 2.3 Oscillator Input/Output (X1, X2)

These pins are used as the connections for an external 32.768 kHz quartz crystal and load capacitors. X1 is the crystal oscillator input and X2 is the output. The MCP7940M is designed to allow for the use of external load capacitors in order to provide additional flexibility when choosing external crystals. The MCP7940M is optimized for crystals with a specified load capacitance of 6-9 pF.

X1 also serves as the external clock input when the MCP7940M is configured to use an external oscillator.

#### 2.4 Multifunction Pin (MFP)

This is an output pin used for the alarm and square wave output functions. It can also serve as a general purpose output pin by controlling the OUT bit in the CONTROL register.

The MFP is an open-drain output and requires a pull-up resistor to Vcc (typically 10 k $\Omega$ ). This pin may be left floating if not used.

#### 3.0 I<sup>2</sup>C BUS CHARACTERISTICS

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

The MCP7940M supports a bidirectional 2-wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the Start and Stop conditions, while the MCP7940M works as slave. Both master and slave can operate as transmitter or receiver but the master device determines which mode is activated.

#### 3.1.1 BUS CHARACTERISTICS

The following **bus protocol** has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is high. Changes in the data line while the clock line is high will be interpreted as a Start or Stop condition.

Accordingly, the following bus conditions have been defined (Figure 3-1).

#### 3.1.1.1 Bus Not Busy (A)

Both data and clock lines remain high.

#### 3.1.1.2 Start Data Transfer (B)

A high-to-low transition of the SDA line while the clock (SCL) is high determines a Start condition. All commands must be preceded by a Start condition.

#### 3.1.1.3 Stop Data Transfer (C)

A low-to-high transition of the SDA line while the clock (SCL) is high determines a Stop condition. All operations must end with a Stop condition.

#### 3.1.1.4 Data Valid (D)

The state of the data line represents valid data when, after a Start condition, the data line is stable for the duration of the high period of the clock signal.

The data on the line must be changed during the low period of the clock signal. There is one bit of data per clock pulse.

Each data transfer is initiated with a Start condition and terminated with a Stop condition. The number of the data bytes transferred between the Start and Stop conditions is determined by the master device.

#### 3.1.1.5 Acknowledge

Each receiving device, when addressed, is obliged to generate an Acknowledge signal after the reception of each byte. The master device must generate an extra clock pulse which is associated with this Acknowledge bit.

A device that acknowledges must pull down the SDA line during the Acknowledge clock pulse in such a way that the SDA line is stable-low during the high period of the Acknowledge-related clock pulse. Of course, setup and hold times must be taken into account. During reads, a master must signal an end of data to the slave by NOT generating an Acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave (MCP7940M) will leave the data line high to enable the master to generate the Stop condition.

FIGURE 3-1: DATA TRANSFER SEQUENCE ON THE SERIAL BUS



FIGURE 3-2: ACKNOWLEDGE TIMING



#### 3.1.2 DEVICE ADDRESSING

The control byte is the first byte received following the Start condition from the master device (Figure 3-3). The control byte begins with a 4-bit control code. For the MCP7940M, this is set '1101' for register read and write operations. The next three bits are non-configurable Chip Select bits that must always be set to '1'.

The last bit of the control byte defines the operation to be performed. When set to a '1' a read operation is selected, and when set to a '0' a write operation is selected.

The combination of the 4-bit control code and the three Chip Select bits is called the slave address. Upon receiving a valid slave address, the slave device outputs an acknowledge signal on the SDA line. Depending on the state of the R/W bit, the MCP7940M will select a read or a write operation.

FIGURE 3-3: CONTROL BYTE FORMAT



#### 4.0 **FUNCTIONAL DESCRIPTION**

The MCP7940M is a highly-integrated Real-Time Clock/Calendar (RTCC). Using an on-board, lowpower oscillator, the current time is maintained in seconds, minutes, hours, day of week, date, month, and year. The MCP7940M also features 64 bytes of general purpose SRAM. Two alarm modules allow interrupts to be generated at specific times with flexible comparison options. Digital trimming can be used to compensate for inaccuracies inherent with crystals.

The RTCC configuration and Status registers are used to access all of the modules featured on the MCP7940M.

#### 4.1 **Memory Organization**

The MCP7940M features two different blocks of memory: the RTCC registers and general purpose SRAM (Figure 4-1). They share the same address space, accessed through the '11011111X' control byte. Unused locations are not accessible. The MCP7940M will not acknowledge if the address is out of range, as shown in the shaded region of the memory map in Figure 4-1.

The RTCC registers are contained in addresses 0x00-0x1F. Table 4-1 shows the detailed RTCC register map. There are 64 bytes of user-accessible SRAM, located in the address range 0x20-0x5F. The SRAM is a separate block from the RTCC registers.

FIGURE 4-1: **MEMORY MAP** 



### **MCP7940M**

TABLE 4-1: DETAILED RTCC REGISTER MAP

| Addr.                     | Register Name | Bit 7                 | Bit 6                | Bit 5           | Bit 4       | Bit 3    | Bit 2    | Bit 1    | Bit 0    |  |
|---------------------------|---------------|-----------------------|----------------------|-----------------|-------------|----------|----------|----------|----------|--|
|                           |               |                       | S                    | ection 4.3 "T   | imekeeping' | ,        |          |          |          |  |
| 00h                       | RTCSEC        | ST                    | SECTEN2              | SECTEN1         | SECTEN0     | SECONE3  | SECONE2  | SECONE1  | SECONE0  |  |
| 01h                       | RTCMIN        | _                     | MINTEN2              | MINTEN1         | MINTEN0     | MINONE3  | MINONE2  | MINONE1  | MINONE0  |  |
| 02h                       | RTCHOUR       | _                     | 12/24                | AM/PM<br>HRTEN1 | HRTEN0      | HRONE3   | HRONE2   | HRONE1   | HRONE0   |  |
| 03h                       | RTCWKDAY      | _                     | _                    | OSCRUN          | _           | _        | WKDAY2   | WKDAY1   | WKDAY0   |  |
| 04h                       | RTCDATE       | _                     | _                    | DATETEN1        | DATETEN0    | DATEONE3 | DATEONE2 | DATEONE1 | DATEONE0 |  |
| 05h                       | RTCMTH        | _                     | _                    | LPYR            | MTHTEN0     | MTHONE3  | MTHONE2  | MTHONE1  | MTHONE0  |  |
| 06h                       | RTCYEAR       | YRTEN3                | YRTEN2               | YRTEN1          | YRTEN0      | YRONE3   | YRONE2   | YRONE1   | YRONE0   |  |
| 07h                       | CONTROL       | OUT                   | SQWEN                | ALM1EN          | ALM0EN      | EXTOSC   | CRSTRIM  | SQWFS1   | SQWFS0   |  |
| 08h                       | OSCTRIM       | SIGN                  | TRIMVAL6             | TRIMVAL5        | TRIMVAL4    | TRIMVAL3 | TRIMVAL2 | TRIMVAL1 | TRIMVAL0 |  |
| 09h Reserved – Do not use |               |                       |                      |                 |             |          |          |          |          |  |
|                           |               |                       |                      | Section 4.4     | "Alarms"    |          |          |          |          |  |
| 0Ah                       | ALM0SEC       | _                     | SECTEN2              | SECTEN1         | SECTEN0     | SECONE3  | SECONE2  | SECONE1  | SECONE0  |  |
| 0Bh                       | ALM0MIN       | _                     | MINTEN2              | MINTEN1         | MINTEN0     | MINONE3  | MINONE2  | MINONE1  | MINONE0  |  |
| 0Ch                       | ALM0HOUR      | _                     | 12/24 <sup>(2)</sup> | AM/PM<br>HRTEN1 | HRTEN0      | HRONE3   | HRONE2   | HRONE1   | HRONE0   |  |
| 0Dh                       | ALM0WKDAY     | ALMPOL                | ALM0MSK2             | ALM0MSK1        | ALM0MSK0    | ALM0IF   | WKDAY2   | WKDAY1   | WKDAY0   |  |
| 0Eh                       | ALM0DATE      | _                     | _                    | DATETEN1        | DATETEN0    | DATEONE3 | DATEONE2 | DATEONE1 | DATEONE0 |  |
| 0Fh                       | ALM0MTH       | _                     | _                    | _               | MTHTEN0     | MTHONE3  | MTHONE2  | MTHONE1  | MTHONE0  |  |
| 10h                       | Reserved      | Reserved – D          | o not use            |                 |             |          |          |          |          |  |
|                           |               |                       |                      | Section 4.4     | "Alarms"    |          |          |          |          |  |
| 11h                       | ALM1SEC       | _                     | SECTEN2              | SECTEN1         | SECTEN0     | SECONE3  | SECONE2  | SECONE1  | SECONE0  |  |
| 12h                       | ALM1MIN       | _                     | MINTEN2              | MINTEN1         | MINTEN0     | MINONE3  | MINONE2  | MINONE1  | MINONE0  |  |
| 13h                       | ALM1HOUR      | _                     | 12/24 <sup>(2)</sup> | AM/PM<br>HRTEN1 | HRTEN0      | HRONE3   | HRONE2   | HRONE1   | HRONE0   |  |
| 14h                       | ALM1WKDAY     | ALMPOL <sup>(3)</sup> | ALM1MSK2             | ALM1MSK1        | ALM1MSK0    | ALM1IF   | WKDAY2   | WKDAY1   | WKDAY0   |  |
| 15h                       | ALM1DATE      | _                     | _                    | DATETEN1        | DATETEN0    | DATEONE3 | DATEONE2 | DATEONE1 | DATEONE0 |  |
| 16h                       | ALM1MTH       | _                     | _                    | _               | MTHTEN0     | MTHONE3  | MTHONE2  | MTHONE1  | MTHONE0  |  |
| 17h-1Fh                   | Reserved      | Reserved – D          | o not use            |                 |             |          |          |          |          |  |

Note 1: Grey areas are unimplemented.

<sup>2:</sup> The  $12/\overline{24}$  bits in the ALMxHOUR registers are read-only and reflect the value of the  $12/\overline{24}$  bit in the RTCHOUR register.

**<sup>3:</sup>** The ALMPOL bit in the ALM1WKDAY register is read-only and reflects the value of the ALMPOL bit in the ALM0WKDAY register.

#### 4.2 Oscillator Configuration

The MCP7940M can be operated in two different oscillator configurations: using an external crystal or using an external clock input.

#### 4.2.1 EXTERNAL CRYSTAL

The crystal oscillator circuit on the MCP7940M is designed to operate with a standard 32.768 kHz tuning fork crystal and matching external load capacitors. By using external load capacitors, the MCP7940M allows for a wide selection of crystals. Suitable crystals have a load capacitance (CL) of 6-9 pF. Crystals with a load capacitance of 12.5 pF are not recommended.

Figure 4-2 shows the pin connections when using an external crystal.

FIGURE 4-2: CRYSTAL OPERATION



- **Note 1:** The ST bit must be set to enable the crystal oscillator circuit.
  - **2:** Always verify oscillator performance over the voltage and temperature range that is expected for the application.

#### 4.2.1.1 Choosing Load Capacitors

CL is the effective load capacitance as seen by the crystal, and includes the physical load capacitors, pin capacitance, and stray board capacitance. Equation 4-1 can be used to calculate CL.

 $\mathsf{C}_{\mathsf{X}1}$  and  $\mathsf{C}_{\mathsf{X}2}$  are the external load capacitors. They must be chosen to match the selected crystal's specified load capacitance.

**Note:** If the load capacitance is not correctly matched to the chosen crystal's specified value, the crystal may give a frequency outside of the crystal manufacturer's specifications.

### EQUATION 4-1: LOAD CAPACITANCE CALCULATION

$$CL = \frac{C_{X1} \times C_{X2}}{C_{X1} + C_{X2}} + CSTRAY$$

Where:

CL = Effective load capacitance  $C_{X1}$  = Capacitor value on X1 + COSC  $C_{X2}$  = Capacitor value on X2 + COSCCSTRAY = PCB stray capacitance

#### 4.2.1.2 Layout Considerations

The oscillator circuit should be placed on the same side of the board as the device. Place the oscillator circuit close to the respective oscillator pins. The load capacitors should be placed next to the oscillator itself, on the same side of the board.

Use a grounded copper pour around the oscillator circuit to isolate it from surrounding circuits. The grounded copper pour should be routed directly to Vss. Do not run any signal traces or power traces inside the ground pour. Also, if using a two-sided board, avoid any traces on the other side of the board where the crystal is placed.

Layout suggestions are shown in Figure 4-3. In-line packages may be handled with a single-sided layout that completely encompasses the oscillator pins. With fine-pitch packages, it is not always possible to completely surround the pins and components. A suitable solution is to tie the broken guard sections to a mirrored ground layer. In all cases, the guard trace(s) must be returned to ground.

For additional information and design guidance on oscillator circuits, please refer to these Microchip Application Notes, available at the corporate web site (www.microchip.com):

- AN1365, "Recommended Usage of Microchip Serial RTCC Devices"
- AN1519, "Recommended Crystals for Microchip Stand-Alone Real-Time Clock Calendar Devices"

FIGURE 4-3: SUGGESTED PLACEMENT OF THE OSCILLATOR CIRCUIT



#### 4.2.2 EXTERNAL CLOCK INPUT

A 32.768 kHz external clock source can be connected to the X1 pin (Figure 4-4). When using this configuration, the X2 pin should be left floating.

**Note:** The EXTOSC bit must be set to enable an external clock source.

### FIGURE 4-4: EXTERNAL CLOCK INPUT OPERATION



#### 4.2.3 OSCILLATOR FAILURE STATUS

The MCP7940M features an oscillator failure flag, OSCRUN, that indicates whether or not the oscillator is running. The OSCRUN bit is automatically set after 32 oscillator cycles are detected. If no oscillator cycles are detected for more than Tosf, then the OSCRUN bit is automatically cleared (Figure 4-5). This can occur if the oscillator is stopped by clearing the ST bit or due to oscillator failure.

#### FIGURE 4-5: OSCILLATOR FAILURE STATUS TIMING DIAGRAM



#### TABLE 4-2: SUMMARY OF REGISTERS ASSOCIATED WITH OSCILLATOR CONFIGURATION

| Name     | Bit 7 | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   | Register<br>on Page |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------------------|
| RTCSEC   | ST    | SECTEN2 | SECTEN1 | SECTEN0 | SECONE3 | SECONE2 | SECONE1 | SECONE0 | 14                  |
| RTCWKDAY | _     | _       | OSCRUN  | _       | _       | WKDAY2  | WKDAY1  | WKDAY0  | 16                  |
| CONTROL  | OUT   | SQWEN   | ALM1EN  | ALM0EN  | EXTOSC  | CRSTRIM | SQWFS1  | SQWFS0  | 24                  |

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used by oscillator configuration.

#### 4.3 Timekeeping

The MCP7940M maintains the current time and date using an external 32.768 kHz crystal or clock source. Separate registers are used for tracking seconds, minutes, hours, day of week, date, month, and year. The MCP7940M automatically adjusts for months with less than 31 days and compensates for leap years from 2001 to 2399. The year is stored as a two-digit value.

Both 12-hour and 24-hour time formats are supported and are selected using the  $12/\overline{24}$  bit.

The day of week value counts from 1 to 7, increments at midnight, and the representation is user-defined (i.e., the MCP7940M does not require 1 to equal Sunday, etc.).

All time and date values are stored in the registers as binary-coded decimal (BCD) values.

When reading from the timekeeping registers, the registers are buffered to prevent errors due to rollover of counters. The following events cause the buffers to be updated:

- When a read is initiated from the RTCC registers (addresses 0x00 to 0x1F)
- During an RTCC register read operation, when the register address rolls over from 0x1F to 0x00

The timekeeping registers should be read in a single operation to utilize the on-board buffers and avoid rollover issues.

- **Note 1:** Loading invalid values into the time and date registers will result in undefined operation.
  - 2: To avoid rollover issues when loading new time and date values, the oscillator/ clock input should be disabled by clearing the ST bit for External Crystal mode and the EXTOSC bit for External Clock Input mode. After waiting for the OSCRUN bit to clear, the new values can be loaded and the ST or EXTOSC bit can then be re-enabled.

#### 4.3.1 DIGIT CARRY RULES

The following list explains which timer values cause a digit carry when there is a rollover:

- Time of day: from 11:59:59 PM to 12:00:00 AM (12-hour mode) or 23:59:59 to 00:00:00 (24-hour mode), with a carry to the Date and Weekday fields
- Date: carries to the Month field according to Table 5-3
- Weekday: from 7 to 1 with no carry
- Month: from 12/31 to 01/01 with a carry to the Year field
- Year: from 99 to 00 with no carry

TABLE 4-3: DAY TO MONTH ROLLOVER SCHEDULE

| Month | Name      | Maximum Date            |
|-------|-----------|-------------------------|
| 01    | January   | 31                      |
| 02    | February  | 28 or 29 <sup>(1)</sup> |
| 03    | March     | 31                      |
| 04    | April     | 30                      |
| 05    | May       | 31                      |
| 06    | June      | 30                      |
| 07    | July      | 31                      |
| 08    | August    | 31                      |
| 09    | September | 30                      |
| 10    | October   | 31                      |
| 11    | November  | 30                      |
| 12    | December  | 31                      |

Note 1: 29 during leap years, otherwise 28.

### REGISTER 4-1: RTCSEC: TIMEKEEPING SECONDS VALUE REGISTER (ADDRESS 0x00)

| R/W-0 | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0   |
|-------|---------|---------|---------|---------|---------|---------|---------|
| ST    | SECTEN2 | SECTEN1 | SECTEN0 | SECONE3 | SECONE2 | SECONE1 | SECONE0 |
| bit 7 |         |         |         |         |         |         | bit 0   |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'
-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7 Start Oscillator bit

1 = Oscillator enabled0 = Oscillator disabled

bit 6-4 SECTEN<2:0>: Binary-Coded Decimal Value of Second's Tens Digit

Contains a value from 0 to 5

bit 3-0 SECONE<3:0>: Binary-Coded Decimal Value of Second's Ones Digit

#### REGISTER 4-2: RTCMIN: TIMEKEEPING MINUTES VALUE REGISTER (ADDRESS 0x01)

| U-0   | R/W-0   |
|-------|---------|---------|---------|---------|---------|---------|---------|
| _     | MINTEN2 | MINTEN1 | MINTEN0 | MINONE3 | MINONE2 | MINONE1 | MINONE0 |
| bit 7 |         |         |         |         |         |         | bit 0   |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7 **Unimplemented:** Read as '0'

bit 6-4 MINTEN<2:0>: Binary-Coded Decimal Value of Minute's Tens Digit

Contains a value from 0 to 5

bit 3-0 MINONE<3:0>: Binary-Coded Decimal Value of Minute's Ones Digit

Contains a value from 0 to 9

#### REGISTER 4-3: RTCHOUR: TIMEKEEPING HOURS VALUE REGISTER (ADDRESS 0x02)

| U-0   | R/W-0 | R/W-0           | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  |
|-------|-------|-----------------|--------|--------|--------|--------|--------|
| _     | 12/24 | AM/PM<br>HRTEN1 | HRTEN0 | HRONE3 | HRONE2 | HRONE1 | HRONE0 |
| bit 7 |       | _               |        |        | _      |        | bit 0  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

#### If $12/\overline{24} = 1$ (12-hour format):

bit 7 Unimplemented: Read as '0'

bit 6 **12/24**: 12 or 24 Hour Time Format bit

1 = 12-hour format 0 = 24-hour format

bit 5 **AM/PM:** AM/PM Indicator bit

1 = PM 0 = AM

bit 4 HRTEN0: Binary-Coded Decimal Value of Hour's Tens Digit

Contains a value from 0 to 1

bit 3-0 **HRONE<3:0>:** Binary-Coded Decimal Value of Hour's Ones Digit

Contains a value from 0 to 9

#### If 12/24 = 0 (24-hour format):

bit 7 Unimplemented: Read as '0'

bit 6 **12/24**: 12 or 24 Hour Time Format bit

1 = 12-hour format 0 = 24-hour format

bit 5-4 HRTEN<1:0>: Binary-Coded Decimal Value of Hour's Tens Digit

Contains a value from 0 to 2.

bit 3-0 **HRONE<3:0>:** Binary-Coded Decimal Value of Hour's Ones Digit

#### REGISTER 4-4: RTCWKDAY: TIMEKEEPING WEEKDAY VALUE REGISTER (ADDRESS 0x03)

| U-0   | U-0 | R-0    | U-0 | U-0 | R/W-0  | R/W-0  | R/W-1  |
|-------|-----|--------|-----|-----|--------|--------|--------|
| _     | _   | OSCRUN | -   | _   | WKDAY2 | WKDAY1 | WKDAY0 |
| bit 7 |     |        |     |     |        |        | bit 0  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7-6 **Unimplemented:** Read as '0' bit 5 **OSCRUN:** Oscillator Status bit

1 = Oscillator is enabled and running

0 = Oscillator has stopped or has been disabled

bit 4-3 **Unimplemented:** Read as '0'

bit 2-0 WKDAY<2:0>: Binary-Coded Decimal Value of Day of Week

Contains a value from 1 to 7. The representation is user-defined.

#### REGISTER 4-5: RTCDATE: TIMEKEEPING DATE VALUE REGISTER (ADDRESS 0x04)

| U-0   | U-0 | R/W-0    | R/W-0    | R/W-0    | R/W-0    | R/W-0    | R/W-1    |
|-------|-----|----------|----------|----------|----------|----------|----------|
| _     | _   | DATETEN1 | DATETEN0 | DATEONE3 | DATEONE2 | DATEONE1 | DATEONE0 |
| bit 7 |     |          |          |          |          |          | bit 0    |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7-6 **Unimplemented:** Read as '0'

bit 5-4 DATETEN<1:0>: Binary-Coded Decimal Value of Date's Tens Digit

Contains a value from 0 to 3

bit 3-0 DATEONE<3:0>: Binary-Coded Decimal Value of Date's Ones Digit

#### REGISTER 4-6: RTCMTH: TIMEKEEPING MONTH VALUE REGISTER (ADDRESS 0x05)

| U-0   | U-0 | R-0  | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-1   |
|-------|-----|------|---------|---------|---------|---------|---------|
| _     | _   | LPYR | MTHTEN0 | MTHONE3 | MTHONE2 | MTHONE1 | MTHONE0 |
| bit 7 |     |      |         |         |         |         | bit 0   |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7-6 **Unimplemented:** Read as '0'

bit 5 LPYR: Leap Year bit

1 = Year is a leap year0 = Year is not a leap year

bit 4 MTHTEN0: Binary-Coded Decimal Value of Month's Tens Digit

Contains a value of 0 or 1

bit 3-0 MTHONE<3:0>: Binary-Coded Decimal Value of Month's Ones Digit

Contains a value from 0 to 9

#### REGISTER 4-7: RTCYEAR: TIMEKEEPING YEAR VALUE REGISTER (ADDRESS 0x06)

| R/W-0  | R/W-1  |
|--------|--------|--------|--------|--------|--------|--------|--------|
| YRTEN3 | YRTEN2 | YRTEN1 | YRTEN0 | YRONE3 | YRONE2 | YRONE1 | YRONE0 |
| bit 7  |        |        |        |        |        |        | bit 0  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7-4 YRTEN<3:0>: Binary-Coded Decimal Value of Year's Tens Digit

Contains a value from 0 to 9

bit 3-0 YRONE<3:0>: Binary-Coded Decimal Value of Year's Ones Digit

Contains a value from 0 to 9

#### TABLE 4-4: SUMMARY OF REGISTERS ASSOCIATED WITH TIMEKEEPING

| Name     | Bit 7  | Bit 6   | Bit 5           | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    | Register on Page |
|----------|--------|---------|-----------------|----------|----------|----------|----------|----------|------------------|
| RTCSEC   | ST     | SECTEN2 | SECTEN1         | SECTEN0  | SECONE3  | SECONE2  | SECONE1  | SECONE0  | 14               |
| RTCMIN   | _      | MINTEN2 | MINTEN1         | MINTEN0  | MINONE3  | MINONE2  | MINONE1  | MINONE0  | 15               |
| RTCHOUR  |        | 12/24   | AM/PM<br>HRTEN1 | HRTEN0   | HRONE3   | HRONE2   | HRONE1   | HRONE0   | 15               |
| RTCWKDAY | _      | _       | OSCRUN          | _        | _        | WKDAY2   | WKDAY1   | WKDAY0   | 16               |
| RTCDATE  | _      | _       | DATETEN1        | DATETEN0 | DATEONE3 | DATEONE2 | DATEONE1 | DATEONE0 | 16               |
| RTCMTH   | _      | 1       | LPYR            | MTHTEN0  | MTHONE3  | MTHONE2  | MTHONE1  | MTHONE0  | 17               |
| RTCYEAR  | YRTEN3 | YRTEN2  | YRTEN1          | YRTEN0   | YRONE3   | YRONE2   | YRONE1   | YRONE0   | 17               |

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used in timekeeping.

#### 4.4 Alarms

The MCP7940M features two independent alarms. Each alarm can be used to either generate an interrupt at a specific time in the future, or to generate a periodic interrupt every minute, hour, day, day of week, or month.

There is a separate interrupt flag, ALMxIF, for each alarm. The interrupt flags are set by hardware when the chosen alarm mask condition matches (Table 4-5). The interrupt flags must be cleared in software.

If either alarm module is enabled by setting the corresponding ALMxEN bit in the CONTROL register, and if the square wave clock output is disabled (SQWEN = 0), then the MFP will operate in Alarm Interrupt Output mode. Refer to **Section 4.5 "Output Configurations"** for details.

Both Alarm0 and Alarm1 offer identical operation. All time and date values are stored in the registers as binary-coded decimal (BCD) values.

Note:

Throughout this section, references to the register and bit names for the alarm modules are referred to generically by the use of 'x' in place of the specific module number. Thus, "ALMxSEC" might refer to the seconds register for Alarm0 or Alarm1.

TABLE 4-5: ALARM MASKS

| ALMxMSK<2:0> | Alarm Asserts on Match of                                |
|--------------|----------------------------------------------------------|
| 000          | Seconds                                                  |
| 001          | Minutes                                                  |
| 010          | Hours                                                    |
| 011          | Day of Week                                              |
| 100          | Date                                                     |
| 101          | Reserved                                                 |
| 110          | Reserved                                                 |
| 111          | Seconds, Minutes, Hours, Day of<br>Week, Date, and Month |

- Note 1: The alarm interrupt flags must be cleared by the user. If a flag is cleared while the corresponding alarm condition still matches, the flag will be set again, generating another interrupt.
  - 2: Loading invalid values into the alarm registers will result in undefined operation.

FIGURE 4-6: ALARM BLOCK DIAGRAM



#### 4.4.1 CONFIGURING THE ALARM

In order to configure the alarm modules, the following steps need to be performed:

- Load the timekeeping registers and enable the oscillator
- Configure the ALMxMSK<2:0> bits to select the desired alarm mask
- Set or clear the ALMPOL bit according to the desired output polarity
- 4. Ensure the ALMxIF flag is cleared
- Based on the selected alarm mask, load the alarm match value into the appropriate register(s)
- Enable the alarm module by setting the ALMxEN bit

#### REGISTER 4-8: ALMxSEC: ALARM0/1 SECONDS VALUE REGISTER (ADDRESSES 0x0A/0x11)

| U-0   | R/W-0   |
|-------|---------|---------|---------|---------|---------|---------|---------|
| _     | SECTEN2 | SECTEN1 | SECTEN0 | SECONE3 | SECONE2 | SECONE1 | SECONE0 |
| bit 7 |         |         |         |         |         |         | bit 0   |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7 **Unimplemented:** Read as '0'

bit 6-4 SECTEN<2:0>: Binary-Coded Decimal Value of Second's Tens Digit

Contains a value from 0 to 5

bit 3-0 SECONE<3:0>: Binary-Coded Decimal Value of Second's Ones Digit

Contains a value from 0 to 9

#### REGISTER 4-9: ALMxMIN: ALARM0/1 MINUTES VALUE REGISTER (ADDRESSES 0x0B/0x12)

| U-0   | R/W-0   |
|-------|---------|---------|---------|---------|---------|---------|---------|
| _     | MINTEN2 | MINTEN1 | MINTEN0 | MINONE3 | MINONE2 | MINONE1 | MINONE0 |
| bit 7 |         |         |         |         |         |         | bit 0   |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7 Unimplemented: Read as '0'

bit 6-4 MINTEN<2:0>: Binary-Coded Decimal Value of Minute's Tens Digit

Contains a value from 0 to 5

bit 3-0 MINONE<3:0>: Binary-Coded Decimal Value of Minute's Ones Digit

#### REGISTER 4-10: ALMxHOUR: ALARM0/1 HOURS VALUE REGISTER (ADDRESSES 0x0C/0x13)

| U-0   | R-0   | R/W-0           | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  |
|-------|-------|-----------------|--------|--------|--------|--------|--------|
| _     | 12/24 | AM/PM<br>HRTEN1 | HRTEN0 | HRONE3 | HRONE2 | HRONE1 | HRONE0 |
| bit 7 |       |                 |        |        | _      |        | bit 0  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

#### If $12/\overline{24} = 1$ (12-hour format):

bit 7 **Unimplemented:** Read as '0'

bit 6 **12/24:** 12 or 24 Hour Time Format bit<sup>(1)</sup>

1 = 12-hour format
0 = 24-hour format

bit 5 AM/PM: AM/PM Indicator bit

1 = PM 0 = AM

bit 4 HRTEN0: Binary-Coded Decimal Value of Hour's Tens Digit

Contains a value from 0 to 1

bit 3-0 **HRONE<3:0>:** Binary-Coded Decimal Value of Hour's Ones Digit

Contains a value from 0 to 9

#### If $12/\overline{24} = 0$ (24-hour format):

bit 7 **Unimplemented:** Read as '0'

bit 6 12/24: 12 or 24 Hour Time Format bit<sup>(1)</sup>

1 = 12-hour format0 = 24-hour format

bit 5-4 HRTEN<1:0>: Binary-Coded Decimal Value of Hour's Tens Digit

Contains a value from 0 to 2.

bit 3-0 **HRONE<3:0>:** Binary-Coded Decimal Value of Hour's Ones Digit

Contains a value from 0 to 9

**Note 1:** This bit is read-only and reflects the value of the  $12/\overline{24}$  bit in the RTCHOUR register.

## REGISTER 4-11: ALMxWKDAY: ALARM0/1 WEEKDAY VALUE REGISTER (ADDRESSES 0x0D/0x14)

| R/W-0  | R/W-0    | R/W-0    | R/W-0    | R/W-0  | R/W-0  | R/W-0  | R/W-1  |
|--------|----------|----------|----------|--------|--------|--------|--------|
| ALMPOL | ALMxMSK2 | ALMxMSK1 | ALMxMSK0 | ALMxIF | WKDAY2 | WKDAY1 | WKDAY0 |
| bit 7  |          |          |          |        |        |        | bit 0  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7 ALMPOL: Alarm Interrupt Output Polarity bit

1 = Asserted output state of MFP is a logic high level 0 = Asserted output state of MFP is a logic low level

bit 6-4 ALMxMSK<2:0>: Alarm Mask bits

000 = Seconds match 001 = Minutes match

010 = Hours match (logic takes into account 12-/24-hour operation)

011 = Day of week match

100 = Date match

101 = Reserved; do not use 110 = Reserved; do not use

111 = Seconds, Minutes, Hour, Day of Week, Date and Month

bit 3 **ALMxIF:** Alarm Interrupt Flag bit<sup>(1,2)</sup>

1 = Alarm match occurred (must be cleared in software)

0 = Alarm match did not occur

bit 2-0 WKDAY<2:0>: Binary-Coded Decimal Value of Day bits

Contains a value from 1 to 7. The representation is user-defined.

Note 1: If a match condition still exists when this bit is cleared, it will be set again automatically.

2: The ALMxIF bit cannot be written to a 1 in software. Writing to the ALMxWKDAY register will always clear the ALMxIF bit.

#### REGISTER 4-12: ALMxDATE: ALARM0/1 DATE VALUE REGISTER (ADDRESSES 0x0E/0x15)

| U-0   | U-0 | R/W-0    | R/W-0    | R/W-0    | R/W-0    | R/W-0    | R/W-1    |
|-------|-----|----------|----------|----------|----------|----------|----------|
| _     | _   | DATETEN1 | DATETEN0 | DATEONE3 | DATEONE2 | DATEONE1 | DATEONE0 |
| bit 7 |     |          |          |          |          |          | bit 0    |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7-6 **Unimplemented:** Read as '0'

bit 5-4 DATETEN<1:0>: Binary-Coded Decimal Value of Date's Tens Digit

Contains a value from 0 to 3

bit 3-0 DATEONE<3:0>: Binary-Coded Decimal Value of Date's Ones Digit

#### REGISTER 4-13: ALMxMTH: ALARM0/1 MONTH VALUE REGISTER (ADDRESSES 0x0F/0x16)

| U-0   | U-0 | U-0 | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-1   |
|-------|-----|-----|---------|---------|---------|---------|---------|
| _     | _   | _   | MTHTEN0 | MTHONE3 | MTHONE2 | MTHONE1 | MTHONE0 |
| bit 7 |     |     |         |         |         |         | bit 0   |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7-5 **Unimplemented:** Read as '0'

bit 4 MTHTEN0: Binary-Coded Decimal Value of Month's Tens Digit

Contains a value of 0 or 1

bit 3-0 MTHONE<3:0>: Binary-Coded Decimal Value of Month's Ones Digit

Contains a value from 0 to 9

#### TABLE 4-6: SUMMARY OF REGISTERS ASSOCIATED WITH ALARMS

| Name      | Bit 7  | Bit 6    | Bit 5           | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    | Register<br>on Page |
|-----------|--------|----------|-----------------|----------|----------|----------|----------|----------|---------------------|
| ALM0SEC   | _      | SECTEN2  | SECTEN1         | SECTEN0  | SECONE3  | SECONE2  | SECONE1  | SECONE0  | 19                  |
| ALM0MIN   | _      | MINTEN2  | MINTEN1         | MINTEN0  | MINONE3  | MINONE2  | MINONE1  | MINONE0  | 19                  |
| ALM0HOUR  | _      | 12/24    | AM/PM<br>HRTEN1 | HRTEN0   | HRONE3   | HRONE2   | HRONE1   | HRONE0   | 20                  |
| ALM0WKDAY | ALMPOL | ALM0MSK2 | ALM0MSK1        | ALM0MSK0 | ALM0IF   | WKDAY2   | WKDAY1   | WKDAY0   | 21                  |
| ALM0DATE  | _      | _        | DATETEN1        | DATETEN0 | DATEONE3 | DATEONE2 | DATEONE1 | DATEONE0 | 21                  |
| ALM0MTH   | _      | _        | _               | MTHTEN0  | MTHONE3  | MTHONE2  | MTHONE1  | MTHONE0  | 22                  |
| ALM1SEC   | _      | SECTEN2  | SECTEN1         | SECTEN0  | SECONE3  | SECONE2  | SECONE1  | SECONE0  | 19                  |
| ALM1MIN   | _      | MINTEN2  | MINTEN1         | MINTEN0  | MINONE3  | MINONE2  | MINONE1  | MINONE0  | 19                  |
| ALM1HOUR  | _      | 12/24    | AM/PM<br>HRTEN1 | HRTEN0   | HRONE3   | HRONE2   | HRONE1   | HRONE0   | 20                  |
| ALM1WKDAY | ALMPOL | ALM1MSK2 | ALM1MSK1        | ALM1MSK0 | ALM1IF   | WKDAY2   | WKDAY1   | WKDAY0   | 21                  |
| ALM1DATE  | _      | _        | DATETEN1        | DATETEN0 | DATEONE3 | DATEONE2 | DATEONE1 | DATEONE0 | 21                  |
| ALM1MTH   | _      | _        | _               | MTHTEN0  | MTHONE3  | MTHONE2  | MTHONE1  | MTHONE0  | 22                  |
| CONTROL   | OUT    | SQWEN    | ALM1EN          | ALM0EN   | EXTOSC   | CRSTRIM  | SQWFS1   | SQWFS0   | 24                  |

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used by alarms.

### 4.5 Output Configurations

The MCP7940M features Square Wave Clock Output, Alarm Interrupt Output, and General Purpose Output modes. All of the output functions are multiplexed onto MFP according to Table 4-7.

If none of the output functions are being used, the MFP can safely be left floating.

Note: The MFP is an open-drain output and requires a pull-up resistor to Vcc (typically  $10 \text{ k}\Omega$ ).

TABLE 4-7: MFP OUTPUT MODES

| SQWEN | ALM0EN | ALM1EN | Mode                        |
|-------|--------|--------|-----------------------------|
| 0     | 0      | 0      | General Purpose<br>Output   |
| 0     | 1      | 0      | Alama Intamorat             |
| 0     | 0      | 1      | Alarm Interrupt Output      |
| 0     | 1      | 1      | Catput                      |
| 1     | Х      | Х      | Square Wave Clock<br>Output |

FIGURE 4-7: MFP OUTPUT BLOCK DIAGRAM



#### REGISTER 4-14: CONTROL: RTCC CONTROL REGISTER (ADDRESS 0x07)

| R/W-1 | R/W-0 | R/W-0  | R/W-0  | R/W-0  | R/W-0   | R/W-0  | R/W-0  |
|-------|-------|--------|--------|--------|---------|--------|--------|
| OUT   | SQWEN | ALM1EN | ALM0EN | EXTOSC | CRSTRIM | SQWFS1 | SQWFS0 |
| bit 7 | bit 6 | bit 5  | bit 4  | bit 3  | bit 2   | bit 1  | bit 0  |

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

-n = Value at POR '1' = Bit is set '0' = Bit is clear x = Bit is unknown

bit 7 **OUT:** Logic Level for General Purpose Output bit

Square Wave Clock Output Mode (SQWEN = 1):

Unused.

<u>Alarm Interrupt Output mode (ALM0EN = 1 or ALM1EN = 1):</u>

Unused.

General Purpose Output mode (SQWEN = 0, ALM0EN = 0, and ALM1EN = 0):

1 = MFP signal level is logic high0 = MFP signal level is logic low

bit 6 **SQWEN:** Square Wave Output Enable bit

1 = Enable Square Wave Clock Output mode0 = Disable Square Wave Clock Output mode

bit 5 ALM1EN: Alarm 1 Module Enable bit

1 = Alarm 1 enabled 0 = Alarm 1 disabled

bit 4 ALM0EN: Alarm 0 Module Enable bit

1 = Alarm 0 enabled 0 = Alarm 0 disabled

bit 3 **EXTOSC:** External Oscillator Input bit

1 = Enable X1 pin to be driven by external 32.768 kHz source

0 = Disable external 32.768 kHz input

bit 2 CRSTRIM: Coarse Trim Mode Enable bit

Coarse Trim mode results in the MCP7940M applying digital trimming every 64 Hz clock cycle.

1 = Enable Coarse Trim mode. If SQWEN = 1, MFP will output trimmed 64 Hz<sup>(1)</sup> nominal clock signal.

0 = Disable Coarse Trim mode

See Section 4.6 "Digital Trimming" for details

bit 1-0 **SQWFS<1:0>:** Square Wave Clock Output Frequency Select bits

If SQWEN = 1 and CRSTRIM = 0:

Selects frequency of clock output on MFP

 $00 = 1 \text{ Hz}^{(1)}$  $01 = 4.096 \text{ kHz}^{(1)}$ 

 $10 = 8.192 \text{ kHz}^{(1)}$ 

11 = 32.768 kHz

If SQWEN = 0 or CRSTRIM = 1:

Unused.

**Note 1:** The 8.192 kHz, 4.096 kHz, 64 Hz, and 1 Hz square wave clock output frequencies are affected by digital trimming.

#### 4.5.1 SQUARE WAVE OUTPUT MODE

The MCP7940M can be configured to generate a square wave clock signal on MFP. The input clock frequency, Fosc, is divided according to the SQWFS<1:0> bits as shown in Table 4-8.

**Note:** All of the clock output rates are affected by digital trimming except for the 1:1 postscaler value (SQWFS<1:0> = 00).

TABLE 4-8: CLOCK OUTPUT RATES

| SQWFS<1:0> | Postscaler | Nominal<br>Frequency |  |
|------------|------------|----------------------|--|
| 0.0        | 1:1        | 32.768 kHz           |  |
| 01         | 1:4        | 8.192 kHz            |  |
| 10         | 1:8        | 4.096 kHz            |  |
| 11         | 1:32,768   | 1 Hz                 |  |

**Note 1:** Nominal frequency assumes Fosc is 32.768 kHz.

### 4.5.2 ALARM INTERRUPT OUTPUT MODE

The MFP will provide an interrupt output when enabled alarms match and the square wave clock output is disabled. This prevents the user from having to poll the alarm interrupt flag to check for a match.

The ALMxIF flags control when the MFP is asserted, as described in the following sections.

#### 4.5.2.1 Single Alarm Operation

When only one alarm module is enabled, the MFP output is based on the corresponding ALMxIF flag and the ALMPOL flag. If ALMPOL = 1, the MFP output reflects the value of the ALMxIF flag. If ALMPOL = 0, the MFP output reflects the inverse of the ALMxIF flag (Table 4-9).

TABLE 4-9: SINGLE ALARM OUTPUT TRUTH TABLE

| ALMPOL | ALMxIF <sup>(1)</sup> | MFP |  |
|--------|-----------------------|-----|--|
| 0      | 0                     | 1   |  |
| 0      | 1                     | 0   |  |
| 1      | 0                     | 0   |  |
| 1      | 1                     | 1   |  |

**Note 1:** ALMxIF refers to the interrupt flag corresponding to the alarm module that is enabled.

#### 4.5.2.2 Dual Alarm Operation

When both alarm modules are enabled, the MFP output is determined by a combination of the ALM0IF, ALM1IF, and ALMPOL flags.

If ALMPOL = 1, the ALM0IF and ALM1IF flags are OR'd together and the result is output on MFP. If ALMPOL = 0, the ALM0IF and ALM1IF flags are AND'd together, and the result is inverted and output on MFP (Table 4-10). This provides the user with flexible options for combining alarms.

**Note:** If ALMPOL = 0 and both alarms are enabled, the MFP will only assert when both ALM0IF and ALM1IF are set.

TABLE 4-10: DUAL ALARM OUTPUT TRUTH TABLE

| ALMPOL | ALM0IF | ALM1IF | MFP |  |
|--------|--------|--------|-----|--|
| 0      | 0      | 0      | 1   |  |
| 0      | 0      | 1      | 1   |  |
| 0      | 1      | 0      | 1   |  |
| 0      | 1      | 1      | 0   |  |
| 1      | 0      | 0      | 0   |  |
| 1      | 0      | 1      | 1   |  |
| 1      | 1      | 0      | 1   |  |
| 1      | 1      | 1      | 1   |  |

### 4.5.3 GENERAL PURPOSE OUTPUT MODE

If the square wave clock output and both alarm modules are disabled, the MFP acts as a general purpose output. The output logic level is controlled by the OUT bit.