19.07.2014 Views

PIC24HJ64 Datasheet

PIC24HJ64 Datasheet

PIC24HJ64 Datasheet

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

PIC24HJ32GP302/304, <strong>PIC24HJ64</strong>GPX02/X04, AND PIC24HJ128GPX02/X04<br />

21.1 RTCC Module Registers<br />

The RTCC module registers are organized into three<br />

categories:<br />

• RTCC Control Registers<br />

• RTCC Value Registers<br />

• Alarm Value Registers<br />

21.1.1 REGISTER MAPPING<br />

To limit the register interface, the RTCC Timer and<br />

Alarm Time registers are accessed through corresponding<br />

register pointers. The RTCC Value register<br />

window (RTCVALH and RTCVALL) uses the RTCPTR<br />

bits (RCFGCAL) to select the desired timer<br />

register pair (see Table 21-1).<br />

By writing the RTCVALH byte, the RTCC Pointer value,<br />

RTCPTR bits, decrement by one until they reach<br />

‘00’. Once they reach ‘00’, the MINUTES and<br />

SECONDS value will be accessible through RTCVALH<br />

and RTCVALL until the pointer value is manually<br />

changed.<br />

TABLE 21-1:<br />

RTCPTR<br />

<br />

RTCVAL REGISTER MAPPING<br />

RTCC Value Register Window<br />

RTCVAL<br />

RTCVAL<br />

00 MINUTES SECONDS<br />

01 WEEKDAY HOURS<br />

10 MONTH DAY<br />

11 — YEAR<br />

The Alarm Value register window (ALRMVALH and<br />

ALRMVALL) uses the ALRMPTR bits<br />

(ALCFGRPT) to select the desired Alarm register<br />

pair (see Table 21-2).<br />

By writing the ALRMVALH byte, the Alarm Pointer<br />

value, ALRMPTR bits, decrement by one until<br />

they reach ‘00’. Once they reach ‘00’, the ALRMMIN<br />

and ALRMSEC value will be accessible through<br />

ALRMVALH and ALRMVALL until the pointer value is<br />

manually changed.<br />

TABLE 21-2:<br />

ALRMPTR<br />

<br />

ALRMVAL REGISTER<br />

MAPPING<br />

Alarm Value Register Window<br />

ALRMVAL<br />

ALRMVAL<br />

00 ALRMMIN ALRMSEC<br />

01 ALRMWD ALRMHR<br />

10 ALRMMNTH ALRMDAY<br />

11 — —<br />

Considering that the 16-bit core does not distinguish<br />

between 8-bit and 16-bit read operations, the user must<br />

be aware that when reading either the ALRMVALH or<br />

ALRMVALL bytes will decrement the ALRMPTR<br />

value. The same applies to the RTCVALH or RTCVALL<br />

bytes with the RTCPTR being decremented.<br />

Note:<br />

This only applies to read operations and<br />

not write operations.<br />

21.1.2 WRITE LOCK<br />

In order to perform a write to any of the RTCC Timer<br />

registers, the RTCWREN bit (RCFGCAL) must be<br />

set (refer to Example 21-1).<br />

Note:<br />

To avoid accidental writes to the timer, it is<br />

recommended that the RTCWREN bit<br />

(RCFGCAL) is kept clear at any<br />

other time. For the RTCWREN bit to be<br />

set, there is only 1 instruction cycle time<br />

window allowed between the 55h/AA<br />

sequence and the setting of RTCWREN;<br />

therefore, it is recommended that code<br />

follow the procedure in Example 21-1.<br />

EXAMPLE 21-1: SETTING THE RTCWREN BIT<br />

MOV #NVMKEY, W1 ;move the address of NVMKEY into W1<br />

MOV #0x55, W2<br />

MOV #0xAA, W3<br />

MOV W2, [W1] ;start 55/AA sequence<br />

MOV W3, [W1]<br />

BSET RCFGCAL, #13 ;set the RTCWREN bit<br />

DS70293B-page 232 Preliminary © 2008 Microchip Technology Inc.

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!