HIGHLIGHTS

This section of the manual contains the following major topics:

37.1 Introduction ................................................................. 37-2
37.2 RTCC Module Registers .................................................. 37-3
37.3 RTCC Operation ........................................................... 37-11
37.4 RTCC Alarm ................................................................. 37-14
37.5 RTCC Calibration .......................................................... 37-17
37.6 Operation in Power-Saving Modes ................................. 37-19
37.7 Register Map ............................................................... 37-20
37.8 Related Application Notes ............................................. 37-21
37.9 Revision History .......................................................... 37-22
37.1 INTRODUCTION

This section discusses the Real-Time Clock and Calendar (RTCC) module that provides a full Binary-coded Decimal (BCD) clock calendar. Some of the key features of the RTCC module are listed below:

- 24-hour (military time) clock
- 100-year calendar up to year 2099
- Counts seconds, minutes, hours, weekday, date, month and year with leap year compensation
- BCD representation of time, calendar and alarm
- Programmable Alarm with repeat mode
- Square wave generation using Alarm or 1 Hz Clock Output on RTCC pin
- RTCC Calibration

The RTCC module provides a time reference to an application running on the device with minimum to no intervention from the CPU. The current date and time is tracked in a set of counter registers that update once per second.

The RTCC and the Secondary Oscillator (SOSC) will continue to function when the device is held under reset by pulling the MCLR pin low. Figure 37-1 shows a block diagram of the RTCC module.
37.2 RTCC MODULE REGISTERS

The RTCC module registers are organized into three categories:

- **RTCC Control Registers**
  - **RCFGCAL**: RTCC Calibration and Configuration Register
  - **PADCFG1**: Pad Configuration Control Register
  - **ALCFGRPT**: Alarm Configuration Register

- **RTCC Value Registers**
  - **RTCVAL** (when RTCPTR<1:0> = 11): Year Value Register
  - **RTCVAL** (when RTCPTR<1:0> = 10): Month and Day Value Register
  - **RTCVAL** (when RTCPTR<1:0> = 01): Weekday and Hours Value Register
  - **RTCVAL** (when RTCPTR<1:0> = 00): Minutes and Seconds Value Register

- **Alarm Value Registers**
  - **ALRMVAL** (when ALRMPTR<1:0> = 10): Alarm Month and Day Value Register
  - **ALRMVAL** (when ALRMPTR<1:0> = 01): Alarm Weekday and Hours Value Register
  - **ALRMVAL** (when ALRMPTR<1:0> = 00): Alarm Minutes and Seconds Value Register

37.2.1 Register Mapping

To limit the register interface, the RTCC Timer and RTCC Alarm registers are accessed through corresponding register pointers. The RTCC Value register uses the RTCPTR bits (RCFGCAL<9:8>) to select the desired timer register pair, as shown in Table 37-1.

The RTCPTR<1:0> bits (RCFGCAL<9:8>) are automatically decremented each time the upper eight bits of the RTCVAL register are accessed by the user-assigned application. Once they reach a value of ‘00’, any further access of these upper eight bits by the user-assigned application has no effect on the RTCPTR bits.

<table>
<thead>
<tr>
<th>RTCPTR &lt;1:0&gt;</th>
<th>RTCC Value Register Window</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>RTCVAL&lt;15:8&gt;</td>
<td>RTCVAL&lt;7:0&gt;</td>
</tr>
<tr>
<td>00</td>
<td>Minutes</td>
<td>Seconds</td>
</tr>
<tr>
<td>01</td>
<td>Weekday</td>
<td>Hours</td>
</tr>
<tr>
<td>10</td>
<td>Month</td>
<td>Day</td>
</tr>
<tr>
<td>11</td>
<td>—</td>
<td>Year</td>
</tr>
</tbody>
</table>

The RTCC Alarm Value register uses the ALRMPTR bits (ALCFGRPT<9:8>) to select the desired Alarm register pair, as shown in Table 37-2.

The ALRMPTR<1:0> bits (ALCFGRPT<9:8>) are automatically decremented each time the upper eight bits of the ALRMVAL register are accessed by the user-assigned application. Once they reach a value of ‘00’, any further access of these upper eight bits by the user-assigned application has no effect on the ALRMPTR bits.

<table>
<thead>
<tr>
<th>ALRMPTR &lt;1:0&gt;</th>
<th>Alarm Value Register Window</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>ALRMVAL&lt;15:8&gt;</td>
<td>ALRMVAL&lt;7:0&gt;</td>
</tr>
<tr>
<td>00</td>
<td>Minutes</td>
<td>Seconds</td>
</tr>
<tr>
<td>01</td>
<td>Weekday</td>
<td>Hours</td>
</tr>
<tr>
<td>10</td>
<td>Month</td>
<td>Day</td>
</tr>
<tr>
<td>11</td>
<td>—</td>
<td>Year</td>
</tr>
</tbody>
</table>

Considering that the 16-bit core does not distinguish between 8-bit and 16-bit read operations, reading either the upper bytes or lower bytes decrements the ALRMPTR<1:0> value. The same applies to the RTCPTR<1:0> value. While writing, the RTCPTR and ALRMPTR register value will decrement only when writing to the RTCVALL and ALRMVALL bytes, respectively. Writing to the RTCVALL and ALRMVALL does not affect the corresponding pointer bits.

**Note:** Displaying RTCVAL or ALRMVAL registers in the MPLAB® IDE Watch window will cause these registers to decrement.
### 37.2.2 RTCC Control Registers

