Data Sheet, Feb. 2003

## C515C <br> 8-Bit Single-Chip Microcontroller

## Microcontrollers

Infineon
technologies

## Edition 2003-02

Published by Infineon Technologies AG,
St.-Martin-Strasse 53,
81669 München, Germany
© Infineon Technologies AG 2003.
All Rights Reserved.

## Attention please!

The information herein is given to describe certain components and shall not be considered as a guarantee of 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.

## 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 (www.infineon.com).

## 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.

## C515C

8-Bit Single-Chip Microcontroller

## C515C Data Sheet

| Revision History: | 2003-02 |  |
| :--- | :--- | :---: |
| Previous Version: | 2000-08 |  |
| Page | Subjects (major changes since last revision) |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |

Enhanced Hooks Technology ${ }^{\text {TM }}$ is a trademark of Infineon Technologies.

## We Listen to Your Comments

Any information within this document that you feel is wrong, unclear or missing at all? Your feedback will help us to continuously improve the quality of this document. Please send your proposal (including a reference to this document) to: mcdocu.comments@infineon.com


## Features

- Full upward compatibility with SAB 80C515A
- On-chip program memory (with optional memory protection)
- C515C-8R 64 Kbytes on-chip ROM
- C515C-8E 64 Kbytes on-chip OTP
- alternatively up to 64 Kbytes external program memory
- 256 bytes on-chip RAM
- 2 Kbytes of on-chip XRAM
- Up to 64 Kbytes external data memory
- Superset of the 8051 architecture with 8 datapointers
- Up to 10 MHz external operating frequency ( $1 \mu \mathrm{~s}$ instruction cycle time at 6 MHz external clock)
- On-chip emulation support logic (Enhanced Hooks Technology)
- Current optimized oscillator circuit and EMI optimized design
(further features are on next page)


Figure $1 \quad$ C515C Functional Units

- Eight ports: $48+1$ digital I/O lines, 8 analog inputs
- Quasi-bidirectional port structure (8051 compatible)
- Port 5 selectable for bidirectional port structure (CMOS voltage levels)
- Full-CAN controller on-chip
- 256 register/data bytes are located in external data memory area
- max. 1 MBaud at $8-10 \mathrm{MHz}$ operating frequency
- Three 16-bit timer/counters
- Timer 2 can be used for compare/capture functions
- 10-bit A/D converter with multiplexed inputs and built-in self calibration
- Full duplex serial interface with programmable baudrate generator (USART)
- SSC synchronous serial interface (SPI compatible)
- Master and slave capable
- Programmable clock polarity/clock-edge to data phase relation
- LSB/MSB first selectable
- 2.5 MHz transfer rate at 10 MHz operating frequency
- Seventeen interrupt vectors, at four priority levels selectable
- Extended watchdog facilities
- 15-bit programmable watchdog timer
- Oscillator watchdog
- Power saving modes
- Slow-down mode
- Idle mode (can be combined with slow-down mode)
- Software power-down mode with wake-up capability through $\overline{\text { INTO }}$ or RXDC pin
- Hardware power-down mode
- CPU running condition output pin
- ALE can be switched off
- Multiple separate $V_{\mathrm{DD}} / V_{\mathrm{SS}}$ pin pairs
- P-MQFP-80-1 package
- Temperature Ranges:

SAB-C515C versions: $T_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}$
SAF-C515C versions: $T_{\mathrm{A}}=-40$ to $85^{\circ} \mathrm{C}$
SAH-C515C versions: $T_{\mathrm{A}}=-40$ to $110^{\circ} \mathrm{C}$
Note: Versions for extended temperature range $-40^{\circ} \mathrm{C}$ to $110^{\circ} \mathrm{C}(\mathrm{SAH}-\mathrm{C} 515 \mathrm{C})$ are available on request.

The C515C is an enhanced, upgraded version of the SAB 80C515A 8-bit microcontroller which additionally provides a full CAN interface, a SPI compatible synchronous serial interface, extended power save provisions, additional on-chip RAM, 64K of on-chip program memory, two new external interrupts and RFI related improvements. With a maximum external clock rate of 10 MHz it achieves a 600 ns instruction cycle time ( $1 \mu \mathrm{~s}$ at 6 MHz ).

The C515C-8R contains a non-volatile 64 Kbytes read-only program memory. The C515C-L is identical to the C515C-8R, except that it lacks the on-chip program memory. The C515C-8E is the OTP version in the C515C microcontroller with an on-chip 64 Kbytes one-time programmable (OTP) program memory. The C515C is mounted in a P-MQFP-80-1 package.
If compared to the C515C-8R and C515C-L, the C515C-8E OTP version additionally provides two features:

- The wake-up from software power down mode can, additionally to the external pin P3.2/INTO wake-up capability, also be triggered alternatively by a second pin P4.7/RXDC.
- For power consumption reasons the on-chip CAN controller can be switched off.

Table 1 Differences in Internal Program Memory of the C505 MCUs

| Device | Internal Program Memory |  |
| :--- | :--- | :--- |
|  | ROM | OTP |
| C515C-LM | - | - |
| C515C-8RM | 64 Kbytes | - |
| C515C-8EM | - | 64 Kbytes |

Note: The term C515C refers to all versions described within this document unless otherwise noted.

## 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 C515C please refer to the "Product information Microcontrollers", which summarizes all available microcontroller variants.
Note: The ordering codes for the Mask-ROM versions are defined for each product after verification of the respective ROM code.


Figure 2 Logic Symbol


Figure 3 C515C Pin Configuration P-MQFP-80-1 (top view)

## Table 2 Pin Definitions and Functions

| Symbol | Pin Number | I/O ${ }^{1)}$ | Function |
| :---: | :---: | :---: | :---: |
|  | P-MQFP-80-1 |  |  |
| ¢RESET | 1 | I | RESET <br> A low level on this pin for the duration of two machine cycles while the oscillator is running resets the C515C. A small internal pullup resistor permits power-on reset using only a capacitor connected to $V_{\mathrm{SS}}$. |
| $V_{\text {AREF }}$ | 3 | - | Reference voltage for the A/D converter |
| $V_{\text {AGND }}$ | 4 | - | Reference ground for the A/D converter |
| P6.0-P6.7 | 12-5 | 1 | Port 6 is an 8-bit unidirectional input port to the A/D converter. Port pins can be used for digital input, if voltage levels simultaneously meet the specifications high/low input voltages and for the eight multiplexed analog inputs. |
| $\overline{\text { P7.0 / } \overline{\text { INT7 }}}$ | 23 | I/O | Port 7 <br> is an 1-bit quasi-bidirectional I/O port with internal pull-up resistor. When a 1 is written to P 7.0 it is pulled high by an internal pull-up resistor, and in that state can be used as input. As input, P7.0 being externally pulled low will source current ( $I_{\mathrm{IL}}$, in the DC characteristics) because of the internal pull-up resistor. If P7.0 is used as interrupt input, its output latch must be programmed to a one (1). The secondary function is assigned to the port 7 pin as follows: <br> P7.0 $\overline{\text { NT7 }}$, Interrupt 7 input |

Table 2 Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | 1/0 ${ }^{1)}$ | Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | P-MQFP-80-1 |  |  |  |  |
| P3.0-P3.7 | 15-22 | I/O | Port 3 <br> is an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 3 pins that have 1 's written to them are pulled high by the internal pullup resistors, and in that state can be used as inputs. As inputs, port 3 pins being externally pulled low will source current ( $I_{\mathrm{IL}}$, in the DC characteristics) because of the internal pullup resistors. Port 3 also contains the interrupt, timer, serial port and external memory strobe pins that are used by various options. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. The secondary functions are assigned to the pins of port 3 , as follows: |  |  |
|  | 15 |  | P3.0 | RXD | Receiver data input (asynch.) or data input/output (synch.) of serial interface |
|  | 16 |  | P3. 1 | TXD | Transmitter data output (asynch.) or clock output (synch.) of serial interface |
|  | 17 |  | P3.2 | $\overline{\text { INTO }}$ | External interrupt 0 input / timer 0 gate control input |
|  | 18 |  | P3.3 | $\overline{\text { INT1 }}$ | External interrupt 1 input / timer 1 gate control input |
|  | 19 |  | P3. 4 | T0 | Timer 0 counter input |
|  | 20 |  | P3. 5 | T1 | Timer 1 counter input |
|  | 21 |  | P3.6 | $\overline{W R}$ | $\overline{W R}$ control output; latches the data byte from port 0 into the external data memory |
|  | 22 |  | P3.7 | $\overline{\mathrm{RD}}$ | $\overline{\mathrm{RD}}$ control output; enables the external data memory |

Table 2 Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | I/O ${ }^{1 /}$ | Function |
| :---: | :---: | :---: | :---: |
|  | P-MQFP-80-1 |  |  |
| P1.0-P1.7 | $31-24$ <br> 31 <br> 30 <br> 29 <br> 28 <br> 27 <br> 26 <br> 25 <br> 24 | I/O | Port 1 <br> is an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 1 pins that have 1's written to them are pulled high by the internal pullup resistors, and in that state can be used as inputs. As inputs, port 1 pins being externally pulled low will source current ( $I_{\mathrm{LL}}$, in the DC characteristics) because of the internal pullup resistors. The port is used for the low-order address byte during program verification. Port 1 also contains the interrupt, timer, clock, capture and compare pins that are used by various options. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate (except when used for the compare functions). The secondary functions are assigned to the port 1 pins as follows: <br> P1.0 $\overline{\text { INT3 }}$ CC0 Interrupt 3 input / compare 0 output / capture 0 input <br> P1.1 INT4 CC1 Interrupt 4 input/ compare 1 output / capture 1 input <br> P1.2 INT5 CC2 Interrupt 5 input/ compare 2 output / capture 2 input <br> P1.3 INT6 CC3 Interrupt 6 input/ compare 3 output / capture 3 input <br> P1.4 $\overline{\text { NT2 } 2 ~ I n t e r r u p t ~} 2$ input <br> P1.5 T2EX Timer 2 external reload / trigger input <br> P1.6 CLKOUT System clock output <br> P1.7 T2 Counter 2 input |
| XTAL2 | 36 | I | XTAL2 <br> Input to the inverting oscillator amplifier and input to the internal clock generator circuits. <br> To drive the device from an external clock source, XTAL2 should be driven, while XTAL1 is left unconnected. Minimum and maximum high and low times as well as rise/fall times specified in the AC characteristics must be observed. |

Table 2 Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | $1 / O^{1)}$ | Function |
| :---: | :---: | :---: | :---: |
|  | P-MQFP-80-1 |  |  |
| XTAL1 | 37 | 0 | XTAL1 <br> Output of the inverting oscillator amplifier. |
| P2.0-P2.7 | 38-45 | I/O | Port 2 <br> is an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 2 pins that have 1's 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_{\mathrm{IL}}$, in the DC characteristics) because of the internal pullup resistors. <br> 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 resistors when issuing 1 's. During accesses to external data memory that use 8-bit addresses (MOVX @Ri), port 2 issues the contents of the P2 special function register. |
| $\overline{\overline{C P U R}}$ | 46 | 0 | CPU Running Condition <br> This output pin is at low level when the CPU is running and program fetches or data accesses in the external data memory area are executed. In idle mode, hardware and software power down mode, and with an active RESET signal CPUR is set to high level. <br> $\overline{\text { CPUR }}$ can be typically used for switching external memory devices into power saving modes. |
| $\overline{\overline{P S E N}}$ | 47 | 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 six oscillator periods, except during external data memory accesses. The signal remains high during internal program execution. |

Table 2 Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | I/O ${ }^{1)}$ | Function |
| :---: | :---: | :---: | :---: |
|  | P-MQFP-80-1 |  |  |
| ALE | 48 | 0 | The Address Latch Enable output is used for latching the address into external memory during normal operation. It is activated every six oscillator periods, except during an external data memory access. ALE can be switched off when the program is executed internally. |
| $\overline{\overline{E A}}$ | 49 | I | External Access Enable <br> When held high, the C515C executes instructions always from the internal ROM. When held low, the C515C fetches all instructions from external program memory. <br> Note: For the ROM protection version $\overline{E A}$ pin is latched during reset. |
| P0.0-P0.7 | 52-59 | I/O | Port 0 <br> is an 8-bit open-drain bidirectional I/O port. Port 0 pins that have 1 's written to them float, and in that state can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external program and data memory. In this application it uses strong internal pullup resistors when issuing 1's. Port 0 also outputs the code bytes during program verification in the C515C. External pullup resistors are required during program verification. |
| P5.0-P5.7 | 67-60 | I/O | Port 5 <br> is an 8-bit quasi-bidirectional I/O port with internal pullup resistors. Port 5 pins that have 1 's written to them are pulled high by the internal pullup resistors, and in that state can be used as inputs. As inputs, port 5 pins being externally pulled low will source current ( $I_{\mathrm{IL}}$, in the DC characteristics) because of the internal pullup resistors. <br> Port 5 can also be switched into a bidirectional mode, in which CMOS levels are provided. In this bidirectional mode, each port 5 pin can be programmed individually as input or output. |

Table 2 Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | I/O ${ }^{1)}$ | Function |
| :---: | :---: | :---: | :---: |
|  | P-MQFP-80-1 |  |  |
| $\overline{\overline{\text { HWPD }}}$ | 69 | I | Hardware Power Down <br> A low level on this pin for the duration of one machine cycle while the oscillator is running resets the C515C. <br> A low level for a longer period will force the part to power down mode with the pins floating. |
| P4.0-P4.7 | 72-74, 76-80 | I/O | Port 4 <br> is an 8-bit quasi-bidirectional I/O port with internal pull-up resistors. Port 4 pins that have 1's written to them are pulled high by the internal pull-up resistors, and in that state can be used as inputs. As inputs, port 4 pins being externally pulled low will source current ( $I_{\mathrm{IL}}$, in the DC characteristics) because of the internal pull-up resistors. <br> P4 also contains the external A/D converter control pin, the SSC pins, the CAN controller input/output lines, and the external interrupt 8 input. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. The alternate functions are assigned to port 4 as follows: <br> P4.0 ADST External A/D converter start pin <br> P4.1 SCLK SSC Master Clock Output / <br> SSC Slave Clock Input <br> P4.2 SRI SSC Receive Input <br> P4.3 STO SSC Transmit Output <br> P4.4 SLS Slave Select Input <br> P4.5 INT8 External interrupt 8 input <br> P4.6 TXDC Transmitter output of the CAN controller <br> P4.7 RXDC Receiver input of the CAN controller |
|  | 72 |  |  |
|  | 73 |  |  |
|  | 74 |  |  |
|  | 76 |  |  |
|  | 77 |  |  |
|  | 78 |  |  |
|  | 79 |  |  |
|  | 80 |  |  |

