# Microcomputer Components 8-bit CMOS Microcontroller C505L Data Sheet 06.99 | C505L Data<br>Revision H | | Original Version: 06.99 | |--------------------------|----------------------|----------------------------------------| | Previous Re | eleases: | | | Page (new version) | Page (prev. version) | Subjects (changes since last revision) | | - | - | - | | - | - | - | For questions on technology, delivery and prices please contact the Infineon Technologies Offices in Germany or the Infineon Technologies Companies and Representatives worldwide: see our webpage at http://www.infineon.com. Enhanced Hooks Technology<sup>TM</sup> is a trademark and patent of Metalink Corporation licensed to Siemens. #### Edition 06.99 Published by Infineon Technologies AG i. Gr., St.-Martin-Strasse 53 D-81541 München © Infineon Technologies AG 1999 All Rights Reserved. #### Attention please! The information herein is given to describe certain components and shall not be considered as warranted characteristics. Terms of delivery and rights to technical change reserved. We hereby disclaim any and all warranties, including but not limited to warranties of non-infringement, regarding circuits, descriptions and charts stated herein. Infineon Technologiesis an approved CECC manufacturer. ## Information For further information on technology, delivery terms and conditions and prices please contact your nearest Infineon Technologies Office in Germany or our Infineon Technologies Representatives worldwide (see address list). #### Warnings Due to technical requirements components may contain dangerous substances. For information on the types in question please contact your nearest Infineon Technologies Office. Infineon Technologies Components may only be used in life-support devices or systems with the express written approval of Infineon Technologies, if a failure of such components can reasonably be expected to cause the failure of that life-support device or system, or to affect the safety or effectiveness of that device or system. Life support devices or systems are intended to be implanted in the human body, or to support and/or maintain and sustain and/or protect human life. If they fail, it is reasonable to assume that the health of the user or other persons may be endangered. # **8-Bit CMOS Microcontroller** C505L #### **Advance Information** #### **Features** - Fully compatible with the standard 8051 microcontroller - Superset of the 8051 architecture with 8 datapointers - Up to 20 MHz operating frequency - 375 ns instruction cycle time @ 16 MHz - 300 ns instruction cycle time @ 20 MHz (50% duty cycle) - Program Memory - 32K bytes of on-chip OTP memory - Externally expandable up to 64 Kbytes - 256-byte on-chip RAM - 256-byte on-chip XRAM - Five 8-bit and one 6-bit digital I/O ports (Port 5 with 6 bits only) - Port 1 with mixed analog/digital I/O capability - Port 3 with 2 LCD output lines as secondary functions - Port 4 and 5 with 8 and 6 LCD output lines respectively as secondary functions (more features are on next page) Figure 1 C505L Functional Units # Features (cont'd): - Three 16-bit timers/counters - Timer 0 / 1 (C501 compatible) - Timer 2 with 4 channels for 16-bit capture/compare operation - 128-segment LCD Controller - 1/4 duty cycle drive - 4 row and 32 column outputs - On-chip programmable reference voltage generation - 20 dedicated LCD output lines (4 rows + 16 columns) - Real-Time Clock - 47-bit digital clock counter - Input frequency of 32.768 KHz required - Operates in a special power down mode - Full duplex serial interface with programmable baudrate generator (USART) - 10-bit A/D Converter with 8 multiplexed inputs - Twelve interrupt sources with four priority levels - On-chip emulation support logic (Enhanced Hooks<sup>TM 1)</sup>) - Programmable 15-bit Watchdog Timer - Oscillator Watchdog - Fast power-on reset - Power-saving modes - Slow-down mode - Idle mode (can be combined with slow-down mode) - 3 special power down modes - Software power-down mode with wake up capability through INTO pin or Real-Time Clock - P-MQFP-80 package - Temperature ranges: SAB-C505L $T_A = 0$ to 70 °C SAF-C505L $T_A = -40$ to 85 °C SAK-C505L $T_A = -40$ to 125 °C (max. operating frequency: 12 MHz) #### **Ordering Information** The ordering code for Infineon Technologies' microcontrollers provides an exact reference to the required product. This ordering code identifies: - the derivative itself, i.e. its function set - the specified temperature rage - the package and the type of delivery For the available ordering codes for the C505L please refer to the "**Product Information Microcontrollers**", which summarizes all available microcontroller variants. <sup>1 &</sup>quot;Enhanced Hooks Technology" is a trademark and patent of Metalink Corporation licensed to Infineon Technologies. Figure 2 Logic Symbol Figure 3 Pin Configuration P-MQFP-80 Package (top view) Table 1 Pin Definitions and Functions | Symbol | Pin Number | I/O*) | Function | |--------|-------------------------------------------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | R0-R3 | 1-4<br>1<br>2<br>3<br>4 | 0 | LCD Row Outputs Output of LCD controller row lines. These pins are driven by the LCD controller and drive the row input lines of the external LCD display. Enabling the LCD Controller makes these pins available for LCD output levels. RO LCD row output 0 R1 LCD row output 1 R2 LCD row output 2 R3 LCD row output 3 These pins should not be used for input. | | C0-C15 | 5-20<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18 | 0 | LCD Column Outputs Output of LCD controller column lines 0 to 15. These pins are driven by the LCD controller and drive the column input lines of the external LCD display. Enabling the LCD controller makes these pins available for LCD output levels. C0 LCD column output 0 C1 LCD column output 1 C2 LCD column output 2 C3 VCCLCD column output 3 C4 LCD column output 4 C5 LCD column output 5 C6 LCD column output 5 C6 LCD column output 7 C8 LCD column output 8 C9 LCD column output 9 C10 LCD column output 10 C11 LCD column output 11 C12 LCD column output 12 C13 LCD column output 13 C14 LCD column output 13 C14 LCD column output 14 | | | 20 | | C15 LCD column output 15 These pins should not be used for input. | <sup>\*)</sup> I = Input O= Output Table 1 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | | | |-----------|-------------------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | P4.0-P4.7 | 21-28<br>21<br>22<br>23<br>24<br>25<br>26<br>27<br>28 | I/O | is a 8-bit quasi-bidirectional port with internal pull-up arrangement. Port 4 pins that have a 1 written to them are pulled high by the internal pull-up transistors and in that state can be used as inputs. As inputs, port 4 pins being externally pulled low will source current ( <i>I</i> <sub>IL</sub> , in the DC characteristics) because of the internal pullup transistors. Port 4 pins can also be configured as LCD column outputs. The secondary functions are assigned to the pins of port 4 as follows: P4.0 / C16 | | | | P5.0-P5.5 | 29-34<br>29-30<br>31<br>32<br>33<br>34 | I/O | is a 6-bit quasi-bidirectional port with internal pull-up arrangement. Port 5 pins that have a 1 written to them are pulled high by internal pull-up transistors and in that state can be used as inputs. As inputs, port 5 pins being externally pulled low will source current ( <i>I</i> <sub>IL</sub> , in the DC characteristics) because of the internal pullup transistors. Port 5 pins can also be configured as LCD column outputs. The secondary functions are assigned to the pins of port 5 as follows: P5.0 / C24 | | | <sup>\*)</sup> I = Input O= Output Table 1 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | | | | | | |-----------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--|--|--|--| | P3.7-P3.0 | 35-42 | 1/0 | Port 3 is an 8-bit quasi-bidirectional port with internal pull-user arrangement. Port 3 pins that have a 1 written to them are pulled high by the internal pull-up transistors and in the state can be used as inputs. As inputs, port 3 pins being externally pulled low will source current ( $I_{\rm IL}$ , in the D characteristics) because of the internal pullup transistor. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate (except for TxD and $\overline{\rm WR}$ ). | | | | | | | | | | P3.4 and P3.5 can also be configured as LCD co outputs C31 and C30 respectively. These pins should r | | | | | | | | | | • | en configured as LCD output pins. inctions are assigned to the pins of port 3 | | | | | | | 42 | | P3.0 / RxD<br>P3.1 / TxD | Receiver data input (asynch.) or data input/output (synch.) of serial interface Transmitter data output (asynch.) or | | | | | | | 41 | | P3.2 / <u>INTO</u> | clock output (synch.) of serial interface External interrupt 0 input / timer 0 gate | | | | | | | 40 | | P3.3 / ĪNT1 | control input External interrupt 1 input / timer 1 gate | | | | | | | 39 | | P3.4 / T0 / C31 | control input Timer 0 counter input / LCD column 31 | | | | | | | 37 | | P3.5 / T1 / C30 | output Timer 1 counter input / LCD column 30 output | | | | | | | | | P3.6 / WR | WR control output; latches the data byte from port 0 into the external data | | | | | | | 36 | | P3.7 / RD | memory RD control output; enables the external | | | | | | | 35 | | | data memory | | | | | <sup>\*)</sup> I = Input O= Output Table 1 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | |--------|------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RESET | 43 | I | <b>RESET</b> A high level on this pin for two machine cycles while the oscillator is running resets the device. An internal diffused resistor to $V_{\rm SS}$ permits power-on reset using only an external capacitor to $V_{\rm DD}$ . | | PSEN | 44 | 0 | The Program Store Enable output is a control signal that enables the external program memory to the bus during external fetch operations. It is activated every three oscillator periods except during external data memory accesses. Remains high during internal program execution. This pin should not be driven during reset operation. | | ALE | 45 | 0 | The <b>Address Latch Enable</b> output is used for latching the low-byte of the address into external memory during normal operation. It is activated every three oscillator periods except during an external data memory access. When instructions are executed from internal program memory ( $\overline{EA} = 1$ ), the ALE generation can be disabled by bit EALE in SFR SYSCON. This pin should not be driven during reset operation. | | EΑ | 46 | I | External Access Enable This pin must be held at high level. Instructions are fetched from the internal OTP memory when the PC is less than 8000 <sub>H</sub> . Instructions are fetched from external program memory, when the PC is greater than 7FFF <sub>H</sub> . This pin must not be held at low level. | <sup>\*)</sup> I = Input O= Output Table 1 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | | | |--------|------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | XTAL2 | 47 | 0 | XTAL2 Output of the inverting oscillator amplifier. | | | | XTAL1 | 48 | I | Input to the inverting oscillator amplifier and input to the internal clock generator circuits. To drive the device from an external clock source, XTAL1 should be driven, while XTAL2 is left unconnected. To operate above a frequency of 16 MHz, a duty cycle of 50% should be maintained. Minimum and maximum high and low times as well as rise/fall times specified in the AC characteristics (refer to data Sheet) must be observed. | | | | XTAL4 | 51 | 0 | XTAL4 Output of the inverting real-time clock oscillator amplifier. | | | | XTAL3 | 52 | I | Input to the inverting real-time clock oscillator amplifier. To drive the real-time clock from an external clock source, XTAL3 should be driven, while XTAL4 is left unconnected. Minimum and maximum high and low times as well as rise/ fall times specified in the AC characteristics (refer to Data sheet) must be observed. | | | <sup>\*)</sup> I = Input O= Output Table 1 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | |-----------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P2.7-P2.0 | 53-60 | I/O | is a an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 2 pins that have a 1 written to them are pulled high by the internal pullup resistors, and in that state can be used as inputs. As inputs, port 2 pins being externally pulled low will source current ( $I_{IL}$ , in the DC characteristics) because of the internal pullup resistors. Port 2 emits the high-order address byte during fetches from external program memory and during accesses to external data memory that use 16-bit addresses (MOVX @DPTR). In this application it uses strong internal pullup transistors when issuing 1s. During accesses to external data memory that use 8-bit addresses (MOVX @Ri), port 2 issues the contents of the P2 special function register and uses only the internal pullup resistors. | | P0.7-P0.0 | 61-68 | I/O | Port 0 is an 8-bit open-drain bidirectional I/O port. Port 0 pins that have a 1 written to them float, and in that state can be used as high-impendance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external program or data memory. In this application it uses strong internal pullup transistors when issuing 1s. | <sup>\*)</sup> I = Input O= Output Table 1 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | | | | | |-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--|--|--| | P1.0-P1.7 | 71-78 | I/O | Port 1 is an 8-bit quasi-bidirectional port with internal pull-arrangement. Port 1 pins can be used for digital input/outpor as analog inputs to the A/D converter. Port 1 pins the have a 1 written to them are pulled high by internal pull-transistors and in that state can be used as inputs. Inputs, port 1 pins being pulled low externally will sour current ( $I_{\rm IL}$ , in the DC characteristics) because of the internal pullup transistors. Port 1 pins are assigned to be used analog inputs via the register P1ANA. As secondary digital functions, port 1 contains the interrutimer, clock, capture and compare pins. The output late corresponding to a secondary function must be programmed to a one (1) for that function to operate (exceptor compare functions). The secondary functions a assigned to the pins of port 1 as follows: | | | | | | | 71 | | P1.0 / AN0 / ĪNT3 / CC0 | interrupt 3 input / | | | | | | 72 | | P1.1 / AN1 / INT4 / CC1 | capture/compare channel 0 I/O Analog input channel 1/ interrupt 4 input / capture/compare channel 1 I/O | | | | | | 73 P1.2 / AN2 / INT5 / CC2 Analog input chan interrupt 5 input / capture/compare (apture/compare (apture/compa | | | | | | | | | | | | | | | | | | 75 | | P1.4 / AN4 | Analog input channel 4 | | | | | | 76 | | P1.5 / AN5 / T2EX | Analog input channel 5 / timer 2 external reload / trigger input | | | | | | 77 | | P1.6 / AN6 / CLKOUT | Analog input channel 6 / system clock output | | | | | | 78 | | P1.7 / AN7 / T2 | Analog input channel 7 / timer/counter 2 input | | | | <sup>\*)</sup> I = Input O= Output Table 1 Pin Definitions and Functions (cont'd) | Symbol | Pin Number | I/O*) | Function | |------------------------------|------------|-------|------------------------------------------| | $\overline{V_{AREF}}$ | 79 | _ | Reference voltage for the A/D converter. | | $\overline{V_{AGND}}$ | 80 | _ | Reference ground for the A/D converter. | | $\overline{V_{\mathtt{SS}}}$ | 49, 70 | _ | Ground (0 V) | | $\overline{V_{DD}}$ | 50, 69 | _ | Power Supply (+ 5 V) | <sup>\*)</sup> I = Input O= Output Figure 4 Block Diagram of the C505L Reset Value: 00<sub>H</sub> # **CPU** The C505L is efficient both as a controller and as an arithmetic processor. It has extensive facilities for binary and BCD arithmetic and excels in its bit-handling capabilities. Efficient use of program memory results from an instruction set consisting of 44% one-byte, 41% two-byte, and 15% three-byte instructions. With a 16-MHz external clock, 58% of the instructions execute in 375 ns (20 MHz: 300 ns). # Special Function Register PSW (Address D0<sub>H</sub>) | Bit No. | MSB | | | | | | | LSB | | |----------|-----|-----------------|----|-----|-----|----|----|-----|-----| | | | D6 <sub>H</sub> | | | | | | | | | $D0_{H}$ | CY | AC | F0 | RS1 | RS0 | OV | F1 | Р | PSW | | Bit | Function | Function | | | | | | | |------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--|--|--|--|--| | CY | | Carry Flag Used by arithmetic instruction. | | | | | | | | AC | Auxiliary (<br>Used by i | | s which execute BCD operations. | | | | | | | F0 | General F | urpose Fl | ag | | | | | | | RS1<br>RS0 | Register Bank select control bits These bits are used to select one of the four register banks. | | | | | | | | | | RS1 | RS0 | Function | | | | | | | | 0 | 0 | Bank 0 selected, data address 00 <sub>H</sub> -07 <sub>H</sub> | | | | | | | | 0 | 1 | Bank 1 selected, data address 08 <sub>H</sub> -0F <sub>H</sub> | | | | | | | | 1 | 0 | Bank 2 selected, data address 10 <sub>H</sub> -17 <sub>H</sub> | | | | | | | | 1 | 1 1 Bank 3 selected, data address 18 <sub>H</sub> -1F <sub>H</sub> | | | | | | | | OV | | Overflow Flag Used by arithmetic instruction. | | | | | | | | F1 | General F | General Purpose Flag | | | | | | | | P | Set/cleare | Parity Flag Set/cleared by hardware after each instruction to indicate an odd/even number of "one" bits in the accumulator, i.e. even parity. | | | | | | | # **Memory Organization** The C505L CPU manipulates operands in the following five address spaces: - up to 64 Kbytes of program memory (32K on-chip OTP memory) - up to 64 Kbytes of external data memory - 256 bytes of internal data memory - 256 bytes of internal XRAM data memory - 20 bytes of LCD Controller registers - 16 bytes of Real-Time Clock (RTC) registers - A 128-byte Special Function Register (SFR) area Figure 5 illustrates the memory address spaces of the C505L. Figure 5 C505L Memory Map # **Reset and System Clock** The reset input is an active high input at pin RESET. Since the reset is synchronized internally, the RESET pin must be held low for at least two machine cycles (12 oscillator periods) while the oscillator is running. A pull-down resistor is internally connected to $V_{\rm SS}$ to allow a power-up reset with an external capacitor only. An automatic reset can be obtained when $V_{\rm DD}$ is applied by connecting the RESET pin to $V_{\rm DD}$ via a capacitor. **Figure 6** shows the possible reset circuitries. Figure 6 Reset Circuitries **Figure 7** and **Figure 8** show the recommended oscillator circiutries for crystal and external clock operations, respectively, for the system or main clock. Figure 7 Recommended Oscillator Circuitries (for XTAL1-XTAL2) Figure 8 Recommended Oscillator Circuitries for Real-Time Clock (XTAL3-XTAL4) # **Multiple Datapointers** As a functional enhancement to the standard 8051 architecture, the C505L contains eight 16-bit datapointers instead of only one datapointer. The instruction set uses just one of these datapointers at a time. The selection of the actual datapointer is done in the special function register DPSEL. **Figure 9** illustrates the datapointer addressing mechanism. Figure 9 External Data Memory Addressing using Multiple Datapointers # **Enhanced Hooks Emulation Concept** The Enhanced Hooks Emulation Concept of the C500 microcontroller family is a new, innovative way to control the execution of C500 MCUs and to gain extensive information on the internal operation of the controllers. Emulation of on-chip memory based programs is possible, too. Each production chip has built-in logic for the support of the Enhanced Hooks Emulation Concept. Therefore, no costly bond-out chips are necessary for emulation. This also ensure that emulation and production chips are identical. The Enhanced Hooks Technology<sup>™1)</sup>, which requires embedded logic in the C500 allows the C500 together with an EH-IC to function similar to a bond-out chip. This simplifies the design and reduces costs of an ICE-system. ICE-systems using an EH-IC and a compatible C500 are able to emulate all operating modes of the different versions of the C500 microcontrollers. This includes emulation of ROM, ROM with code rollover and ROMless modes of operation. It is also able to operate in single step mode and to read the SFRs after a break. Figure 10 Basic C500 MCU Enhanced Hooks Concept Configuration Port 0, port 2 and some of the control lines of the C500 based MCU are used by Enhanced Hooks Emulation Concept to control the operation of the device during emulation and to transfer informations about the program execution and data transfer between the external emulation hardware (ICE-system) and the C500 MCU. <sup>1 &</sup>quot;Enhanced Hooks Technology" is a trademark and patent of Metalink Corporation licensed to Infineon Technologies. Reset Value: XX100X01<sub>B</sub> # **Special Function Registers** The registers, except the program counter and the four general purpose register banks, reside in the special function register area which consists of two portions: the standard special function register area and the mapped special function register area. Some of the C505L's SFRs (PCON1, VR0, VR1 and VR2) are located in the mapped SFR area. For accessing the mapped SFR area, bit RMAP in SFR SYSCON must be set. All other SFRs are located in the standard SFR area which is accessed when RMAP is cleared ("0"). The registers and data locations of the LCD Controller (LCD-SFRs) and the RTC (RTC-SFRs) are located in the external data memory area at addresses $F3DD_H$ to $F3EF_H$ and $F3F0_H$ to $F3FF_H$ respectively. # Special Function Register SYSCON (Address B1<sub>H</sub>) The shaded bits are not described in this section. | Bit | Function | |------|------------------------------------------------------------------------------------------------------------------------------------| | RMAP | SFR map bit RMAP = 0: Access to the non-mapped (standard) SFR area is enabled. RMAP = 1: Access to the mapped SFR area is enabled. | | _ | Reserved bits for future use. Read by CPU returns undefined values. | As long as bit RMAP is set, mapped SFR area can be accessed. This bit is not cleared automatically by hardware. Thus, when non-mapped/mapped registers are to be accessed, the bit RMAP must be cleared/set respectively by software. All SFRs with addresses where address bits 0-2 are 0 (e.g. $80_H$ , $88_H$ , $90_H$ , $98_H$ , ..., $F8_H$ , $FF_H$ ) are bit-addressable. The 51 SFRs in the standard and mapped SFR area include pointers and registers that provide an interface between the CPU and the other on-chip peripherals. The SFRs of the C505L are listed in **Table 2** and **Table 3**. In **Table 2** they are organized in groups which refer to the functional blocks of the C505L. The LCD and RTC-SFRs are also included in **Table 2**. **Table 3** illustrates the contents of the SFRs in numeric order of their addresses. **Table 4** lists the LCD and the RTC-SFRs in numeric order of their addresses. Table 2 **Special Function Registers - Functional Blocks** | Block | Symbol | Name | Address | Contents after Reset | |---------------------|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CPU | ACC B DPH DPL DPSEL PSW SP SYSCON <sup>2)</sup> VR0 <sup>4)</sup> VR1 <sup>4)</sup> VR2 <sup>4)</sup> | Accumulator B-Register Data Pointer, High Byte Data Pointer, Low Byte Data Pointer Select Register Program Status Word Register Stack Pointer System Control Register Version Register 0 Version Register 1 Version Register 2 | EO <sub>H</sub> <sup>1)</sup> FO <sub>H</sub> <sup>1)</sup> 83 <sub>H</sub> 82 <sub>H</sub> 92 <sub>H</sub> DO <sub>H</sub> <sup>1)</sup> 81 <sub>H</sub> FC <sub>H</sub> FD <sub>H</sub> | 00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>XXXXX000 <sub>B</sub> <sup>3)</sup><br>00 <sub>H</sub><br>07 <sub>H</sub><br>XX10XX01 <sub>B</sub> <sup>3)</sup><br>C5 <sub>H</sub><br>85 <sub>H</sub> | | A/D-<br>Converter | ADCON0 <sup>2)</sup><br>ADCON1<br>ADDATH<br>ADDATL<br>P1ANA <sup>2)</sup> | A/D Converter Control Register 0 A/D Converter Control Register 1 A/D Converter Data Register High Byte A/D Converter Data Register Low Byte Port 1 Analog Input Selection Register | D8 <sub>H</sub> <sup>1)</sup> DC <sub>H</sub> D9 <sub>H</sub> DA <sub>H</sub> 90 <sub>H</sub> <sup>4)</sup> | 00X00000 <sub>B</sub> <sup>3)</sup><br>01XXX000 <sub>B</sub> <sup>3)</sup><br>00 <sub>H</sub><br>00XXXXXX <sub>B</sub> <sup>3)</sup><br>FF <sub>H</sub> | | Interrupt<br>System | IEN0 <sup>2)</sup> IEN1 <sup>2)</sup> IP0 <sup>2)</sup> IP1 TCON <sup>2)</sup> T2CON <sup>2)</sup> SCON <sup>2)</sup> IRCON | Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 Interrupt Priority Register 1 Timer Control Register Timer 2 Control Register Serial Channel Control Register Interrupt Request Control Register | A8 <sub>H</sub> <sup>1)</sup> B8 <sub>H</sub> <sup>1)</sup> A9 <sub>H</sub> B9 <sub>H</sub> 88 <sub>H</sub> <sup>1)</sup> C8 <sub>H</sub> <sup>1)</sup> C8 <sub>H</sub> <sup>1)</sup> | 00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>XX000000 <sub>B</sub> <sup>3)</sup><br>00 <sub>H</sub><br>00X00000 <sub>B</sub><br>00 <sub>H</sub><br>00 <sub>H</sub> | | XRAM | XPAGE<br>SYSCON <sup>2)</sup> | Page Address Register for Extended on-chip XRAM, LCD Controller and RTC System Control Register | 91 <sub>H</sub> | 00 <sub>H</sub><br>XX10XX01 <sub>B</sub> <sup>3)</sup> | | Ports | P0<br>P1<br>P1ANA <sup>2)</sup><br>P2<br>P3<br>P4<br>P5 | Port 0 Port 1 Port 1 Analog Input Selection Register Port 2 Port 3 Port 4 Port 5 | 80 <sub>H</sub> <sup>1)</sup> 90 <sub>H</sub> <sup>1)</sup> 90 <sub>H</sub> <sup>1)4)</sup> A0 <sub>H</sub> <sup>1)</sup> B0 <sub>H</sub> <sup>1)</sup> E8 <sub>H</sub> <sup>1)</sup> | FF <sub>H</sub> FF <sub>H</sub> FF <sub>H</sub> FF <sub>H</sub> OO <sub>B</sub> XX111111 <sub>B</sub> | <sup>1)</sup> Bit-addressable SFRs <sup>2)</sup> This SFR is listed repeatedly since some bits of it also belong to other functional blocks. 3) "X" means that the value is undefined and the location is reserved 4) This SFR is a mapped SFR. For accessing this SFR, bit RMAP in SFR SYSCON must be set. <sup>5)</sup> The content of this SFR varies with the actual step of the C505L (e.g. 01<sub>H</sub> for the first step) Table 2 Special Function Registers - Functional Blocks (cont'd) | Block | Symbol | Name | Address | Contents after Reset | |------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Serial<br>Channel | ADCON0 <sup>2)</sup> PCON <sup>2)</sup> SBUF SCON SRELL SRELH | A/D Converter Control Register 0 Power Control Register Serial Channel Buffer Register Serial Channel Control Register Serial Channel Reload Register, low byte Serial Channel Reload Register, high byte | <b>D8<sub>H</sub></b> <sup>1)</sup><br>87 <sub>H</sub><br>99 <sub>H</sub><br><b>98<sub>H</sub></b> <sup>1)</sup><br>AA <sub>H</sub><br>BA <sub>H</sub> | 00X00000 <sub>B</sub> <sup>3)</sup><br>00 <sub>H</sub><br>XX <sub>H</sub> <sup>3)</sup><br>00 <sub>H</sub><br>D9 <sub>H</sub><br>XXXXXXX11 <sub>B</sub> <sup>3)</sup> | | Timer 0/<br>Timer 1 | TCON<br>TH0<br>TH1<br>TL0<br>TL1<br>TMOD | Timer 0/1 Control Register Timer 0, High Byte Timer 1, High Byte Timer 0, Low Byte Timer 1, Low Byte Timer Mode Register | 88 <sub>H</sub> <sup>1)</sup><br>8C <sub>H</sub><br>8D <sub>H</sub><br>8A <sub>H</sub><br>8B <sub>H</sub> | 00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub> | | Compare/<br>Capture<br>Unit /<br>Timer 2 | CCEN CCH1 CCH2 CCH3 CCL1 CCL2 CCL3 CRCH CRCL TH2 TL2 TL2 T2CON IEN0² IEN1² | Comp./Capture Enable Reg. Comp./Capture Reg. 1, High Byte Comp./Capture Reg. 2, High Byte Comp./Capture Reg. 3, High Byte Comp./Capture Reg. 1, Low Byte Comp./Capture Reg. 2, Low Byte Comp./Capture Reg. 3, Low Byte Comp./Capture Reg. 3, Low Byte Reload Register High Byte Reload Register Low Byte Timer 2, High Byte Timer 2, Low Byte Timer 2 Control Register Interrupt Enable Register 0 Interrupt Enable Register 1 | C1 <sub>H</sub> C3 <sub>H</sub> C5 <sub>H</sub> C7 <sub>H</sub> C2 <sub>H</sub> C4 <sub>H</sub> C6 <sub>H</sub> CB <sub>H</sub> CCH CA <sub>H</sub> CCH CB <sub>H</sub> CCH CB <sub>H</sub> CCH CB <sub>H</sub> CCH CB <sub>H</sub> CCH CB <sub>H</sub> CCH CB <sub>H</sub> CCH | 00 <sub>H</sub> <sup>3)</sup> 00 <sub>H</sub> | | Watchdog | WDTREL<br>IEN0 <sup>2)</sup><br>IEN1 <sup>2)</sup><br>IPO <sup>2)</sup> | Watchdog Timer Reload Register Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 | 86 <sub>H</sub> <b>A8<sub>H</sub></b> <sup>1)</sup> <b>B8<sub>H</sub></b> <sup>1)</sup> A9 <sub>H</sub> | 00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub> | | Power<br>Save<br>Modes | PCON <sup>2)</sup><br>PCON1 <sup>4)</sup> | Power Control Register Power Control Register 1 | 87 <sub>H</sub><br>88 <sub>H</sub> ¹) | 00 <sub>H</sub><br>0XX0XXXX <sub>B</sub> <sup>3)</sup> | <sup>1)</sup> Bit-addressable SFRs <sup>2)</sup> This SFR is listed repeatedly since some bits of it also belong to other functional blocks. <sup>3) &</sup>quot;X" means that the value is undefined and the location is reserved <sup>4)</sup> SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set. Table 2 Special Function Registers - Functional Blocks (cont'd) | Block | Symbol | Name | Address | Contents after Reset | |------------|--------------------|-------------------------------------------|-------------------|----------------------------------| | LCD | DAC0 | D/A Conversion Register | F3DC <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | Controller | LCON | LCD Control Register | F3DD <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | LCRL | LCD Timer Reload Low Register | F3DE <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | LCRH | LCD Timer Reload High Register | F3DF <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | DIGn <sup>5)</sup> | LCD Digit Register 'n'5) | F3En <sub>H</sub> | 00 <sub>H</sub> <sup>5) 6)</sup> | | Real-Time | RTCON | Real-Time Clock Control Register | F3F0 <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | Clock | RTCR0 | Real-Time Clock Initialization Register 0 | F3F1 <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | RTCR1 | Real-Time Clock Initialization Register 1 | F3F2 <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | RTCR2 | Real-Time Clock Initialization Register 2 | F3F3 <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | RTCR3 | Real-Time Clock Initialization Register 3 | F3F4 <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | RTCR4 | Real-Time Clock Initialization Register 4 | F3F5 <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | CLREG0 | Clock Count Register 0 | F3F6 <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | CLREG1 | Clock Count Register 1 | F3F7 <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | CLREG2 | Clock Count Register 2 | F3F8 <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | CLREG3 | Clock Count Register 3 | F3F9 <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | CLREG4 | Clock Count Register 4 | F3FA <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | RTINT0 | Real-Time Clock Interrupt Register 0 | F3FB <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | RTINT1 | Real-Time Clock Interrupt Register 1 | F3FC <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | RTINT2 | Real-Time Clock Interrupt Register 2 | F3FD <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | RTINT3 | Real-Time Clock Interrupt Register 3 | F3FE <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | | | RTINT4 | Real-Time Clock Interrupt Register 4 | F3FF <sub>H</sub> | 00 <sub>H</sub> <sup>6)</sup> | <sup>1)</sup> Bit-addressable SFRs <sup>2)</sup> This SFR is listed repeatedly since some bits of it also belong to other functional blocks. <sup>3) &</sup>quot;X" means that the value is undefined and the location is reserved.4) SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set. <sup>5)</sup> The notation "n" (n = 0 to F) in the LCD Digit Register address definition defines the number of the related LCD digit. <sup>6)</sup> This register is located in the on-chip external data memory area. Table 3 Contents of the SFRs, SFRs in Numeric Order of Their Addresses | Addr | Register | Content<br>after<br>Reset <sup>1)</sup> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------------------------------|----------|-----------------------------------------|-------------|-------------|-------|-------|-------|-------|-------|-------| | 80 <sub>H</sub> <sup>2)</sup> | P0 | FF <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 81 <sub>H</sub> | SP | 07 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 82 <sub>H</sub> | DPL | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 83 <sub>H</sub> | DPH | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 86 <sub>H</sub> | WDTREL | 00 <sub>H</sub> | WDT<br>PSEL | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 87 <sub>H</sub> | PCON | 00 <sub>H</sub> | SMOD | PDS | IDLS | SD | GF1 | GF0 | PDE | IDLE | | 88 <sub>H</sub> <sup>2)</sup> | TCON | 00 <sub>H</sub> | TF1 | TR1 | TF0 | TR0 | IE1 | IT1 | IE0 | IT0 | | 88 <sub>H</sub> ³) | PCON1 | 0XX0-<br>XXXX <sub>B</sub> | EWPD | _ | _ | WS | _ | - | - | - | | 89 <sub>H</sub> | TMOD | 00 <sub>H</sub> | GATE | C/T | M1 | MO | GATE | C/T | M1 | MO | | 8A <sub>H</sub> | TL0 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 8B <sub>H</sub> | TL1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 8C <sub>H</sub> | TH0 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 8D <sub>H</sub> | TH1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 90 <sub>H</sub> <sup>2)</sup> | P1 | FF <sub>H</sub> | T2 | CLK-<br>OUT | T2EX | .4 | INT6 | INT5 | INT4 | ĪNT3 | | 90 <sub>H</sub> ³) | P1ANA | FF <sub>H</sub> | EAN7 | EAN6 | EAN5 | EAN4 | EAN3 | EAN2 | EAN1 | EAN0 | | 91 <sub>H</sub> | XPAGE | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | 92 <sub>H</sub> | DPSEL | XXXX-<br>X000 <sub>B</sub> | _ | _ | _ | _ | _ | .2 | .1 | .0 | | 98 <sub>H</sub> ²) | SCON | 00 <sub>H</sub> | SM0 | SM1 | SM2 | REN | TB8 | RB8 | TI | RI | | 99 <sub>H</sub> | SBUF | XX <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | A0 <sub>H</sub> <sup>2)</sup> | P2 | FF <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | A8 <sub>H</sub> <sup>2)</sup> | IEN0 | 00 <sub>H</sub> | EA | WDT | ET2 | ES | ET1 | EX1 | ET0 | EX0 | | A9 <sub>H</sub> | IP0 | 00 <sub>H</sub> | OWDS | WDTS | .5 | .4 | .3 | .2 | .1 | .0 | | $AA_H$ | SRELL | D9 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | <sup>1)</sup> X means that the value is undefined and the location is reserved <sup>2)</sup> Bit-addressable SFRs3) SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set. Table 3 Contents of the SFRs, SFRs in Numeric Order of Their Addresses (cont'd) | Addr | Register | Content<br>after<br>Reset <sup>1)</sup> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------------------------------|----------|-----------------------------------------|------------|------------|------------|------------|------------|------------|------------|------------| | B0 <sub>H</sub> <sup>2)</sup> | P3 | FF <sub>H</sub> | RD | WR | T1 | ТО | ĪNT1 | ĪNT0 | TxD | RxD | | B1 <sub>H</sub> | SYSCON | XX10-<br>XX01 <sub>B</sub> | _ | _ | EALE | RMAP | _ | _ | XMAP1 | XMAP0 | | B8 <sub>H</sub> <sup>2)</sup> | IEN1 | 00 <sub>H</sub> | EXEN2 | SWDT | EX6 | EX5 | EX4 | EX3 | ESWI | EADC | | B9 <sub>H</sub> | IP1 | XX00-<br>0000 <sub>B</sub> | _ | _ | .5 | .4 | .3 | .2 | .1 | .0 | | $BA_H$ | SRELH | XXXX-<br>XX11 <sub>B</sub> | _ | _ | _ | _ | _ | _ | .1 | .0 | | C0 <sub>H</sub> <sup>2)</sup> | IRCON | 00 <sub>H</sub> | EXF2 | TF2 | IEX6 | IEX5 | IEX4 | IEX3 | SWI | IADC | | C1 <sub>H</sub> | CCEN | 00 <sub>H</sub> | COCA<br>H3 | COCAL<br>3 | COCA<br>H2 | COCAL<br>2 | COCA<br>H1 | COCAL<br>1 | COCA<br>H0 | COCAL<br>0 | | C2 <sub>H</sub> | CCL1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C3 <sub>H</sub> | CCH1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C4 <sub>H</sub> | CCL2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C5 <sub>H</sub> | CCH2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C6 <sub>H</sub> | CCL3 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C7 <sub>H</sub> | CCH3 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | C8 <sub>H</sub> <sup>2)</sup> | T2CON | 00X0-<br>0000 <sub>B</sub> | T2PS | I3FR | _ | T2R1 | T2R0 | T2CM | T2I1 | T2I0 | | CA <sub>H</sub> | CRCL | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | CB <sub>H</sub> | CRCH | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | CCH | TL2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | CD <sub>H</sub> | TH2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | D0 <sub>H<sup>2)</sup></sub> | PSW | 00 <sub>H</sub> | CY | AC | F0 | RS1 | RS0 | OV | F1 | Р | | D8 <sub>H</sub> <sup>2)</sup> | ADCON0 | 00X0-<br>0000 <sub>B</sub> | BD | CLK | _ | BSY | ADM | MX2 | MX1 | MX0 | | D9 <sub>H</sub> | ADDATH | 00 <sub>H</sub> | .9 | .8 | .7 | .6 | .5 | .4 | .3 | .2 | | DA <sub>H</sub> | ADDATL | 00XX-<br>XXXX <sub>B</sub> | .1 | .0 | _ | _ | _ | _ | _ | _ | <sup>1)</sup> X means that the value is undefined and the location is reserved 2) Bit-addressable SFRs Table 3 Contents of the SFRs, SFRs in Numeric Order of Their Addresses (cont'd) | Addr | Register | Content<br>after<br>Reset <sup>1)</sup> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------------------------|----------|-----------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------| | DC <sub>H</sub> | ADCON1 | 01XX-<br>X000 <sub>B</sub> | ADCL1 | ADCL0 | _ | _ | _ | MX2 | MX1 | MX0 | | E0 <sub>H</sub> <sup>2)</sup> | ACC | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | E8 <sub>H<sup>2)</sup></sub> | P4 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F0 <sub>H<sup>2)</sup></sub> | В | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F8 <sub>H</sub> <sup>2)</sup> | P5 | XX00-<br>0000 <sub>H</sub> | _ | _ | .5 | .4 | .3 | .2 | .1 | .0 | | FC <sub>H</sub> <sup>3)4)</sup> | VR0 | C5 <sub>H</sub> | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | | FD <sub>H</sub> <sup>3)4)</sup> | VR1 | 85 <sub>H</sub> | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | | FE <sub>H</sub> <sup>3)4)</sup> | VR2 | 5) | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | <sup>1)</sup> X means that the value is undefined and the location is reserved. <sup>2)</sup> Bit-addressable SFRs. <sup>3)</sup> SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set. <sup>4)</sup> These are read-only registers. <sup>5)</sup> The content of this SFR varies with the actual of the step C505L (e.g. 01<sub>H</sub> for the first step). Table 4 Contents of the LCD and the RTC Registers in Numeric Order of Their Addresses | Addr. | Register | Content<br>after<br>Reset | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------------------|----------|---------------------------|-------|-------|-------|-------|-------|-------|-------|-------| | F3DC <sub>H</sub> | DAC0 | 00 <sub>H</sub> | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | | F3DD <sub>H</sub> | LCON | 00 <sub>H</sub> | DSB1 | DSB0 | 0 | 0 | 0 | 0 | CSEL | LCEN | | F3DE <sub>H</sub> | LCRL | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3DF <sub>H</sub> | LCRH | 00 <sub>H</sub> | SLT | .14 | .13 | .12 | .11 | .10 | .9 | .8 | | F3En <sub>H</sub> | DIGn 1) | 00 <sub>H</sub> | SEGF | SEGA | SEGG | SEGB | SEGE | SEGC | SEGH | SEGD | | F3F0 <sub>H</sub> | RTCON | 00 <sub>H</sub> | 0 | 0 | 0 | 0 | RTPD | IRTC | ERTC | RTCS | | F3F1 <sub>H</sub> | RTCR0 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3F2 <sub>H</sub> | RTCR1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3F3 <sub>H</sub> | RTCR2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3F4 <sub>H</sub> | RTCR3 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3F5 <sub>H</sub> | RTCR4 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3F6 <sub>H</sub> | CLREG0 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3F7 <sub>H</sub> | CLREG1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3F8 <sub>H</sub> | CLREG2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3F9 <sub>H</sub> | CLREG3 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3FA <sub>H</sub> | CLREG4 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3FB <sub>H</sub> | RTINT0 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3FC <sub>H</sub> | RTINT1 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3FD <sub>H</sub> | RTINT2 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3FE <sub>H</sub> | RTINT3 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | | F3FF <sub>H</sub> | RTINT4 | 00 <sub>H</sub> | .7 | .6 | .5 | .4 | .3 | .2 | .1 | .0 | <sup>1)</sup> The notation "n" (n = 0 to F) in the LCD Digit Register address definition defines the number of the related LCD digit. # **Digital I/O Ports** The C505L has five 8-bit and one 6-bit (port 5) digital I/O ports. Port 0 is an open-drain bidirectional I/O port, while ports 1 through 5 are quasi-bidirectional I/O ports with internal pull-up resistors. When configured as inputs, ports 1-5 will be pulled high, and will source current when externally pulled low. Port 0 will float when configured as input. The output drivers of port 0 and 2 and the input buffers of port 0 are also used for accessing external memory. In this application, port 0 outputs the low byte of the external memory address, time-multiplexed with the byte being written or read. Port 2 outputs the high byte of the external memory address when the address is 16 bits wide. Otherwise, the port 2 pins continue emitting the P2 Special Function register (SFR) contents. In this function, port 0 is not an open-drain port, but uses a strong internal pull-up. Therefore, the parallel I/O ports of the C505L can be grouped into six different types which are listed in **Table 5**. Table 5 C505L Port Structure Types | Туре | Description | |------|----------------------------------------------------------------------------------| | A | Standard digital I/O ports which can also be used for external address/data bus. | | В | Standard multifunctional digital I/O port lines | | С | Mixed digital/analog I/O port lines with programmable analog input function | | D | LCD Output Lines | | E | Standard digital I/O or LCD output lines | | F | Standard multifunctional digital I/O or LCD output lines | Type A and B port pins are standard C501-compatible I/O port lines, which can be used for digital I/O. The type A ports (port 0 and port 2) are also designed for accessing external data or program memory. Type B port lines are located at port 3 (except P3.4 and P3.5), and are used for digital I/O or for other alternate functions as described in the pin description. Type D port lines provide the LCD controller outputs R0-R3 and C0-C15 as primary functions. Type E port lines are located at port 4 and port 5 and provide the LCD controller output lines as alternate functions. Type F port lines are at P3.4/T0 and P3.5/T1 and have a digital alternate input each, apart from LCD output functions. The C505L provides eight analog input lines that are implemented as mixed digital/analog inputs (type C). The 8 analog inputs, AN0-AN7, are located at the port 1 pins P1.0 to P1.7. After reset, all analog inputs are disabled and the related pins of port 1 are configured as digital inputs. The analog function of the specific port 1 pins are enabled by bits in the SFRs P1ANA. Writing a 0 to a bit position of P1ANA assigns the corresponding pin to operate as analog input. Note: P1ANA is a mapped SFR and can only be accessed if bit RMAP in SFR SYSCON is set. If a digital value is to be read by port 1, the voltage levels are to be held within the input voltage specifications $(V_{\parallel}/V_{\parallel})$ . #### Timer / Counter 0 and 1 Timer/Counter 0 and 1 can be used in four operating modes as listed in **Table 6**: Table 6 Timer/Counter 0 and 1 Operating Modes | Mode | Description | TN | MOD | Input Clock | | | |------|-----------------------------------------------------------------------------------------|----|-----|---------------------------|----------------------------|--| | | | M1 | MO | internal | external (max) | | | 0 | 8-bit timer/counter with a divide-by-32 prescaler | 0 | 0 | $f_{\rm OSC}/(6\times32)$ | $f_{\rm OSC}/(12\times32)$ | | | 1 | 16-bit timer/counter | 0 | 1 | | | | | 2 | 8-bit timer/counter with 8-bit autoreload | 1 | 0 | | | | | 3 | Timer/counter 0 used as one<br>8-bit timer/counter and one 8-bit timer<br>Timer 1 stops | 1 | 1 | $f_{\rm OSC}/6$ | $f_{\rm OSC}/12$ | | In the "timer" function ( $C/\overline{T}$ = '0') the register is incremented every machine cycle. Therefore the count rate is $f_{OSC}/6$ . In the "counter" function the register is incremented in response to a 1-to-0 transition at its corresponding external input pin (P3.4/T0, P3.5/T1). Since it takes two machine cycles to detect a falling edge the max. count rate is $f_{\rm OSC}/12$ . External inputs $\overline{\rm INT0}$ and $\overline{\rm INT1}$ (P3.2, P3.3) can be programmed to function as a gate to facilitate pulse width measurements. **Figure 11** illustrates the input clock logic. Figure 11 Timer/Counter 0 and 1 Input Clock Logic # Timer/Counter 2 with Compare/Capture/Reload The timer 2 of the C505L provides additional compare/capture/reload features, which allow the selection of the following operating modes: Compare : up to 4 PWM signals with 16-bit/300 ns resolution (@ 20 MHz clock) - Capture : up to 4 high speed capture inputs with 300 ns resolution - Reload : modulation of timer 2 cycle time The block diagram in **Figure 12** shows the general configuration of timer 2 with the additional compare/capture/reload registers. The I/O pins which can used for timer 2 control are located as multifunctional port functions at port 1. Figure 12 Timer 2 Block Diagram #### **Timer 2 Operating Modes** The timer 2, which is a 16-bit-wide register, can operate as timer, event counter, or gated timer. A roll-over of the count value in TL2/TH2 from all 1's to all 0's sets the timer overflow flag TF2 in SFR IRCON, which can generate an interrupt. The bits in register T2CON are used to control the timer 2 operation. <u>Timer Mode:</u> In timer function, the count rate is derived from the oscillator frequency. A prescaler offers the possibility of selecting a count rate of 1/6 or 1/12 of the oscillator frequency. <u>Gated Timer Mode:</u> In gated timer function, the external input pin T2 (P1.7) functions as a gate to the input of timer 2. If T2 is high, the internal clock input is gated to the timer. T2 = 0 stops the counting procedure. This facilitates pulse width measurements. The external gate signal is sampled once every machine cycle. Event Counter Mode: In the event counter function, the timer 2 is incremented in response to a 1-to-0 transition at its corresponding external input pin T2 (P1.7). In this function, the external input is sampled every machine cycle. Since it takes two machine cycles (12 oscillator periods) to recognize a 1-to-0 transition, the maximum count rate is 1/6 of the oscillator frequency. There are no restrictions on the duty cycle of the external input signal, but to ensure that a given level is sampled at least once before it changes, it must be held for at least one full machine cycle. #### Reload of Timer 2: Two reload modes are selectable: In mode 0, when timer 2 rolls over from all 1's to all 0's, it not only sets TF2 but also causes the timer 2 registers to be loaded with the 16-bit value in the CRC register, which is preset by software. In mode 1, a 16-bit reload from the CRC register is caused by a negative transition at the corresponding input pin P1.5/T2EX. This transition will also set flag EXF2 if bit EXEN2 in SFR IEN1 has been set. #### **Timer 2 Compare Modes** The compare function of a timer/register combination operates as follows: the 16-bit value stored in a compare or compare/capture register is compared with the contents of the timer register; if the count value in the timer register matches the stored value, an appropriate output signal is generated at a corresponding port pin and an interrupt can be generated. ## Compare Mode 0 In compare mode 0, upon matching the timer and compare register contents, the output signal changes from low to high. It goes back to a low level on timer overflow. As long as compare mode 0 is enabled, the appropriate output pin is controlled by the timer circuit only and writing to the port will have no effect. **Figure 13** shows a functional diagram of a port circuit when used in compare mode 0. The port latch is directly controlled by the timer overflow and compare match signals. The input line from the internal bus and the write-to-latch line of the port latch are disconnected when compare mode 0 is enabled. Figure 13 Port Latch in Compare Mode 0 # Compare Mode 1 If compare mode 1 is enabled and the software writes to the appropriate output latch at the port, the new value will not appear at the output pin until the next compare match occurs. Thus, it can be choosen whether the output signal has to make a new transition (1-to-0 or 0-to-1, depending on the actual pin-level) or should keep its old value at the time when the timer value matches the stored compare value. In compare mode 1 (see **Figure 14**) the port circuit consists of two separate latches. One latch (which acts as a "shadow latch") can be written under software control, but its value will only be transferred to the port latch (and thus to the port pin) when a compare match occurs. Figure 14 Compare Function in Compare Mode 1 # **Timer 2 Capture Modes** Each of the compare/capture registers CC1 to CC3 and the CRC register can be used to latch the current 16-bit value of the timer 2 registers TL2 and TH2. Two different modes are provided for this function. In mode 0, the external event causing a capture is: - for CC registers 1 to 3: a positive transition at pins CC1 to CC3 of port 1 - for the CRC register: a positive or negative transition at the corresponding pin, depending on the status of the bit I3FR in SFR T2CON. In <u>mode 1</u> a capture occurs in response to a write instruction to the low order byte of a capture register. The write-to-register signal (e.g. write-to-CRCL) is used to initiate a capture. The timer 2 contents will be latched into the appropriate capture register in the cycle following the write instruction. In this mode no interrupt request will be generated. # Serial Interface (USART) The serial port is full duplex and can operate in four modes (one synchronous mode, three asynchronous modes) as illustrated in **Table 7**. Table 7 USART Operating Modes | Mada | SC | ON | Description | |------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | Mode | SM0 | SM1 | | | 0 | 0 | 0 | Shift register mode, fixed baud rate<br>Serial data enters and exits through R×D; T×D outputs the shift clock;<br>8-bit are transmitted/received (LSB first) | | 1 | 0 | 1 | 8-bit UART, variable baud rate 10 bits are transmitted (through T×D) or received (at R×D) | | 2 | 1 | 0 | 9-bit UART, fixed baud rate 11 bits are transmitted (through T×D) or received (at R×D) | | 3 | 1 | 1 | 9-bit UART, variable baud rate<br>Like mode 2 | For clarification some terms regarding the difference between "baud rate clock" and "baud rate" should be mentioned. In the <u>asynchronous modes</u> the serial interfaces require a clock rate which is 16 times the baud rate for internal synchronization. Therefore, the baud rate generators/timers have to provide a "baud rate clock" (output signal in **Figure 15**) to the serial interface which - divided by 16 - results in the actual "baud rate". Further, the abbrevation $f_{\rm OSC}$ refers to the oscillator frequency (crystal or external clock operation). The variable baud rates for modes 1 and 3 of the serial interface can be derived either from timer 1 or from a dedicated baud rate generator (see **Figure 15**). Figure 15 Block Diagram of Baud Rate Generation for the Serial Interface **Table 8** below lists the values/formulas for the baud rate calculation of the serial interface with its dependencies of the control bits BD and SMOD. Table 8 Serial Interface - Baud Rate Dependencies | Serial Interface | <b>Active Control Bits</b> | | Baud Rate Calculation | |--------------------------------------------|----------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------| | Operating Modes | BD | SMOD | | | Mode 0 (Shift Register) | _ | _ | f <sub>OSC</sub> / 6 | | Mode 1 (8-bit UART)<br>Mode 3 (9-bit UART) | 0 | X | Controlled by timer 1 overflow: (2 <sup>SMOD</sup> × timer 1 overflow rate) / 32 | | | 1 | X | Controlled by baud rate generator $(2^{\text{SMOD}} \times f_{\text{OSC}})$ / $(32 \times \text{baud rate generator overflow rate})$ | | Mode 2 (9-bit UART) | _ | 0 | $f_{ m OSC}$ / 32 $f_{ m OSC}$ / 16 | ### **LCD Controller Unit** The Liquid Crystal Display (LCD) controller unit in the C505L is designed for the control of an LCD display module of 128 display segments (4 rows and 32 columns) using the 1/4 duty-cycle driving method. The C505L can be programmed to generate reference voltages for adjusting the contrast of the display. An example of a typical LCD module is shown in **Figure 16**. The table describes the different combinations of the row and column signals required to activate a particular segment. The signals R0-R3 and C0-C31 are the row and column signals, respectively, connected to the display module. Figure 16 Organization of a Typical LCD Display Module The memory required by the LCD controller includes a control register, LCON, the D/A Converter register DAC0 and 16 individual digit registers (DIGx, x = 0 to F). These registers are implemented in the on-chip external data memory area. Accesses to these registers are similar to on-chip XRAM accesses (MOVX instructions) and therefore must be preceded by an enable operation on the on-chip XRAM. Note: The actual segment organization within the display unit could be different from the example considered here. In such cases, the segment names/positions may vary. The user should consult the manufacturer of the LCD display unit used regarding its segment organization. The LCD outputs of the C505L must work at a frequency which is not more than 360 Hz in order to activate a display segment. To achieve this 360-Hz frequency limit, the LCD controller uses a scheme as shown in **Figure 17**. Figure 17 LCD Clocking The generated LCD clock has a duty-cycle of 50%. The table in **Figure 17** shows the recommended reload values at different input frequencies ( $f_{\text{LCDIN}}$ ) to generate LCD clocks of frequencies less than 360 Hz. The frequency of the LCD clock could be calculated by: $$f_{LCD} = \frac{f_{LCDIN}}{2 \times (15\text{-bit reload value})}$$ Hz ## **Display Voltage Levels** The LCD controller outputs three voltage levels required for driving the LCD display module. These voltage levels are generated by a programmable 8-bit D/A converter via the register DAC0 and a resistive divider network. The D/A converter is enabled by the LCD controller enable bit LCEN (LCON.0). Any write operation to the register DAC0 with the LCD controller enabled, starts the D/A conversion and thereby the display outputs. Therefore, the C505L can be used with a wide range of LCD display modules. ## **LCD Controller in Power Saving Mode** In order to reduce power consumption, the C505L can be put into the software power down mode 2. In this mode, the LCD controller and the D/A converter do not lose their register contents and remain in operation, provided the following conditions are satisfied: - The input clock to the LCD is the 32.768 kHz real-time clock input, and - The real-time clock input at XTAL3 and XTAL4 pins is still valid. ### **Real-Time Clock** The real-time clock unit of the C505L contains a dedicated oscillator and a 47-bit timer which is used to count time elapsed with respect to an initial time. The C505L real-time clock does not provide for any error correction. Any such corrections can be done by software only. ### **Functionality** The real-time clock can be initialized to a 40-bit initial value, which are loaded into the upper 40-bits of the timer. The lower 7 bits of the counter are never accessible by the user and merely act as prescalers that are initialized to $0000000_B$ after a start operation on the real-time clock. One increment of the clock register is made for every cycle of the input clock (32.768 kHz). The functionality of the real-time clock is shown in **Figure 18**. Figure 18 Real-Time Clock The register memory for the real-time clock is implemented in the on-chip external data memory area. Accesses to these registers are similar to on-chip XRAM accesses (MOVX instructions) and therefore must be preceded by an enable operation on the on-chip XRAM. These registers include the RTCON, RTCR0 to RTCR4 (RTCR), CLREG0 to CLREG4 (CLREG) and RTINT0 to RTINT4 (RTINT) registers. ## **Real-Time Clock in Power Saving Modes** Once started in the normal mode, the oscillator as well as the whole real-time clock could remain in operation during certain power-down modes where the power supply could be reduced to a minimum of **3 V**. These are the power down modes 2 and 3, where other functional units of the C505L are powered down (**See "Power Saving Modes" on Page 50.**). The upper 40-bit content of the real-time clock counter can be compared with the content of the programmable RTINT register in order to generate an interrupt request while the C505L is in one of software power-down modes 2 or 3, provided all of the following conditions are fulfilled: - The C505L is in one of the software power-down modes 2 or 3, - Wake-up from software power-down is enabled (bit EWPD = 1 in SFR PCON1) - Real-time clock wake-up source is selected (bit WS = 1 in SFR PCON1), - The real-time clock interrupt is enabled (bit ERTC = 1 of RTCON), and - Normally operating $V_{\rm DD}$ levels are maintained In this case, the handling is similar to the wake-up from power-down through P3.2/INTO. #### 10-Bit A/D Converter The C505L includes a high performance / high speed 10-bit A/D-Converter (ADC) with 8 analog input channels. It operates with a successive approximation technique and uses self calibration mechanisms for reduction and compensation of offset and linearity errors. The A/D converter provides the following features: - 8 multiplexed input channels (port 1), which can also be used as digital inputs/outputs - 10-bit resolution - Single or continuous conversion mode - Internal start-of-conversion trigger capability - Interrupt request generation after each conversion - Using successive approximation conversion technique via a capacitor array - Built-in hidden calibration of offset and linearity errors The 10-bit ADC uses two clock signals for operation: the conversion clock $f_{\rm ADC}$ (= $1/t_{\rm ADC}$ ) and the input clock $f_{\rm IN}$ (= $1/t_{\rm IN}$ ). $f_{\rm ADC}$ is derived from the C505L system clock $f_{\rm OSC}$ which is applied at the XTAL pins. The input clock $f_{\rm IN}$ is equal to $f_{\rm OSC}$ The conversion $f_{\rm ADC}$ clock is limited to a maximum frequency of 2 MHz. Therefore, the ADC clock prescaler must be programmed to a value which assures that the conversion clock does not exceed 2 MHz. The prescaler ratio is selected by the bits ADCL1 and ADCL0 of SFR ADCON1. | MCU System Clock Rate $(f_{OSC})$ | $f_{IN}$ [MHz] | Prescaler<br>Ratio | $f_{ extsf{ADC}}$ [MHz] | ADCL1 | ADCL0 | |-----------------------------------|----------------|--------------------|-------------------------|-------|-------| | 2 MHz | 2 | ÷ 4 | 0.5 | 0 | 0 | | 6 MHz | 6 | ÷ 4 | 1.5 | 0 | 0 | | 8 MHz | 8 | ÷ 4 | 2 | 0 | 0 | | 12 MHz | 12 | ÷ 8 | 1.5 | 0 | 1 | | 16 MHz | 16 | ÷ 8 | 2 | 0 | 1 | | 20 MHz | 20 | ÷ 16 | 1.25 | 1 | 0 | Figure 19 10-Bit A/D Converter Clock Selection Figure 20 Block Diagram of the 10-Bit A/D Converter ### **Interrupt System** The C505L provides 12 interrupt vectors with four priority levels. Five interrupt requests can be generated by the on-chip peripherals (timer 0, timer 1, timer 2, serial interface, A/D converter) and six interrupts may be triggered externally (P3.2/INT0, P3.3/INT1, P1.0/AN0/INT3/CC0, P1.1/AN1/INT4/CC1, P1.2/AN2/INT5/CC2, P1.3/AN3/INT6/CC3). Additionally, the P1.5/AN5/T2EX can trigger an interrupt. There is one software-generated interrupt (bit SWI in SFR IEN1) in addition to the above interrupts. The wake-up from power-down mode interrupt has a special functionality which allows an exit from the software power-down mode by a short low pulse at either pin P3.2/INT0 or by the real-time clock interrupt. Figure 21 to Figure 23 give a general overview of the interrupt sources and illustrate the corresponding request and the control flags. **Table 9** lists all interrupt sources with the corresponding request flags and interrupt vector addresses. Table 9 Interrupt Source and Vectors | Interrupt Source | Interrupt Vector Address | Interrupt Request Flags | |--------------------------------|--------------------------|-------------------------------------| | External Interrupt 0 | 0003 <sub>H</sub> | IE0 | | Timer 0 Overflow | 000B <sub>H</sub> | TF0 | | External Interrupt 1 | 0013 <sub>H</sub> | IE1 | | Timer 1 Overflow | 001B <sub>H</sub> | TF1 | | Serial Channel | 0023 <sub>H</sub> | RI / TI | | Timer 2 Overflow / Ext. Reload | 002B <sub>H</sub> | TF2 / EXF2 | | A/D Converter | 0043 <sub>H</sub> | IADC | | Software Interrupt | 004B <sub>H</sub> | SWI | | External interrupt 3 | 0053 <sub>H</sub> | IEX3 | | External Interrupt 4 | 005B <sub>H</sub> | IEX4 | | External Interrupt 5 | 0063 <sub>H</sub> | IEX5 | | External interrupt 6 | 006B <sub>H</sub> | IEX6 | | Wake-up from power-down mode | 007B <sub>H</sub> | IRTC (real-time clock wake-up only) | Figure 21 Interrupt Structure, Overview Part 1 Figure 22 Interrupt Structure, Overview Part 2 Figure 23 Interrupt Structure, Overview Part 3 #### **Fail Save Mechanisms** The C505L offers enhanced fail safe mechanisms, which allow an automatic recovery from software upset or hardware failure: - a programmable watchdog timer (WDT), with variable time-out period from 192 $\mu$ s up to approx. 393.2 ms at 16 MHz (314.5 ms at 20 MHz). - an oscillator watchdog (OWD) which monitors the on-chip oscillator and forces the microcontroller into reset state in case the on-chip oscillator fails; it also provides the clock for a fast internal reset after power-on. The watchdog timer in the C505L is a 15-bit timer, which is incremented by a count rate of $f_{\rm OSC}/12$ up to $f_{\rm OSC}/192$ . The system clock of the C505L is divided by two prescalers, a divide-by-two and a divide-by-16 prescaler. For programming of the watchdog timer overflow rate, the upper 7 bits of the watchdog timer can be written. **Figure 24** shows the block diagram of the watchdog timer unit. Figure 24 Block Diagram of the Watchdog Timer The watchdog timer can be started by software (bit SWDT in SFR IEN1) but it cannot be stopped during active mode of the device. If the software fails to refresh the running watchdog timer an internal reset will be initiated on watchdog timer overflow. For refreshing of the watchdog timer the content of the SFR WDTREL is transferred to the upper 7-bit of the watchdog timer. The refresh sequence consists of two consecutive instructions which set the bits WDT and SWDT each. The reset cause (external reset or reset caused by the watchdog) can be examined by software (flag WDTS). It must be noted, however, that the watchdog timer is halted during the idle mode and power down mode of the processor. ## **Oscillator Watchdog** The oscillator watchdog unit serves for four functions: ### Monitoring of the on-chip oscillator's function The watchdog supervises the on-chip oscillator's frequency; if it is lower than the frequency of the auxiliary RC oscillator in the watchdog unit, the internal clock is supplied by the RC oscillator and the device is brought into reset; if the failure condition disappears (i.e. the on-chip oscillator has a higher frequency than the RC oscillator), the part executes a final reset phase of typ. 1 ms in order to allow the oscillator to stabilize; then the oscillator watchdog reset is released and the part starts program execution again. ## Fast internal reset after power-on The oscillator watchdog unit provides a clock supply for the reset before the on-chip oscillator has started. The oscillator watchdog unit also works identically to the monitoring function. ### - Control of wake-up from software power-down mode When the software power-down mode is left by a low level at the P3.2/INTO pin or an active Real-Time Clock Interrupt Request flag IRTC, the oscillator watchdog unit assures that the microcontroller resumes operation (execution of the power-down wake-up interrupt) with the nominal clock rate. In the power-down mode the RC oscillator and the on-chip oscillator are stopped. Both oscillators are started again when power-down mode is released. When the on-chip oscillator has a higher frequency than the RC oscillator, the microcontroller starts operation after a final delay of typ. 1 ms in order to allow the on-chip oscillator to stabilize. Note: The oscillator watchdog unit is always enabled. Data Sheet 48 06.99 Figure 25 Block Diagram of the Oscillator Watchdog ### **Power Saving Modes** The C505L provides three basic power saving modes, the idle mode, the slow-down mode and the software power down mode. #### - Idle mode The CPU is gated off from the oscillator. All peripherals are still provided with the clock and are able to work. Idle mode is entered by software and can be left by an interrupt or reset. #### Slow down mode The controller remains fully functional, but its normal clock frequency is internally divided by 32. This slows down all parts of the controller, the CPU and all peripherals, to 1/32 of their normal operating frequency and also reduces power consumption. ### Software power down modes: **Software power-down mode 1**, in which all the peripheral blocks and the CPU are stopped. This mode is used to save contents of internal RAM, XRAM and SFRs with a very low standby current. **Software power-down mode 2**, in which only the Real-time clock and LCD controller are operating. In this mode, the CPU and the rest of the peripherals are stopped. The RC oscillator and the on-chip oscillator are stopped, the real-time clock oscillator that operates with the XTAL3 and XTAL4 pins is still running and the real-time count is maintained in this mode. **Software power-down mode 3**, in which only the real-time clock is operating. In this mode, the clock input into the CPU, LCD controller and the rest of the peripherals are stopped. The only difference between this mode and mode 2 is that the LCD controller is also stopped in this mode. In all the software power-down modes, $V_{\rm DD}$ can be reduced to minimize power consumption. In the case of the software power-down mode 3, $V_{\rm DD}$ can be reduced to **3 V** (lower specification limit). It must be ensured, however, that $V_{\rm DD}$ is not reduced before any of the power-down modes is invoked, and that $V_{\rm DD}$ is restored to its normal operating level before leaving the power-down mode. Any of these software power-down modes can be exited either by an active reset signal or by a wake-up request. Using reset to leave power-down mode puts the microcontroller with its SFRs into the reset state. Program execution then starts from the address $0000_H$ . Using a wake-up request to exit the power-down mode starts the RC oscillator and the on-chip oscillator and maintains the state of the SFRs, which were frozen when power-down mode was entered. When the C505L is in software power-down mode 1, a wake-up operation is possible only through P3.2/INTO. There are two ways to use a wake-up request to exit power-down modes 2 and 3: - Wake-up via P3.2/INTO pin, or - Wake-up via the real-time clock interrupt Table 10 Power Saving Modes Overview | Mode | Entering<br>Sequence<br>Example | Leaving by | Remarks | | |-------------------------------|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--| | Idle mode | ORL PCON, #01H<br>ORL PCON, #20H | Occurrence of an interrupt from a peripheral unit Hardware Reset | CPU clock is stopped; CPU maintains their data; peripheral units are active (if enabled) and provided with clock | | | Slow Down Mode | In normal mode:<br>ORL PCON, #10H | ANL PCON,#0EFH Hardware Reset | Internal clock rate is reduced to 1/32 of its nominal frequency | | | | With idle mode:<br>ORL PCON, #01H<br>ORL PCON, #30H | Occurrence of an interrupt from a peripheral unit | CPU clock is stopped;<br>CPU maintains their data;<br>peripheral units are active | | | | | Hardware reset | (if enabled) and provided with 1/32 of its nominal frequency | | | Software<br>Power Down Mode1 | <br>bit LCEN (LCON | Short low pulse at pin P3.2/INT0 | Oscillator is stopped; contents of on-chip RAM, | | | | register) is cleared;<br>bit RTPD (RTCON<br>register) is set;<br>ORL PCON, #02H<br>ORL PCON, #40H | Hardware Reset | XRAM and SFR's are maintained; | | | Software<br>Power Down Mode 2 | bits LCEN and CSEL (LCON register) are set, | Short low pulse at pin P3.2/INT0 or real-time clock wake-up interrupt | Oscillator is stopped;<br>contents of on-chip RAM,<br>XRAM and SFR's are<br>maintained; LCD Controller | | | | bit RTPD (RTCON register) is cleared; ORL PCON, #02H | Hardware Reset | and real-time clock are functioning | | | Software<br>Power Down Mode 3 | orl PCON, #40H bit LCEN (LCON register) is cleared; bit RTPD (RTCON | Short low pulse at pin P3.2/INT0 or real-time clock wake-up interrupt | Oscillator is stopped;<br>contents of on-chip RAM,<br>XRAM and SFR's are<br>maintained; | | | | register) is cleared;<br><br>ORL PCON, #02H<br>ORL PCON, #40H | Hardware Reset | real-time clock is functioning | | ## **OTP Memory Operation** The C505L contains a 32 Kbyte one-time programmable (OTP) program memory. With the C505L fast programming cycles are achieved (1 byte in 100 $\mu$ s). Also several levels of OTP memory protection can be selected. For programming of the device, the C505L must be put into the programming mode. This typically is done not in-system but in a special programming hardware. In the programming mode the C505L operates as a slave device similar as an EPROM stand-alone memory device and must be controlled with address/data information, control lines, and an external 11.5 V programming voltage. **Figure 26** shows the pins of the C505L which are required for controlling of the OTP programming mode. Figure 26 Programming Mode Configuration ## **Pin Configuration in Programming Mode** Figure 27 P-MQFP-80 Pin Configuration of the C505L in Programming Mode (top view) **Table 11** is a functional description of all C505L pins that are required for OTP memory programming. Table 11 Pin Definitions and Functions of the C505L in Programming Mode | Symbol | Pin Number | I/O *) | Function | | | | | | |------------------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|------------------------------------------------------------------------|--|--|--| | | P-MQFP-80 | | | | | | | | | RESET | 43 | I | Reset This input must be at static "1" (active) level during the whole programming mode. | | | | | | | PMSEL0<br>PMSEL1 | 42<br>41 | 1 | Programming Mode SELection pins These pins are used to select the different access modes in programming mode. PMSEL1,0 must satisfy a setup time to rising edge of PALE. When the logic level of PMSEL1,0 is changed, PALE must be at low level. | | | | | | | | | | PMSEL1 | EL1 PMSEL0 Access Mode | | | | | | | | | 0 | 0 | Reserved | | | | | | | | 0 | 1 | Read signature bytes | | | | | | | | 1 | 0 | Program/read lock-bits | | | | | | | | 1 | 1 | Program/read OTP memory byte | | | | | PSEL | 40 | I | This input is | | de SELect pasic programming mode selection cording to Figure 28. | | | | | PRD | 39 | I | This input is | | AD strobe I access control for OTP memory nd lock-bit read operations. | | | | | PALE | 38 | I | Programming Address Latch Enable PALE is used to latch the high address lines. The high address lines must satisfy a setup and hold time to/from the falling edge of PALE. PALE must be at a low level when the logic level of PMSEL1,0 is changed. | | | | | | | XTAL2 | 47 | 0 | XTAL2 Output of the inverting oscillator amplifier. | | | | | | | XTAL1 | 48 | I | XTAL1 Input to the oscillator amplifier. | | | | | | <sup>\*)</sup> I = Input O= Output Table 11 Pin Definitions and Functions of the C505L in Programming Mode (cont'd) | Symbol | Pin Number | I/O *) | Function | |------------------------------|-----------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | P-MQFP-80 | | | | $\overline{V_{\mathtt{SS}}}$ | 49, 70 | _ | Circuit ground potential Must be applied in programming mode. | | $V_{DD}$ | 50, 69 | _ | Power supply terminal Must be applied in programming mode. | | A0-A7,<br>A8-A14<br>(Port 2) | 60-53 | I | Address lines Multiplexed address input lines A0-A7 and A8-A14. A8-A14 must be latched with PALE. | | PSEN | 44 | I | Program Store ENable This input must be at static "0" level during the whole programming mode. | | PROG | 45 | I | PROGramming mode write strobe This input is used in programming mode as a write strobe for OTP memory program, and lock-bit write operations. During basic programming mode selection a low level must be applied to PROG. | | $\overline{EA}/V_PP$ | 46 | - | Programming voltage This pin must be at 11.5 V ( $V_{\rm PP}$ ) voltage level during programming of an OTP memory byte or lock-bit. During an OTP memory read operation, this pin must be at $V_{\rm IH}$ high level. This pin is also used for basic programming mode selection. At basic programming mode selection a low level must be applied to $\overline{\rm EA}/V_{\rm PP}$ . | | D7-D0<br>(Port 0) | 68-61 | I/O | Data lines 0-7 During programming mode, data bytes are transferred via the bidirectional D7-D0 lines that are located at port 0 pins. | | N.C. | 1-37, 51-52,<br>71-80 | _ | Not Connected These pins should not be connected in programming mode. | <sup>\*)</sup> I = Input O= Output # **Basic Programming Mode Selection** The basic programming mode selection scheme is shown in Figure 28. Figure 28 Basic Programming Mode Selection Table 12 Access Modes Selection | Access Made | EA/ | PROG | PRD | PI | MSEL | Address | Data | | |-------------------------|--------------|------|-----|----|------|--------------------------|-----------|--| | Access Mode | $V_{\sf PP}$ | PRUG | PKD | 1 | 0 | (Port 2) | (Port 0) | | | Program OTP memory byte | $V_{PP}$ | | Н | Н | Н | A0-7 | D0-7 | | | Read OTP memory byte | $V_{IH}$ | Н | Т | | | A8-14 | | | | Program OTP lock bits | $V_{PP}$ | ЪГ | Н | Н | L | _ | D1,D0 see | | | Read OTP lock bits | $V_{IH}$ | Н | Ъ | | | | Table 13 | | | Read OTP version byte | $V_{IH}$ | Н | Т | L | Н | Byte addr. of sign. byte | D0-7 | | # Lock Bits Programming / Read The C505L has two programmable lock-bits that, when programmed according to **Table 13**, provide four levels of protection for the on-chip OTP code memory. Table 13 Lock Bit Protection Types | Lock I | Bits at D1,D0 | Protection | Protection Type | |--------|---------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D1 | D0 | Level | | | 1 | 1 | Level 0 | The OTP lock feature is disabled. During normal operation of the C505L, the state of the $\overline{\sf EA}$ pin is not latched on reset. | | 1 | 0 | Level 1 | During normal operation of the C505L, MOVC instructions executed from external program memory are prevented from fetching code bytes from internal memory. EA is sampled and latched on reset. An OTP memory read operation is only possible in the OTP verification mode. Further programming of the OTP memory is disabled (reprogramming security). | | 0 | 1 | Level 2 | Same as level 1, but OTP memory read operation using OTP verification mode is disabled. | | 0 | 0 | Level 3 | Same as level 2, but external code execution by setting $\overline{EA}$ = low during normal operation of the C505L is not possible. External code execution, which is initiated by an internal program (e.g. by an internal jump instruction above the OTP memory boundary), is still possible. | Note: A "1" means that the lock-bit is not programmed. A "0" means that lock-bit is programmed. # **Version Bytes** The steppings of the C505L versions will contain the following version register/byte information: | Stepping | _ | Version Byte 1 = VR1<br>(mapped addr. FD <sub>H</sub> ) | Version Byte 2 = VR2<br>(mapped addr. FE <sub>H</sub> ) | |---------------|-----------------|---------------------------------------------------------|---------------------------------------------------------| | C505L CA-Step | C5 <sub>H</sub> | 85 <sub>H</sub> | 04 <sub>H</sub> | Note: Future steppings of C505L would have a different version byte 2 content. ## **Absolute Maximum Ratings** | Parameter | Symbol | Lim | it Values | Unit | Notes | |--------------------------------------------------------------------|------------|-------|--------------------|------|-------| | | | min. | max. | | | | Storage temperature | $T_{ST}$ | - 40 | 150 | °C | _ | | Voltage on $V_{\rm DD}$ pins with respect to ground $(V_{\rm SS})$ | $V_{DD}$ | - 0.5 | 6.5 | V | _ | | Voltage on any pin with respect to ground $(V_{\rm SS})$ | $V_{IN}$ | - 0.5 | $V_{\rm DD}$ + 0.5 | V | _ | | Input current on any pin during overload condition | _ | - 10 | 10 | mA | _ | | Absolute sum of all input currents during overload condition | _ | _ | 100 mA | mA | _ | | Power dissipation | $P_{DISS}$ | _ | 1 | W | _ | Note: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage of the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for longer periods may affect device reliability. During absolute maximum rating overload conditions $(V_{\text{IN}} > V_{\text{DD}} \text{ or } V_{\text{IN}} < V_{\text{SS}})$ the voltage on $V_{\text{DD}}$ pins with respect to ground $(V_{\text{SS}})$ must not exceed the values defined by the absolute maximum ratings. # **Operating Conditions** | Parameter | Symbol | Lim | it Values | Unit | Notes | |------------------------------------------------------------|-------------------------------|----------------------|-----------------------|------|------------------------------| | | | min. | max. | | | | Supply Voltage (Normal mode) | $V_{DD}$ | 4.25 | 5.5 | V | _ | | Supply Voltage (Software Power down mode 3 only) | | 3 | | V | Not during wake-up sequence. | | Ground voltage | $V_{SS}$ | 0 | | V | _ | | Ambient temperature<br>SAB-C505L<br>SAF-C505L<br>SAK-C505L | T <sub>A</sub> T <sub>A</sub> | 0<br>- 40<br>- 40 | 70<br>85<br>125 | °C | _ | | Analog reference voltage | $V_{AREF}$ | 4 | V <sub>DD</sub> + 0.1 | V | _ | | Analog ground voltage | $V_{AGND}$ | V <sub>SS</sub> -0.1 | V <sub>SS</sub> + 0.2 | V | _ | | Analog input voltage | $V_{AIN}$ | $V_{AGND}$ | $V_{AREF}$ | V | _ | | CPU clock | $f_{CPU}$ | 2 | 20 | MHz | _ | # **DC Characteristics** (Operating Conditions apply) | Parameter | Symbol | Limit \ | <b>Values</b> | Unit | <b>Test Condition</b> | | |-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-------------|-------------------------------------------------------------------------|--| | | | min. | max. | | | | | Input low voltages all except $\overline{EA}$ , RESET, XTAL3 $\overline{EA}$ pin RESET pin XTAL3 | $egin{array}{c} V_{IL} \ V_{IL1} \ V_{IL2} \ V_{IL3} \ \end{array}$ | - 0.5<br>- 0.5<br>- 0.5<br>- 0.5 | $0.2 \ V_{\rm DD} - 0.1 \\ 0.2 \ V_{\rm DD} - 0.3 \\ 0.2 \ V_{\rm DD} + 0.1 \\ 0.7 \ V_{\rm DD}$ | V<br>V<br>V | -<br>-<br>- | | | Input high voltages except XTAL1, RESET, XTAL3 and $\overline{EA}$ XTAL1 RESET, $\overline{EA}$ XTAL3 | $V_{\mathrm{IH}}$ $V_{\mathrm{IH1}}$ $V_{\mathrm{IH2}}$ $V_{\mathrm{IH3}}$ | $0.2 \ V_{\rm DD} + 0.9 \\ 0.7 \ V_{\rm DD} \\ 0.6 \ V_{\rm DD} \\ 0.9 \ V_{\rm DD}$ | $V_{\rm DD}$ + 0.5 $V_{\rm DD}$ + 0.5 $V_{\rm DD}$ + 0.5 $V_{\rm DD}$ + 0.5 | V<br>V<br>V | -<br>-<br>- | | | Output low voltages Ports 1, 2, 3, 4, 5 Port 0, ALE, PSEN | $V_{ m OL} \ V_{ m OL1}$ | _<br>_ | 0.45<br>0.45 | V<br>V | $I_{\rm OL}$ = 1.6 mA <sup>1)</sup> $I_{\rm OL}$ = 3.2 mA <sup>1)</sup> | | | Output high voltages Ports 1, 2, 3, 4, 5 | $V_{OH}$ | 2.4<br>0.9 V <sub>DD</sub> | _<br>_ | V<br>V | $I_{OH} = -80 \mu A$<br>$I_{OH} = -10 \mu A$ | | | Port 0 in external bus mode, ALE, PSEN | $V_{OH2}$ | 2.4<br>0.9 V <sub>DD</sub> | | V | $I_{OH} = -800 \mu\text{A}^{2}$<br>$I_{OH} = -80 \mu\text{A}^{2}$ | | | Logic 0 input current<br>Ports 1, 2, 3, 4, 5 | $I_{IL}$ | - 10 | - 70 | μΑ | V <sub>IN</sub> = 0.45 V | | | Logical 0-to-1 transition current<br>Ports 1, 2, 3, 4, 5 | $I_{TL}$ | <b>–</b> 65 | - 650 | μΑ | <i>V</i> <sub>IN</sub> = 2 V | | | Input leakage current Port 0, AN0-7(Port 1), EA | $I_{LI}$ | _ | ± 1 | μΑ | $0.45 < V_{IN} < V_{DD}$ | | | Pin capacitance | $C_{IO}$ | _ | 10 | pF | $f_{\rm c}$ = 1 MHz,<br>$T_{\rm A}$ = 25 °C | | | Overload current | $I_{OV}$ | _ | ± 5 | mA | 8) 9) | | | Programming voltage | $V_{PP}$ | 10.9 | 12.1 | V | 11.5 V 5% <sup>12)</sup> | | | Supply current at $\overline{\text{EA}}/V_{\text{PP}}$ | _ | _ | 30 | mA | 12) | | Notes see Page 63. # **Power Supply Current** (Operating Conditions apply) | Parameter | | Symbol | Limit | Limit Values | | <b>Test Condition</b> | |---------------------------------------------------------------------------|------------------|-------------------------------------------------|---------------------|---------------------|----------------|----------------------------------------------------------------------------------------------| | | | | typ. <sup>10)</sup> | max. <sup>11)</sup> | | | | Active Mode | 16 MHz<br>20 MHz | $I_{ m DD}$ $I_{ m DD}$ | 28.7<br>34.0 | 36.6<br>43.0 | mA | 4) | | Idle Mode | 16 MHz<br>20 MHz | $I_{ m DD}$ $I_{ m DD}$ | 13.7<br>15.9 | 19.4<br>22.0 | mA | 5) | | Active Mode with slow-down enabled | 16 MHz<br>20 MHz | $I_{ m DD}$ $I_{ m DD}$ | 5.7<br>6.2 | 7.6<br>8.1 | mA | 6) | | Idle Mode with slow-down enabled | 16 MHz<br>20 MHz | $I_{ m DD}$ $I_{ m DD}$ | 4.7<br>4.9 | 7.5<br>8.0 | mA | 7) | | Power down current: Software Power-do Software Power-do Software Power-do | wn mode 2 | $I_{ ext{PD1}}$ $I_{ ext{PD2}}$ $I_{ ext{PD3}}$ | 20<br>250<br>20 | 50<br>300<br>50 | μΑ<br>μΑ<br>μΑ | $V_{\rm DD} = 25.5 V^{3}$<br>$V_{\rm DD} = 4.25 - 5.5 V^{3}$<br>$V_{\rm DD} = 35.5 V^{3}$ | Notes see next page. #### Notes: - 1) Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the $V_{\rm OL}$ of ALE and port 3. The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1-to-0 transitions during bus operation. In the worst case (capacitive loading > 100 pF), the noise pulse on ALE line may exceed 0.8 V. In such cases it may be desirable to qualify ALE with a schmitt-trigger, or use an address latch with a schmitt-trigger strobe input. - 2) Capacitive loading on ports 0 and 2 may cause the $V_{\rm OH}$ on ALE and $\overline{\rm PSEN}$ to momentarily fall below the 0.9 $V_{\rm DD}$ specification when the address lines are stabilizing. - 3) Power-down modes: - $I_{\rm PD1}$ is measured under following conditions: $\overline{\rm EA} = {\rm Port}~0 = V_{\rm DD}$ ; RESET = $V_{\rm SS}$ .; XTAL2 = XTAL4 = N.C.; XTAL1 = XTAL3 = $V_{\rm SS}$ ; $V_{\rm AGND} = V_{\rm SS}$ ; $V_{\rm AREF} = V_{\rm DD}$ ; all other pins are disconnected. Conditions for $I_{PD2}$ and $I_{PD3}$ are similar except that XTAL3 and XTAL4 have a valid input from the 32.768 KHz crystal and the power supply limits. - 4) $I_{\rm DD}$ (active mode) is measured with: $\underline{X}\underline{T}\underline{A}\underline{L}1$ driven with $t_{\rm R}/t_{\rm F}=5$ ns, 50% duty cycle , $V_{\rm IL}=V_{\rm SS}+0.5$ V, $V_{\rm IH}=V_{\rm DD}-0.5$ V; $\underline{X}\underline{T}\underline{A}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline{N}\underline{L}2=\underline$ - 5) $I_{\rm DD}$ (idle mode) is measured with all output pins disconnected and with all peripherals disabled; XTAL1 driven with $t_{\rm R}/t_{\rm F}$ = 5 ns, 50% duty cycle, $V_{\rm IL} = V_{\rm SS}$ + 0.5 V, $V_{\rm IH} = V_{\rm DD}$ 0.5 V; XTAL2 = N.C.; RESET = $\overline{\rm EA} = V_{\rm SS}$ ; Port0 = $V_{\rm DD}$ ; all other pins are disconnected; the microcontroller is put into idle mode by software; - 6) $I_{\rm DD}$ (active mode with slow-down) is measured with all output pins disconnected and with all peripherals disabled; XTAL1 driven with $t_{\rm R}/t_{\rm F}$ = 5 ns, 50% duty cycle, $V_{\rm IL} = V_{\rm SS}$ + 0.5 V, $V_{\rm IH} = V_{\rm DD}$ 0.5 V; XTAL2 = N.C.; RESET = $\overline{\rm EA} = V_{\rm SS}$ ; all other pins are disconnected; the microcontroller is put into slow-down mode by software; - 7) $I_{\rm DD}$ (idle mode with slow-down) is measured with all output pins disconnected and with all peripherals disabled; XTAL1 driven with $t_{\rm R}/t_{\rm F}$ = 5 ns, 50% duty cycle, $V_{\rm IL} = V_{\rm SS} + 0.5$ V, $V_{\rm IH} = V_{\rm DD} 0.5$ V; XTAL2 = N.C.; RESET = $\overline{\rm EA} = V_{\rm SS}$ ; Port0 = $V_{\rm DD}$ ; all other pins are disconnected; the microcontroller is put into idle mode with slow-down enabled by software; - 8) Overload conditions under operating conditions occur if the voltage on the respective pin exceeds the specified operating range (i.e. $V_{\rm OV} > V_{\rm DD} + 0.5 \rm V$ or $V_{\rm OV} < V_{\rm SS} 0.5 \rm V$ ). The absolute sum of input overload currents on all port pins may not exceed **50 mA**. The supply voltage ( $V_{\rm DD}$ and $V_{\rm SS}$ ) must remain within the specified limits. - 9) Not 100% tested, guaranteed by design characterization - 10) The typical $I_{\rm DD}$ values are periodically measured at $T_{\rm A}$ = + 25 °C but not 100% tested. - 11) The maximum $I_{\rm DD}$ values are measured under worst case conditions ( $T_{\rm A}$ = 0 °C or 40 °C and $V_{\rm DD}$ = 5.5 V) - 12) Only valid in programming mode. Figure 29 $I_{\mathrm{DD}}$ Diagram Table 14 **Power Supply Current Calculation Formulas** | Parameter | Symbol | Formula | |------------------------------------|-----------------------------------|----------------------------------------------------------------------| | Active mode | $I_{ m DD\ typ}$ $I_{ m DD\ max}$ | $1.33 \times f_{\rm OSC}$ + 7.33<br>$1.61 \times f_{\rm OSC}$ + 10.8 | | Idle mode | $I_{ m DD\ typ} \ I_{ m DD\ max}$ | $0.54 \times f_{\rm OSC}$ + 5.07 $0.66 \times f_{\rm OSC}$ + 8.83 | | Active mode with slow-down enabled | $I_{ m DD\ typ} \ I_{ m DD\ max}$ | $0.12 \times f_{\rm OSC}$ + 3.87<br>$0.12 \times f_{\rm OSC}$ + 5.77 | | Idle mode with slow-down enabled | $I_{ m DD\ typ} \ I_{ m DD\ max}$ | $0.05 \times f_{\rm OSC}$ + 3.9 $0.12 \times f_{\rm OSC}$ + 5.67 | Note: 1. $f_{\rm OSC}$ is the oscillator frequency in MHz. $I_{\rm DD}$ values are given in mA. 2. $I_{\rm DD}$ graph for idle mode with slow-down enabled is not shown since it is very similar to active mode with slow-down enabled. # **LCD-Output Characteristics** (Operating Conditions apply) | Parameter | Symbol | | Limit Val | Unit | Test | | |------------------------------------------------|------------------------------------------------|------|--------------------------------------------------|-----------|------|-------------------------------------------------------| | | | min. | typ. | max. | | Condition | | Full range output voltage, of D/A Converter | Vo | 0 | - | 4.75 ± 7% | V | Normal mode $V_{\rm DD}$ range (operating conditions) | | Settling Time of D/A Converter Output | $t_{SET}$ | _ | _ | 350 | S | $V_{\mathrm{DD}}$ = 5 V | | DC differential non-linearity of D/A Converter | DNL | _ | - | 1 | LSB | _ | | DC integral non-linearity of D/A Converter | INL | _ | _ | 6 | % | $V_{\rm DD}$ = 5 V | | DC Offset Voltage of D/A<br>Converter | _ | _ | _ | 15 | mV | _ | | LCD Voltage levels | $V_{\rm LCD1} \\ V_{\rm LCD2} \\ V_{\rm LCD3}$ | _ | $V_{\rm O}$ $2 \times V_{\rm O}/3$ $V_{\rm O}/3$ | _ | V | 1) | Note: 1) Conditions as in $V_{\rm O}$ apply. # A/D Converter Characteristics (Operating Conditions apply) | Parameter | Symbol | Limi | t Values | Unit | Test Condition | | |-------------------------------------------------|-------------------|------------|-----------------------------------------------------------------------------------------------------------|------|--------------------------------------------------------------------------------------------------------|--| | | | min. | max. | | | | | Analog input voltage | $V_{AIN}$ | $V_{AGND}$ | $V_{AREF}$ | V | 1) | | | Sample time | $t_{\mathbb{S}}$ | _ | $64 \times t_{\rm IN}$ $32 \times t_{\rm IN}$ $16 \times t_{\rm IN}$ $8 \times t_{\rm IN}$ | ns | Prescaler ÷ 32 Prescaler ÷ 16 Prescaler ÷ 8 Prescaler ÷ 4 <sup>2)</sup> | | | Conversion cycle time | $t_{ADCC}$ | _ | $384 \times t_{\text{IN}}$ $192 \times t_{\text{IN}}$ $96 \times t_{\text{IN}}$ $48 \times t_{\text{IN}}$ | ns | Prescaler ÷ 32 Prescaler ÷ 16 Prescaler ÷ 8 Prescaler ÷ 4 <sup>3)</sup> | | | Total unadjusted error | $T_{\sf UE}$ | _ | ± 2 | LSB | $V_{\rm SS}$ + 0.5 V $\leq V_{\rm AIN} \leq V_{\rm DD} - 0.5 \ {\rm V}^{4)}$ | | | | | _ | ± 4 | LSB | $V_{\rm SS} < V_{\rm AIN} < V_{\rm DD}$ + 0.5 V $V_{\rm DD}$ - 0.5 V $< V_{\rm AIN} < V_{\rm DD}^{-4}$ | | | Internal resistance of reference voltage source | $R_{AREF}$ | _ | t <sub>ADC</sub> / 250<br>- 0.25 | kΩ | $t_{\rm ADC}$ in [ns] <sup>5) 6)</sup> | | | Internal resistance of analog source | R <sub>ASRC</sub> | _ | <i>t</i> <sub>S</sub> / 500 – 0.25 | kΩ | t <sub>S</sub> in [ns] <sup>2) 6)</sup> | | Notes see next page. # **Clock Calculation Table:** | Clock Prescaler Ratio | ADCL1, 0 | $t_{ADC}$ | $t_{S}$ | $t_{ADCC}$ | |-----------------------|----------|---------------------------|--------------------|---------------------| | ÷ 32 | 1 1 | $32 \times t_{IN}$ | $64 \times t_{IN}$ | $384 \times t_{IN}$ | | ÷ 16 | 1 0 | $16 \times t_{\text{IN}}$ | $32 \times t_{IN}$ | $192 \times t_{IN}$ | | ÷ 8 | 0 1 | $8 \times t_{IN}$ | $16 \times t_{IN}$ | $96 \times t_{IN}$ | | ÷ 4 | 0 0 | $4 \times t_{IN}$ | $8 \times t_{IN}$ | $48 \times t_{IN}$ | Further timing conditions: $t_{\rm ADC}$ min = 500 ns $t_{\rm IN}$ = 1 $/f_{\rm OSC}$ = $t_{\rm CLP}$ #### Notes: - 1) $V_{\text{AIN}}$ may exceed $V_{\text{AGND}}$ or $V_{\text{AREF}}$ up to the absolute maximum ratings. However, the conversion result in these cases will be X000<sub>H</sub> or X3FF<sub>H</sub>, respectively. - 2) During the sample time the input capacitance $C_{\mathsf{AIN}}$ must be charged/discharged by the external source. The internal resistance of the analog source must allow the capacitance to reach their final voltage level within $t_{\mathsf{S}}$ . After the end of the sample time $t_{\mathsf{S}}$ , changes of the analog input voltage have no effect on the conversion result. - 3) This parameter includes the sample time $t_S$ , the time for determining the digital result and the time for the calibration. Values for the conversion clock $t_{ADC}$ depend on programming and can be taken from the table on the previous page. - 4) $T_{\rm UE}$ is tested at $V_{\rm AREF}$ = 5.0 V, $V_{\rm AGND}$ = 0 V, $V_{\rm DD}$ = 4.9 V. It is guaranteed by design characterization for all other voltages within the defined voltage range. If an overload condition occurs on maximum 2 unused analog input pins and the absolute sum of input overload currents on all analog input pins does not exceed 10 mA, an additional conversion error of 1/2 LSB is permissible. - 5) During the conversion the ADC's capacitance must be repeatedly charged or discharged. The internal resistance of the reference source must allow the capacitance to reach their final voltage level within the indicated time. The maximum internal resistance results from the programmed conversion timing. - 6) Not 100% tested, but guaranteed by design characterization. # AC Characteristics (16 MHz, 0.4 to 0.6 Duty Cycle) (Operating Conditions apply) ( $C_L$ for port 0, ALE and $\overline{\text{PSEN}}$ outputs = 100 pF; $C_L$ for all other outputs = 80 pF) # **Program Memory Characteristics** | Parameter | Symbol | Limit Values | | | | | |------------------------------------|-------------------|------------------------------------------|------|------------------------------------------|-------------------------------------|----| | | | 16-MHz clock<br>Duty Cycle<br>0.4 to 0.6 | | Variable Clock<br>1/CLP= 2 MHz to 16 MHz | | | | | | min. | max. | min. | max. | | | ALE pulse width | $t_{LHLL}$ | 48 | _ | CLP – 15 | _ | ns | | Address setup to ALE | t <sub>AVLL</sub> | 10 | _ | TCL <sub>Hmin</sub> – 15 | _ | ns | | Address hold after ALE | $t_{LLAX}$ | 10 | _ | TCL <sub>Hmin</sub> – 15 | _ | ns | | ALE to valid instruction in | $t_{LLIV}$ | _ | 75 | _ | 2 CLP – 50 | ns | | ALE to PSEN | $t_{LLPL}$ | 10 | _ | TCL <sub>Lmin</sub> – 15 | _ | ns | | PSEN pulse width | $t_{PLPH}$ | 73 | _ | CLP+<br>TCL <sub>Hmin</sub> – 15 | _ | ns | | PSEN to valid instruction in | $t_{PLIV}$ | _ | 38 | - | CLP +<br>TCL <sub>Hmin</sub> - 50 | ns | | Input instruction hold after PSEN | $t_{PXIX}$ | 0 | _ | 0 | _ | ns | | Input instruction float after PSEN | | _ | 15 | _ | TCL <sub>Lmin</sub> - 10 | ns | | Address valid after PSEN | $t_{PXAV}^{*)}$ | 20 | _ | TCL <sub>Lmin</sub> – 5 | _ | ns | | Address to valid instruction in | t <sub>AVIV</sub> | _ | 95 | _ | 2 CLP +<br>TCL <sub>Hmin</sub> – 55 | ns | | Address float to PSEN | t <sub>AZPL</sub> | - 5 | _ | <b>-</b> 5 | _ | ns | <sup>1)</sup> Interfacing the C505L to devices with float times up to 20 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers. # AC Characteristics (16 MHz, 0.4 to 0.6 Duty Cycle) (cont'd) # **External Data Memory Characteristics** | Parameter | Symbol | Limit Values | | | | | |-----------------------------|--------------------|------------------------------------------|------|-------------------------------------|-------------------------------------|----| | | | 16-MHz clock<br>Duty Cycle<br>0.4 to 0.6 | | Variab<br>1/CLP= 2 M | | | | | | min. | max. | min. | max. | | | RD pulse width | $t_{RLRH}$ | 158 | _ | 3 CLP - 30 | _ | ns | | WR pulse width | t <sub>WLWH</sub> | 158 | _ | 3 CLP - 30 | _ | ns | | Address hold after ALE | t <sub>LLAX2</sub> | 48 | _ | CLP – 15 | _ | ns | | RD to valid data in | $t_{RLDV}$ | _ | 100 | - | 2 CLP +<br>TCL <sub>Hmin</sub> - 50 | ns | | Data hold after RD | $t_{RHDX}$ | 0 | _ | 0 | _ | ns | | Data float after RD | $t_{RHDZ}$ | _ | 51 | _ | CLP – 12 | ns | | ALE to valid data in | $t_{LLDV}$ | _ | 200 | _ | 4 CLP – 50 | ns | | Address to valid data in | $t_{AVDV}$ | _ | 200 | _ | 4 CLP +<br>TCL <sub>Hmin</sub> – 75 | ns | | ALE to WR or RD | $t_{LLWL}$ | 73 | 103 | CLP +<br>TCL <sub>Lmin</sub> - 15 | CLP+<br>TCL <sub>Lmin</sub> + 15 | ns | | Address valid to WR | t <sub>AVWL</sub> | 95 | _ | 2 CLP – 30 | _ | ns | | WR or RD high to ALE high | t <sub>WHLH</sub> | 10 | 40 | TCL <sub>Hmin</sub> – 15 | TCL <sub>Hmin</sub> + 15 | ns | | Data valid to WR transition | $t_{QVWX}$ | 5 | _ | TCL <sub>Lmin</sub> – 20 | _ | ns | | Data setup before WR | t <sub>QVWH</sub> | 163 | _ | 3 CLP +<br>TCL <sub>Lmin</sub> - 50 | _ | ns | | Data hold after WR | t <sub>WHQX</sub> | 5 | _ | TCL <sub>Hmin</sub> – 20 | _ | ns | | Address float after RD | $t_{RLAZ}$ | _ | 0 | _ | 0 | ns | # AC Characteristics (16 MHz, 0.4 to 0.6 Duty Cycle) (cont'd) ## **External Clock Drive Characteristics** | Parameter | Symbol | | k = 16 MHz<br>le 0.4 to 0.6 | Variable (<br>1/CLP = 2 | Unit | | |-----------------------|------------------|------|-----------------------------|-------------------------|------------------------|----| | | | min. | max. | min. | max. | | | Oscillator period | CLP | 62.5 | 62.5 | 62.5 | 500 | ns | | High time | TCL <sub>H</sub> | 25 | _ | 25 | CLP - TCL <sub>L</sub> | ns | | Low time | TCLL | 25 | _ | 25 | CLP - TCL <sub>H</sub> | ns | | Rise time | $t_{R}$ | _ | 10 | _ | 10 | ns | | Fall time | $t_{F}$ | _ | 10 | _ | 10 | ns | | Oscillator duty cycle | DC | 0.4 | 0.6 | 25 / CLP | 1 – 25 / CLP | _ | | Clock cycle | TCL | 25 | 37.5 | $CLP \times DC_{min}$ | $CLP \times DC_{max}$ | ns | Note: The 16 MHz values in the tables are given as an example for a typical duty cycle variation of the oscillator clock from 0.4 to 0.6. # AC Characteristics (20 MHz, 0.5 Duty Cycle) (Operating Conditions apply) $C_{\rm L}$ for port 0, ALE and $\overline{\rm PSEN}$ outputs = 100 pF; $C_{\rm L}$ for all other outputs = 80 pF) ## **Program Memory Characteristics** | Parameter | Symbol | Limit Values | | | | Unit | |------------------------------------|------------------------|--------------------------------|------|-------------------------------------------|-----------------|------| | | | 20 MHz clock<br>0.5 Duty Cycle | | Variable Clock<br>1/CLP = 2 MHz to 20 MHz | | | | | | min. | max. | min. | max. | | | ALE pulse width | t <sub>LHLL</sub> | 35 | _ | CLP – 15 | _ | ns | | Address setup to ALE | t <sub>AVLL</sub> | 10 | _ | CLP/2 - 15 | _ | ns | | Address hold after ALE | t <sub>LLAX</sub> | 10 | _ | CLP/2 - 15 | _ | ns | | ALE to valid instruction in | t <sub>LLIV</sub> | _ | 55 | _ | 2 CLP – 45 | ns | | ALE to PSEN | t <sub>LLPL</sub> | 10 | _ | CLP/2 - 15 | _ | ns | | PSEN pulse width | $t_{PLPH}$ | 60 | _ | 3/2 CLP<br>- 15 | _ | ns | | PSEN to valid instruction in | $t_{PLIV}$ | _ | 25 | _ | 3/2 CLP<br>- 50 | ns | | Input instruction hold after PSEN | $t_{PXIX}$ | 0 | _ | 0 | _ | ns | | Input instruction float after PSEN | $t_{PXIZ^{*)}}$ | _ | 20 | _ | CLP/2 - 5 | ns | | Address valid after PSEN | $t_{PXAV^{^{\star})}}$ | 20 | _ | CLP/2 - 5 | _ | ns | | Address to valid instruction in | t <sub>AVIV</sub> | _ | 65 | _ | 5/2 CLP<br>- 60 | ns | | Address float to PSEN | t <sub>AZPL</sub> | - 5 | _ | -5 | _ | ns | <sup>&</sup>quot;) Interfacing the C505L to devices with float times up to 20 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers. ## AC Characteristics (20 MHz, 0.5 Duty Cycle) (cont'd) ### **External Data Memory Characteristics** | Parameter | Symbol | Limit Values | | | | | |-----------------------------|--------------------|--------------------------------|------|-------------------------------------------|--------------|----| | | | 20 MHz clock<br>0.5 Duty Cycle | | Variable Clock<br>1/CLP = 2 MHz to 20 MHz | | | | | | min. | max. | min. | max. | | | RD pulse width | $t_{RLRH}$ | 120 | _ | 3 CLP – 30 | _ | ns | | WR pulse width | t <sub>WLWH</sub> | 120 | _ | 3 CLP – 30 | _ | ns | | Address hold after ALE | t <sub>LLAX2</sub> | 35 | _ | CLP – 15 | _ | ns | | RD to valid data in | $t_{RLDV}$ | _ | 75 | _ | 5/2 CLP- 50 | ns | | Data hold after RD | $t_{RHDX}$ | 0 | _ | 0 | _ | ns | | Data float after RD | $t_{RHDZ}$ | _ | 38 | _ | CLP – 12 | ns | | ALE to valid data in | $t_{LLDV}$ | _ | 150 | _ | 4 CLP – 50 | ns | | Address to valid data in | $t_{AVDV}$ | _ | 150 | _ | 9/2 CLP – 75 | ns | | ALE to WR or RD | $t_{LLWL}$ | 60 | 90 | 3/2 CLP – 15 | 3/2 CLP + 15 | ns | | Address valid to WR | t <sub>AVWL</sub> | 70 | _ | 2 CLP – 30 | _ | ns | | WR or RD high to ALE high | t <sub>WHLH</sub> | 10 | 40 | CLP/2 - 15 | CLP/2 + 15 | ns | | Data valid to WR transition | $t_{QVWX}$ | 5 | _ | CLP/2 - 20 | _ | ns | | Data setup before WR | $t_{QVWH}$ | 125 | _ | 7/2 CLP – 50 | _ | ns | | Data hold after WR | $t_{WHQX}$ | 5 | _ | CLP/2 - 20 | _ | ns | | Address float after RD | $t_{RLAZ}$ | _ | 0 | _ | 0 | ns | ### **External Clock Drive Characteristics** | Symbol | | Unit | | |------------------|---------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|----| | | | | | | | min. | max. | | | CLP | 50 | 500 | ns | | TCL <sub>H</sub> | 15 | CLP - TCL <sub>L</sub> | ns | | TCLL | 15 | CLP - TCL <sub>H</sub> | ns | | $t_{R}$ | _ | 10 | ns | | $t_{F}$ | _ | 10 | ns | | DC | 0.5 | 0.5 | _ | | | CLP TCL <sub>H</sub> TCL <sub>L</sub> t <sub>R</sub> t <sub>F</sub> | V Freq. 5 min. CLP 50 TCL <sub>H</sub> 15 TCL <sub>L</sub> 15 t <sub>R</sub> - t <sub>F</sub> - | | Figure 30 Program Memory Read Cycle Figure 31 Data Memory Read Cycle Figure 32 Data Memory Write Cycle Figure 33 External Clock Drive on XTAL1 # **AC Characteristics of Programming Mode** $V_{\rm DD}$ = 5 V $\,$ 10 %; $V_{\rm PP}$ = 11.5 V $\,$ 5 %; $T_{\rm A}$ = 25 °C $\pm$ 10 °C | Parameter | Symbol | L | Unit | | |----------------------------------------------------|-------------------|------|------|----| | | | min. | max. | | | PALE pulse width | $t_{PAW}$ | 35 | _ | ns | | PMSEL setup to PALE rising edge | $t_{PMS}$ | 10 | _ | _ | | Address setup to PALE, PROG, or PRD falling edge | $t_{PAS}$ | 10 | - | ns | | Address hold after PALE, PROG, or PRD falling edge | $t_{PAH}$ | 10 | - | ns | | Address, data setup to PROG or PRD | $t_{PCS}$ | 100 | _ | ns | | Address, data hold after PROG or PRD | $t_{PCH}$ | 0 | _ | ns | | PMSEL setup to PROG or PRD | $t_{PMS}$ | 10 | _ | ns | | PMSEL hold after PROG or PRD | $t_{PMH}$ | 10 | _ | ns | | PROG pulse width | $t_{\sf PWW}$ | 100 | _ | μs | | PRD pulse width | $t_{PRW}$ | 100 | _ | ns | | Address to valid data out | $t_{PAD}$ | _ | 75 | ns | | PRD to valid data out | $t_{PRD}$ | _ | 20 | ns | | Data hold after PRD | $t_{PDH}$ | 0 | _ | ns | | Data float after PRD | $t_{PDF}$ | _ | 20 | ns | | PROG high between two consecutive PROG low pulses | t <sub>PWH1</sub> | 1 | - | μs | | PRD high between two consecutive PRD low pulses | t <sub>PWH2</sub> | 100 | - | ns | | XTAL clock period | t <sub>CLKP</sub> | 83.3 | 500 | ns | Figure 34 Programming Code Byte - Write Cycle Timing Figure 35 Verify Code Byte - Read Cycle Timing Figure 36 Lock Bit Access Timing Figure 37 Version Byte Read Timing #### **OTP Verification Mode Characteristics** Note: ALE pin described below is the pin 45. | Parameter | Symbol | Limit Values | | | Unit | |-----------------------|------------------|--------------|------------------|-------|------| | | | min. | typ. | max. | | | ALE pulse width | $t_{AWD}$ | _ | CLP | _ | ns | | ALE period | t <sub>ACY</sub> | _ | 6 CLP | _ | ns | | Data valid after ALE | $t_{DVA}$ | _ | _ | 2 CLP | ns | | Data stable after ALE | $t_{DSA}$ | 4 CLP | _ | _ | ns | | P3.5 setup to ALE low | t <sub>AS</sub> | _ | TCL <sub>H</sub> | _ | ns | | Oscillator frequency | 1/ CLP | 4 | _ | 6 | MHz | Figure 38 OTP Verification Mode Note: This mode cannot be entered if OTP protection levels of 1 to 3 are programmed. AC Inputs during testing are driven at $V_{\rm DD}$ – 0.5 V for a logic '1' and 0.45 V for a logic '0'. Timing measurements are made at $V_{\rm IHmin}$ for a logic '1' and $V_{\rm ILmax}$ for a logic '0'. Figure 39 AC Testing: Input, Output Waveforms For timing purposes a port pin is no longer floating when a 100 mV change from load voltage occurs and begins to float when a 100 mV change from the loaded $V_{\rm OH}/V_{\rm OL}$ level occurs. $I_{\rm OL}/I_{\rm OH} \ge \pm$ 20 mA Figure 40 AC Testing: Float Waveforms Figure 41 Recommended Oscillator Circuits for Crystal Oscillator at XTAL1 Figure 42 Recommended Oscillator Circuits for Real-Time Clock Oscillator at XTAL3 The recommended oscillator circuitry for the Real-Time Clock oscillator configuration using a crystal oscillator of 32.768 KHz. Figure 43 P-MQFP-80-1 Package Outline #### **Sorts of Packing** Package outlines for tubes, trays etc. are contained in our Data Book "Package Information" SMD = Surface Mounted Device Dimensions in mm