#### Register 37-1: RCFGCAL: RTCC Calibration and Configuration Register

<table>
<thead>
<tr>
<th>R/W-0</th>
<th>U-0</th>
<th>R/W-0</th>
<th>R-0</th>
<th>R-0</th>
<th>R/W-0</th>
<th>R/W-0</th>
<th>R/W-0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RTCEN**(1)**</td>
<td>—</td>
<td>RTCWREN</td>
<td>RTCSYNC</td>
<td>HALFSEC**(2)**</td>
<td>RTCOE</td>
<td>RTCPTR&lt;1:0&gt;</td>
<td></td>
</tr>
</tbody>
</table>

Legend:

- **R** = Readable bit
- **W** = Writable bit
- **U** = Unimplemented bit, read as ‘0’
- ‘-n’ = Value at POR
- ‘1’ = Bit is set
- ‘0’ = Bit is cleared
- ‘x’ = Bit is unknown

<table>
<thead>
<tr>
<th>bit 15</th>
<th>bit 14</th>
<th>bit 13</th>
<th>bit 12</th>
<th>bit 11</th>
<th>bit 10</th>
<th>bit 9-8</th>
<th>bit 7-0</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>RTCEN</strong>(1): RTCC Enable bit**(1)**</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1 = RTCC module is enabled</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0 = RTCC module is disabled</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Unimplemented:</strong> Read as ‘0’</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>RTCWREN</strong>: RTCC Value Registers Write Enable bit</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1 = RTCVAL register can be written to by the user-assigned application</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0 = RTCVAL register is locked out from being written to by the user-assigned application</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>RTCSYNC</strong>: RTCC Value Registers Read Synchronization bit</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1 = A rollover is about to occur in 32 clock edges (approximately 1 ms)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0 = A rollover will not occur</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>HALFSEC</strong>(2): Half-Second Status bit**(2)**</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1 = Second half period of a second</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0 = First half period of a second</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>RTCOE</strong>: RTCC Output Enable bit</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1 = RTCC output enabled</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0 = RTCC output disabled</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>RTCPTR&lt;1:0&gt;:</strong> RTCC Value Register Pointer bits</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Points to the corresponding RTCC Value register when reading the RTCVAL register; the RTCPTR&lt;1:0&gt; value decrements on every access of RTCVAL until it reaches ‘00’. Refer to 37.2.1 “Register Mapping” for bit descriptions.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>CAL&lt;7:0&gt;:</strong> RTCC Drift Calibration bits</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>01111111 = Maximum positive adjustment; adds 508 RTCC clock pulses every one minute</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>00000001 = Minimum positive adjustment; adds 4 RTCC clock pulses every one minute</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>00000000 = No adjustment</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11111111 = Minimum negative adjustment; subtracts 4 RTCC clock pulses every one minute</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10000000 = Maximum negative adjustment; subtracts 512 RTCC clock pulses every one minute</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Note 1:** A write to the RTCEN bit is only allowed when RTCWREN = 1.

**Note 2:** This bit is read-only. It is cleared to ‘0’ on a write to the lower half of the MINSEC register.

**Note:** This register is only affected by a Power-on Reset (POR).
### Section 37. Real-Time Clock and Calendar (RTCC)

#### Register 37-2: PADCFG1: Pad Configuration Control Register

<table>
<thead>
<tr>
<th>bit 15-2</th>
<th>bit 1</th>
<th>bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Unimplemented: Read as '0'</td>
<td><strong>RTSECSEL</strong>: RTCC Seconds Clock Output Select bit(^{(1)})</td>
<td><strong>Not used by the RTCC module</strong>: Refer to the “RTCC” chapter in the specific device data sheet for a description of this bit.</td>
</tr>
</tbody>
</table>

**Legend:**
- R = Readable bit
- W = Writable bit
- U = Unimplemented bit, read as '0'
- -n = Value at POR
- ‘1’ = Bit is set
- ‘0’ = Bit is cleared
- x = Bit is unknown

<table>
<thead>
<tr>
<th>bit 15-2</th>
<th>bit 8</th>
<th>bit 7</th>
<th>bit 6</th>
<th>bit 5</th>
<th>bit 4</th>
<th>bit 3</th>
<th>bit 2</th>
<th>bit 1</th>
<th>bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>R/W-0</td>
<td>R/W-0</td>
</tr>
<tr>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
</tr>
</tbody>
</table>

Note 1: To enable the actual RTCC output, the RTCOE bit (RCFGCAL\(<10>\)) must be set.
Register 37-3: ALCFGRT: Alarm Configuration Register

<table>
<thead>
<tr>
<th>bit 15</th>
<th>bit 8</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W-0</td>
<td>R/W-0</td>
</tr>
<tr>
<td>R/W-0</td>
<td>R/W-0</td>
</tr>
<tr>
<td>R/W-0</td>
<td>R/W-0</td>
</tr>
<tr>
<td>R/W-0</td>
<td>R/W-0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>bit 7</th>
<th>bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W-0</td>
<td>R/W-0</td>
</tr>
<tr>
<td>R/W-0</td>
<td>R/W-0</td>
</tr>
<tr>
<td>R/W-0</td>
<td>R/W-0</td>
</tr>
</tbody>
</table>

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

bit 15  ALRMEN: Alarm Enable bit
1 = Alarm is enabled (cleared automatically after an alarm event whenever ARPT<7:0> = 0x00 and
   CHIME = 0)
0 = Alarm is disabled