Table 2 Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | I/O | Function |
| :--- | :--- | :--- | :--- |
|  | P-MQFP-80-1 |  | I |
| PE/SWD | 75 |  | Power saving mode enable / Start watchdog <br> timer <br> A low level on this pin allows the software to enter <br> the power down, idle and slow down mode. In case <br> the low level is also seen during reset, the watchdog <br> timer function is off on default. <br> Use of the software controlled power saving modes <br> is blocked, when this pin is held on high level. A high <br> level during reset performs an automatic start of the <br> watchdog timer immediately after reset. When left <br> unconnected this pin is pulled high by a weak <br> internal pull-up resistor. |
| $V_{\text {SSCLK }}$ | 13 | - | Ground (0 V) for on-chip oscillator <br> This pin is used for ground connection of the on-chip <br> oscillator circuit. |
| $V_{\text {DDCLK }}$ | 14 | - | Supply voltage for on-chip oscillator <br> This pin is used for power supply of the on-chip <br> oscillator circuit. |
| $V_{\text {DDE1 }}$ | 32 | - | Supply voltage for I/O ports <br> These pins are used for power supply of the I/O <br> ports during normal, idle, and power down mode. |
| $V_{\text {DDE2 }}$ | 68 | - | Ground (0 V) for I/O ports <br> These pins are used for ground connections of the <br> I/O ports during normal, idle, and power down <br> mode. |
| $V_{\text {SSE1 }}$ | 35 <br> 70 | - | Supply voltage for internal logic <br> This pins is used for the power supply of the internal <br> logic circuits during normal, idle, and power down <br> mode. |
| $V_{\text {SSE2 }}$ | 33 | - | Ground (0 V) for internal logic <br> This pin is used for the ground connection of the <br> internal logic circuits during normal, idle, and power <br> down mode. |
| $V_{\text {DD1 }}$ | 34 |  |  |

Table 2 Pin Definitions and Functions (cont'd)

| Symbol | Pin Number | I/O ${ }^{1)}$ | Function |
| :---: | :---: | :---: | :---: |
|  | P-MQFP-80-1 |  |  |
| $\overline{V_{\text {DDEXT }}}$ | 50 | - | Supply voltage for external access pins <br> This pin is used for power supply of the I/O ports and control signals which are used during external accesses (for Port 0, Port 2, ALE, PSEN, P3.6/WR, and P3.7/(̄D). |
| $V_{\text {SSEXT }}$ | 51 | - | Ground ( O V) for external access pins This pin is used for the ground connection of the I/O ports and control signals which are used during external accesses (for Port 0, Port 2, ALE, PSEN, P3.6/WR, and P3.7/ $\overline{\mathrm{RD}}$ ). |
| N.C. | 2, 71 | - | Not connected <br> These pins should not be connected. |

1) $I=$ Input; $O=$ Output

C515C


Figure 4 Block Diagram of the C515C

## CPU

The C515C 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 6 MHz crystal, $58 \%$ of the instructions are executed in $1 \mu \mathrm{~s}$ ( 10 MHz : 600 ns ).

## PSW

Special Function Register
Reset Value: $\mathbf{0 0}_{\mathbf{H}}$ Bit No. MSB LSB


| Bit | Function |  |  |
| :---: | :---: | :---: | :---: |
| CY | Carry Flag Used by arithmetic instruction. |  |  |
| AC | Auxiliary Carry Flag Used by instructions which execute BCD operations. |  |  |
| F0 | General Purpose Flag |  |  |
| $\begin{aligned} & \text { RS1 } \\ & \text { RSO } \end{aligned}$ | Register Bank select control bits These bits are used to select one of the four register banks. |  |  |
|  | RS1 | RSO | Function |
|  | 0 | 0 | Bank 0 selected, data address $00^{-}-07_{\mathrm{H}}$ |
|  | 0 | 1 | Bank 1 selected, data address $08_{\mathrm{H}}-0 \mathrm{~F}_{\mathrm{H}}$ |
|  | 1 | 0 | Bank 2 selected, data address $10^{-17}{ }^{-17}$ |
|  | 1 | 1 | Bank 3 selected, data address $18^{-1} \mathrm{~F}_{\mathrm{H}}$ |
| OV | Overflow Flag Used by arithmetic instruction. |  |  |
| F1 | General Purpose Flag |  |  |
| P | Parity Flag <br> 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 C515C CPU manipulates data and operands in the following five address spaces:

- up to 64 Kbytes of internal/external program memory
- up to 64 Kbytes of external data memory
- 256 bytes of internal data memory
- 256 bytes CAN controller registers / data memory
- 2 Kbytes of internal XRAM data memory
- a 128 byte special function register area

Figure 5 illustrates the memory address spaces of the C515C.


Figure $5 \quad$ C515C Memory Map

## Control of XRAM/CAN Controller Access

The XRAM in the C515C is a memory area that is logically located at the upper end of the external memory space, but is integrated on the chip. Because the XRAM and the CAN controller is used in the same way as external data memory the same instruction types (MOVX) must be used for accessing the XRAM. Two bits in SFR SYSCON, XMAPO and XMAP1, control the accesses to the XRAM and the CAN controller.

## SYSCON

Special Function Register


| Bit No. | MSB |  | 5 | 4 | 3 | 2 | LSB |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 |  |  |  |  | 1 | 0 |  |
| $\mathrm{B1}_{\mathrm{H}}$ | - | PMOD | EALE | RMAP | - | CSWO | XMAP1 | XMAPO | SYSCON |

The function of the shaded bits is not described in this section.

| Bit | Function |
| :---: | :---: |
| XMAP1 | XRAM/CAN controller visible access control Control bit for $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ signals during XRAM/CAN Controller accesses. If addresses are outside the XRAM/CAN controller address range or if XRAM is disabled, this bit has no effect. XMAP1 $=0$ : The signals $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ are not activated during accesses to the XRAM/CAN Controller <br> XMAP1 $=1$ : Ports 0,2 and the signals $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ are activated during accesses to XRAM/CAN Controller. In this mode, address and data information during XRAM/CAN Controller accesses are visible externally. |
| XMAP0 | Global XRAM/CAN controller access enable/disable control XMAPO $=0$ : The access to XRAM and CAN controller is enabled. XMAPO $=1$ : The access to XRAM and CAN controller is disabled (default after reset). All MOVX accesses are performed via the external bus. Further, this bit is hardware protected. |

Bit XMAPO is hardware protected. If it is reset once (XRAM/CAN controller access enabled) it cannot be set by software. Only a reset operation will set the XMAPO bit again.

The XRAM/CAN controller can be accessed by read/write instructions (MOVX A,DPTR, MOVX @ DPTR,A), which use the 16 -bit DPTR for indirect addressing. For accessing the XRAM or CAN controller, the effective address stored in DPTR must be in the range of $\mathrm{F}^{700_{\mathrm{H}}}$ to $\mathrm{FFFF}_{\mathrm{H}}$.
The XRAM can be also accessed by read/write instructions (MOVX A,@Ri, MOVX @ Ri,A), which use only an 8-bit address (indirect addressing with registers RO or R1). Therefore, a special page register XPAGE which provides the upper address information (A8-A15) during 8 -bit XRAM accesses. The behaviour of Port 0 and P2 during a MOVX access depends on the control bits XMAPO and XMAP1 in register SYSCON and on the state of pin EA. Table 3 lists the various operating conditions.

Table 3 Behaviour of P0/P2 and $\overline{R D} / \overline{W R}$ During MOVX Accesses

|  |  |  | XMAP1, XMAP0 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 00 | 10 | X1 |
| $\overline{E A}=0$ | MOVX <br> @DPTR | DPTR < XRAM/CAN address range | a) $\mathrm{PO} / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) ext.memory is used | a) $\mathrm{PO} / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{\mathrm{RD}} / \overline{W R}$ active <br> c) ext.memory <br> is used | a) $\mathrm{PO} / \mathrm{P} 2 \rightarrow \mathrm{Bus}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used |
|  |  | DPTR $\geq$ <br> XRAMCAN <br> address range | a) $\mathrm{PO} / \mathrm{P} 2 \rightarrow$ Bus <br> ( $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$-Data) <br> b) $\overline{R D} / \overline{W R}$ inactive <br> c) XRAM is used | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow$ Bus <br> ( $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$-Data) <br> b) $\overline{R D} / \overline{W R}$ active <br> c) XRAM is used | a) $\mathrm{PO} / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) ext.memory is used |
|  | MOVX <br> @ Ri | XPAGE < <br> XRAMCAN <br> addr. page range | a) $\mathrm{PO} \rightarrow \mathrm{Bus}$ $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) ext.memory <br> is used | a) $\mathrm{PO} \rightarrow \mathrm{Bus}$ $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory <br> is used | a) $\mathrm{PO} \rightarrow \mathrm{Bus}$ $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used |
|  |  | XPAGE $\geq$ XRAMCAN addr. page range | a) $\mathrm{PO} \rightarrow \mathrm{Bus}$ <br> ( $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$-Data) $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ inactive <br> c) XRAM is used | a) PO $\rightarrow$ Bus <br> ( $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$-Data only) $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) XRAM is used | a) $\mathrm{PO} \rightarrow \mathrm{Bus}$ P2 $\rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) ext.memory is used |
| $\overline{\overline{E A}}=1$ | MOVX <br> @ DPTR | DPTR < XRAM/CAN address range | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow \mathrm{Bus}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used | a) $\mathrm{PO} / \mathrm{P} 2 \rightarrow \mathrm{Bus}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used | a) $\mathrm{PO} / \mathrm{P} 2 \rightarrow \mathrm{Bus}$ <br> b) $\overline{R D} / W R$ active <br> c) ext.memory is used |
|  |  | DPTR $\geq$ <br> XRAMCAN <br> address range | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow \mathrm{I} / 0$ <br> b) $\overline{R D} / \overline{W R}$ inactive <br> c) XRAM is used | a) $\mathrm{P} 0 / \mathrm{P} 2 \rightarrow \mathrm{Bus}$ ( $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$-Data) <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) XRAM is used | a) $\mathrm{PO} / \mathrm{P} 2 \rightarrow$ Bus <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) ext.memory <br> is used |
|  | MOVX <br> @ Ri | XPAGE < <br> XRAMCAN <br> addr. page range | a) $\mathrm{PO} \rightarrow \mathrm{Bus}$ $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) ext.memory <br> is used | a) $\mathrm{PO} \rightarrow \mathrm{Bus}$ $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) ext.memory is used | a) $\mathrm{PO} \rightarrow \mathrm{Bus}$ $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ active <br> c) ext.memory <br> is used |
|  |  | XPAGE $\geq$ XRAMCAN addr. page range | a) $\mathrm{P} 2 \rightarrow / / \mathrm{O}$ PO/P2 $\rightarrow$ I/O <br> b) $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$ inactive <br> c) XRAM is used | a) $\mathrm{PO} \rightarrow$ Bus ( $\overline{\mathrm{RD}} / \overline{\mathrm{WR}}$-Data) P2 $\rightarrow / / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) XRAM is used | a) $\mathrm{PO} \rightarrow$ Bus $\mathrm{P} 2 \rightarrow \mathrm{I} / \mathrm{O}$ <br> b) $\overline{R D} / \overline{W R}$ active <br> c) ext.memory is used |

## Reset and System Clock

The reset input is an active low 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 pullup resistor is internally connected to $V_{\mathrm{DD}}$ to allow a power-up reset with an external capacitor only. An automatic reset can be obtained when $V_{\mathrm{DD}}$ is applied by connecting the RESET pin to $V_{\mathrm{SS}}$ via a capacitor. Figure 6 shows the possible reset circuitries.


## Figure 6 Reset Circuitries

Figure 7 shows the recommended oscillator circiutries for crystal and external clock operation.


Figure 7 Recommended Oscillator Circuitries

## Multiple Datapointers

As a functional enhancement to the standard 8051 architecture, the C515C 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 8 illustrates the datapointer addressing mechanism.


Figure $8 \quad$ 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 ROM 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, 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 9 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.

## Special Function Registers

The registers, except the program counter and the four general purpose register banks, reside in the special function register area. The special function register area consists of two portions: the standard special function register area and the mapped special function register area. Two special function registers of the C515C (PCON1 and DIR5) are located in the mapped special function register area. For accessing the mapped special function register area, bit RMAP in special function register SYSCON must be set. All other special function registers are located in the standard special function register area which is accessed when RMAP is cleared ("0"). As long as bit RMAP is set, mapped special function register area can be accessed. This bit is not cleared by hardware automatically. Thus, when non-mapped/mapped registers are to be accessed, the bit RMAP must be cleared/set by software, respectively each.
SYSCON
Special Function Register
(B1H) C515C-8R Reset Value: $\mathrm{X010XX01}_{\mathrm{B}}$ C515C-8E Reset Value: X010X001B

| Bit No. | MSB |  |  |  |  |  |  | LSB |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| ${ }^{B 1} \mathrm{H}$ | - | PMOD | EALE | RMAP | - | CSWO | XMAP1 | XMAPO | SYSCON |

The function of the shaded bits is not described in this section.

| Bit | Function |
| :--- | :--- |
| RMAP | Special function register map bit <br> RMAP $=0:$The access to the non-mapped (standard) special <br> function register area is enabled (reset value). <br> RMAP $=1:$The access to the mapped special function register <br> area is enabled. |

The 59 special function registers (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 C515C are listed in Table 4 and Table 5. In Table 4 they are organized in groups which refer to the functional blocks of the C515C. The CANSFRs are also included in Table 4. Table 5 illustrates the contents of the SFRs in numeric order of their addresses. Table 6 list the CAN-SFRs in numeric order of their addresses.

Table 4 Special Function Registers - Functional Block

| Block | Symbol | Name | Addr | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CPU}}$ | ACC <br> B <br> DPH <br> DPL <br> DPSEL <br> PSW <br> SP <br> SYSCON ${ }^{1)}$ | Accumulator <br> B-Register <br> Data Pointer, High Byte <br> Data Pointer, Low Byte <br> Data Pointer Select Register <br> Program Status Word Register <br> Stack Pointer <br> $\begin{array}{ll}\text { System Control Register } & \text { C515C-8R } \\ \text { C515C-8E }\end{array}$ | $\begin{array}{\|l} \hline \mathrm{EO}_{\mathrm{H}_{2}}^{2)} \\ \mathrm{FO}_{\mathrm{H}}{ }^{2} \\ 83_{\mathrm{H}} \\ 82_{\mathrm{H}} \\ 92_{\mathrm{H}} \\ \mathrm{D} 0_{\mathrm{H}}{ }^{2)} \\ 81_{\mathrm{H}} \\ \mathrm{~B} 1_{\mathrm{H}} \\ \mathrm{~B} 1_{\mathrm{H}} \end{array}$ | $\begin{aligned} & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \mathrm{XXXXX000}{ }_{\mathrm{B}}{ }^{3)} \\ & 00_{\mathrm{H}} \\ & 07_{\mathrm{H}} \\ & \mathrm{X010XX01}{ }_{\mathrm{B}}{ }^{3)} \\ & \mathrm{X010X001}{ }_{\mathrm{B}}{ }^{3} \end{aligned}$ |
| A/DConverter | $\begin{aligned} & \text { ADCON01) } \\ & \text { ADCON1 } \\ & \text { ADDATH } \\ & \text { ADDATL } \end{aligned}$ | A/D Converter Control Register 0 <br> A/D Converter Control Register 1 <br> A/D Converter Data Register High Byte <br> A/D Converter Data Register Low Byte | $\begin{aligned} & \left.\mathbf{D 8}_{\mathrm{H}}{ }^{2}\right) \\ & \mathrm{DC}_{\mathrm{H}} \\ & \mathrm{D} 9_{\mathrm{H}} \\ & \mathrm{DA} \mathrm{~A}_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & 00_{H} \\ & 0 X X X 000_{B}{ }^{3)} \\ & 00_{H} \\ & 00 X X X X X_{B}{ }^{3)} \end{aligned}$ |
| Interrupt System | IENO ${ }^{1)}$ <br> IEN1 ${ }^{1)}$ <br> IEN2 <br> IP0 ${ }^{1)}$ <br> IP1 <br> TCON ${ }^{1)}$ <br> T2CON ${ }^{1)}$ <br> SCON ${ }^{1)}$ <br> IRCON | Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Enable Register 2 Interrupt Priority Register 0 Interrupt Priority Register 1 Timer Control Register <br> Timer 2 Control Register Serial Channel Control Register Interrupt Request Control Register |  | $\begin{aligned} & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \mathrm{XX00X00X}_{B}{ }^{3)} \\ & 00_{\mathrm{H}} \\ & 0 \mathrm{XOOOOOO}_{\mathrm{B}}{ }^{3)} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \hline \end{aligned}$ |
| XRAM | XPAGE <br> SYSCON ${ }^{1)}$ | Page Address Register for Extended on-chip XRAM and CAN Controller System Control Register C515C-8R C515C-8E | $\begin{aligned} & 91_{\mathrm{H}} \\ & \\ & \mathrm{~B} 1_{\mathrm{H}} \\ & \mathrm{~B} 1_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & 00 \mathrm{O}_{\mathrm{H}} \\ & \mathrm{X010XX01}_{\mathrm{B}}{ }^{3)} \\ & \mathrm{X010X001}_{\mathrm{B}}{ }^{3)} \end{aligned}$ |
| Ports | P0 <br> P1 <br> P2 <br> P3 <br> P4 <br> P5 <br> DIR5 <br> P6 <br> P7 <br> SYSCON ${ }^{1)}$ | Port 0 <br> Port 1 <br> Port 2 <br> Port 3 <br> Port 4 <br> Port 5 <br> Port 5 Direction Register <br> Port 6, Analog/Digital Input <br> Port 7 <br> $\begin{array}{ll}\text { System Control Register } & \begin{array}{l}\text { C515C-8R } \\ \text { C515C-8E }\end{array}\end{array}$ |  | $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ <br> $\mathrm{FF}_{\mathrm{H}}$ $\begin{array}{\|l} \text { XXXXXXX1 }_{B}{ }^{3)} \\ \text { X010XX01 }_{\mathrm{B}}{ }^{3} \\ \text { X010X001 }_{3}{ }^{3} \\ \hline \end{array}$ |
| Watchdog | $\begin{array}{\|l} \hline \text { WDTREL } \\ \text { IEN0 }{ }^{1)} \\ \text { IEN1 }{ }^{11} \\ \text { IPO }^{11} \end{array}$ | Watchdog Timer Reload Register Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 | $\begin{aligned} & 86_{\mathrm{H}} \\ & \left.\mathbf{A} \mathbf{H}_{\mathbf{H}} 2\right) \\ & \left.\mathbf{B 8} \mathbf{H}_{2}\right) \\ & \mathrm{A} 9_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \end{aligned}$ |

