## Freescale Semiconductor Application Note Document Number: AN3874 Rev. 0, 06/2009 # i.MX25 Real Time Clock (RTC) by Multimedia Applications Division Freescale Semiconductor, Inc. Austin. TX ### 1 Introduction This document describes how to initialize and maintain the Real Time Clock (RTC) on the i.MX25. The RTC is a digital clock which can be used to accurately keep track of the current time. Some benefits of having an embedded real time clock include: - Low power consumption (since the RTC on the i.MX25 can run from a coin cell battery) - Frees the ARM<sup>®</sup> core to do tasks other than time keeping - Continues to keep time even while the i.MX25 is powered down This application note is intended for non-security customers with non-secure devices. For customers who require security to be enabled, refer to the *i.MX258 Security Reference Manual* for detailed information on how to use the RTC and DryIce module. #### Contents | 1. | Introduction | 1 | |----|------------------------------------|----| | 2. | Real Time Clock | 2 | | 3. | External Signal Description | 3 | | 4. | Memory Map and Register Definition | 3 | | 5. | Example 1 | 14 | | 6. | Revision History | 16 | **Real Time Clock** ### 2 Real Time Clock The RTC on the i.MX25 device is embedded as part of the DryIce module. Even though the DryIce is a security module, the RTC function is still available as part of the i.MX25. The RTC is a 47-bit time counter which runs from the 32.768 KHz clock source. The 15 least significant bits count the number of clock cycles in each second while the 32 most significant bits count the number of seconds. The RTC also includes a programmable 47-bit clock alarm with an interrupt which can be used as a system wake-up from low power mode or as a general interrupt at a pre-defined time. Additionally the RTC includes a general purpose 32-bit register to allow storing of data during system power down assuming the RTC remains powered by the backup battery (BAT\_VDD). The RTC includes its own embedded power management unit which generates the NVCC\_DRYICE output supply. This power management unit monitors the main power supply (Qvdd) and switches the DryIce power supply (this includes power to the RTC) from the backup supply (BAT\_VDD) to the main supply when then main supply powers up. The power management unit also switches the DryIce supply from the main supply to the backup supply when the main supply powers down. This seamless transition allows users to power down the i.MX25 while maintaining the RTC time without software or hardware interaction as long as the back up supply (BAT\_VDD) is present. The features of the power management unit are as follows: - Switches from backup power to main power when the main power supply is $1.2 \text{ V} \pm 50 \text{ mV}$ - Switches from main power to backup power when main power supply is $1.0 \text{ V} \pm 50 \text{ mV}$ - Switch is guaranteed across process corners - Switch is guaranteed between –100°C junction temperature and 150°C junction temperature - Switch is not guaranteed below –100°C or above 150°C junction temperature Figure 1. Power Management Unit The i.MX25 processor can be put into an ultra low power mode by powering down the entire system and only maintaining the backup supply (BAT\_VDD). In this mode the RTC continues to increment the time counter (if it is enabled), and the 32.768 KHz clock remains active. The backup power supply ensures that the DryIce (RTC) registers retain their state during system power-down and that the time counter remains operational. To further reduce power, if an external clock source is used, the internal oscillator can be bypassed using the OSCB bit in the control register or the external bypass pin on the i.MX25. ## 3 External Signal Description The external signals of the RTC are described in Table 1. **Table 1. Signal Properties** | Signal | Function | I/O | Reset | |--------------|-------------------------------------------------------|-----|-------| | BAT_VDD | Backup power supply (core voltage level ) for Drylce | I | _ | | NVCC_DRYICE | Drylce power supply (core voltage level) after switch | 0 | _ | | NGND_DRYICE | Drylce ground | I/O | _ | | OSC32K_EXTAL | 32.768 KHz crystal input | I | 0 | | OSC32K_XTAL | Oscillator output to the 32.768 KHz crystal | 0 | 0 | | OSC_BYP | Bypass the 32.768 KHz oscillator | I | 0 | ## 4 Memory Map and Register Definition This section includes the module memory map and detailed descriptions of all of the registers. ### 4.1 Memory Map Table 2 shows the DryIce (RTC) memory map. **Table 2. Block Memory Map** | Address | Register <sup>1</sup> | Access | Reset <sup>2</sup> Value | Section/Page | | | | | | |------------------------|-----------------------------------------|--------|--------------------------|--------------|--|--|--|--|--| | General Registers | | | | | | | | | | | 0x53FF_C000<br>(RTCMR) | RTC Time Counter MSB Register (RTCMR) | R/W | 0x0000_0000 | 4.1.2.1/6 | | | | | | | 0x53FF_C004<br>(RTCLR) | RTC Time Counter LSB Register (RTCLR) | R/W | 0x0000_0000 | 4.1.2.2/7 | | | | | | | 0x53FF_C008<br>(RCAMR) | RTC Clock Alarm MSB Register (RCAMR) | R/W | 0x0000_0000 | 4.1.2.3/7 | | | | | | | 0x53FF_C00C<br>(RCALR) | RTC Clock Alarm LSB Register (RCALR) | R/W | 0x0000_0000 | 4.1.2.4/8 | | | | | | | 0x53FF_C010<br>(DCR) | Drylce Control Register (DCR) | R/W | 0x0000_0000 | 4.1.2.5/9 | | | | | | | 0x53FF_C014<br>(DSR) | Drylce Status Register (DSR) | R/W | 0x0000_0001 | 4.1.2.6/10 | | | | | | | 0x53FF_C018<br>(DIER) | Drylce Interrupt Enable Register (DIER) | R/W | 0x0000_0000 | 4.1.2.7/12 | | | | | | | 0x53FF_C03C<br>(DGPR) | Drylce General Purpose Register (DGPR) | R/W | 0x0000_0000 | 4.1.2.8/14 | | | | | | <sup>1</sup> Includes short name and long name. In this table, the short name appears in the first column. <sup>&</sup>lt;sup>2</sup> Reset refers to Drylce POR. ### 4.1.1 Register Summary The conventions in Figure 2 and Table 3 serve as a key for the register summary and individual register diagrams. Figure 2. Key to Register Fields Table 3 provides a key for register figures and tables and the register summary. #### **Table 3. Register Conventions** | Convention | Description | | | | | | | | |----------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | | Depending on its placement in the read or write row, indicates that the bit is not readable or not writable. | | | | | | | | | FIELDNAME | Identifies the field. Its presence in the read or write row indicates that it can be read or written. | | | | | | | | | Register Field Types | | | | | | | | | | R | Read only. Writing this bit has no effect. | | | | | | | | | W | Write only. | | | | | | | | | R/W | Standard read/write bit. Only software can change the bit's value (other than a hardware reset). | | | | | | | | | rwm | A read/write bit that may be modified by a hardware in some fashion other than by a reset. | | | | | | | | | w1c | Write one to clear. A status bit that can be read, and is cleared by writing a one. | | | | | | | | | Self-clearing bit | Writing a one has some effect on the module, but it always reads as zero. (Previously designated slfclr) | | | | | | | | | | Reset Values | | | | | | | | | 0 | Resets to zero. | | | | | | | | | 1 | Resets to one. | | | | | | | | | _ | Undefined at reset. | | | | | | | | | u | Unaffected by reset. | | | | | | | | | [signal_name] | Reset value is determined by polarity of indicated signal. | | | | | | | | Table 4 shows the DryIce register summary. **Table 4. Drylce Register Summary** | Name | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |-------------|---|----|----|----|----|----|----|----|---------|--------|----|----|----|----|----|----|----| | Nume | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x53FF_C000 | R | | | | | | | | RTC[4 | 17.201 | | | | | | | | | (RTCMR) | W | | | | | | | | n i O[² | +7.32] | | | | | | | | | | R | | | | | | | | DTCI | 24.461 | | | | | | | | | RTC[31:16] | | | | | | | | | | | | | | | | | | ### **Table 4. Drylce Register Summary (continued)** | | | 1 | 1 | 1 | 1 | ı | 1 | | ı | | | 1 | 1 | ı | | 1 | | |-------------|--------|-----|-------------|----|----|----|---------|---------|-------------------------------------|---------|----|----|-----|-----|-----|-----|---------| | Name | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | R | | RTC[15:1] 0 | | | | | | | | | | | | 0 | | | | 0x53FF_C004 | W | | | | | | | | | | | | | | | | | | (RTCLR) | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | W | | | | | | | | | | | | | | | | | | | R | | | | | | | | RCA[- | 47:321 | | | | | | | | | 0x53FF_C008 | W | | RCA[47:32] | | | | | | | | | | | | | | | | (RCAMR) | R | | | | | | | | RCAI: | 31:16] | | | | | | | | | | W | | | | | | | | | • • , | | | | | | | | | | R | | | | | | | R | CA[15: | :11 | | | | | | | 0 | | 0x53FF_C004 | W | | | | | | | | | | 1 | | | | | | | | (RTCLR) | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | W | | | | | | | | | | | | | | | | | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | тсн | TCS | FSH | | 0x53FF_C010 | W | | | | | | | | | | | | | | L | L | L | | (DCR) | R | | os | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 455 | TOF | 0 | 0 | 0 | | | W | NSA | СВ | | | | | | | | | | APE | TCE | | | SW<br>R | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | EBD | 0 | 0 | 0 | 0 | | 0x53FF_C014 | W | | | | | | | | | | | | w1c | | | | | | (DSR) | R | 0 | 0 | 0 | 0 | 0 | WB<br>F | WN<br>F | WC<br>F | WE<br>F | 0 | 0 | CAF | 0 | TCO | NVF | SVF | | | W | | | | | | | | | w1c | | | w1c | | w1c | w1c | w1c | | | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x53FF_C018 | W | | | | | | | | | | | | | | | | | | (DIER) | R | 0 | 0 | 0 | 0 | 0 | 0 | WCI | | | 0 | 0 | CAI | 0 | TOI | 0 | 0 | | | W | | | | | | | Е | Е | Е | | | E | | E | | | | | R | | | | | | | | GPR | 31:16] | | | | | | | | | 0x53FF_C03C | W | | | | | | | | · · · · · · · · · · · · · · · · · · | 0] | | | | | | | | | (DGPR) | R<br>W | - | | | | | | | GPR | [15:0] | | | | | | | | | | | | | | | | | | | | | | | | | | | ### 4.1.2 Register Descriptions This section consists of register descriptions in address order. Each description includes a standard register diagram with an associated figure number. Details of register bit and field function follow the register diagrams, in bit order. DryIce is a security module and some registers could be set to only be accessible by secure software. However the secure registers are accessible by non-secure software when the Non-Secure Access bit in the DryIce Control Register is set. Therefore it is imperative that the non-secure bit is set when using non-secure applications or non-secure i.MX25 devices to ensure proper RTC operation. With the exception of the DryIce Interrupt Enable Register and the DryIce Status Register bits [11:8], all DryIce registers are clocked by the 32.768 KHz clock source. This limits the maximum throughput of writes to these registers to once every two 32.768 KHz clock cycles and means that the actual register does not update until the third 32.768 KHz clock cycle after the write is performed. The Write Next Flag, Write Busy Flag and Write Completed Flag (with associated interrupts) can be used to determine when a register write has completed and when the next register write can be performed. The DryIce Interrupt Enable Register and the DryIce Status Register bits [11:8] are clocked by the peripheral bus clock. These register bits update immediately and writing to the DryIce Interrupt Enable Register does not affect the Write Next Flag, Write Busy Flag or Write Completed Flag. In addition, the Write Busy Flag does not need to be clear to write to the DryIce Interrupt Enable Register. All register reads complete after three or four peripheral clock cycles, returning the data in the register at the time of the register read. Pending writes to that register are not reflected in the data returned unless the write has completed. ### 4.1.2.1 RTC Time Counter MSB Register (RTCMR) The RTC Time Counter MSB Register contains the 32 most significant bits (47:16) of the 47-bit RTC Time Counter. Clocked by a 32.768 KHz clock, this register is effectively a 32-bit seconds counter. See Figure 3 for illustration of valid bits in the RTC Time Counter MSB Register and Table 5 for description of the bit fields. Figure 3. RTC Time Counter MSB Register i.MX25 Real Time Clock (RTC), Rev. 0 | Table 5. RTC Time Counter MSB Register Field Descriptions | Table 5. | <b>RTC Time</b> | Counter MS | B Register | Field De | scriptions | |-----------------------------------------------------------|----------|-----------------|------------|------------|----------|------------| |-----------------------------------------------------------|----------|-----------------|------------|------------|----------|------------| | Field | Description | |--------------------|-------------------| | 31–0<br>RTC[47:16] | RTC Time Counter. | #### 4.1.2.2 RTC Time Counter LSB Register (RTCLR) The RTC Time Counter LSB Register contains the 15 least significant bits (15:1) of the 47-bit RTC secure time counter. Clocked by a 32.768 KHz clock, this register effectively counts the number of clock cycles in each second. See Figure 4 for illustration of valid bits in the RTC Time Counter LSB Register and Table 6 for description of the bit fields. Figure 4. RTC Time Counter LSB Register **Table 6. RTC Time Counter LSB Register Field Descriptions** | Field | Description | |--------------------|-------------------| | 31–17<br>RTC[15:1] | RTC Time Counter. | | 16–0 | Reserved. | ### 4.1.2.3 RTC Clock Alarm MSB Register (RCAMR) The RTC Clock Alarm Register contains the 32 most significant bits (47:16) of the 47-bit RTC Clock Alarm. This register can be written by secured software only, unless the Non-Secure Access bit is set. It can however be read by any software. See Figure 5 for illustration of valid bits in the RTC Clock Alarm Register and Table 7 for description of the bit fields. i.MX25 Real Time Clock (RTC), Rev. 0 Figure 5. Drylce Clock Alarm Register **Table 7. Drylce Clock Alarm Register Field Descriptions** | Field | Description | |--------------------|------------------| | 31–0<br>RCA[47:16] | RTC Clock Alarm. | ### 4.1.2.4 RTC Clock Alarm LSB Register (RCALR) The RTC Clock Alarm Register contains the 15 least significant bits (15:1) of the 47-bit RTC Clock Alarm. This register can be written by secured software only, unless the Non-Secure Access bit is set. It can however be read by any software. See Figure 6 for illustration of valid bits in the RTC Clock Alarm Register and Table 8 for description of the bit fields. Figure 6. RTC Clock Alarm Register | Field | Description | |-------------------|------------------| | 31–0<br>DCA[15:1] | RTC Clock Alarm. | ### 4.1.2.5 Drylce Control Register (DCR) The DryIce Control Register (DCR) contains all of the necessary control bits for the DryIce module. This register can only be read or written by secured software, unless the Non-Secure Access bit is set. See Figure 7 for illustration of valid bits in the DryIce Control Register and Table 9 for description of the bit fields. Figure 7. Drylce Control Register **Table 9. Drylce Control Register Field Descriptions** | Field | Description | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-19 | Reserved. | | 18<br>TCHL | Time Counter Hard Lock. When set, prevents any writes to the RTC Time Counter Registers. Once set, this bit can only be reset by the Drylce POR (including Drylce software reset). 0 Write access is allowed. 1 Write access is not allowed. | | 17<br>TCSL | Time Counter Soft Lock. When set, prevents any writes to the RTC Time Counter Registers. Once set, this bit can only be reset by the Drylce POR or the System POR. 0 Write access is allowed. 1 Write access is not allowed. | | 16<br>FSHL | Failure State Hard Lock. When set, prevents the Non-Valid Flag from being set, preventing Drylce from leaving the Failure state. Once set, this bit can only be reset by the Drylce POR (including Drylce software reset). O Drylce can leave Failure state. Drylce cannot leave Failure state. | **Table 9. Drylce Control Register Field Descriptions (continued)** | Field | Description | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15<br>NSA | Non-Secure Access. When set this bit allows non-secure software to access all Drylce registers, even those that usually require secure software to access. This bit is reset by the System POR. Only secure software can access secure registers. Any software can access secure registers. | | 14<br>OSCB | Oscillator Bypass. When set this bit bypasses the 32.768 KHz oscillator, allowing only an external clock to drive the 32.768 KHz clock source. Oscillator not bypassed. External clock or external crystal can drive 32.768 KHz clock source. Oscillator bypassed. External clock can drive 32.768 KHz clock source. | | 13–5 | Reserved. | | 4<br>APE | Alarm Pin Enable. When set, the output alarm pin is enabled. The alarm pin asserts when Drylce is in system power-down mode and, the Clock Alarm Flag is set, or Time Counter Overflow is set, or Monotonic Counter Overflow is set, or Drylce is in the Failure state. O Alarm pin disabled. Alarm pin enabled. | | 3<br>TCE | Time Counter Enable. When set, the RTC Time Counter Register increments provided Drylce is in the valid state and Time Counter Overflow is not set. This bit cannot be cleared if the Time Counter Lock bit is set. 0 RTC Time Counter is disabled. 1 RTC Time Counter is enabled. | | 2-1 | Reserved. | | 0<br>SWR | Software Reset. Resets the Drylce module as if a Drylce POR had occurred. This has the effect of moving Drylce into the failure state. This bit cannot be set when Drylce is in the failure state. This is a self clearing bit and is always read as zero. O No effect. Reset the module to its default state. | #### 4.1.2.6 **Drylce Status Register (DSR)** The DryIce Status Register (DSR) register provides the status of the DryIce module. This register can be written by secured software only, unless the Non-Secure Access bit is set. It can however be read by any software. See Figure 8 for illustration of valid bits in the DryIce Status Register and Table 10 for description of the bit fields. Figure 8. Drylce Status Register **Table 10. Drylce Status Register Field Descriptions** | Field | Description | |-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–21 | Reserved | | 20<br>EBD | External boot detected. When set, indicates that an external boot was detected. An external boot causes Drylce to enter the failure state. This bit can be cleared by secure software writing a logic one to this bit in the non-valid state. 0 External boot not detected. 1 External boot detected. | | 19-11 | Reserved | | 10<br>WBF | Write Busy Flag. This bit indicates that a register write is being performed and writes to any Drylce register (except Drylce Interrupt Enable Register) is ignored. This bit is cleared by System POR or when the Write Next Flag is set. O Can write to Drylce register. Cannot write to Drylce register. | | 9<br>WNF | Write Next Flag. This bit indicates that the next register write can be performed to the Drylce registers. This bit is cleared by System POR or by reading the Drylce Status Register when this bit is set. This bit does not set following a write to the Drylce Interrupt Enable Register since the next register write can be performed immediately. O Cannot perform next write to Drylce register, or write not busy. Can perform next write to Drylce register. | | 8<br>WCF | Write Complete Flag. This bit indicates that a register write has completed. This bit is cleared by System POR or by reading the Drylce Status Register when this bit is set. This bit does not set following a write to the Drylce Interrupt Enable Register since the register write is completed immediately. O Register has not updated with write data, or write not busy. Register has updated with write data. | **Table 10. Drylce Status Register Field Descriptions (continued)** | Field | Description | |----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>WEF | Write Error Flag. This bit indicates that a write to one of the registers was cancelled. This can be due to a write that occurs about the same time that Drylce is isolated or a write that occurs about the same time as a System POR. This bit can be cleared by secure software writing a logic one to this bit. O All writes completed. Write was cancelled. | | 6-5 | Reserved | | 4<br>CAF | Clock Alarm Flag. This bit sets when the 47-bit Drylce Time Counter Register increments to the value stored in the 47-bit Drylce Clock Alarm Register. This bit can be cleared by secure software writing a logic one to this bit. O Alarm has not occurred. 1 Alarm has occurred. | | 3 | Reserved | | 2<br>TCO | Time Counter Overflow. When set, indicates that the Time Counter overflowed. This bit can be cleared by secure software writing a logic one to this bit provided Drylce is in the Valid or Non-Valid state. 0 Time Counter has not overflowed. 1 Time Counter has overflowed. | | 1<br>NVF | Non-Valid Flag. When set, indicates that Drylce is in the Non-Valid state. This bit sets if the Security Violation Flag is set during System POR and the Failure State Hard Lock bit is clear. This bit can be cleared by secure software writing a logic one to this bit. O Drylce is in the Valid or Failure state. 1 Drylce is in the Non-Valid state. | | 0<br>SVF | Security Violation Flag. When set, indicates that a security violation has been detected and Drylce has transitioned to the Failure state. If the Non-Valid Flag is also set (which happens following the next System POR), then Drylce has transitioned to the Non-Valid state. This bit can only be cleared if the Non-Valid Flag is set and by secure software writing a logic one to this bit, provided that the security violation is no longer present. O Drylce is in the Valid or Non-Valid state. Security violation has occurred and Drylce is in the Failure or Non-Valid state. | ### 4.1.2.7 Drylce Interrupt Enable Register (DIER) The DryIce Interrupt Enable Register is used to enable and disable the DryIce interrupt sources. This register can only written by secured software, unless the Non-Secure Access bit is set. It can be read by any software. See Figure 9 for illustration of valid bits in the DryIce Interrupt Enable Register and Table 11 for description of the bit fields. Figure 9. Drylce Interrupt Enable Register **Table 11. Drylce Interrupt Enable Register Field Descriptions** | Field | Description | |-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–10 | Reserved. | | 9<br>WNIE | Write Next Interrupt Enable. When set, this bit enables the Write Next Flag to generate a Drylce normal interrupt. This bit is reset by System POR. 0 Interrupt is disabled. 1 Interrupt is enabled. | | 8<br>WCIE | Write Complete Interrupt Enable. When set, this bit enables the Write Complete Flag to generate a Drylce normal interrupt. This bit is reset by System POR. O Interrupt is disabled. Interrupt is enabled. | | 7<br>WEIE | Write Error Interrupt Enable. When set, this bit enables the Write Error Flag to generate a Drylce normal interrupt. This bit is reset by System POR. O Interrupt is disabled. Interrupt is enabled. | | 6-5 | Reserved. | | 4<br>CAIE | Clock Alarm Interrupt Enable. When set, this bit enables the Clock Alarm Flag to generate a Drylce normal interrupt. This bit is reset by System POR. O Interrupt is disabled. Interrupt is enabled. | | 3 | Reserved | | 2<br>TOIE | Time Overflow Interrupt Enable. When set, this bit enables the Time Counter Overflow status bit to generate a Drylce security interrupt. This bit is reset by System POR. 0 Interrupt is disabled. 1 Interrupt is enabled. | | 1-0 | Reserved. | Example ### 4.1.2.8 Drylce General Purpose Register (DGPR) The DryIce General Purpose Register (DGPR) is a 32-bit register that can be used for any purpose that requires retaining 32-bits of data during i.MX25 power-down. It can be read and written by any application. See Figure 10 for illustration of valid bits in the DryIce general purpose Register and Table 12 for description of the bit fields. Figure 10. Drylce General Purpose Register **Table 12. Drylce General Purpose Register Field Descriptions** | Field | Description | |-------------------|---------------------------| | 31–0<br>GPR[31:0] | General Purpose Register. | ## 5 Example ### 5.1 Basic Software Initialization of RTC Below is a programming example which provides the minimum to get the RTC started. **Example 1. Basic RTC Initialization** ``` #define reg32_read(addr) *(unsigned int *)((addr)) #define reg32_write(addr,val) *((unsigned int *)(addr)) = (val) #define WDOG_WCR (0x53FDC000) // DRYICE - RTC register defines #define DRYICE_RTCMR (0x53FFC000) // RTC Time Counter MSB Register #define DRYICE_RTCLR (0x53FFC004) // RTC Time Counter LSB Register #define DRYICE_RCAMR (0x53FFC008) // RTC Clock Alarm MSB Register ``` i.MX25 Real Time Clock (RTC), Rev. 0 ``` #define DRYICE_RCALR (0x53FFC00C) // RTC Clock Alarm LSB Register #define DRYICE_DCR (0x53FFC010) // DryIce Control Register #define DRYICE_DSR (0x53FFC014) // DryIce Status Register #define DRYICE_DIER (0x53FFC018) // DryIce Interrupt Enable Register #define DRYICE_DGPR (0x53FFC03C) // DryIce General Purpose Register void reg32_dryice32kdomain_write(unsigned int addr , unsigned int wdata); void main(void){ int i; // Disable WDOG *(unsigned short *)(WDOG_WCR) = 0x0030; reg32_dryice32kdomain_write(DRYICE_DCR,0x8000); //disable security to allow any register writes reg32_dryice32kdomain_write(DRYICE_DSR,0x03); // clear any security errors reg32_dryice32kdomain_write(DRYICE_RTCMR,0x00); // need to write to the RTCMR to get RTC started reg32_dryice32kdomain_write(DRYICE_DCR,0x8008); // enable the RTC while(1); //you can now power down i.MX25 if you are supplying BAT_VDD and RTC will keep counting //======Use the following to write to registers on 32kHz clock domain======== void reg32_dryice32kdomain_write(unsigned int addr , unsigned int wdata) { unsigned int masked_wdata, rdata_tmp; unsigned int dryice_status; reg32_write(addr, wdata); while ((reg32_read(DRYICE_DSR) & 0x200) != 0x200); // this line can be deleted if you are sure that previous 32kHz write operation has finished before this write. while ((reg32_read(DRYICE_DSR) & 0x100) != 0x100); reg32_read(DRYICE_DSR); ``` **Revision History** #### 5.2 Software Restrictions DryIce has the following software restrictions: - All DryIce register writes are committed on the third 32.768 KHz clock cycle following the peripheral bus write, except for the DryIce Interrupt Enable Register which takes effect immediately. - The maximum throughput of register writes (except for DryIce Interrupt Enable Register) is one register write can complete every two 32.768 KHz clock cycles. - All register write accesses complete with zero wait states due to the DryIce register interface. Subsequent writes are ignored if the Write Busy Flag is set. - Register read accesses complete with either three or four wait states due to the DryIce register interface. - All DryIce registers must be written using 32-bit operations, otherwise a bus error is generated. - Attempting to read or write a Drylce register when Drylce is isolated generates a bus error. ### 5.3 BAT VDD The back-up power supply is powered through the BAT\_VDD supply. The range for this supply can be set from 1.15 to 1.55 V. The typical drain on BAT\_VDD is under 15 $\mu$ A. Early characterization on a very small number of samples indicate this value to be much lower at room temperature (at around 6 $\mu$ A), but a full characterization across a large sample still needs to be done. There are a number of battery options users can choose from which are widely available on the market today. More specifically there is a wide range of silver oxide (low drain) micro-batteries which fit into the voltage range of BAT\_VDD. Based on the mAh capacity of the battery and the low current consumption from BAT\_VDD, some batteries are able maintain the RTC for a number of years. ## 6 Revision History Table 13 provides a revision history for this application note. **Table 13. Document Revision History** | Rev.<br>Number | Date | Substantive Change(s) | |----------------|---------|-----------------------| | 0 | 06/2009 | Initial release | #### THIS PAGE INTENTIONALLY LEFT BLANK **Revision History** ### THIS PAGE INTENTIONALLY LEFT BLANK 19 #### THIS PAGE INTENTIONALLY LEFT BLANK #### How to Reach Us: #### Home Page: www.freescale.com #### Web Support: http://www.freescale.com/support #### **USA/Europe or Locations Not Listed:** Freescale Semiconductor, Inc. Technical Information Center, EL516 2100 East Elliot Road Tempe, Arizona 85284 1-800-521-6274 or +1-480-768-2130 www.freescale.com/support #### Europe, Middle East, and Africa: Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) www.freescale.com/support #### Japan: Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com #### Asia/Pacific: Freescale Semiconductor China Ltd. Exchange Building 23F No. 118 Jianguo Road Chaoyang District Beijing 100022 China +86 10 5879 8000 support.asia@freescale.com #### For Literature Requests Only: Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 1-800 441-2447 or +1-303-675-2140 Fax: +1-303-675-2150 LDCForFreescaleSemiconductor @ hibbertgroup.com Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part. Freescale and the Freescale logo are trademarks or registered trademarks of Freescale Semiconductor, Inc. in the U.S. and other countries. ARM is the registered trademark of ARM Limited. All other product or service names are the property of their respective owners. © Freescale Semiconductor, Inc., 2009. All rights reserved. Document Number: AN3874 Rev. 0 06/2009