bit 14  CHIME: Chime Enable bit
1 = Chime is enabled; ARPT<7:0> bits are allowed to roll over from 0x00 to 0xFF
0 = Chime is disabled; ARPT<7:0> bits stop once they reach 0x00

bit 13-10  AMASK<3:0>: Alarm Mask Configuration bits
0000 = Every half second
0001 = Every second
0010 = Every 10 seconds
0011 = Every minute
0100 = Every 10 minutes
0101 = Every hour
0110 = Once a day
0111 = Once a week
1000 = Once a month
1001 = Once a year (except when configured for February 29, once every four years)
101x = Reserved
11xx = Reserved

bit 9-8  ALRMPTR<1:0>: Alarm Value Register Window Pointer bits
Points to the corresponding Alarm Value registers when reading ALRMVALH and ALRMVALL registers; the ALRMPTR<1:0> value decrements on every read or write of ALRMVALH until it reaches '00'. Refer to 37.2.1 “Register Mapping”, for bit description.

bit 7-0  ARPT<7:0>: Alarm Repeat Counter Value bits
11111111 = Alarm will repeat 255 more times
•
•
00000000 = Alarm will not repeat
The counter decrements on any alarm event. The counter is prevented from rolling over from 0x00 to
0xFF unless CHIME = 1.
37.2.3 RTCC Value Registers

Register 37-4: RTCVAL (when RTCPTR<1:0> = 11): Year Value Register

<table>
<thead>
<tr>
<th>bit 15</th>
<th>bit 8</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W-x</td>
<td>R/W-x</td>
</tr>
<tr>
<td>YRTEN&lt;3:0&gt;</td>
<td>YRONE&lt;3:0&gt;</td>
</tr>
</tbody>
</table>

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

Note: A write to this register is only allowed when RTCWREN = 1.

Register 37-5: RTCVAL (when RTCPTR<1:0> = 10): Month and Day Value Register

<table>
<thead>
<tr>
<th>bit 15</th>
<th>bit 8</th>
</tr>
</thead>
<tbody>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>R/W-x</td>
<td>R/W-x</td>
</tr>
<tr>
<td>MTHTEN0</td>
<td>MTHONE&lt;3:0&gt;</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>bit 7</th>
<th>bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>R/W-x</td>
<td>R/W-x</td>
</tr>
<tr>
<td>DAYTEN&lt;1:0&gt;</td>
<td>DAYONE&lt;3:0&gt;</td>
</tr>
</tbody>
</table>

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

Note: A write to this register is only allowed when RTCWREN = 1.
Register 37-6: RTCVAL (when RTCPTR<1:0> = 01): Weekday and Hours Value Register

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value at POR</th>
<th>Set</th>
<th>Clear</th>
<th>Unknown</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>WDAY&lt;2:0&gt;</td>
<td>000</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13-11</td>
<td>Unimplemented: Read as ‘0’</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10-8</td>
<td>HRTEN&lt;1:0&gt;</td>
<td>00</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7-5</td>
<td>HRONE&lt;3:0&gt;</td>
<td>000</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4-2</td>
<td>Unimplemented: Read as ‘0’</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Unimplemented: Read as ‘0’</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Legend:
- R = Readable bit
- W = Writable bit
- U = Unimplemented bit, read as ‘0’
- = Value at POR
- ‘1’ = Bit is set
- ‘0’ = Bit is cleared
- x = Bit is unknown

Note: A write to this register is only allowed when RTCWREN = 1.

Register 37-7: RTCVAL (when RTCPTR<1:0> = 00): Minutes and Seconds Value Register

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value at POR</th>
<th>Set</th>
<th>Clear</th>
<th>Unknown</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>MINTEN&lt;2:0&gt;</td>
<td>000</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13-11</td>
<td>Unimplemented: Read as ‘0’</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10-8</td>
<td>SECTEN&lt;2:0&gt;</td>
<td>000</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7-5</td>
<td>SECONE&lt;3:0&gt;</td>
<td>000</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4-2</td>
<td>Unimplemented: Read as ‘0’</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Unimplemented: Read as ‘0’</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Legend:
- R = Readable bit
- W = Writable bit
- U = Unimplemented bit, read as ‘0’
- = Value at POR
- ‘1’ = Bit is set
- ‘0’ = Bit is cleared
- x = Bit is unknown

Note: A write to this register is only allowed when RTCWREN = 1.
### Section 37. Real-Time Clock and Calendar (RTCC)

#### 37.2.4 Alarm Value Registers

**Register 37-8:** ALRMVAL (when ALRMPTR<1:0> = 10): Alarm Month and Day Value Register

<table>
<thead>
<tr>
<th>U-0</th>
<th>U-0</th>
<th>U-0</th>
<th>R/W-x</th>
<th>R/W-x</th>
<th>R/W-x</th>
<th>R/W-x</th>
<th>R/W-x</th>
</tr>
</thead>
<tbody>
<tr>
<td>—</td>
<td>—</td>
<td>—</td>
<td></td>
<td>MTHTEN0</td>
<td>MTHONE&lt;3:0&gt;</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

bit 15

<table>
<thead>
<tr>
<th>U-0</th>
<th>U-0</th>
<th>R/W-x</th>
<th>R/W-x</th>
<th>R/W-x</th>
<th>R/W-x</th>
</tr>
</thead>
<tbody>
<tr>
<td>—</td>
<td>—</td>
<td>DAYTEN&lt;1:0&gt;</td>
<td></td>
<td>DAYONE&lt;3:0&gt;</td>
<td></td>
</tr>
</tbody>
</table>

bit 7