Table 4 Special Function Registers - Functional Block (cont'd)

| Block | Symbol | Name | Addr | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| Serial <br> Channel | $\begin{aligned} & \text { ADCON01) } \\ & \text { PCON }{ }^{1)} \\ & \text { SBUF } \\ & \text { SCON } \\ & \text { SRELL } \\ & \text { SRELH } \end{aligned}$ | 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 |  | $\begin{aligned} & 00_{H} \\ & 00_{H} \\ & X X_{H}{ }^{3)} \\ & 00_{H} \\ & D 9_{H} \\ & \text { XXXXXX11 }{ }^{3}{ }^{3)} \end{aligned}$ |
| CAN <br> Controller | CR | Control Register | $\mathrm{F}^{7} 70 \mathrm{O}_{\mathrm{H}}$ | 101 |
|  | SR | Status Register | F701H | $\mathrm{XX}{ }^{\text {6 }}{ }^{\text {\% }}$ |
|  | IR | Interrupt Register | $\mathrm{F}^{\mathrm{F}} \mathrm{F}^{\mathrm{H}} \mathrm{H}$ | $\mathrm{XX}^{\text {H }}{ }^{6}$ |
|  | BTR0 | Bit Timing Register Low | F704 ${ }_{\text {H }}$ | $\mathrm{UU}_{\mathrm{H}}{ }^{\text {b }}$ |
|  | BTR1 | Bit Timing Register High | F705 ${ }_{\text {H }}$ | OUUUUUUU ${ }^{6}{ }^{6}$ |
|  | GMS0 | Global Mask Short Register Low | $\mathrm{F}^{\text {7 }}$ 6 ${ }_{\mathrm{H}}$ | $\mathrm{UU}_{\mathrm{H}}{ }^{6}$ |
|  | GMS1 | Global Mask Short Register High | $\mathrm{F}^{\text {7 }}$ 7 ${ }_{\mathrm{H}}$ | UUU11111 ${ }_{B}{ }^{6)}$ |
|  | UGMLO | Upper Global Mask Long Register Low | F708 ${ }_{\mathrm{H}}$ | $U U_{H}{ }^{6)}$ |
|  | UGML1 | Upper Global Mask Long Register High | F709 ${ }_{\mathrm{H}}$ | $U U_{H}{ }^{6}$ |
|  | LGMLO | Lower Global Mask Long Register Low | $\mathrm{F}^{\text {7 }}$ A $\mathrm{H}_{\mathrm{H}}$ | $U U_{H}{ }^{6)}$ |
|  | LGML1 | Lower Global Mask Long Register High | $\mathrm{F}^{\text {7 }} \mathrm{B}_{\mathrm{H}}$ | UUUUU000 ${ }^{6}{ }^{6}$ |
|  | UMLMO | Upper Mask of Last Message Register Low | $\mathrm{F}^{\text {7 }}$ C $\mathrm{H}_{\mathrm{H}}$ | $\mathrm{UU}_{\mathrm{H}}{ }^{6}$ |
|  | UMLM1 | Upper Mask of Last Message Register High | F70D ${ }_{\text {H }}$ | $\mathrm{UU}_{\mathrm{H}}{ }^{6}$ |
|  | LMLMO | Lower Mask of Last Message Register Low | F70E ${ }_{\text {H }}$ | $\mathrm{UU}_{\mathrm{H}}{ }^{6}$ |
|  | LMLM1 | Lower Mask of Last Message Register High <br> Message Object Registers: | $\mathrm{F}^{\text {7 }}$ ( $\mathrm{F}_{\mathrm{H}}$ | UUUUU000 ${ }^{6}{ }^{6)}$ |
|  | MCRO | Message Control Register Low | $\mathrm{F}_{7 \mathrm{nO}}^{\mathrm{H}}{ }^{5}$ ) | $\mathrm{UU}_{\mathrm{H}^{6}}{ }^{\text {a }}$ |
|  | MCR1 | Message Control Register High | $\mathrm{F} 7 \mathrm{n} 1^{5}{ }^{5}$ | $U U_{H^{6}}{ }^{6}$ |
|  | UARO | Upper Arbitration Register Low | $\mathrm{F}_{2} \mathrm{n}^{2} \mathrm{H}^{5)}$ | $U U_{H}^{6)}$ |
|  | UAR1 | Upper Arbitration Register High | $\mathrm{F}_{7} \mathrm{n}_{\mathrm{H}_{5}{ }^{5}}$ | $U U_{H}^{6)}$ |
|  | LAR0 | Lower Arbitration Register Low | $\mathrm{F} 7 \mathrm{n} 4_{\mathrm{H}}^{5)}$ | $U U_{H}{ }^{6)}$ |
|  | LAR1 | Lower Arbitration Register High | $\mathrm{F} 7 \mathrm{n} 5_{\mathrm{H}}^{5)}$ | UUUUU000 ${ }^{6}{ }^{6}$ |
|  | MCFG | Message Configuration Register | $\mathrm{F}^{2} \mathrm{n}^{-}{ }^{5)}$ | UUUUUU00 ${ }_{B}{ }^{6)}$ |
|  | DB0n | Message Data Byte 0 | $\mathrm{F}_{2} 7_{\mathrm{H}_{\mathrm{E}}^{5}}^{5)}$ | $\mathrm{XX}^{6}{ }^{6}$ |
|  | DB1n | Message Data Byte 1 | $\mathrm{F}_{7} \mathrm{n}_{4}{ }^{5}$ ) | $\mathrm{XX}^{6}{ }^{6}$ |
|  | DB2n | Message Data Byte 2 | $\mathrm{F}_{\mathrm{n}} 9_{\mathrm{H}}^{51}$ | $\mathrm{XX}^{6}{ }^{6}$ |
|  | DB3n | Message Data Byte 3 | $\mathrm{F}_{7 n \mathrm{H}^{5}}{ }^{5}$ | $\mathrm{XX}^{6}{ }^{6)}$ |
|  | DB4n | Message Data Byte 4 | $\mathrm{F}_{\mathrm{n}} \mathrm{nB}_{\mathrm{H}}{ }^{5}$ | $X^{(16)}$ |
|  | DB5n | Message Data Byte 5 | $\mathrm{F}_{\mathrm{ln}}^{\mathrm{H}_{5}^{5}}$ | $\mathrm{XX}^{6}{ }^{6}$ |
|  | DB6n | Message Data Byte 6 | $\mathrm{F}_{7 \mathrm{nD}}^{\mathrm{H}}{ }^{5}$ ) | $\mathrm{XX}^{6}{ }^{6}$ |
|  | DB7n | Message Data Byte 7 | $\mathrm{F}_{7 n \mathrm{n}_{\mathrm{H}}{ }^{5)}}$ | $\mathrm{XX}_{\mathrm{H}}{ }^{6}$ |

Table 4 Special Function Registers - Functional Block (cont'd)

| Block | Symbol | Name | Addr | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| SSC <br> Interface | $\begin{aligned} & \text { SSCCON } \\ & \text { STB } \\ & \text { SRB } \\ & \text { SCF } \\ & \text { SCIEN } \\ & \text { SSCMOD } \end{aligned}$ | SSC Control Register <br> SSC Transmit Buffer <br> SSC Receive Register <br> SSC Flag Register <br> SSC Interrupt Enable Register <br> SSC Mode Test Register | $\begin{aligned} & 93_{\mathrm{H}}{ }^{2}{ }^{94_{\mathrm{H}}} \\ & 95_{\mathrm{H}} \\ & A B_{H}{ }^{2} \\ & A C_{\mathrm{H}} \\ & 96_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & 07_{\mathrm{H}} \\ & \mathrm{XX}_{\mathrm{H}}{ }^{3)} \\ & \mathrm{XX}_{\mathrm{H}}{ }^{3)} \\ & \mathrm{XXXXXXO}_{\mathrm{B}}{ }^{3)} \\ & \mathrm{XXXXXXOO}_{\mathrm{B}}{ }^{3)} \\ & 00_{\mathrm{H}} \end{aligned}$ |
| Timer 0/ Timer 1 | $\begin{array}{\|l\|} \hline \text { TCON } \\ \text { TH0 } \\ \text { TH1 } \\ \text { TLO } \\ \text { TL1 } \\ \text { TMOD } \end{array}$ | Timer 0/1 Control Register <br> Timer 0, High Byte <br> Timer 1, High Byte <br> Timer 0, Low Byte <br> Timer 1, Low Byte <br> Timer Mode Register | $\begin{aligned} & 88_{\mathrm{H}}^{2}{ }^{2} \\ & 8 \mathrm{C}_{\mathrm{H}} \\ & 8 \mathrm{D}_{\mathrm{H}} \\ & 8 \mathrm{~A}_{\mathrm{H}} \\ & 8 \mathrm{~B}_{\mathrm{H}} \\ & 89_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & \hline 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \end{aligned}$ |
| Compare/ CaptureUnit/ Timer 2 | CCEN <br> CCH1 <br> CCH2 <br> CCH3 <br> CCL1 <br> CCL2 <br> CCL3 <br> CRCH <br> CRCL <br> TH2 <br> TL2 <br> T2CON | Comp./Capture Enable Reg. <br> Comp./Capture Reg. 1, High Byte <br> Comp./Capture Reg. 2, High Byte <br> Comp./Capture Reg. 3, High Byte <br> Comp./Capture Reg. 1, Low Byte <br> Comp./Capture Reg. 2, Low Byte <br> Comp./Capture Reg. 3, Low Byte <br> Com./Rel./Capt. Reg. High Byte <br> Com./Rel./Capt. Reg. Low Byte <br> Timer 2, High Byte <br> Timer 2, Low Byte <br> Timer 2 Control Register | $\mathrm{C}_{\mathrm{H}}$ <br> $\mathrm{C}_{\mathrm{H}}$ <br> $\mathrm{C}_{\mathrm{H}}^{\mathrm{H}}$ <br> $\mathrm{C}_{\mathrm{H}}$ <br> $\mathrm{C}_{\mathrm{H}} \mathrm{H}$ <br> $\mathrm{C}_{\mathrm{H}}^{\mathrm{H}}$ <br> $\mathrm{C}_{\mathrm{H}}^{\mathrm{H}}$ <br> $\mathrm{CB}_{\mathrm{H}}$ <br> $\mathrm{CA}_{\mathrm{H}}$ <br> $\mathrm{CD}_{\mathrm{H}}$ <br> $\mathrm{CC}_{\mathrm{H}}$ <br> $\mathrm{CB}_{\mathrm{H}}{ }^{2}$ | $0^{0} \mathrm{H}$ <br> $00_{\mathrm{H}}$ <br> $0^{00}$ <br> $0^{00} \mathrm{H}$ <br> $0^{00}$ <br> $0^{00}$ <br> $0^{00}$ <br> $0^{00} \mathrm{H}$ <br> $0^{00} \mathrm{H}$ <br> $0^{00} \mathrm{H}$ <br> $0^{00}$ <br> $00_{\mathrm{H}}$ |
| Power Save Modes | $\begin{aligned} & \hline \text { PCON }{ }^{1)} \\ & \text { PCON1 } \end{aligned}$ | Power Control Register  <br> Power Control Register 1 C515C-8R <br>  C515C-8E | $\begin{aligned} & \hline 87_{\mathrm{H}_{7)}} \\ & 88_{\mathrm{H}}^{7)} \\ & 88_{\mathrm{H}}{ }^{7} \\ & \hline \end{aligned}$ | $\begin{aligned} & 00_{\mathrm{H}} \\ & 0^{0 X X X X X X}{ }_{B}^{3)} \\ & 0^{3} X_{0 X X X X}^{B} \end{aligned}$ |

[^0]Table 5 Contents of the SFRs, SFRs in Numeric Order of their Addresses