**Legend:**
- R = Readable bit
- W = Writable bit
- U = Unimplemented bit, read as ‘0’
- -n = Value at POR
- ‘1’ = Bit is set
- ‘0’ = Bit is cleared
- x = Bit is unknown

bit 15-13 **Unimplemented:** Read as ‘0’

bit 12  **MTHTEN0:** Binary Coded Decimal Value of Month’s Tens Digit; contains a value of 0 or 1

bit 11-8 **MTHONE<3:0>:** Binary Coded Decimal Value of Month’s Ones Digit; contains a value from 0 to 9

bit 7-6 **Unimplemented:** Read as ‘0’

bit 5-4 **DAYTEN<1:0>:** Binary Coded Decimal Value of Day’s Tens Digit; contains a value from 0 to 3

bit 3-0 **DAYONE<3:0>:** Binary Coded Decimal Value of Day’s Ones Digit; contains a value from 0 to 9

**Note:** A write to this register is only allowed when RTCWREN = 1.

**Register 37-9:** ALRMVAL (when ALRMPTR<1:0> = 01): Alarm Weekday and Hours Value Register

<table>
<thead>
<tr>
<th>U-0</th>
<th>U-0</th>
<th>U-0</th>
<th>U-0</th>
<th>U-0</th>
<th>R/W-x</th>
<th>R/W-x</th>
<th>R/W-x</th>
</tr>
</thead>
<tbody>
<tr>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td></td>
<td>WDAY&lt;2:0&gt;</td>
<td></td>
</tr>
</tbody>
</table>

bit 15

<table>
<thead>
<tr>
<th>U-0</th>
<th>U-0</th>
<th>R/W-x</th>
<th>R/W-x</th>
<th>R/W-x</th>
<th>R/W-x</th>
</tr>
</thead>
<tbody>
<tr>
<td>—</td>
<td>—</td>
<td>HRTEN&lt;1:0&gt;</td>
<td></td>
<td>HRONE&lt;3:0&gt;</td>
<td></td>
</tr>
</tbody>
</table>

bit 7

**Legend:**
- R = Readable bit
- W = Writable bit
- U = Unimplemented bit, read as ‘0’
- -n = Value at POR
- ‘1’ = Bit is set
- ‘0’ = Bit is cleared
- x = Bit is unknown

bit 15-11 **Unimplemented:** Read as ‘0’

bit 10-8 **WDAY<2:0>:** Binary Coded Decimal Value of Weekday Digit; contains a value from 0 to 6

bit 7-6 **Unimplemented:** Read as ‘0’

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:** A write to this register is only allowed when RTCWREN = 1.
Register 37-10: ALRMVAL (when ALRMPTR<1:0> = 00): Alarm Minutes and Seconds Value Register

<table>
<thead>
<tr>
<th>bit 15</th>
<th>R/W-x</th>
<th>bit 8</th>
</tr>
</thead>
<tbody>
<tr>
<td>U-0</td>
<td>—</td>
<td>R/W-x</td>
</tr>
<tr>
<td>—</td>
<td>MINTEN&lt;2:0&gt;</td>
<td>MINONE&lt;3:0&gt;</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>bit 7</th>
<th>R/W-x</th>
<th>bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>U-0</td>
<td>—</td>
<td>R/W-x</td>
</tr>
<tr>
<td>—</td>
<td>SECTEN&lt;2:0&gt;</td>
<td>SECON&lt;3:0&gt;</td>
</tr>
</tbody>
</table>

Legend:
- R = Readable bit
- W =Writable bit
- U = Unimplemented bit, read as ‘0’
- -n = Value at POR
- ‘1’ = Bit is set
- ‘0’ = Bit is cleared
- x = Bit is unknown

- bit 15: Unimplemented: Read as ‘0’
- bit 14-12: MINTEN<2:0>: Binary Coded Decimal Value of Minute’s Tens Digit; contains a value from 0 to 5
- bit 11-8: MINONE<3:0>: Binary Coded Decimal Value of Minute’s Ones Digit; contains a value from 0 to 9
- 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: SECON<3:0>: Binary Coded Decimal Value of Second’s Ones Digit; contains a value from 0 to 9

Note: A write to this register is only allowed when RTCWREN = 1.
37.3 RTCC OPERATION

The RTCC module is intended to be clocked by an external real-time clock crystal oscillating at 32.768 kHz. The prescaler divides the crystal oscillator frequency to produce the 1 Hz update frequency for the clock and the calendar. The current date and time is tracked in a 7-byte counter register that updates once per second.

Each counter counts in BCD, as it allows easy conversion to decimal digits for display or printing. The count sequence of the individual byte counters is shown in Figure 37-2. Note that the day of month and month counters roll over to one. All other counters roll over to zero. The end of the month date is automatically adjusted for months with fewer than 31 days, including corrections for leap year valid up to 2100. Upon initial application of power, the counters contain random information.

Figure 37-2: RTCC Timer

Note: To allow the RTCC module to be clocked by the secondary crystal oscillator, the Secondary Oscillator Enable bit, LPOSCEN OSCON<1>, in the Oscillator Control register must be set. Refer to Section 39. “Oscillator (Part III)” (DS70216), for more details.

37.3.1 Write RTCC Timer

The user-assigned application can configure the time and calendar by writing the desired seconds, minutes, hours, weekday, date, month and year to the RTCC registers. Under normal operation, writes to the RTCC timer registers are not allowed. Attempted writes will appear to execute normally, but the contents of the registers will remain unchanged. To write to the RTCC register, the RTCWREN bit (RCFGCAL<13>) must be set. Setting the RTCWREN bit allows writes to the RTCC registers. Conversely, clearing the RTCWREN bit prevents writes.