| Addr. | Register | Content after Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $80_{\mathrm{H}}{ }^{2)}$ | P0 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $81_{\mathrm{H}}$ | SP | $07_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{82}{ }^{\text {H }}$ | DPL | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $83_{\mathrm{H}}$ | DPH | $00_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $86_{H}$ | WDTREL | $00_{\mathrm{H}}$ | WDT PSEL | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $87_{\mathrm{H}}$ | PCON | $00_{\mathrm{H}}$ | SMOD | PDS | IDLS | SD | GF1 | GF0 | PDE | IDLE |
| $88_{\mathrm{H}}{ }^{2)}$ | TCON | $00_{\mathrm{H}}$ | TF1 | TR1 | TFO | TR0 | IE1 | IT1 | IE0 | ITO |
| $88_{\mathrm{H}}{ }^{3)}$ | PCON14) | $\begin{aligned} & 0 X X X- \\ & X X X X_{B} \end{aligned}$ | EWPD | - | - | - | - | - | - | - |
| $88_{\mathrm{H}}{ }^{3)}$ | PCON1 ${ }^{5)}$ | $\begin{aligned} & 0 X X 0- \\ & X_{X X X} \end{aligned}$ | EWPD | - | - | WS | - | - | - | - |
| $89_{\mathrm{H}}$ | TMOD | $0^{0}{ }_{H}$ | GATE | C/T | M1 | M0 | GATE | C/T | M1 | M0 |
| $8 \mathrm{~A}_{\mathrm{H}}$ | TLO | $00_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8 \mathrm{~B}_{\mathrm{H}}$ | TL1 | $00_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8 \mathrm{C}_{\mathrm{H}}$ | THO | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8 \mathrm{D}_{\mathrm{H}}$ | TH1 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $90_{\mathrm{H}}{ }^{2)}$ | P1 | $\mathrm{FF}_{\mathrm{H}}$ | T2 | $\begin{aligned} & \text { CLK- } \\ & \text { OUT } \end{aligned}$ | T2EX | INT2 | INT6 | INT5 | INT4 | INT3 |
| $91_{\mathrm{H}}$ | XPAGE | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $92_{\mathrm{H}}$ | DPSEL | $\begin{aligned} & \mathrm{XXXX}- \\ & \mathrm{XOOO}_{\mathrm{B}} \end{aligned}$ | - | - | - | - | - | . 2 | . 1 | . 0 |
| $93^{\text {H }}$ | SSCCON | $07_{\mathrm{H}}$ | SCEN | TEN | MSTR | CPOL | CPHA | BRS2 | BRS1 | BRS0 |
| $94_{H}$ | STB | $\mathrm{XX}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $95_{\mathrm{H}}$ | SRB | $\mathrm{XX}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $96^{H}$ | SSCMOD | $00_{\mathrm{H}}$ | LOOPB | TRIO | 0 | 0 | 0 | 0 | 0 | LSBSM |
| $98^{2}{ }^{2)}$ | SCON | $0^{0} \mathrm{H}$ | SMO | SM1 | SM2 | REN | TB8 | RB8 | TI | RI |
| $99^{\text {H }}$ | SBUF | $\mathrm{XX}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $9 \mathrm{~A}_{\mathrm{H}}$ | IEN2 | $\begin{array}{\|l\|} \hline \text { X00X- } \\ \text { X00X } \\ \hline \end{array}$ | - | - | EX8 | EX7 | - | ESSC | ECAN | - |
| $\mathrm{AO}^{2)}$ | P2 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{ABH}^{2)}$ | IENO | $0^{0} \mathrm{H}$ | EAL | WDT | ET2 | ES | ET1 | EX1 | ETO | EXO |
| $\underline{A 9}$ | IPO | $0^{0} \mathrm{H}$ | OWDS | WDTS | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |

Table 5 Contents of the SFRs, SFRs in Numeric Order of their Addresses (cont'd)

| Addr. | Register | Content after Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{AA}_{\mathrm{H}}$ | SRELL | D9 ${ }_{\text {H }}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{AB}_{\mathrm{H}}$ | SCF | $\begin{aligned} & \mathrm{XXXX} \\ & \text { XXOO } \end{aligned}$ | - | - | - | - | - | - | WCOL | TC |
| $\mathrm{AC}_{\mathrm{H}}$ | SCIEN | $\begin{aligned} & \mathrm{XXXX} \\ & \mathrm{XXOO} \end{aligned}$ | - | - | - | - | - | - | WCEN | TCEN |
| $\mathrm{BO}^{2}{ }^{2}$ | P3 | $\mathrm{FF}_{\mathrm{H}}$ | RD | WR | T1 | T0 | INT1 | INTO | TxD | RxD |
| $\mathrm{B1}_{\mathrm{H}}$ | SYSCON ${ }^{4)}$ | $\begin{array}{\|l\|l\|l\|} \text { X010- } \\ \text { XX01 } \end{array}$ | - | PMOD | EALE | RMAP | - | - | XMAP1 | XMAPO |
| $B 1_{H}$ | SYSCON ${ }^{5}$ | $\begin{aligned} & \mathrm{X} 010- \\ & \mathrm{X} 001_{B} \end{aligned}$ | - | PMOD | EALE | RMAP | - | CSWO | XMAP1 | XMAPO |
| $\mathrm{B8}_{\mathrm{H}}{ }^{2}$ | IEN1 | $00_{\mathrm{H}}$ | EXEN2 | SWDT | EX6 | EX5 | EX4 | EX3 | EX2 | EADC |
| $\mathrm{B9}_{\mathrm{H}}$ | IP1 | $\begin{aligned} & 0 \times 00- \\ & 0000_{B} \end{aligned}$ | PDIR | - | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{BA}_{\mathrm{H}}$ | SRELH | $\begin{aligned} & \mathrm{XXXX} \\ & \mathrm{XX11} \end{aligned}$ | - | - | - | - | - | - | . 1 | . 0 |
| $\mathrm{COH}^{2}{ }^{2}$ | IRCON | $00_{H}$ | EXF2 | TF2 | IEX6 | IEX5 | IEX4 | IEX3 | IEX2 | IADC |
| $\mathrm{C1}_{\mathrm{H}}$ | CCEN | $0^{0} \mathrm{H}$ | $\begin{aligned} & \text { COCA } \\ & \text { H3 } \end{aligned}$ | $\begin{aligned} & \text { COCA } \\ & \text { L3 } \end{aligned}$ | $\begin{aligned} & \text { COCA } \\ & \text { H2 } \end{aligned}$ | $\begin{aligned} & \hline \text { COCA } \\ & \text { L2 } \end{aligned}$ | $\begin{aligned} & \text { COCA } \\ & \mathrm{H} 1 \end{aligned}$ | $\begin{aligned} & \text { COCA } \\ & \text { L1 } \end{aligned}$ | $\begin{aligned} & \text { COCA } \\ & \text { HO } \end{aligned}$ | $\begin{aligned} & \text { COCA } \\ & \text { LO } \end{aligned}$ |
| C 2 H | CCL1 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C3}_{\mathrm{H}}$ | CCH1 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C} 4 \mathrm{H}^{\text {chen }}$ | CCL2 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C5}_{\mathrm{H}}$ | CCH 2 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C6}_{\mathrm{H}}$ | CCL3 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C7}_{\mathrm{H}}$ | CCH3 | $00_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C8H}^{2}{ }^{2}$ | T2CON | $0^{0} \mathrm{H}$ | T2PS | I3FR | I2FR | T2R1 | T2R0 | T2CM | T211 | T210 |
| $\mathrm{CA}_{\mathrm{H}}$ | CRCL | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{CB}_{\mathrm{H}}$ | CRCH | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{CC}_{\mathrm{H}}$ | TL2 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{CD}_{\mathrm{H}}$ | TH2 | $0^{+}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |

Table $5 \quad$ Contents of the SFRs, SFRs in Numeric Order of their Addresses (cont'd)

| Addr. | Register | Content after Reset ${ }^{1)}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{DOH}^{2}{ }^{2}$ | PSW | $0^{00}$ | CY | AC | F0 | RS1 | RS0 | OV | F1 | P |
| $\mathrm{DB}^{2}{ }^{2}$ | ADCONo | $0^{0} \mathrm{H}$ | BD | CLK | ADEX | BSY | ADM | MX2 | MX1 | MXO |
| D9 ${ }_{\text {H }}$ | ADDATH | $0^{0} \mathrm{H}$ | . 9 | . 8 | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 |
| $\mathrm{DA}_{\mathrm{H}}$ | ADDATL | $\begin{aligned} & 00 X X- \\ & \text { XXXX }_{B} \end{aligned}$ | . 1 | . 0 | - | - | - | - | - | - |
| $\mathrm{DB}_{\mathrm{H}}$ | P6 | - | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\overline{D C}_{H}$ | ADCON1 | $\begin{aligned} & 0 \times X X- \\ & \mathrm{XOOO}_{\mathrm{B}} \end{aligned}$ | ADCL | - | - | - | 0 | MX2 | MX1 | MXO |
| $\mathrm{EOH}^{2}{ }^{2}$ | ACC | $\mathrm{OO}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{E8H}^{2}{ }^{2}$ | P4 | $\mathrm{FF}_{\mathrm{H}}$ | RXDC | TXDC | $\overline{\text { INT8 }}$ | $\overline{\text { SLS }}$ | STO | SRI | SCLK | $\overline{\text { ADST }}$ |
| $\mathrm{FO}^{2}{ }^{2}$ | B | $0^{0}{ }_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F8H}^{2}{ }^{2}$ | P5 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F}_{\mathrm{H}}{ }^{2}$ | DIR5 ${ }^{6)}$ | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{FA}_{\mathrm{H}}$ | P7 | $\begin{aligned} & \mathrm{XXXX} \\ & \mathrm{XXX1} \end{aligned}$ | - | - | - | - | - | - | - | $\overline{\text { INT7 }}$ |
| $\overline{\mathrm{FC}_{\mathrm{H}}}$ | $\mathrm{VRO}^{778)}$ | $\mathrm{C5}_{\mathrm{H}}$ | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |
| $\mathrm{FD}_{\mathrm{H}}$ | VR1 ${ }^{778)}$ | $95_{\mathrm{H}}$ | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 |
| $\mathrm{FE}_{\mathrm{H}}$ | $\mathrm{VR2}^{778)}$ | $0_{2}{ }^{9}{ }^{\text {) }}$ | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |

1) " $X$ " means that the value is undefined and the location is reserved.
2) Bit-addressable special function registers
3) SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set.
4) This SFR is available in the C515C-8R and C515C-L.
5) This SFR is available in the C515C-8E.
6) This SFR is a mapped SFR. For accessing this SFR, bit PDIR in SFR IP1 must be set.
7) This SFR is a mapped SFR. For accessing this SFR, bit RMAP in SFR SYSCON must be set.
8) These SFRs are read-only registers (C515C-8E only).
9) The content of this SFR varies with the actual step of the C515C-8E (e.g. $01_{\mathrm{H}}$ for the first step).

Table 6 Contents of the CAN Registers in Numeric Order of their Addresses

| Addr. $\mathrm{n}=1 \text { to } \mathrm{F}_{\mathrm{H}}{ }^{1)}$ | Register | Content after Reset ${ }^{2}$ ) | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| F700 ${ }_{\text {H }}$ | CR | $0^{01}$ | TEST | CCE | 0 | 0 | EIE | SIE | IE | INIT |
| $\mathrm{F}^{\text {701 }} \mathrm{H}$ | SR | XX ${ }_{\text {H }}$ | BOFF | EWRN | - | RXOK | TXOK | LEC2 | LEC1 | LEC0 |
| $\mathrm{F}^{702}{ }_{\mathrm{H}}$ | IR | $X X_{H}$ | INTID |  |  |  |  |  |  |  |
| F704 ${ }_{\text {H }}$ | BTR0 | $\mathrm{UU}_{\mathrm{H}}$ | SJW |  | BRP |  |  |  |  |  |
| $\mathrm{F}^{7} 05_{\mathrm{H}}$ | BTR1 | OUUU. $\mathrm{UUUU}_{\mathrm{B}}$ | 0 |  | TSEG2 |  | TSEG1 |  |  |  |
| $\mathrm{F}^{\text {706 }}{ }_{\text {H }}$ | GMS0 | $\mathrm{UU}_{\mathrm{H}}$ | ID28-21 |  |  |  |  |  |  |  |
| $\mathrm{F}^{707}{ }_{\text {H }}$ | GMS1 | $\begin{aligned} & \text { UUU1. } \\ & 1111_{\mathrm{B}} \end{aligned}$ | ID20-18 |  |  | 1 | 1 | 1 | 1 | 1 |
| $\mathrm{F}^{708}{ }_{\mathrm{H}}$ | UGMLO | $\mathrm{UU}_{\mathrm{H}}$ | ID28-21 |  |  |  |  |  |  |  |
| $\mathrm{F}^{709}{ }_{\mathrm{H}}$ | UGML1 | $\mathrm{UU}_{\mathrm{H}}$ | ID20-13 |  |  |  |  |  |  |  |
| $\mathrm{F}^{\text {70A }}$ H | LGMLO | $\mathrm{UU}_{\mathrm{H}}$ | ID12-5 |  |  |  |  |  |  |  |
| $\mathrm{F}^{\text {70B }}$ H | LGML1 | UUUU. $\mathrm{UOOO}_{\mathrm{B}}$ | ID4-0 |  |  |  |  | 0 | 0 | 0 |
| $\mathrm{F70C}_{\mathrm{H}}$ | UMLM0 | $\mathrm{UU}_{\mathrm{H}}$ | ID28-21 |  |  |  |  |  |  |  |
| ${\mathrm{F} 70 \mathrm{D}_{\mathrm{H}}}^{\text {l }}$ | UMLM1 | $\mathrm{UU}_{\mathrm{H}}$ | ID20-18 |  |  | ID17-13 |  |  |  |  |
| $\mathrm{F70E}_{\mathrm{H}}$ | LMLMO | $\mathrm{UU}_{\mathrm{H}}$ | ID12-5 |  |  |  |  |  |  |  |
| $\mathrm{F}^{7} 0 \mathrm{~F}_{\mathrm{H}}$ | LMLM1 | UUUU. $\mathrm{UOOO} \mathrm{B}_{\mathrm{B}}$ | ID4-0 |  |  |  |  | 0 | 0 | 0 |
| $\underline{\mathrm{F} 7 \mathrm{n} \mathrm{H}_{\mathrm{H}}}$ | MCR0 | $\mathrm{UU}_{\mathrm{H}}$ | MSGVAL |  | TXIE |  | RXIE |  | INTPND |  |
| $\mathrm{F}_{7 \mathrm{n} 1}^{\mathrm{H}}$ | MCR1 | $\mathrm{UU}_{\mathrm{H}}$ | RMTPND |  | TXRQ |  | MSGLST CPUUPD |  | NEWDAT |  |
| $\mathrm{F7n2}_{\mathrm{H}}$ | UAR0 | $\mathrm{UU}_{\mathrm{H}}$ | ID28-21 |  |  |  |  |  |  |  |
| $\mathrm{F}_{7 \mathrm{n} 3}^{\mathrm{H}}$ | UAR1 | $\mathrm{UU}_{\mathrm{H}}$ | ID20-18 |  |  | ID17-13 |  |  |  |  |
| $\mathrm{F}_{\mathrm{n} 4}{ }_{\mathrm{H}}$ | LAR0 | $\mathrm{UU}_{\mathrm{H}}$ | ID12-5 |  |  |  |  |  |  |  |
| $\mathrm{F}_{7 \mathrm{n} 5}{ }_{\mathrm{H}}$ | LAR1 | UUUU. $\mathrm{UOOO}_{\mathrm{B}}$ | ID4-0 |  |  |  |  | 0 | 0 | 0 |
| $\overline{\mathrm{F}} \mathrm{n} 6_{\mathrm{H}}$ | MCFG | UUUU. $\mathrm{UUOO}_{\mathrm{B}}$ | DLC |  |  |  | DIR | XTD | 0 | 0 |
| $\overline{\mathrm{F}} \mathrm{n} 7_{\mathrm{H}}$ | DBOn | X $\mathrm{X}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F7n8}_{\mathrm{H}}$ | DB1n | $X X_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F}_{\mathrm{nn}} \mathrm{H}_{\mathrm{H}}$ | DB2n | $X X_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F7nA}_{\mathrm{H}}$ | DB3n | $X X_{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F}_{7 \mathrm{nB}}^{\mathrm{H}}$ | DB4n | XX ${ }_{\text {H }}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |

Table 6 Contents of the CAN Registers in Numeric Order of their Addresses (cont'd)

| Addr. $\mathrm{n}=1 \text { to } \mathrm{F}_{\mathrm{H}}{ }^{1)}$ | Register | Content after Reset ${ }^{2}$ | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{F7nC}_{\mathrm{H}}$ | DB5n | XX $\mathrm{XH}^{\text {H }}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F7nD}_{\mathrm{H}}$ | DB6n | $\mathrm{XX}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{F}_{7 \mathrm{nE}}^{\mathrm{H}}$ | DB7n | XX H | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |

1) The notation " n " in the address definition defines the number of the related message object.
2) " X " means that the value is undefined and the location is reserved. " $U$ " means that the value is unchanged by a reset operation. " $U$ " values are undefined (as " $X$ ") after a power-on reset operation.

## Digital I/O Ports

The C515C allows for digital I/O on 49 lines grouped into 6 bidirectional 8-bit ports and one 1 -bit port. Each port bit consists of a latch, an output driver and an input buffer. Read and write accesses to the I/O ports P0 through P7 are performed via their corresponding special function registers P0 to P7. The port structure of port 5 of the C515C is especially designed to operate either as a quasi-bidirectional port structure, compatible to the standard 8051-Family, or as a genuine bidirectional port structure. This port operating mode can be selected by software (setting or clearing the bit PMOD in the SFR SYSCON).
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 SFR contents.

## Analog Input Ports

Ports 6 is available as input port only and provides two functions. When used as digital inputs, the corresponding SFR P6 contains the digital value applied to the port 6 lines. When used for analog inputs the desired analog channel is selected by a three-bit field in SFR ADCONO or SFR ADCON1. Of course, it makes no sense to output a value to these input-only ports by writing to the SFR P6. This will have no effect.
If a digital value is to be read, the voltage levels are to be held within the input voltage specifications ( $V_{\mathrm{IL}} / V_{\mathrm{IH}}$ ). Since P6 is not bit-addressable, all input lines of P6 are read at the same time by byte instructions.
Nevertheless, it is possible to use port 6 simultaneously for analog and digital input. However, care must be taken that all bits of P6 that have an undetermined value caused by their analog function are masked.

## Port Structure Selection of Port 5

After a reset operation of the C515C, the quasi-bidirectional 8051-compatible port structure is selected. For selection of the bidirectional (CMOS) port 5 structure the bit PMOD of SFR SYSCON must be set. Because each port 5 pin can be programmed as an input or an output, additionally, after the selection of the bidirectional mode the direction register DIR5 of port 5 must be written. This direction register is mapped to the port 5 register. This means, the port register address is equal to its direction register address. Figure 10 illustrates the port and direction register configuration.


Figure 10 Port Register, Direction Register

## Timer / Counter 0 and 1

Timer / Counter 0 and 1 can be used in four operating modes as listed in Table 7:
Table $7 \quad$ Timer/Counter 0 and 1 Operating Modes

| Mode | Description | TMOD |  | Timer/Counter Input Clock |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | M1 | M0 | internal | external (max) |
| 0 | 8-bit timer/counter with a <br> divide-by-32 prescaler | 0 | 0 | $f_{\mathrm{OSC}} / 6 \times 32$ | $f_{\mathrm{OSC}} / 12 \times 32$ |
| 1 | 16-bit timer/counter | 0 | 1 | $f_{\mathrm{OSC}} / 6$ | $f_{\mathrm{OSC}} / 12$ |
| 2 | 8-bit timer/counter with 8-bit <br> autoreload | 1 | 0 |  |  |
| 3 | Timer/counter 0 used as <br> one 8-bit timer/counter and <br> one 8-bit timer / Timer 1 <br> stops | 1 | 1 |  |  |