To set the RTCWREN bit, a specific command sequence must be executed, and it can be cleared at any time:

1. Write 0x55 to NVMKEY.
2. Write 0xAA to NVMKEY.
3. Set the RTCWREN bit using a single cycle instruction.

The RTCC module is enabled by setting the RTCEN bit (RCFGCAL<15>). To set or clear the RTCEN bit, the RTCWREN bit (RCFGCAL<13>) must be set.

If the entire clock (hours, minutes and seconds) needs to be corrected, it is recommended to disable the RTCC module, which stops the clock from counting while writing to the RTCC Timer Register. This avoids coincidental write operation with the timer increment.
It is not required to stop the clock if only one location (hours or minutes or seconds) needs to be updated. Doing so would introduce an error in the timekeeping. An example of where only one field needs to be updated is while correcting the hours for daylight savings time. Also, the prescaler resets when the minute or seconds register is written to.

To write to the clock “on-the-fly”, the best method is to wait for the RTCSYNC bit (RCFGCAL<12>) to be ‘0’ and then write to the timekeeping registers. The RTCSYNC bit is set 32 clock edges (~1 ms) before a rollover is about to occur in the prescaler. The code in Example 37-1 demonstrates a RTCC timekeeping register write operation.

**Example 37-1:  RTCC Timekeeping Register Write Operation**

```
;*******************************
; Enable RTCC Timer Access
;*******************************
MOV  #0x55,W0
MOV  W0, NVMKEY
MOV  #0xAA,W0
MOV  W0, NVMKEY
BSET RCFGCAL,#RTCWREN ; Set RTCWREN bit

;*******************************
; Disable RTCC module
;*******************************
BCLR RCFGCAL,#RTCEN  ; Clear RTCEN bit

;*******************************
; Write to RTCC Timer
;*******************************
MOV  RCFGCAL,w0
OR #0x300,w0
MOV  w0,RCFGCAL ; Set RTCPTR to 3

MOV  #0x0007,w0 ; Set Year (#0x00YY)
MOV  #0x1028,w1 ; Set Month and Day (#0xMMDD)
MOV  #0x0110,w2 ; Set Weekday and Hour (#0x0WHH)
MOV  #0x0000,w3 ; Set Minute and Second (#0xMMSS)

MOV  w0,RTCVAL
MOV  w1,RTCVAL
MOV  w2,RTCVAL
MOV  w3,RTCVAL

;*******************************
; Enable RTCC module
;*******************************
BSET RCFGCAL,#RTCEN  ; Set RTCEN bit

;*******************************
; Disable RTCC Timer Access
;*******************************
BCLR RCFGCAL,#RTCWREN ; Clear RTCWREN bit
```
37.3.2 Read RTCC Timer

The time and calendar information is obtained by reading the appropriate register bytes. The RTCC timer cannot be stopped to read the current time as stopping the RTCC would introduce an error in its timekeeping. Therefore, the RTCC timer is read “on-the-fly”.

Since clocking of the counter occurs asynchronously to reading the counter, it is possible to read the counter while it is being incrementated (rollover). This may result in incorrect time reading. Therefore, to ensure correct reading of the entire contents of the clock (or that part of interest), it must be read without a clock rollover occurring.

To read the clock “on-the-fly”, the best method is to wait for the RTCSYNC bit (RCFGCAL<12>) to be ’0’, and then read the timekeeping registers. The RTCSYNC bit is set 32 clock edges (~1 ms) before a rollover is about to occur in the prescaler.

If the user-assigned application cannot wait for RTCSYNC bit to become ’0’, the alternate method is to read the timekeeping registers twice. If the data is the same both times, it is considered to be valid. Therefore, an access that is minimum of two and a maximum of three are required. The code in Example 37-2 shows an RTCC timekeeping register read operation.

Example 37-2: RCAL Timekeeping Register Read Operation

```c
;**********************************************
; Wait for RTCSYNC bit to become '0'
;**********************************************
while(RCFGCALbits.RTCSYNC==1);

;**********************************************
; Read RTCC timekeeping register
;**********************************************
RCFGCALbits.RTCPTR=3;

year=RTCVAL;
month_date=RTCVAL;
wday_hour=RTCVAL;
min_sec=RTCVAL;
```
37.4 RTCC ALARM

Alarms are available to interrupt the CPU at a particular time, or at periodic time intervals, such as once per minute or once per day. During each clock update, the RTCC compares the selected Alarm registers with the corresponding clock registers. When a match occurs, an alarm event is generated.

The Alarm Mask (AMASK<3:0>) bits in the Alarm Configuration (ALCFGRPT<13:10>) are used to mask registers that do not have to be compared. Figure 37-3 illustrates the alarm BCD register nibbles that are compared with the timekeeping register for different AMASK settings.

Figure 37-3: RTCC Alarm
Section 37. Real-Time Clock and Calendar (RTCC)

For example, to set an alarm for each morning at six o’clock (06:00:00 in 24-hour format):
1. In the Alarm register, load the hours byte with 06 (BCD), the minutes byte with 00 (BCD),
   and the seconds byte with 00 (BCD).
2. Mask off the month, date and weekday bytes and just compare hour, minute and second
   by setting the addressing mask (AMASK) bits to ‘0b0110. Each day when the time rolls
   over from 05:59:59, an alarm event is generated.

   Note: The alarm must be disabled (ALRMEN = 0) while writing to the Alarm register,
   otherwise it may result in a false alarm. The Alarm register can be read any time.