In the "timer" function ( $\mathrm{C} / \mathrm{T}=$ ' 0 ') the register is incremented every machine cycle. Therefore the count rate is $f_{\mathrm{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_{\text {OSC }} / 12$. External inputs $\overline{\mathrm{NTO}}$ and 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 C515C provides additional compare/capture/reload features, which allow the selection of the following operating modes:

- Compare: up to 4 PWM signals with 16 -bit/ 600 ns resolution
- Capture: up to 4 high speed capture inputs with 600 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.
Timer Mode: 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.
Gated Timer Mode: 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 T 2 (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 / 12$ 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

## 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 8.

Table 8 USART Operating Modes

| Mode | SCON |  | Description |
| :--- | :--- | :--- | :--- |
|  | SMO | SM1 |  |
| 0 | 0 | 0 | Shift register mode, fixed baud rate <br> Serial data enters and exits through $\mathrm{R} \times \mathrm{D} ; \mathrm{T} \times \mathrm{D}$ outputs <br> the shift clock; 8-bit are transmitted/received (LSB first) |
| 1 | 0 | 1 | 8-bit UART, variable baud rate <br> 10 bits are transmitted (through $\mathrm{T} \times \mathrm{D}$ ) or received (at <br> R×D) |
| 2 | 1 | 0 | 9-bit UART, fixed baud rate <br> 11 bits are transmitted (through $\mathrm{T} \times \mathrm{D}$ ) or received (at <br> R $\times \mathrm{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 asynchronous modes 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 - there divided by 16 - results in the actual "baud rate". Further, the abbreviation $f_{\text {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).


Note: The switch configuration shows the reset state.
MCS02733

Figure 15 Block Diagram of Baud Rate Generation for the Serial Interface
Table 9 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 9 Serial Interface - Baud Rate Dependencies

| Serial Interface <br> Operating Modes | Active Control <br> Bits |  | Baud Rate Calculation |
| :--- | :--- | :--- | :--- |
|  | BD | SMOD |  |
| Mode 0 (Shift <br> Register) | - | - | $f_{\text {OSC }} / 6$ |
| Mode 1 (8-bit UART) <br> Mode 3 (9-bit UART) | 0 | $X$ | Controlled by timer 1 overflow: <br> $\left(2^{\text {SMOD }} \times\right.$ timer 1 overflow rate) $/ 32$ |
|  | 1 | X | Controlled by baud rate generator <br> $\left(2^{\text {SMOD }} \times f_{\mathrm{OSC}}\right) /$ <br> $(32 \times$ baud rate generator overflow rate) |
| Mode 2 (9-bit UART) | - | 0 | $f_{\mathrm{OSC}} / 32$ <br> $f_{\mathrm{OSC}} / 16$ |

## SSC Interface

The C515C microcontroller provides a Synchronous Serial Channel unit, the SSC. This interface is compatible to the popular SPI serial bus interface. Figure 16 shows the block diagram of the SSC. The central element of the SSC is an 8 -bit shift register. The input and the output of this shift register are each connected via a control logic to the pin P4.2 / SRI (SSC Receiver In) and P4.3 / STO (SSC Transmitter Out). This shift register can be written to (SFR STB) and can be read through the Receive Buffer Register SRB.


Figure 16 SSC Block Diagram
The SSC has implemented a clock control circuit, which can generate the clock via a baud rate generator in the master mode, or receive the transfer clock in the slave mode. The clock signal is fully programmable for clock polarity and phase. The pin used for the clock signal is P4.1 / SCLK. When operating in slave mode, a slave select input is provided which enables the SSC interface and also will control the transmitter output. The pin used for this is P4.4 / SLS.
The SSC control block is responsible for controlling the different modes and operation of the SSC, checking the status, and generating the respective status and interrupt signals.

## CAN Controller

The on-chip CAN controller is the functional heart which provides all resources that are required to run the standard CAN protocol (11-bit identifiers) as well as the extended CAN protocol (29-bit identifiers). It provides a sophisticated object layer to relieve the CPU of as much overhead as possible when controlling many different message objects (up to 15). This includes bus arbitration, resending of garbled messages, error handling, interrupt generation, etc. In order to implement the physical layer, external components have to be connected to the C515C.

The internal bus interface connects the on-chip CAN controller to the internal bus of the microcontroller. The registers and data locations of the CAN interface are mapped to a specific 256 bytes wide address range of the external data memory area (F700 H to $\mathrm{F}_{\mathrm{FF}}^{\mathrm{H}} \mathrm{H}$ ) and can be accessed using MOVX instructions. Figure 17 shows a block diagram of the on-chip CAN controller.


Figure 17 CAN Controller Block Diagram
The TX/RX Shift Register holds the destuffed bit stream from the bus line to allow the parallel access to the whole data or remote frame for the acceptance match test and the parallel transfer of the frame to and from the Intelligent Memory.
The Bit Stream Processor (BSP) is a sequencer controlling the sequential data stream between the TX/RX Shift Register, the CRC Register, and the bus line. The BSP also controls the EML and the parallel data stream between the TX/RX Shift Register and the Intelligent Memory such that the processes of reception, arbitration, transmission, and error signalling are performed according to the CAN protocol. Note that the automatic retransmission of messages which have been corrupted by noise or other external error conditions on the bus line is handled by the BSP.

The Cyclic Redundancy Check Register (CRC) generates the Cyclic Redundancy Check code to be transmitted after the data bytes and checks the CRC code of incoming messages. This is done by dividing the data stream by the code generator polynomial.
The Error Management Logic (EML) is responsible for the fault confinement of the CAN device. Its counters, the Receive Error Counter and the Transmit Error Counter, are incremented and decremented by commands from the Bit Stream Processor. According to the values of the error counters, the CAN controller is set into the states error active, error passive and busoff.
The Bit Timing Logic (BTL) monitors the busline input RXDC and handles the busline related bit timing according to the CAN protocol. The BTL synchronizes on a recessive to dominant busline transition at Start of Frame (hard synchronization) and on any further recessive to dominant busline transition, if the CAN controller itself does not transmit a dominant bit (resynchronization). The BTL also provides programmable time segments to compensate for the propagation delay time and for phase shifts and to define the position of the Sample Point in the bit time. The programming of the BTL depends on the baudrate and on external physical delay times.
The Intelligent Memory (CAM/RAM array) provides storage for up to 15 message objects of maximum 8 data bytes length. Each of these objects has a unique identifier and its own set of control and status bits. After the initial configuration, the Intelligent Memory can handle the reception and transmission of data without further CPU actions.

## Switch-off Capability of the CAN Controller (C515C-8E only)

For power consumption reasons, the on-chip CAN controller in the C515C-8E can be switched off by setting bit CSWO (bit 2) in SFR SYSCON. When the CAN controller is switched off its clock signal is turned off and the operation of the CAN controller is stopped. This switch-off state of the CAN controller is equal to its state in software power down mode. After clearing bit CSWO again the CAN controller has to be reconfigured.

## 10-Bit A/D Converter

The C515C 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 6), which can also be used as digital inputs
- 10-bit resolution
- Single or continuous conversion mode
- Internal or external 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 main functional blocks of the A/D converter are shown in Figure 19.
The A/D converter uses basically two clock signals for operation: the input clock $f_{\text {IN }}$ ( $=1 / t_{\mathrm{IN}}$ ) and the conversion clock $f_{\mathrm{ADC}}\left(=1 / t_{\mathrm{ADC}}\right)$. These clock signals are derived from the C515C system clock $f_{\text {Osc }}$ which is applied at the XTAL pins. The input clock $f_{\text {IN }}$ is equal to $f_{\text {OSC }}$. The conversion clock is limited to a maximum frequency of 2 MHz and therefore must be adapted to $f_{\text {Osc }}$ by programming the conversion clock prescaler. The table in Figure 18 shows the prescaler ratios and the resulting A/D conversion times which must be selected for typical system clock rates.


| MCU System <br> Clock Rate <br> $\left(f_{\text {osc }}\right)$ | ADCL | Conversion <br> Clock <br> $f_{\text {ADC }}[\mathrm{MHz}]$ |
| :--- | :--- | :--- |
| 2 MHz | 0 | .5 |
| 4 MHz | 0 | 1 |
| 6 MHz | 0 | 1.5 |
| 8 MHz | 0 | 2 |
| 10 MHz | 1 | 1.25 |

Figure 18 A/D Converter Clock Selection

C515C


Figure 19 A/D Converter Block Diagram

## Interrupt System

The C515C provides 17 interrupt sources with four priority levels. Seven interrupts can be generated by the on-chip peripherals (timer 0, timer 1, timer 2, serial interface, A/D converter, SSC interface, CAN controller), and ten interrupts may be triggered externally (P1.5/T2EX, P3.2/INT0, P3.3/INT1, P1.4/INT2, P1.0/INT3, P1.1/INT4, P1.2/INT5, P1.3/INT6, P7.0/INT7, P4.5//NT8). The wake-up from power-down mode interrupt has a special functionality which allows to exit from the software power-down mode by a short low pulse at pin P3.2/INTO.
In the C515C the 17 interrupt sources are combined to six groups of two or three interrupt sources. Each interrupt group can be programmed to one of the four interrupt priority levels. Figure 20 to Figure 22 give a general overview of the interrupt sources and illustrate the interrupt request and control flags.

C515C


Figure 20 Interrupt Request Sources (Part 1)


Figure 21 Interrupt Request Sources (Part 2)


Figure 22 Interrupt Request Sources (Part 3)

Table 10 Interrupt Source and Vectors

| Interrupt Source | Interrupt Vector <br> Address | Interrupt Request Flags |
| :--- | :--- | :--- |
| External Interrupt 0 | $0003_{\mathrm{H}}$ | IEO |
| Timer 0 Overflow | $000 \mathrm{~B}_{\mathrm{H}}$ | TF0 |
| External Interrupt 1 | $0013_{\mathrm{H}}$ | IE1 |
| Timer 1 Overflow | $001 \mathrm{~B}_{\mathrm{H}}$ | TF1 |
| Serial Channel | $0023_{\mathrm{H}}$ | RI / TI |
| Timer 2 Overflow / Ext. Reload | $002 \mathrm{~B}_{\mathrm{H}}$ | TF2 / EXF2 |
| A/D Converter | $0043_{\mathrm{H}}$ | IADC |
| External Interrupt 2 | $004 \mathrm{~B}_{\mathrm{H}}$ | IEX2 |
| External Interrupt 3 | $0053_{\mathrm{H}}$ | IEX3 |
| External Interrupt 4 | $005 \mathrm{~B}_{\mathrm{H}}$ | IEX4 |
| External Interrupt 5 | $0063_{\mathrm{H}}$ | IEX5 |
| External Interrupt 6 | $006 \mathrm{~B}_{\mathrm{H}}$ | IEX6 |
| Wake-up from power-down | $007 \mathrm{~B}_{\mathrm{H}}$ | - |
| mode | $0^{\text {CAN controller }}$ | $008 \mathrm{~B}_{\mathrm{H}}$ |
| External Interrupt 7 | $00 \mathrm{~A}_{\mathrm{H}}$ | - |
| External Interrupt 8 | $00 \mathrm{AB}_{\mathrm{H}}$ | - |
| SSC interface | $0093_{\mathrm{H}}$ | - |

## Fail Save Mechanisms

The C515C offers two on-chip peripherals which monitor the program flow and ensure an automatic "fail-safe" reaction for cases where the controller's hardware fails or the software hangs up:

- A programmable watchdog timer (WDT) with variable time-out period from 512 microseconds up to approx. 1.1 seconds at 6 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.


## Programmable Watchdog Timer

The watchdog timer in the C515C is a 15-bit timer, which is incremented by a count rate of $f_{\text {OSC }} / 12$ up to $f_{\text {OSC }} / 192$. For programming of the watchdog timer overflow rate, the upper 7 bit of the watchdog timer can be written. Figure 23 shows the block diagram of the watchdog timer unit.


Figure 23 Block Diagram of the Programmable Watchdog Timer
The watchdog timer can be started by software (bit SWDT) or by hardware through pin $\overline{P E} / S W D$, but it cannot be stopped during active mode of the C515C. 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.

- Restart from the hardware power down mode

If the hardware power down mode is terminated the oscillator watchdog has to control the correct start-up of the on-chip oscillator and to restart the program. The oscillator watchdog function is only part of the complete hardware power down sequence; however, the watchdog works identically to the monitoring function.

- Control of external wake-up from software power-down mode

When the software power-down mode is left by a low level at the P3.2//INT0 pin, 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.


Figure 24 Block Diagram of the Oscillator Watchdog

## Power Saving Modes

The C515C provides two basic power saving modes, the idle mode and the power down mode. Additionally, a slow down mode is available. This power saving mode reduces the internal clock rate in normal operating mode and it can be also used for further power reduction in idle 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.

- Power down mode

The operation of the C515C is completely stopped and the oscillator is turned off. This mode is used to save the contents of the internal RAM with a very low standby current.
Software power down mode: Software power down mode is entered by software and can be left by reset or by a short low pulse at pin P3.2/INT0 (or P4.7/RXDC, C515C-8E only).
Hardware power down mode: Hardware power down mode is entered when the pin $\overline{H W P D}$ is put to low level.

- Slow-down mode

The controller keeps up the full operating functionality, 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^{\text {th }}$ of their normal operating frequency. Slowing down the frequency significantly reduces power consumption. The slow down mode can be combined with the idle mode.
Table 11 gives a general overview of the entry and exit conditions of the power saving modes.
In the power down mode of operation, $V_{D D}$ can be reduced to minimize power consumption. It must be ensured, however, that $V_{D D}$ is not reduced before the power down mode is invoked, and that $V_{\mathrm{DD}}$ is restored to its normal operating level, before the power down mode is terminated.
If e.g. the idle mode is left through an interrupt, the microcontroller state (CPU, ports, peripherals) remains preserved. If a power saving mode is left by a hardware reset, the microcontroller state is disturbed and replaced by the reset state of the C515C.
If WS (bit 4) is SFR PCON1 is set (C515C-8E only), pin P4.7/ $\overline{\mathrm{RXDC}}$ is alternatively selected as wake-up pin for the software power down mode. If WS (bit 4) is SFR PCON1 is cleared (C515C-8E only), pin P3.2/INT0 is selected as wake-up pin for the software power down mode.
For the C515C-8R, P3.2/INT0 is always selected as wake-up pin.

Table 11 Power Saving Modes Overview

| Mode | Entering <br> (2-Instruction <br> Example) | Leaving by | Remarks |
| :--- | :--- | :--- | :--- |
| Idle mode | ORL PCON, \#01 H <br> ORL PCON, \#20 | Occurrence of an <br> interrupt from a <br> peripheral unit | CPU clock is stopped; <br> CPU maintains their data; <br> peripheral units are active (if <br> enabled) and provided with <br> clock |
|  | Hardware Reset |  |  |

## OTP Memory Operation (C515C-8E only)

The C515C-8E contains a 64 Kbytes one-time programmable (OTP) program memory. With the C515C-8E fast programming cycles are achieved ( 1 byte in $100 \mu \mathrm{~s}$ ). Also several levels of OTP memory protection can be selected.
For programming of the device, the $\mathrm{C} 515 \mathrm{C}-8 \mathrm{E}$ 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 C515C-8E operates as a slave device similar as an EPROM standalone memory device and must be controlled with address/data information, control lines, and an external 11.5 V programming voltage. Figure 25 shows the pins of the C515C-8E which are required for controlling of the OTP programming mode.


Figure 25 Programming Mode Configuration of the C515C-8E

## C515C-8E Pin Configuration in Programming Mode



Figure 26 P-MQFP-80-1 Pin Configuration of the C515C-8E in Programming Mode (top view)

The following Table 12 contains the functional description of all C515C-8E pins which are required for OTP memory programming.

## Table 12 Pin Definitions and Functions in Programming Mode

| Symbol | Pin Number | I/O ${ }^{1)}$ | Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RESET | 1 | I | This input must be at static "0" (active) level during the whole programming mode. |  |  |
| PMSELO | 15 | I | Programming mode selection pins |  |  |
| PMSEL1 | 16 | I | modes in programming mode. PMSEL1,0 must satisfy a setup time to the rising edge of PALE. When the logic level of PMSEL1,0 is changed, PALE must be at low |  |  |
|  |  |  | PMSEL1 | PMSELO | Access Mode |
|  |  |  | 0 | 0 | Reserved |
|  |  |  | 0 | 1 | Read version bytes |
|  |  |  | 1 | 0 | Program/read lock bits |
|  |  |  | 1 | 1 | Program/read OTP memory byte |
| $\overline{\overline{\text { PSEL }}}$ | 17 | I | This input is used for the basic programming mode selection and must be switched according Figure 27. |  |  |
| $\overline{\overline{P R D}}$ | 18 | I | Program <br> This inpu memory operation | ing mode is used for ad, version | read strobe read access control for OTP byte read, and lock bit read |
| PALE | 19 | I | Program PALE is address li the falling whenever | ing addre ed to latch es must sa dge of PA he logic leve | s latch enable <br> the high address lines. The high isfy a setup and hold time to/from E. PALE must be at low level el of PMSEL1,0 is changed. |
| XTAL2 | 36 | I | Input to the oscillator amplifier. |  |  |
| XTAL1 | 37 | 0 | XTAL1 <br> Output of the inverting oscillator amplifier. |  |  |

Table 12 Pin Definitions and Functions in Programming Mode (cont'd)

| Symbol | Pin Number | I/O ${ }^{1}$ | Function |
| :---: | :---: | :---: | :---: |
| A0/A8 - A7/A15 | 38-45 | 1 | Address lines <br> P2.0-7 are used as multiplexed address input lines A0-A7 and A8-A15. A8-A15 must be latched with PALE. |
| $\overline{\text { PSEN }}$ | 47 | I | $\overline{\text { Program store enable }}$ <br> This input must be at static "0" level during the whole programming mode. |
| $\overline{\overline{P R O G}}$ | 48 | I | Programming mode write strobe <br> 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{\overline{\mathrm{EA}}} / V_{\mathrm{PP}}$ | 49 | I | External Access / Programming voltage <br> This pin must be at $11.5 \mathrm{~V}\left(V_{\mathrm{PP}}\right)$ voltage level during programming of an OTP memory byte or lock bit. During an OTP memory read operation this pin must be at high level $\left(V_{I H}\right)$. This pin is also used for basic programming mode selection. At basic programming mode selection a low level must be applied to $\overline{\mathrm{EA}} / V_{\mathrm{PP}}$. |
| D0-7 | 52-58 | I/O | Data lines 0-7 <br> During programming mode, data bytes are read or written from or to the C515C-8E via the bidirectional D0-7 which are located at port 0 . |
| $V_{\text {SS }}$ | $\begin{aligned} & 13,34,35, \\ & 51,70 \end{aligned}$ | - | Circuit ground potential must be applied to these pins in programming mode. |
| $V_{\text {DD }}$ | $\begin{aligned} & 14,32,33, \\ & 50,69 \end{aligned}$ | - | Power supply terminal must be applied to these pins in programming mode. |
| N.C. | $\begin{aligned} & \text { 2-12, 20-31, } \\ & 46,60-67, \\ & 69,71-80 \end{aligned}$ | - | Not Connected These pins should not be connected in programming mode. |

[^1]
## C515C-8E Basic Programming Mode Selection

The basic programming mode selection scheme is shown in Figure 27.


Figure 27 C515C-8E Basic Programming Mode Selection

Table 13 Access Modes Selection

| Access Mode | $\begin{aligned} & \overline{\mathrm{EA}} / \\ & \boldsymbol{V}_{\mathrm{PP}} \end{aligned}$ | $\overline{\text { PROG }}$ | $\overline{\text { PRD }}$ | PMSEL |  | Address （Port 2） | Data <br> （Port 0） |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 1 | 0 |  |  |
| Program OTP memory byte | $V_{\text {PP }}$ | $\square$ | H | H | H | $\begin{aligned} & \text { A0-7 } \\ & \text { A8-15 } \end{aligned}$ | D0－7 |
| Read OTP memory byte | $V_{\mathrm{IH}}$ | H | ち |  |  |  |  |
| Program OTP lock bits | $V_{\text {PP }}$ | 乙， | H | H | L | － | $\begin{aligned} & \text { D1, D0 } \\ & \text { see } \\ & \text { Table } 14 \end{aligned}$ |
| Read OTP lock bits | $V_{\mathrm{IH}}$ | H | 乙 |  |  |  |  |
| Read OTP version byte | $V_{\mathrm{IH}}$ | H | ち | L | H | Byte addr． of version byte | D0－7 |

## C515C－8E Lock Bits Programming／Read

The C515C－8E has two programmable lock bits which，when programmed according Table 14，provide four levels of protection for the on－chip OTP code memory．The state of the lock bits can also be read．

Table 14 Lock Bit Protection Types

| Lock Bits atD1, D0 |  | Protection Level | Protection Type |
| :---: | :---: | :---: | :---: |
| D1 | D0 |  |  |
| 1 | 1 | Level 0 | The OTP lock feature is disabled. During normal operation of the C515C-8E, the state of the $\overline{\mathrm{EA}}$ pin is not latched on reset. |
| 1 | 0 | Level 1 | During normal operation of the C515C-8E, MOVC instructions executed from external program memory are disabled from fetching code bytes from internal memory. $\overline{E A}$ is sampled and latched on reset. An OTP memory read operation is only possible according to ROM verification mode 2, as it is defined for a protected ROM version of the C515C-8R. Further programming of the OTP memory is disabled (reprogramming security). |
| 0 | 1 | Level 2 | Same as level 1, but also OTP memory read operation using ROM verification mode 2 is disabled. |
| 0 | 0 | Level 3 | Same as level 2 ; but additionally external code execution by setting $\overline{\mathrm{EA}}=$ low during normal operation of the C515C-8E is no more possible. <br> External code execution, which is initiated by an internal program (e.g. by an internal jump instruction above the ROM boundary), is still possible. |

## Absolute Maximum Ratings

| Parameter | Symbol | Limit Values |  | Unit | Notes |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | min. | max. |  |  |
| Storage temperature | $T_{\mathrm{ST}}$ | -65 | 150 | ${ }^{\circ} \mathrm{C}$ | - |
| Voltage on $V_{\mathrm{DD}}$ pins with <br> respect to ground $\left(V_{\mathrm{SS}}\right)$ | $V_{\mathrm{DD}}$ | -0.5 | 6.5 | V | - |
| Voltage on any pin with respect <br> to ground ( $V_{\mathrm{SS}}$ ) | $V_{\mathrm{IN}}$ | -0.5 | $V_{\mathrm{DD}}+0.5$ | V | - |
| Input current on any pin during <br> overload condition | - | -10 | 10 | mA | - |
| Absolute sum of all input <br> currents during overload | - | - | I 100 mAl | mA | - |
| condition |  |  | - |  |  |
| Power dissipation | $P_{\mathrm{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_{I N}>V_{D D}$ or $V_{I N}<V_{S S}$ ) the voltage on $V_{D D}$ pins with respect to ground ( $V_{S S}$ ) must not exceed the values defined by the absolute maximum ratings.

C515C

## Operating Conditions

| Parameter | Symbol | Limit Values |  | Unit | Notes |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | min. | max. |  |  |
| Supply voltage | $V_{\mathrm{DD}}$ | 4.25 | 5.5 | V | Active mode, <br> $f_{\text {OSCmax }}=10 \mathrm{MHz}$ |
|  |  | 2 | 5.5 | V | Power Down <br> mode |
| Ground voltage | $V_{\mathrm{SS}}$ |  | 0 |  | V |
| Reference voltage |  |  |  |  |  |
| SAB-C515C |  |  |  | ${ }^{\circ} \mathrm{C}$ | - |
| SAF-C505 | $T_{\mathrm{A}}$ | 0 | 70 |  |  |
| SAH-C505 | $T_{\mathrm{A}}$ | -40 | 85 |  |  |
| Analog reference voltage | $V_{\mathrm{AREF}}$ | 4 | $V_{\mathrm{DD}}+0.1$ | V | - |
| Analog ground voltage | $V_{\mathrm{AGND}}$ | $V_{\mathrm{SS}}-0.1$ | $V_{\mathrm{SS}}+0.2$ | V | - |
| Analog input voltage | $V_{\mathrm{AIN}}$ | $V_{\mathrm{AGND}}$ | $V_{\mathrm{AREF}}$ | V | - |
| XTAL clock | $f_{\mathrm{OSC}}$ | 2 | 110 | MHz | - |

DC Characteristics (Operating Conditions apply)

| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |  |
| Input low voltages all except $\overline{E A}, \overline{R E S E T}, \overline{H W P D}$ EA pin $\overline{\text { RESET }}$ and HWPD pins Port 5 in CMOS mode | $V_{\mathrm{IL}}$ <br> $V_{\mathrm{IL} 1}$ <br> $V_{\mathrm{IL} 2}$ <br> $V_{\text {ILC }}$ | $\begin{array}{\|l} -0.5 \\ -0.5 \\ -0.5 \\ -0.5 \end{array}$ | $\begin{aligned} & 0.2 V_{\mathrm{DD}}-0.1 \\ & 0.2 V_{\mathrm{DD}}-0.3 \\ & 0.2 V_{\mathrm{DD}}+0.1 \\ & 0.3 V_{\mathrm{DD}} \end{aligned}$ | V | - |
| Input high voltages all except XTAL2, RESET, and HWPD) XTAL2 pin $\overline{\text { RESET }}$ and $\overline{\text { HWPD }}$ pins Port 5 in CMOS mode | $\begin{aligned} & V_{\mathrm{IH}} \\ & V_{\mathrm{IH} 1} \\ & V_{\mathrm{IH} 2} \\ & V_{\mathrm{IHC}} \end{aligned}$ | $\begin{aligned} & 0.2 V_{\mathrm{DD}}+0.9 \\ & 0.7 V_{\mathrm{DD}} \\ & 0.6 V_{\mathrm{DD}} \\ & 0.7 V_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & V_{\mathrm{DD}}+0.5 \\ & V_{\mathrm{DD}}+0.5 \\ & V_{\mathrm{DD}}+0.5 \\ & V_{\mathrm{DD}}+0.5 \end{aligned}$ | V | - |
| Output low voltages <br> Ports 1, 2, 3, 4, 5, 7 (incl. CMOS) <br> Port 0, ALE, $\overline{\text { PSEN, }}, \overline{\mathrm{CPUR}}$ <br> P4.1, P4.3 in push-pull mode | $V_{\mathrm{OL}}$ <br> $V_{\mathrm{OL} 1}$ <br> $V_{\text {OL3 }}$ |  | $\begin{array}{\|l} 0.45 \\ 0.45 \\ 0.45 \end{array}$ | V | $\begin{aligned} & I_{\mathrm{OL}}=1.6 \mathrm{~mA}^{1)} \\ & I_{\mathrm{OL}}=3.2 \mathrm{~mA}^{11} \\ & I_{\mathrm{OL}}=3.75 \mathrm{~mA}^{1)} \end{aligned}$ |
| Output high voltages <br> Ports 1, 2, 3, 4, 5, 7 <br> Port 0 in external bus mode, <br> ALE, $\overline{P S E N}, \overline{C P U R}$ <br> Port 5 in CMOS mode <br> P4.1, P4.3 in push-pull mode | $V_{\mathrm{OH}}$ <br> $V_{\mathrm{OH} 2}$ <br> $V_{\mathrm{OHC}}$ <br> $V_{\mathrm{OH} 3}$ | $\begin{aligned} & 2.4 \\ & 0.9 V_{\mathrm{DD}} \\ & 2.4 \\ & 0.9 V_{\mathrm{DD}} \\ & 0.9 V_{\mathrm{DD}} \\ & 0.9 V_{\mathrm{DD}} \end{aligned}$ |  | V | $\begin{aligned} & I_{\mathrm{OH}}=-80 \mu \mathrm{~A} \\ & I_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & I_{\mathrm{OH}}=-800 \mu \mathrm{~A} \\ & I_{\mathrm{OH}}=-80 \mu \mathrm{~A}^{2} \\ & I_{\mathrm{OH}}=-800 \mu \mathrm{~A} \\ & I_{\mathrm{OH}}=-833 \mu \mathrm{~A} \end{aligned}$ |
| Logic 0 input current Ports 1, 2, 3, 4, 5, 7 | $I_{\text {IL }}$ | -10 | -70 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0.45 \mathrm{~V}$ |
| Logical 0-to-1 transition current Ports 1, 2, 3, 4, 5, 7 | $I_{\text {TL }}$ | -65 | -650 | $\mu \mathrm{A}$ | $V_{\mathrm{IN}}=2 \mathrm{~V}$ |
| Input leakage current <br> Port 0, EA, P6, HWPD, AIN0-7 | $I_{\text {LI }}$ | - | $\pm 1$ | $\mu \mathrm{A}$ | $0.45<V_{\text {IN }}<V_{\text {DD }}$ |
| Input low current To $\overline{\text { RESET }}$ for reset XTAL2 PE/SWD | $\begin{aligned} & I_{\mathrm{LI} 2} \\ & I_{\mathrm{LI} 3} \\ & I_{\mathrm{LI} 4} \end{aligned}$ |  | $\begin{aligned} & -100 \\ & -15 \\ & -20 \end{aligned}$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\mathrm{IN}}=0.45 \mathrm{~V} \\ & V_{\mathrm{IN}}=0.45 \mathrm{~V} \\ & V_{\mathrm{IN}}=0.45 \mathrm{~V} \end{aligned}$ |
| Pin capacitance | $C_{10}$ | - | 10 | pF | $\begin{aligned} & f_{\mathrm{c}}=1 \mathrm{MHz}, \\ & T_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Overload current | $I_{\text {OV }}$ | - | $\pm 5$ | mA | 3)4) |
| Programming voltage | $V_{\text {PP }}$ | 10.9 | 12.1 | V | $11.5 \mathrm{~V} \pm 5 \%$ |

1) Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the $V_{\text {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_{\mathrm{OH}}$ on ALE and $\overline{\text { PSEN }}$ to momentarily fall below the $0.9 V_{\mathrm{DD}}$ specification when the address lines are stabilizing.
3) Overload conditions under operating conditions occur if the voltage on the respective pin exceeds the specified operating range (i.e. $V_{\mathrm{OV}}>V_{\mathrm{DD}}+0.5 \mathrm{~V}$ or $V_{\mathrm{OV}}<V_{\mathrm{SS}}-0.5 \mathrm{~V}$ ). The absolute sum of input overload currents on all port pins may not exceed 50 mA . The supply voltage ( $V_{\mathrm{DD}}$ and $V_{\mathrm{SS}}$ ) must remain within the specified limits.
${ }^{4)}$ Not $100 \%$ tested, guaranteed by design characterization.