Example 37-3 shows the code to configure the Alarm registers to generate an alarm every
morning at six o’clock.

Example 37-3: Writing to Alarm Register

```asm
;**************************************************
; Disable Alarm
;**************************************************
ALCFGRPTbits.ALRMEN=0;

;**************************************************
; Write to Alarm Register (Time: 06:00:00)
;**************************************************
ALCFGRPTbits.ALRMPTR=2;
ALRMVAL=0;
ALRMVAL=0x0006;
ALRMVAL=0x0000;

;**************************************************
; Select Alarm Mask to compare hour, minute, second
;**************************************************
ALCFGRPTbits.AMASK=0b0110;

;**************************************************
; Enable Alarm
;**************************************************
ALCFGRPTbits.CHIME=1;
ALCFGRPTbits.ALRMEN=1;
```
37.4.1 Alarm Mode Selection

The alarm is enabled using the ALRMEN bit (ALCFGRPT<14>), which can generate a one-short alarm and a recurring alarm.

37.4.1.1 ONE-SHORT ALARM

This Alarm event is generated when the clock matches the selected alarm nibbles. The Alarm is automatically disabled on an alarm event. To configure a one-short alarm, do the following:

1. Clear the Chime Enable bit, CHIME (ALCFGRPT<14>), in the Alarm Configuration register.
2. Program the Alarm repeat counter (ARPT<7:0>) to '0'.

37.4.1.2 CHIME DISABLE

When CHIME = 0, the Alarm repeat counter (ARPT<7:0>) is decremented on every alarm event and the alarm is disabled when the repeat counter becomes zero.

37.4.1.3 CHIME ENABLE

Indefinite repetition of the Alarm can occur if the CHIME bit is set. When CHIME = 1, the Alarm repeat counter (APRT<7:0>) is decremented indefinitely after each time the alarm is issued.

37.4.2 Alarm Interrupt and Output

The Alarm event can generate an RTCC interrupt or toggle the RTCC output pin. An RTCC interrupt is enabled as a source of interrupt via the respective RTCC Interrupt Enable bit, RTCIE. The interrupt priority level (RTCIP<2:0>) bits must be written with a non-zero value for the RTCC to be a source of interrupt. Refer to Section 32. “Interrupts (Part III)” (DS70214), for more details.

In addition, an Alarm event can toggle the RTCC pin thereby generating a periodic clock at half the alarm rate. The RTCC pin is also capable of outputting the seconds clock. The user-assigned application can select between the alarm output, or the seconds clock output. The RTSECSEL bit (PADCFG1<1>) selects between these two outputs. When RTSECSEL = 0, the alarm toggles the pin on every alarm event. When RTSECSEL = 1, the seconds clock is selected.
37.5 RTCC CALIBRATION

Calibration is provided to compensate the nominal crystal frequency and for variations in the external crystal frequency over temperature. Calibration is accomplished by adding or subtracting counts every one minute. Adding counts speeds up the clock and subtracting counts slows the clock. The number of pulses blanked (subtracted for negative calibration) or inserted (added for positive calibration) is set by the 8-bit signed value loaded into the calibration (CAL<7:0>) bits, in the RTCC Configuration and Calibration Control (RCFGCAL<7:0>) register.

Each calibration step either adds four or subtracts four oscillator cycles for every one minute (60 x 32.768 kHz = 1,966,080 oscillator cycles). This equates to ±2.034 parts per million (ppm) of adjustment per calibration step or ±5.35 seconds per month. It allows calibrating the timekeeping accuracy to within three seconds per month. Table 37-3 details the amount of adjustment for each value in the calibration register.

Table 37-3: Calibration Adjustment Values

<table>
<thead>
<tr>
<th>Calibration Value (CAL&lt;7:0&gt;)</th>
<th>Adjustment Accuracy (ppm)</th>
<th>Time (sec/month)</th>
<th>Calibration Value (CAL&lt;7:0&gt;)</th>
<th>Adjustment Accuracy (ppm)</th>
<th>Time (sec/month)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>—</td>
<td>-1</td>
<td>-2.03</td>
<td>-5.27</td>
</tr>
<tr>
<td>1</td>
<td>2.03</td>
<td>5.27</td>
<td>-2</td>
<td>-4.07</td>
<td>-10.55</td>
</tr>
<tr>
<td>2</td>
<td>4.07</td>
<td>10.55</td>
<td>-3</td>
<td>-6.1</td>
<td>-15.82</td>
</tr>
<tr>
<td>3</td>
<td>6.1</td>
<td>15.82</td>
<td>-4</td>
<td>-8.14</td>
<td>-21.09</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>125</td>
<td>254.31</td>
<td>659.18</td>
<td>-126</td>
<td>-256.35</td>
<td>-664.45</td>
</tr>
<tr>
<td>126</td>
<td>256.35</td>
<td>664.45</td>
<td>-127</td>
<td>-258.38</td>
<td>-669.73</td>
</tr>
<tr>
<td>127</td>
<td>258.38</td>
<td>669.73</td>
<td>-128</td>
<td>-260.42</td>
<td>-675</td>
</tr>
</tbody>
</table>

To establish how much calibration is required in a given application, the following method (specially suited to the Manufacturing environment) can be used:

1. Output the seconds clock (1 Hz) on the RTCC pin, measure the crystal oscillator frequency, and calculate the crystal frequency deviation in Hz.
2. Frequency Error = 32.768 kHz – Measured Frequency.
3. Calculate counter error per minute due to frequency deviation:
   Count Error = (Frequency Error) x 60
4. Set the CAL<7:0> bits to (Count Error/4).

Note: The user-assigned application can use a temperature sensor to adjust the calibration value to compensate for the temperature drift.
37.5.1 Writing the Calibration Value

The RTCC module performs calibration or adjusts the prescaler for every minute, as shown in Figure 37-4. The calibration point is at the 512th clock edge following the seconds BCD counter rollover (59 to 00).

Figure 37-4: Calibration Point

At the calibration point, the RTCC module reads the 8-bit signed value (CAL<7:0>) and adjusts the prescaler counter accordingly. To ensure that the RTCC module reads the correct calibration value, it should not be updated by the CPU at the same time the RTCC module reads the value. When the seconds byte is zero, the calibration value must be updated when the HALFSEC bit (RCFGCAL<11>) becomes ‘1’. The code in Example 37-4 shows how to update the calibration value “on-the-fly”.

Example 37-4: Writing the Calibration Value

```
;**************************************************
; Read RTCC timer to check the seconds
; If seconds byte is 0, wait for HALFSEC bit to become 1
;**************************************************
RCFGCALbits.RTCPTR=0;
seconds=(RTCVAL & 0xFF);
if(seconds == 0)
    while(RCFGCALbits.HALFSEC==0);

;**************************************************
; Write to the calibration value
;**************************************************
RCFGCALbits.CAL=calvalue;
```
37.6 OPERATION IN POWER-SAVING MODES

37.6.1 Sleep Mode

When the device enters Sleep mode, the system clock is disabled. As the RTCC timer is clocked from the Secondary Oscillator, it will continue to run in Sleep mode.

If enabled, the Alarm interrupt wakes the device from Sleep and the following occurs:

- If the assigned priority for the interrupt is less than, or equal to, the current CPU priority, the device wakes up and continues code execution from the instruction following the \texttt{PWRSAV} instruction that initiated Sleep mode.
- If the assigned priority level for the interrupt source is greater than the current CPU priority, the device wakes up and the CPU exception process begins. Code execution continues from the first instruction of the timer Interrupt Service Routine (ISR). Refer to Section 9. “Watchdog Timer and Power-Saving Modes” (DS70196), for more details.

37.6.2 Idle Mode

Idle mode does not affect the operation of the RTCC module.
37.7 REGISTER MAP

Table 37-4 maps the bit functions for the RTCC registers.

<table>
<thead>
<tr>
<th>File Name</th>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
<th>All Resets</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALRMVAL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ALRMVAL Alarm Value Register Window based on ALRMPTR&lt;1:0&gt; xxxxx</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ALCFRPT</td>
<td>ALRME</td>
<td>CHIME</td>
<td>AMASK&lt;3:0&gt;</td>
<td>ALRMPTR&lt;1:0&gt;</td>
<td>ARPT&lt;7:0&gt;</td>
<td>0000</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RTCVAL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RTCVAL RTCC Value Register Window based on RTCPTR&lt;1:0&gt; xxxxx</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RCFGCAL</td>
<td>RTCEN</td>
<td>—</td>
<td>RTCWREN</td>
<td>RTCSYNC</td>
<td>RTCOE</td>
<td>RTCPTR&lt;1:0&gt;</td>
<td>CAL&lt;7:0&gt;</td>
<td>0000</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PADCFG1</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>— RTSECSEL PMPTTL 0000</td>
</tr>
</tbody>
</table>

Legend:  
\( \times \) = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal.
37.8 RELATED APPLICATION NOTES

This section lists application notes that are related to this section of the manual. These application notes may not be written specifically for the dsPIC33F/PIC24H product family, but the concepts are pertinent and could be used with modification and possible limitations. The current application notes related to the Real-Time Clock and Calendar (RTCC) module are:

<table>
<thead>
<tr>
<th>Title</th>
<th>Application Note #</th>
</tr>
</thead>
<tbody>
<tr>
<td>No related application notes at this time.</td>
<td>N/A</td>
</tr>
</tbody>
</table>

Note: Please visit the Microchip web site (www.microchip.com) for additional application notes and code examples for the dsPIC33F/PIC24H family of devices.
37.9 REVISION HISTORY

Revision A (November 2007)
This is the initial released version of this document.

Revision B (September 2009)
This revision incorporates the following updates:

- Registers:
  - Updated the bit value description for bit 7-0, in the RCFGCAL: RTCC Calibration and Configuration Register (see Register 37-1)

- Sections:
  - Updated the Introduction section (see 37.1 “Introduction”) with the following point: The RTCC and the Secondary Oscillator (SOSC) will continue to function when the device is held under reset by pulling the MCLR pin low.
  - Additional minor corrections such as language and formatting updates are incorporated throughout the document

Revision C (March 2012)
This revision includes the following updates:

- Updated the ALRMVAL bit description in the RTCC register map (see Table 37-4)
- Updated the document to includes references to the PIC24H family of devices
- Additional minor updates to text and formatting were incorporated throughout the document
Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip’s Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as “unbreakable.”

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip’s code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer’s risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.

Trademarks

The Microchip name and logo, the Microchip logo, dsPIC, KEELOQ, KEELOQ logo, MPLAB, PIC, PICmicro, PICSTART, PIC18 logo, rPIC and Uni/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MXDEV, MxLAB, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Application Maestro, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICWorks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, REAL ICE, rFLAB, Select Mode, Total Endurance, TSHARC, UniWinDriver, WiperLock and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