## Power Supply Current

| Parameter |  |  | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | typ. ${ }^{1)}$ | max. ${ }^{\text {2 }}$ |  |  |
| Active mode | $\begin{aligned} & \text { C515C-8R/ } \\ & \text { C515C-LM } \end{aligned}$ | $\begin{aligned} & 6 \mathrm{MHz} \\ & 10 \mathrm{MHz} \end{aligned}$ |  | $I_{\text {DD }}$ | $\begin{aligned} & 11.97 \\ & 18.81 \end{aligned}$ | $\begin{aligned} & 13.74 \\ & 21.10 \end{aligned}$ | mA | 3) |
|  | C515C-8E | $\begin{aligned} & 6 \mathrm{MHz} \\ & 10 \mathrm{MHz} \end{aligned}$ | $I_{\text {DD }}$ | $\begin{array}{\|l\|} \hline 11.3 \\ 17.66 \end{array}$ | $\begin{aligned} & 12.94 \\ & 20.10 \end{aligned}$ | mA |  |  |
| Idle mode | $\begin{aligned} & \text { C515C-8R/ } \\ & \text { C515C-LM } \end{aligned}$ | $\begin{array}{\|l\|} \hline 6 \mathrm{MHz} \\ 10 \mathrm{MHz} \end{array}$ | $I_{\text {DD }}$ | $\begin{array}{\|l\|} \hline 6.9 \\ 10.46 \end{array}$ | $\begin{array}{\|l\|} \hline 7.87 \\ 11.87 \end{array}$ | mA | 4) |  |
|  | C515C-8E | $\begin{aligned} & 6 \mathrm{MHz} \\ & 10 \mathrm{MHz} \end{aligned}$ | $I_{\text {DD }}$ | $\begin{aligned} & 3.95 \\ & 4.71 \end{aligned}$ | $\begin{aligned} & 4.70 \\ & 5.50 \end{aligned}$ | mA |  |  |
| Active mode with slow-down enabled | $\begin{aligned} & \text { C515C-8R/ } \\ & \text { C515C-LM } \end{aligned}$ | $\begin{array}{\|l\|} \hline 6 \mathrm{MHz} \\ 10 \mathrm{MHz} \end{array}$ | $I_{\text {DD }}$ | $\begin{aligned} & 4.06 \\ & 4.62 \end{aligned}$ | $\begin{aligned} & 5.03 \\ & 5.75 \end{aligned}$ | mA | 5) |  |
|  | C515C-8E | $\begin{array}{\|l\|} \hline 6 \mathrm{MHz} \\ 10 \mathrm{MHz} \end{array}$ | $I_{\text {DD }}$ | $\begin{aligned} & 4.01 \\ & 4.65 \end{aligned}$ | $\begin{aligned} & 4.77 \\ & 5.53 \end{aligned}$ | mA |  |  |
| Idle mode with slow-down enabled | $\begin{aligned} & \text { C515C-8R/ } \\ & \text { C515C-LM } \end{aligned}$ | $\begin{array}{\|l\|} \hline 6 \mathrm{MHz} \\ 10 \mathrm{MHz} \end{array}$ | $I_{\text {DD }}$ | $\begin{aligned} & 3.54 \\ & 3.86 \end{aligned}$ | $\begin{aligned} & 4.46 \\ & 4.90 \end{aligned}$ | mA | 6) |  |
|  | C515C-8E | $\begin{aligned} & 6 \mathrm{MHz} \\ & 10 \mathrm{MHz} \end{aligned}$ | $I_{\text {DD }}$ | $\begin{aligned} & 3.62 \\ & 4.14 \end{aligned}$ | $\begin{aligned} & 4.21 \\ & 4.77 \end{aligned}$ | mA |  |  |
| Power-down mode | $\begin{aligned} & \text { C515C-8R/ } \\ & \text { C515C-LM } \end{aligned}$ |  | $I_{\text {PD }}$ | 26 | 42.9 | $\mu \mathrm{A}$ | $V_{7)} \mathrm{DD}=2 \ldots 5.5 \mathrm{~V}$ |  |
|  | C515C-8E |  | $I_{\text {PD }}$ | 11.14 | 30 | $\mu \mathrm{A}$ |  |  |
| At $\overline{\mathrm{EA}} / V_{\mathrm{PP}}$ in programming mode | C515C-8E |  | $I_{\text {DDP }}$ | - | 30 | mA | - |  |

1) The typical $I_{\mathrm{DD}}$ values are periodically measured at $T_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and $V_{\mathrm{DD}}=5 \mathrm{~V}$ but not $100 \%$ tested.
2) The maximum $I_{\mathrm{DD}}$ values are measured under worst case conditions ( $T_{\mathrm{A}}=0^{\circ} \mathrm{C}$ or $-40^{\circ} \mathrm{C}$ and $V_{\mathrm{DD}}=5.5 \mathrm{~V}$ )
${ }^{3)} I_{\mathrm{DD}}$ (active mode) is measured with:
XTAL2 driven with $t_{\mathrm{CLCH}}, t_{\mathrm{CHCL}}=5 \mathrm{~ns}, V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{IH}}=V_{\mathrm{DD}}-0.5 \mathrm{~V} ;$ XTAL1 $=\mathrm{N} . \mathrm{C} . ;$
$\overline{\mathrm{EA}}=\overline{\mathrm{PE}} / \mathrm{SWD}=$ Port $0=$ Port $6=V_{\mathrm{DD}} ; \mathrm{HWPD}=V_{\mathrm{DD}} ; \overline{\mathrm{RESET}}=V_{\mathrm{SS}} ;$ all other pins are disconnected.
${ }^{4)} I_{\mathrm{DD}}$ (idle mode) is measured with all output pins disconnected and with all peripherals disabled;
XTAL2 driven with $t_{\mathrm{CLCH}}, t_{\mathrm{CHCL}}=5 \mathrm{~ns}, V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{IH}}=V_{\mathrm{DD}}-0.5 \mathrm{~V}$; XTAL1 $=\mathrm{N} . \mathrm{C} . ;$
$\overline{\mathrm{RESET}}=V_{\mathrm{DD}} ; \overline{\mathrm{EA}}=V_{\mathrm{SS}} ;$ Port0 $=V_{\mathrm{DD}} ;$ all other pins are disconnected;
${ }^{5)} I_{\mathrm{DD}}$ (active mode with slow-down mode) is measured with all output pins disconnected and with all peripherals disabled;
XTAL2 driven with $t_{\mathrm{CLCH}}, t_{\mathrm{CHCL}}=5 \mathrm{~ns}, V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{IH}}=V_{\mathrm{DD}}-0.5 \mathrm{~V} ; \mathrm{XTAL} 1=\mathrm{N} . \mathrm{C} . ;$
$\overline{\operatorname{RESET}}=V_{\mathrm{DD}}$; all other pins are disconnected; the microcontroller is put into slow-down mode by software.
3) $I_{\mathrm{DD}}$ (idle mode with slow-down mode) is measured with all output pins disconnected and with all peripherals disabled;
XTAL2 driven with $t_{\mathrm{CLCH}}, t_{\mathrm{CHCL}}=5 \mathrm{~ns}, V_{\mathrm{IL}}=V_{\mathrm{SS}}+0.5 \mathrm{~V}, V_{\mathrm{IH}}=V_{\mathrm{DD}}-0.5 \mathrm{~V}$; XTAL1 $=\mathrm{N} . \mathrm{C}$.;
$\overline{\text { RESET }}=V_{\mathrm{DD}} ; \overline{\mathrm{EA}}=V_{\mathrm{SS}} ;$ Port0 $=V_{\mathrm{DD}}$; all other pins are disconnected; the microcontroller is put into idle mode with slow-down enabled by software.
4) $I_{P D}$ (power-down mode) is measured under following conditions:
$\overline{\mathrm{EA}}=\overline{\mathrm{RESET}}=$ Port $0=$ Port $6=V_{\mathrm{DD}} ; \mathrm{XTAL1}=\mathrm{N} . \mathrm{C} . ; \mathrm{XTAL2}=V_{\mathrm{SS}} ; \overline{\mathrm{PE}} / \mathrm{SWD}=V_{\mathrm{SS}} ; \overline{\mathrm{HWPD}}=V_{\mathrm{DD}} ;$ $V_{\mathrm{AGND}}=V_{\mathrm{SS}} ; V_{\mathrm{AREF}}=V_{\mathrm{DD}} ;$ all other pins are disconnected.
$I_{\text {PD }}$ (hardware power-down mode) is independent of any particular pin connection.

## Power Supply Current Calculation Formulas

| Parameter |  | Symbol | Formula |
| :---: | :---: | :---: | :---: |
| Active mode | $\begin{aligned} & \text { C515C-8R/ } \\ & \text { C515C-LM } \end{aligned}$ | $I_{\text {DD typ }}$ $I_{\mathrm{DD} \text { max }}$ | $\begin{aligned} & 1.71 \times f_{\mathrm{OSC}}+1.71 \\ & 1.84 \times f_{\mathrm{OSC}}+2.7 \end{aligned}$ |
|  | C515C-8E | $I_{\mathrm{DD} \text { typ }}$ $I_{\mathrm{DD} \text { max }}$ | $\begin{aligned} & 1.59 \times f_{\mathrm{OSC}}+1.76 \\ & 1.79 \times f_{\mathrm{OSC}}+2.2 \end{aligned}$ |
| Idle mode | $\begin{aligned} & \text { C515C-8R/ } \\ & \text { C515C-LM } \end{aligned}$ | IDD typ $I_{\mathrm{DD} \text { max }}$ | $\begin{aligned} & 0.89 \times f_{\mathrm{OSC}}+1.56 \\ & 1.00 \times f_{\mathrm{OSC}}+1.87 \end{aligned}$ |
|  | C515C-8E | $I_{\text {DD typ }}$ $I_{\mathrm{DD} \text { max }}$ | $\begin{aligned} & 0.19 \times f_{\mathrm{OSC}}+2.81 \\ & 0.20 \times f_{\mathrm{OSC}}+3.5 \end{aligned}$ |
| Active mode with slow-down enabled | $\begin{array}{\|l} \hline \text { C515C-8R/ } \\ \text { C515C-LM } \end{array}$ | $I_{\mathrm{DD} \text { typ }}$ $I_{\mathrm{DD} \text { max }}$ | $\begin{aligned} & 0.14 \times f_{\mathrm{OSC}}+3.22 \\ & 0.18 \times f_{\mathrm{OSC}}+3.95 \end{aligned}$ |
|  | C515C-8E | $I_{\text {DD typ }}$ $I_{\mathrm{DD} \text { max }}$ | $\begin{aligned} & 0.16 \times f_{\mathrm{OSC}}+3.05 \\ & 0.19 \times f_{\mathrm{OSC}}+3.63 \end{aligned}$ |
| Idle mode with slow-down enabled | $\begin{aligned} & \text { C515C-8R/ } \\ & \text { C515C-LM } \end{aligned}$ | IDD typ $I_{\mathrm{DD} \text { max }}$ | $\begin{aligned} & 0.08 \times f_{\mathrm{OSC}}+3.06 \\ & 0.11 \times f_{\mathrm{OSC}}+3.8 \end{aligned}$ |
|  | C515C-8E | IDD typ $I_{\mathrm{DD} \text { max }}$ | $\begin{aligned} & 0.13 \times f_{\mathrm{OSC}}+2.84 \\ & 0.14 \times f_{\mathrm{OSC}}+3.37 \end{aligned}$ |

Note: $f_{O S C}$ is the oscillator frequency in $M H z I_{D D}$ values are given in $m A$.


Figure $28 \quad I_{\mathrm{DD}}$ Diagrams of C515C-8R/C515C-LM


Figure $29 I_{\text {DD }}$ Diagrams of C515C-8E

## A/D Converter Characteristics (Operating Conditions apply)

\left.| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | min. | max. |  |  |$\right)$

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 $\mathrm{X} 000_{\mathrm{H}}$ or $\mathrm{X}_{3} \mathrm{FF}_{\mathrm{H}}$, respectively.
2) During the sample time the input capacitance $C_{\text {AIN }}$ can 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_{\mathrm{S}}$. After the end of the sample time $t_{\mathrm{S}}$, changes of the analog input voltage have no effect on the conversion result.
3) This parameter includes the sample time $t_{\mathrm{S}}$, the time for determining the digital result and the time for the calibration. Values for the conversion clock $t_{\text {ADC }}$ depend on programming and can be taken from the table on the previous page.
4) $\mathrm{T}_{\mathrm{UE}}$ is tested at $V_{\mathrm{AREF}}=5.0 \mathrm{~V}, V_{\mathrm{AGND}}=0 \mathrm{~V}, V_{\mathrm{DD}}=4.9 \mathrm{~V}$. It is guaranteed by design characterization for all other voltages within the defined voltage range.
If an overload condition occurs on maximum 2 not selected 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.