All other trademarks mentioned herein are property of their respective companies.

© 2007-2012, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

Printed on recycled paper.


Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Glenview, Oregon and design centers in California and India. The Company’s quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip’s quality system for the design and manufacture of development systems is ISO 9001:2000 certified.
Worldwide Sales and Service

AMERICAS
Corporate Office
2355 West Chandler Blvd.
Chandler, AZ 85224-6199
Tel: 480-792-7200
Fax: 480-792-7277
Technical Support:
http://www.microchip.com/support
Web Address:
www.microchip.com

Atlanta
Duluth, GA
Tel: 678-957-9614
Fax: 678-957-1455

Boston
Westborough, MA
Tel: 774-760-0087
Fax: 774-760-0088

Chicago
Itasca, IL
Tel: 630-285-0071
Fax: 630-285-0075

Cleveland
Independence, OH
Tel: 216-447-0464
Fax: 216-447-0643

Dallas
Addison, TX
Tel: 972-818-7423
Fax: 972-818-2924

Detroit
Farmington Hills, MI
Tel: 248-538-2250
Fax: 248-538-2260

Indianapolis
Noblesville, IN
Tel: 317-773-8323
Fax: 317-773-5453

Los Angeles
Mission Viejo, CA
Tel: 949-462-9523
Fax: 949-462-9608

Santa Clara
Santa Clara, CA
Tel: 408-961-6444
Fax: 408-961-6445

Toronto
Mississauga, Ontario, Canada
Tel: 905-673-0699
Fax: 905-673-6509

ASIA/PACIFIC
Asia Pacific Office
Suites 3707-14, 37th Floor
Tower 6, The Gateway
Harbour City, Kowloon
Hong Kong
Tel: 852-2401-1200
Fax: 852-2401-3431

Australia - Sydney
Tel: 61-2-9868-6733
Fax: 61-2-9868-6755

China - Beijing
Tel: 86-10-8569-7000
Fax: 86-10-8528-2104

China - Chengdu
Tel: 86-28-8665-5511
Fax: 86-28-8665-7889

China - Chongqing
Tel: 86-23-8980-9588
Fax: 86-23-8980-9500

China - Hangzhou
Tel: 86-571-2819-3187
Fax: 86-571-2819-3189

China - Hong Kong SAR
Tel: 852-2401-1200
Fax: 852-2401-3431

China - Nanjing
Tel: 86-25-8473-2660
Fax: 86-25-8473-2666

China - Qingdao
Tel: 86-532-8502-7355
Fax: 86-532-8502-7205

China - Shanghai
Tel: 86-21-5407-5533
Fax: 86-21-5407-5066

China - Shenyang
Tel: 86-24-2334-2829
Fax: 86-24-2334-2393

China - Shenzhen
Tel: 86-755-8203-2660
Fax: 86-755-8203-1760

China - Wuhan
Tel: 86-27-5980-5300
Fax: 86-27-5980-5118

China - Xian
Tel: 86-29-8833-7252
Fax: 86-29-8833-7256

China - Xiian
Tel: 86-592-2388138
Fax: 86-592-2388130

China - Zhuhai
Tel: 86-756-3210040
Fax: 86-756-3210049

ASIA/PACIFIC
India - Bangalore
Tel: 91-80-3090-4444
Fax: 91-80-3090-4123

India - New Delhi
Tel: 91-11-4160-8631
Fax: 91-11-4160-8632

India - Pune
Tel: 91-20-2566-1512
Fax: 91-20-2566-1513

Japan - Osaka
Tel: 81-66-152-7160
Fax: 81-66-152-9310

Japan - Yokohama
Tel: 81-45-471-6166
Fax: 81-45-471-6122

Korea - Daegu
Tel: 82-53-744-4301
Fax: 82-53-744-4302

Korea - Seoul
Tel: 82-2-554-7200
Fax: 82-2-558-5932
or 82-2-558-5934

Malaysia - Kuala Lumpur
Tel: 60-3-6201-9857
Fax: 60-3-6201-9859

Malaysia - Penang
Tel: 60-4-227-8870
Fax: 60-4-227-4068

Philippines - Manila
Tel: 63-2-634-9065
Fax: 63-2-634-9069

Singapore
Tel: 65-6334-8870
Fax: 65-6334-8850

Taiwan - Hsin Chu
Tel: 886-3-5778-366
Fax: 886-3-5770-955

Taiwan - Kaohsiung
Tel: 886-7-536-4818
Fax: 886-7-330-9305

Taiwan - Taipei
Tel: 886-2-2500-6610
Fax: 886-2-2508-0102

Thailand - Bangkok
Tel: 66-2-694-1351
Fax: 66-2-694-1350

EUROPE
Austria - Wels
Tel: 43-7242-2244-39
Fax: 43-7242-2244-393

Denmark - Copenhagen
Tel: 45-4450-2828
Fax: 45-4485-2829

France - Paris
Tel: 33-1-69-53-63-20
Fax: 33-1-69-30-90-79

Germany - Munich
Tel: 49-89-627-144-0
Fax: 49-89-627-144-44

Italy - Milan
Tel: 39-0331-742611
Fax: 39-0331-466781

Netherlands - Drunen
Tel: 31-416-690399
Fax: 31-416-690340

Spain - Madrid
Tel: 34-91-708-08-90
Fax: 34-91-708-08-91

UK - Wokingham
Tel: 44-118-921-5869
Fax: 44-118-921-5820

© 2007-2012 Microchip Technology Inc.