## Clock Calculation Table

| Clock Prescaler Ratio | ADCL | $\boldsymbol{t}_{\mathbf{A D C}}$ | $\boldsymbol{t}_{\mathbf{S}}$ | $\boldsymbol{t}_{\mathbf{A D C C}}$ |
| :--- | :--- | :--- | :--- | :--- |
| $\div 8$ | 1 | $8 \times t_{\mathrm{IN}}$ | $16 \times t_{\mathrm{IN}}$ | $96 \times t_{\mathrm{IN}}$ |
| $\div 4$ | 0 | $4 \times t_{\mathrm{IN}}$ | $8 \times t_{\mathrm{IN}}$ | $48 \times t_{\mathrm{IN}}$ |

Further timing conditions: $\quad t_{\mathrm{ADC}} \min =500 \mathrm{~ns}$

$$
t_{\mathrm{IN}}=1 / f_{\mathrm{OSC}}=t_{\mathrm{CLP}}
$$

AC Characteristics (Operating Conditions apply)
( $C_{\mathrm{L}}$ for port 0, ALE and $\overline{\mathrm{PSEN}}$ outputs $=100 \mathrm{pF} ; C_{\mathrm{L}}$ for all other outputs $=80 \mathrm{pF}$ )
Program Memory Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 10-MHz Clock Duty Cycle 0.4 to 0.6 |  | Variable Clock <br> $1 / \mathrm{CLP}=2 \mathrm{MHz}$ <br> to 10 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| ALE pulse width | $t_{\text {LHLL }}$ | 60 | - | CLP - 40 | - | ns |
| Address setup to ALE | $t_{\text {AVLL }}$ | 15 | - | TCL ${ }_{\text {min }}-25$ | - | ns |
| Address hold after ALE | $t_{\text {LLAX }}$ | 15 | - | TCL ${ }_{\text {Hmin }}-25$ | - | ns |
| ALE to valid instruction in | $t_{\text {LLIV }}$ | - | 113 | - | 2 CLP - 87 | ns |
| ALE to $\overline{\text { PSEN }}$ | $t_{\text {LLPL }}$ | 20 | - | TCL $L_{\text {min }}-20$ | - | ns |
| $\overline{\text { PSEN }}$ pulse width | $t_{\text {PLPH }}$ | 115 | - | $\begin{aligned} & \text { CLP + } \\ & \text { TCL }_{\text {Hin }}-30 \end{aligned}$ | - | ns |
| $\overline{\text { PSEN }}$ to valid instruction in | $t_{\text {PLIV }}$ | - | 75 | - | $\begin{aligned} & \text { CLP + } \\ & \text { TCL }_{\text {H } \text { min }}-65 \end{aligned}$ | ns |
| Input instruction hold after $\overline{\text { PSEN }}$ | $t_{\text {PXIX }}$ | 0 | - | 0 | - | ns |
| Input instruction float after PSEN | $t_{\text {PxIZ }}{ }^{1)}$ | - | 30 | - | TCL $L_{\text {Lmin }}-10$ | ns |
| Address valid after PSEN | $t_{\text {PXAV }}{ }^{1)}$ | 35 | - | $\mathrm{TCL}_{\text {Lmin }}-5$ | - | ns |
| Address to valid instruction in | $t_{\text {AVIV }}$ | - | 180 | - | $\begin{aligned} & 2 \text { CLP }_{+} \\ & \text {TCL }_{\text {Hmin }}-60 \end{aligned}$ | ns |
| Address float to PSEN | $t_{\text {AZPL }}$ | 0 |  | 0 | - | ns |

[^2]External Data Memory Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 10-MHz Clock Duty Cycle 0.4 to 0.6 |  | Variable Clock 1/CLP= 2 MHz to 10 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| $\overline{\mathrm{RD}}$ pulse width | $t_{\text {RLRH }}$ | 230 | - | 3 CLP - 70 | - | ns |
| $\overline{\overline{W R}}$ pulse width | $t_{\text {WLWH }}$ | 230 | - | 3 CLP - 70 | - | ns |
| Address hold after ALE | $t_{\text {LLAX2 }}$ | 48 | - | CLP - 15 | - | ns |
| $\overline{\overline{R D}}$ to valid data in | $t_{\text {RLDV }}$ | - | 150 | - | $\begin{aligned} & 2 \text { CLP + } \\ & \text { TCL }_{\text {Hmin }}-90 \end{aligned}$ | ns |
| Data hold after $\overline{\mathrm{RD}}$ | $t_{\text {RHDX }}$ | 0 | - | 0 | - | ns |
| Data float after $\overline{\mathrm{RD}}$ | $t_{\text {RHDZ }}$ | - | 80 | - | CLP - 20 | ns |
| ALE to valid data in | $t_{\text {LLDV }}$ | - | 267 | - | 4 CLP - 133 | ns |
| Address to valid data in | $t_{\text {AVDV }}$ | - | 285 | - | $\begin{aligned} & 4 C L P+ \\ & \text { TCL }_{\text {Hmin }}-155 \end{aligned}$ | ns |
|  | $t_{\text {LLWL }}$ | 90 | 190 | $\begin{aligned} & \mathrm{CLP}+ \\ & \mathrm{TCL}_{\mathrm{Lmin}}-50 \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { CLP }_{+} \\ \text {TCL }_{\text {Lmin }}+50 \end{array}$ | ns |
| Address valid to $\overline{\mathrm{WR}}$ | $t_{\text {AVWL }}$ | 103 | - | 2 CLP - 97 | - | ns |
| $\overline{\overline{W R}}$ or $\overline{\mathrm{RD}}$ high to ALE high | $t_{\text {WHLH }}$ | 15 | 65 | TCL ${ }_{\text {Hmin }}-25$ | $\mathrm{TCL}_{\text {Hin }}+25$ | ns |
| Data valid to $\overline{W R}$ transition | $t_{\text {QVWX }}$ | 5 | - | TCL Lmin -35 | - | ns |
| Data setup before WR | $t_{\text {QVWH }}$ | 218 | - | $\begin{aligned} & \hline 3 C L P_{+} \\ & \text {TCL }_{\text {Lmin }}-122 \end{aligned}$ | - | ns |
| Data hold after $\overline{\mathrm{WR}}$ | $t_{\text {WHQX }}$ | 13 | - | TCL ${ }_{\text {Hmin }}-27$ | - | ns |
| Address float after $\overline{R D}$ | $t_{\text {RLAZ }}$ | - | 0 | - | 0 | ns |

C515C

SSC Interface Characteristics

| Parameter | Symbol | Limit Values |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |
| Clock Cycle Time: Master Mode Slave Mode | $t_{\text {SCLK }}$ $t_{\text {SCLK }}$ | $\begin{aligned} & 0.4 \\ & 1.0 \end{aligned}$ | $-$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| Clock high time | ${ }^{\text {SCH }}$ | 360 | - | ns |
| Clock low time | $t_{\text {SCL }}$ | 360 | - | ns |
| Data output delay | $t_{\mathrm{D}}$ | - | 100 | ns |
| Data output hold | $t_{\mathrm{HO}}$ | 0 | - | ns |
| Data input setup | $t_{\text {S }}$ | 100 | - | ns |
| Data input hold | $t_{\mathrm{HI}}$ | 100 | - | ns |
| TC bit set delay | $t_{\text {DTC }}$ | - | 8 CLP | ns |

## External Clock Drive at XTAL2

| Parameter | Symbol | CPU Clock $=10 \mathrm{MHz}$ Duty cycle 0.4 to 0.6 |  | Variable CPU Clock $1 / C L P=2$ to 10 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. | min. | max. |  |
| Oscillator period | CLP | 100 | 100 | 100 | 500 | ns |
| High time | TCL ${ }_{\text {H }}$ | 40 | - | 40 | CLP - TCL ${ }_{\text {L }}$ | ns |
| Low time | TCL ${ }_{L}$ | 40 | - | 40 | CLP - TCL ${ }_{\text {H }}$ | ns |
| Rise time | $t_{\mathrm{R}}$ | - | 12 | - | 12 | ns |
| Fall time | $t_{\mathrm{F}}$ | - | 12 | - | 12 | ns |
| Oscillator duty cycle | DC | 0.4 | 0.6 | 40 / CLP | 1-40/CLP | - |
| Clock cycle | TCL | 40 | 60 | $\mathrm{CLP} \times \mathrm{DC}_{\text {min }}$ | $\mathrm{CLP} \times \mathrm{DC}_{\text {max }}$ | ns |

Note: The 10 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 .


Figure 30 Program Memory Read Cycle


Figure 31 Data Memory Read Cycle


Figure 32 Data Memory Write Cycle


Figure 33 External Clock Drive at XTAL2


## Figure 34 SSC Timing

## Notes:

1. Shown is the data/clock relationship for $C P O L=C P H A=1$. The timing diagram is valid for the other cases accordingly.
2. In the case of slave mode and $C P H A=0$, the output delay for the MSB applies to the falling edge of $\overline{S L S}$ (if transmitter is enabled).
3. In the case of master mode and $C P H A=0$, the MSB becomes valid after the data has been written into the shift register, i.e. at least one half SCLK clock cycle before the first clock transition.

## OTP Memory Programming Mode Characteristics

$V_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \% ; V_{\mathrm{PP}}=11.5 \mathrm{~V} \pm 5 \% ; T_{\mathrm{A}}=25^{\circ} \mathrm{C} \pm 10^{\circ} \mathrm{C}$

| Parameter | Symbol | Limit Values |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |
| ALE pulse width | $t_{\text {PAW }}$ | 35 | - | ns |
| PMSEL setup to ALE rising edge | $t_{\text {PMS }}$ | 10 | - | ns |
| Address setup to ALE, $\overline{\text { PROG, or } \overline{\text { RRD }}}$ falling edge | $t_{\text {PAS }}$ | 10 | - | ns |
| Address hold after ALE, $\overline{\text { PROG }}$, or $\overline{\text { PRD }}$ falling edge | $t_{\text {PAH }}$ | 10 | - | ns |
| Address, data setup to PROG or $\overline{\text { PRD }}$ | $t_{\text {PCS }}$ | 100 | - | ns |
| Address, data hold after $\overline{\text { PROG }}$ or $\overline{\text { PRD }}$ | $t_{\text {PCH }}$ | 0 | - | ns |
| PMSEL setup to PROG or $\overline{\text { PRD }}$ | $t_{\text {PMS }}$ | 10 | - | ns |
| PMSEL hold after $\overline{\text { PROG }}$ or $\overline{\text { PRD }}$ | $t_{\text {PMH }}$ | 10 | - | ns |
| $\overline{\overline{\text { PROG }} \text { pulse width }}$ | $t_{\text {PWW }}$ | 100 | - | $\mu \mathrm{S}$ |
| PRD pulse width | $t_{\text {PRW }}$ | 100 | - | ns |
| Address to valid data out | $t_{\text {PAD }}$ | - | 75 | ns |
| $\overline{\text { PRD }}$ to valid data out | $t_{\text {PRD }}$ | - | 20 | ns |
| Data hold after $\overline{\text { PRD }}$ | $t_{\text {PDH }}$ | 0 | - | ns |
| Data float after PRD | $t_{\text {PDF }}$ | - | 20 | ns |
| $\overline{\overline{P R O G}}$ high between two consecutive PROG low pulses | $t_{\text {PWH1 }}$ | 1 | - | $\mu \mathrm{S}$ |
| $\overline{\overline{P R D}}$ high between two consecutive $\overline{\text { PRD }}$ low pulses | $t_{\text {PWH2 }}$ | 100 | - | ns |
| XTAL clock period | $t_{\text {CLKP }}$ | 2 | 10 | MHz |



Figure 35 Programming Code Byte - Write Cycle Timing


Figure 36 Verify Code Byte - Read Cycle Timing


Note: PALE should be low during a lock bit read / write cycle.
MCT03393

Figure 37 Lock Bit Access Timing


Note: $\overline{\text { PROG }}$ must be high during a programming read cycle. MCT03394

Figure 38 Version Byte - Read Timing

ROM/OTP Verification Characteristics for C515C-8R / C515C-8E
ROM Verification Mode 1 (C515C-8R)

| Parameter | Symbol | Limit Values |  | Unit |
| :--- | :--- | :--- | :--- | :--- |
|  |  | min. | max. |  |
| Address to valid data | $t_{\mathrm{AVQV}}$ | - | 5 CLP | ns |


Figure 39 ROM Verification Mode 1

C515C

ROM/OTP Verification Mode 2

| Parameter | Symbol | Limit Values |  |  | Unit |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | min. | typ. | max. |  |
| ALE pulse width | $t_{\text {AWD }}$ | - | CLP | - | ns |
| ALE period | $t_{\mathrm{ACY}}$ | - | 6 CLP | - | ns |
| Data valid after ALE | $t_{\mathrm{DVA}}$ | - | - | 2 CLP | ns |
| Data stable after ALE | $t_{\mathrm{DSA}}$ | 4 CLP | - | - | ns |
| P3.5 setup to ALE low | $t_{\mathrm{AS}}$ | - | $t_{\mathrm{CL}}$ | - | ns |
| Oscillator frequency | $1 / \mathrm{CLP}$ | 4 | - | 6 | MHz |



Figure 40 ROM/OTP Verification Mode 2


AC Inputs during testing are driven at $V_{\mathrm{DD}}-0.5 \mathrm{~V}$ for a logic ' 1 ' and 0.45 V for a logic ' 0 '. Timing measurements are made at $V_{\text {IHmin }}$ for a logic ' 1 ' and $V_{\text {ILmax }}$ for a logic '0'.

Figure 41 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_{\mathrm{OH}} / V_{\mathrm{OL}}$ level occurs. $I_{\mathrm{OL}} / I_{\mathrm{OH}} \geq \pm 20 \mathrm{~mA}$

Figure 42 AC Testing: Float Waveforms
Crystal/Resonator Oscillator Mode

Figure 43 Recommended Oscillator Circuits for Crystal Oscillator

## Package Outlines

## P-MQFP-80-1

(Plastic Metric Quad Flat Package)


1) Does not include plastic or metal protrusions of 0.25 max per side

You can find all of our packages, sorts of packing and others in our Infineon Internet Page "Products": http://www.infineon.com/products.
ww w.infineon.com

Published by Infineon Technologies AG

This datasheet has been download from:
www.datasheetcatalog.com
Datasheets for electronics components.


[^0]:    1) This special function register is listed repeatedly since some bits of it also belong to other functional blocks.
    ${ }^{2)}$ Bit-addressable special function registers
    2) " $X$ " means that the value is undefined and the location is reserved.
    3) This SFR is a mapped SFR. For accessing this SFR, bit PDIR in SFR IP1 must be set.
    ${ }^{5)}$ The notation " n " in the message object address definition defines the number of the related message object.
    4) " X " means that the value is undefined and the location is reserved. " U " means that the value is unchanged by a reset operation. " U " values are undefined (as " $X$ ") after a power-on reset operation.
    5) SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set.
[^1]:    1) $\mathrm{I}=$ Input; $\mathrm{O}=$ Output
[^2]:    1) Interfacing the C 515 C to devices with float times up to 35 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers.
