## SIEMENS

## Microcomputer Components

## 8-Bit CM OS M icrocontroller

## C515

| C515 Data Sheet <br> Revision History: | Current Version: 1997-08-01 |  |
| :--- | :--- | :--- |
| Previous Version: | none (Original Version) |  |
| Page <br> (in previous <br> Version) | Page <br> (in current <br> Version) | Subjects (major changes since last revision) |
|  |  |  |
|  |  |  |

## Edition 1997-08-01

Published by Siemens AG,
Bereich Halbleiter, Marketing-
Kommunikation, Balanstraße 73,

## 81541 München

(C) Siemens AG 1997.

All Rights Reserved.
Attention please!
As far as patents or other rights of third parties are concerned, liability is only assumed for components, not for applications, processes and circuits implemented within components or assemblies.
The information describes the type of component and shall not be considered as assured characteristics.
Terms of delivery and rights to change design reserved.
For questions on technology, delivery and prices please contact the Semiconductor Group Offices in Germany or the Siemens Companies and Representatives worldwide (see address list).
Due to technical requirements components may contain dangerous substances. For information on the types in question please contact your nearest Siemens Office, Semiconductor Group.
Siemens AG is an approved CECC manufacturer.

## Packing

Please use the recycling operators known to you. We can also help you - get in touch with your nearest sales office. By agreement we will take packing material back, if it is sorted. You must bear the costs of transport.
For packing material that is returned to us unsorted or which we are not obliged to accept, we shall have to invoice you for any costs incurred.

## Components used in life-support devices or systems must be expressly authorized for such purpose!

Critical components ${ }^{1}$ of the Semiconductor Group of Siemens AG, may only be used in life-support devices or systems ${ }^{2}$ with the express written approval of the Semiconductor Group of Siemens AG.
1 A critical component is a component used in a life-support device or system whose failure can reasonably be expected to cause the failure of that life-support device or system, or to affect its safety or effectiveness of that device or system.
2 Life support devices or systems are intended (a) to be implanted in the human body, or (b) to support and/or maintain and sustain human life. If they fail, it is reasonable to assume that the health of the user may be endangered.

## SIEMENS

## 8-Bit CMOS Microcontroller

## Advance Information

## Data Sheet

- Full upward compatibility with SAB 80C515
- Up to 24 MHz external operating frequency - 500 ns instruction cycle at 24 MHz operation
- 8 K byte on-chip ROM (with optional ROM protection)
- alternatively up to 64K byte external program memory
- Up to 64 K byte external data memory
- 256 byte on-chip RAM
- Six 8 -bit parallel I/O ports
- One input port for analog/digital input
- Full duplex serial interface (USART)
- 4 operating modes, fixed or variable baud rates
- Three 16 -bit timer/counters
- Timer 0 / 1 (C501 compatible)
- Timer 2 for 16-bit reload, compare, or capture functions
(more features on next page)


Figure 1

## C515 Functional Units

## Features (cont'd):

- 8-bit A/D converter
- 8 multiplexed analog inputs
- Programmable reference voltages
- 16-bit watchdog timer
- Power saving modes
- Idle mode
- Slow down mode (can be combined with idle mode)
- Software power-down mode
- 12 interrupt sources (7 external, 5 internal) selectable at four priority levels
- On-chip emulation support logic (Enhanced Hooks Technology ${ }^{\text {TM }}$ )
- ALE switch-off capability
- P-MQFP-80-1 package
- Temperature Ranges: SAB-C515 $T_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}$

SAF-C515 $\quad T_{\mathrm{A}}=-40$ to $85^{\circ} \mathrm{C}$
SAH-C515 $\quad T_{\mathrm{A}}=-40$ to $110^{\circ} \mathrm{C}$ (max. operating frequency: 16 MHz )

The C515 is an upward compatible version of the SAB 80C515A 8-bit microcontroller which additionally provides ALE switch-off capability, on-chip emulation support, ROM protection, and slow down mode capability. With a maximum external clock rate of 24 MHz it achieves a 500 ns instruction cycle time ( $1 \mu \mathrm{~s}$ at 12 MHz ). The C515 is mounted in a P-MQFP-80 package.

## Ordering Information

| Type | Ordering Code | Package | Description (8-Bit CMOS microcontroller) |
| :---: | :---: | :---: | :---: |
| SAB-C515-1RM | Q67127-DXXXX | P-MQFP-80-1 | with mask programmable ROM ( 16 MHz ) |
| SAB-C515-1R24M | Q67127-DXXXX | P-MQFP-80-1 | with mask programmable ROM ( 24 MHz ) |
| SAF-C515-1RM | Q67127-DXXXX | P-MQFP-80-1 | with mask programmable ROM ( 16 MHz ) ext. temp. $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |
| SAF-C515-1R24M | Q67127-DXXXX | P-MQFP-80-1 | with mask programmable ROM ( 24 MHz ) ext. temp. $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |
| SAB-C515-LM | Q67127-C1030 | P-MQFP-80-1 | for external memory ( 16 MHz ) |
| SAB-C515-L24M | Q67127-C1032 | P-MQFP-80-1 | for external memory ( 24 MHz |
| SAF-C515-LM | Q67127-C1031 | P-MQFP-80-1 | for external memory ( 16 MHz ) ext. temp. $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |
| SAF-C515-L24M | Q67127-C1081 | P-MQFP-80-1 | for external memory ( 24 MHz ) ext. temp. $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |

Note: Versions for extended temperature ranges $-40^{\circ} \mathrm{C}$ to $110{ }^{\circ} \mathrm{C}$ (SAH-C515C-LM and SAH-C515-1RM) are available on request. The ordering number of ROM types (DXXXX extensions) is defined after program release (verification) of the customer.


Figure 2
Logic Symbol

## Additional Literature

For further information about the C515 the following literature is available:

| Title | Ordering Number |
| :--- | :--- |
| C515 8-Bit CMOS Microcontroller User's Manual | B158-H7049-X-X-7600 |
| C500 Microcontroller Family <br> Architecture and Instruction Set User's Manual | B158-H6987-X-X-7600 |
| C500 Microcontroller Family - Pocket Guide | B158-H6986-X-X-7600 |



Figure 3
C515 Pin Configuration (P-MQFP-80 Package, Top View)

Table 1
Pin Definitions and Functions

| Symbol | Pin Number <br> (P-MQFP-80) | I/O*) | Function |
| :--- | :--- | :--- | :--- |
| $\overline{\text { RESET }}$ | 1 | I | RESET <br> A low level on this pin for the duration of two machine <br> cycles while the oscillator is running resets the C515. A <br> small internal pullup resistor permits power-on reset <br> using only a capacitor connected to V |
| VAREF |  |  |  |$|$

*) $1=$ Input
$\mathrm{O}=$ Output

Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number (P-MQFP-80) | I/O*) | Function |
| :---: | :---: | :---: | :---: |
| 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: <br> P3.0 / RxD Receiver data input (asynch.) or data input/output (synch.) of serial interface <br> P3.1 / TxD Transmitter data output (asynch.) or clock output (synch.) of serial interface <br> P3.2 / INTO External interrupt 0 input / timer 0 gate control input <br> P3.3 / INT1 External interrupt 1 input / timer 1 gate control input <br> P3.4 / T0 Timer 0 counter input <br> P3.5/ T1 Timer 1 counter input <br> P3.6 / WR $\overline{W R}$ control output; latches the data byte from port 0 into the external data memory <br> P3.7 / $\overline{R D} \quad \overline{R D}$ control output; enables the external data memory |
|  | 15 |  |  |
|  | 16 |  |  |
|  | 17 |  |  |
|  | 18 |  |  |
|  | 19 |  |  |
|  | 20 |  |  |
|  | 21 |  |  |
|  | 22 |  |  |

[^0]Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number (P-MQFP-80) | I/O*) | Function |
| :---: | :---: | :---: | :---: |
| P1.0-P1.7 | $31-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 : |
|  | 30 |  |  |
|  | 29 |  |  |
|  | 28 |  |  |
|  | 27 |  |  |
|  | 26 |  |  |
|  |  |  |  |
|  |  |  |  |
| $\mathrm{V}_{\text {SS }}$ | 34 | - | Ground (0 V) |
| $\mathrm{V}_{\mathrm{CC}}$ | 33, 69 | - | Supply voltage during normal, idle, and power-down operation. |

*) I = Input
$\mathrm{O}=$ Output

Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number (P-MQFP-80) | I/O*) | Function |
| :---: | :---: | :---: | :---: |
| XTAL2 | 36 | - | 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. |
| XTAL1 | 37 | - | 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. 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{\text { PSEN }}$ | 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. |
| 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. |

*) $1=$ Input
$\mathrm{O}=$ Output

Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number (P-MQFP-80) | 1/0*) | Function |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{EA}}$ | 49 | 1 | External Access Enable <br> When held high, the C515 executes instructions from the internal ROM (C515-1R) as long as the program counter is less than $2000_{\mathrm{H}}$. When held low, the C515 fetches all instructions from ext. program memory. For the C515-L this pin must be tied low. |
| 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 C515-1R. External pullup resistors are required during program verification. |
| P5.B-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{LL}}$, in the DC characteristics) because of the internal pullup resistors. |
| P4.0-P4.7 | $\begin{aligned} & 72-74, \\ & 76-80 \end{aligned}$ | I/O | Port 4 <br> is an 8-bit quasi-bidirectional I/O port with internal pullup 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{LL}}$, in the DC characteristics) because of the internal pull-up resistors. |
| $\overline{\text { PE }}$ | 75 | I | Power saving mode enable <br> A low level on this pin allows the software to enter the power saving modes (idle mode and power down mode). When $\overline{\mathrm{PE}}$ is held at high level it is impossible to enter the power saving modes. When left unconnected this pin is pulled high by a weak internal pull-up resistor. |

*) $1=$ Input
$\mathrm{O}=$ Output

Table 1
Pin Definitions and Functions (cont'd)

| Symbol | Pin Number <br> (P-MQFP-80) | $\mathbf{I} \mathbf{O}^{*}$ ) | Function |
| :--- | :--- | :--- | :--- |
| N.C. | $2,13,14,23$, <br> $32,35,46,50$, <br> $51,68,70,71$ | - | Not connected <br> These pins of the P-MQFP-80 package must not be <br> connected. |
| $\left.{ }^{*}\right)$ I $=$ Input |  |  |  |
| $\mathrm{O}=$ Output |  |  |  |



Figure 4
Block Diagram of the C515C

## CPU

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

Special Function Register PSW (Address $\mathrm{DO}_{\mathrm{H}}$ ) Reset Value : $\mathbf{0 0}_{\mathrm{H}}$

Bit No. MSB LSB

|  | D7H | D6 ${ }_{\text {H }}$ | D5 | D4 | $\mathrm{D}^{\mathrm{H}}$ | D2 | D1 | $\mathrm{DOH}_{\mathrm{H}}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D0H | CY | AC | F0 | RS1 | RS0 | OV | F1 | P | PSW |



## Memory Organization

The C515 CPU manipulates data and operands in the following four address spaces:

- up to 64 Kbyte of internal/external program memory
- up to 64 Kbyte of external data memory
- 256 bytes of internal data memory
- a 128 byte special function register area

Figure 5 illustrates the memory address spaces of the C515.


Figure 5 C515 Memory Map

## 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 ( 24 oscillator periods) while the oscillator is running. A pullup resistor is internally connected to $V_{\mathrm{CC}}$ to allow a power-up reset with an external capacitor only. An automatic reset can be obtained when $V_{\mathrm{Cc}}$ is applied by connecting the RESET pin to $V_{\text {ss }}$ via a capacitor. Figure 6 shows the possible reset circuitries.


Figure 6

## Reset Circuitries

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


Figure 7 Recommended Oscillator Circuitries

## 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 ${ }^{\text {TM }}{ }^{1)}$, 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 8

## 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 programm execution and data transfer between the external emulation hardware (ICE-system) and the C500 MCU.

[^1]
## Special Function Registers

The registers, except the program counter and the four general purpose register banks, reside in the special function register area.

The 59 special function registers (SFRs) include pointers and registers that provide an interface between the CPU and the other on-chip peripherals. All SFRs with addresses where address bits 02 are $0\left(e . g .80_{\mathrm{H}}, 88_{\mathrm{H}}, 90_{\mathrm{H}}, 98_{\mathrm{H}}, \ldots, \mathrm{F}_{\mathrm{H}}, \mathrm{FF}_{\mathrm{H}}\right)$ are bitaddressable.
The SFRs of the C515 are listed in table 2 and table 3. In table 2 they are organized in groups which refer to the functional blocks of the C515. Table 3 illustrates the contents of the SFRs in numeric order of their addresses.

Table 2
Special Function Registers - Functional Blocks

| Block | Symbol | Name | Address | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| CPU | ACC <br> B <br> DPH <br> DPL <br> PSW <br> SP <br> SYSCON | Accumulator <br> B-Register <br> Data Pointer, High Byte <br> Data Pointer, Low Byte <br> Program Status Word Register <br> Stack Pointer <br> System Control Register |  | $\begin{aligned} & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \mathrm{XX} \mathrm{XXXXX}^{3)} \end{aligned}$ |
| A/DConverter | $\begin{aligned} & \text { ADCON }{ }^{2)} \\ & \text { ADDAT } \\ & \text { DAPR } \end{aligned}$ | A/D Converter Control Register A/D Converter Data Register A/D Converter Program Register | $\begin{aligned} & \text { D8 } H^{1)} \\ & D 9_{H} \\ & D A_{H}{ }^{4)} \end{aligned}$ | $\begin{aligned} & 00 \mathrm{X0} 0000_{\mathrm{B}}{ }^{3)} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \hline \end{aligned}$ |
| Interrupt System | IENO ${ }^{2)}$ <br> IEN1 ${ }^{2)}$ <br> IPO ${ }^{2)}$ <br> IP1 <br> IRCON <br> TCON ${ }^{2)}$ <br> T2CON ${ }^{2)}$ <br> SCON ${ }^{2)}$ | Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 Interrupt Priority Register 1 Interrupt Request Control Register Timer Control Register Timer 2 Control Register Serial Channel Control Register |  | $\begin{aligned} & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \mathrm{X} 0000000_{B^{3)}}^{3)} \\ & \mathrm{XXOO} 0000_{\mathrm{B}}{ }^{3)} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \end{aligned}$ |
| Timer 0/ Timer 1 | $\begin{aligned} & \text { TCON }{ }^{2)} \\ & \text { TH0 } \\ & \text { TH1 } \\ & \text { TL0 } \\ & \text { TL1 } \\ & \text { TMOD } \end{aligned}$ | 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_{H}{ }^{1)} \\ & 8 C_{H} \\ & 8 D_{H} \\ & 8 A_{H} \\ & 8 B_{H} \\ & 89_{\mathrm{H}} \\ & \hline \end{aligned}$ | $\begin{aligned} & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \end{aligned}$ |
| Compare/ <br> Capture <br> Unit / <br> 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 ${ }^{2)}$ | Comp./Capture Enable Reg. <br> Comp./Capture Reg. 1, High Byte Comp./Capture Reg. 2, High Byte Comp./Capture Reg. 3, High Byte Comp./Capture Reg. 1, Low Byte Comp./Capture Reg. 2, Low Byte Comp./Capture Reg. 3, Low Byte Com./Rel./Capt. Reg. High Byte Com./Rel./Capt. Reg. Low Byte Timer 2, High Byte Timer 2, Low Byte Timer 2 Control Register | $\mathrm{C}_{\mathrm{H}}$ <br> $\mathrm{C}_{\mathrm{H}} \mathrm{H}$ <br> $\mathrm{C}_{5} \mathrm{H}$ <br> ${ }^{\mathrm{C}} \mathrm{7}_{\mathrm{H}}$ <br> $\mathrm{C}_{2} \mathrm{H}$ <br> $\mathrm{C}_{\mathrm{H}}^{\mathrm{H}}$ <br> $\mathrm{C}_{\mathrm{C}}^{\mathrm{H}}$ <br> $\mathrm{CB}_{\mathrm{H}}$ <br> ${ }^{C A_{H}}$ <br> $\mathrm{CD}_{\mathrm{H}}$ <br> $\mathrm{CC}_{\mathrm{H}}$ <br> $\mathrm{CB}_{\mathrm{H}}{ }^{1)}$ | ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> $0^{00} \mathrm{H}$ <br> $0^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> $0^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ <br> ${ }^{00} \mathrm{H}$ |

1) Bit-addressable special function registers
2) This special function register is listed repeatedly since some bits of it also belong to other functional blocks.
3) " $X$ " means that the value is undefined and the location is reserved

Table 2
Special Function Registers - Functional Blocks (cont'd)

| Block | Symbol | Name | Address | Contents after Reset |
| :---: | :---: | :---: | :---: | :---: |
| Ports | $\begin{aligned} & \text { P0 } \\ & \text { P1 } \\ & \text { P2 } \\ & \text { P3 } \\ & \text { P4 } \\ & \text { P5 } \\ & \text { P6 } \end{aligned}$ | Port 0 <br> Port 1 <br> Port 2 <br> Port 3 <br> Port 4 <br> Port 5 <br> Port 6, Analog/Digital Input |  | $\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> - |
| Serial Channel | $\begin{aligned} & \text { ADCON }^{2)} \\ & \text { PCON }^{2)} \\ & \text { SBUF } \\ & \text { SCON }{ }^{2)} \end{aligned}$ | A/D Converter Control Register Power Control Register Serial Channel Buffer Register Serial Channel Control Register | $\begin{aligned} & \text { D8 } \mathbf{H}^{1} \\ & \mathbf{8 7}_{\mathrm{H}} \\ & 99_{\mathrm{H}} \\ & 98_{\mathbf{H}^{1)}} \end{aligned}$ | $\begin{aligned} & 00 \mathrm{XO} 000 \mathrm{OB}^{3)} \\ & 00_{\mathrm{H}} \\ & \mathrm{X} \mathrm{X}^{3)} \\ & 00_{\mathrm{H}} \end{aligned}$ |
| Watchdog | $\begin{aligned} & \text { IENO }{ }^{2)} \\ & \text { IEN1 }{ }^{2)} \\ & \text { IP0 2) } \end{aligned}$ | Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 | $\begin{aligned} & \mathbf{A 8}^{1 H^{1)}} \\ & \text { B8 }^{11} \\ & \text { A9 }_{\mathbf{H}} \\ & \hline \end{aligned}$ | $\begin{aligned} & 00_{\mathrm{H}} \\ & 00_{\mathrm{H}} \\ & \mathrm{X000} 0000_{\mathrm{B}}{ }^{33)} \end{aligned}$ |
| Power Saving Modes | PCON ${ }^{2}$ | Power Control Register | ${ }^{87} \mathrm{H}$ | ${ }^{00} \mathrm{H}$ |

1) Bit-addressable special function registers
2) This special function register is listed repeatedly since some bits of it also belong to other functional blocks.
3) " $X$ " means that the value is undefined and the location is reserved

Table 3
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^{\text {H2) }}$ | P0 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8{ }^{81} \mathrm{H}$ | SP | ${ }^{07} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8^{82} \mathrm{H}$ | DPL | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{83} \mathrm{H}$ | DPH | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{87} \mathrm{H}$ | PCON | $0^{0} \mathrm{H}$ | SMOD | PDS | IDLS | SD | GF1 | GF0 | PDE | IDLE |
| $88 \mathrm{H}^{2)}$ | TCON | $0^{0} \mathrm{H}$ | TF1 | TR1 | TF0 | TR0 | IE1 | IT1 | IE0 | ITO |
| ${ }^{89} \mathrm{H}$ | TMOD | ${ }^{00} \mathrm{H}$ | GATE | C/T | M1 | M0 | GATE | C/T | M1 | M0 |
| $8 \mathrm{~A}_{\mathrm{H}}$ | TLO | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8^{8 B_{H}}$ | TL1 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8 \mathrm{C}_{\mathrm{H}}$ | TH0 | $0^{0} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $8 \mathrm{D}_{\mathrm{H}}$ | TH1 | $0^{00} \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 |
| $98 \mathrm{H}^{2)}$ | SCON | $0^{0} \mathrm{H}$ | SM0 | SM1 | SM2 | REN | TB8 | RB8 | TI | RI |
| ${ }^{99}{ }_{\text {H }}$ | SBUF | XX ${ }_{\text {H }}$ | . 7 | 6 | . 5 | 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{AO}^{2}{ }^{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 |
| $\mathrm{A9}_{\mathrm{H}}$ | IP0 | $\begin{aligned} & \mathrm{X} 000- \\ & 0000_{\mathrm{B}} \end{aligned}$ | - | WDTS | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{BO}^{2}{ }^{2}$ | P3 | $\mathrm{FF}_{\mathrm{H}}$ | RD | WR | T1 | T0 | INT1 | INTO | TxD | RxD |
| ${ }^{\text {B1 }} \mathrm{H}$ | SYSCON | $\begin{aligned} & \mathrm{XX1X}- \\ & \mathrm{XXXX}_{\mathrm{B}} \end{aligned}$ | - | - | EALE | - | - | - | - | - |
| $\mathrm{B8}^{2}{ }^{2}$ | IEN1 | ${ }^{00} \mathrm{H}$ | EXEN2 | SWDT | EX6 | EX5 | EX4 | EX3 | EX2 | EADC |
| $\mathrm{B9}_{\mathrm{H}}$ | IP1 | $\begin{aligned} & \mathrm{XX00} \\ & 0000_{\mathrm{B}} \end{aligned}$ | - | - | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{CO}^{2}{ }^{2}$ | IRCON | $0^{00} \mathrm{H}$ | EXF2 | TF2 | IEX6 | IEX5 | IEX4 | IEX3 | IEX2 | IADC |
| $\mathrm{Cl}_{\mathrm{H}}$ | CCEN | ${ }^{00} \mathrm{H}$ | $\begin{aligned} & \text { COCA } \\ & \text { H3 } \end{aligned}$ | $\begin{aligned} & \text { COCAL } \\ & 3 \end{aligned}$ | $\begin{aligned} & \text { COCA } \\ & \text { H2 } \end{aligned}$ | $\begin{aligned} & \text { COCAL } \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{COCA} \\ & \mathrm{H} 1 \end{aligned}$ | $\begin{aligned} & \text { COCAL } \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { COCA } \\ & \text { HO } \end{aligned}$ | $\begin{aligned} & \text { COCAL } \\ & 0 \end{aligned}$ |
| C 2 H | CCL1 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |

1) $X$ means that the value is undefined and the location is reserved
2) Bit-addressable special function registers

Table 3
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{C3}_{\mathrm{H}}$ | CCH1 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C}_{4}$ | CCL2 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C}^{\text {¢ }} \mathrm{H}$ | CCH2 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{C6}_{\mathrm{H}}$ | CCL3 | ${ }^{00} \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{C}} \mathrm{H}^{2}$ | T2CON | $0^{00} \mathrm{H}$ | T2PS | I3FR | I2FR | T2R1 | T2R0 | T2CM | T211 | T210 |
| $\mathrm{CA}_{\mathrm{H}}$ | CRCL | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{CBH}_{\mathrm{H}}$ | CRCH | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{CCH}_{\mathrm{H}}$ | TL2 | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{CD}_{\mathrm{H}}$ | TH2 | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{DOH}^{2}$ | PSW | ${ }^{00} \mathrm{H}$ | CY | AC | F0 | RS1 | RS0 | OV | F1 | P |
| $\mathrm{D}^{\text {H }}{ }^{2}$ | ADCON | $\begin{aligned} & 00 \times 0- \\ & 0000_{\mathrm{B}} \end{aligned}$ | BD | CLK | - | BSY | ADM | MX2 | MX1 | MXO |
| D9H | ADDAT | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{DA}_{\mathrm{H}}$ | DAPR | $0^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{\text {DBH }}$ | P6 | - | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| $\mathrm{EOH}^{2}$ | ACC | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| E8 $\mathrm{H}^{2)}$ | P4 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{\text {F0 }} \mathrm{H}^{2}$ | B | ${ }^{00} \mathrm{H}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |
| ${ }^{\text {F }} \mathrm{H}^{2}{ }^{\text {l }}$ | P5 | $\mathrm{FF}_{\mathrm{H}}$ | . 7 | . 6 | . 5 | . 4 | . 3 | . 2 | . 1 | . 0 |

1) $X$ means that the value is undefined and the location is reserved
2) Bit-addressable special function registers

## Digital I/O Ports

The C515 allows for digital I/O on 48 lines grouped into 6 bidirectional 8-bit ports. 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 P5 are performed via their corresponding special function registers P0 to P5.

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, timemultiplexed 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 ADCON. 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 $\left(V_{\mathrm{IL}} / V_{\mathrm{IH}}\right)$. 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.

Timer / Counter 0 and 1
Timer/Counter 0 and 1 can be used in four operating modes as listed in table 4 :
Table 4
Timer/Counter 0 and 1 Operating Modes

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

In the "timer" function ( $\mathrm{C} / \overline{\mathrm{T}}=$ ' 0 ') the register is incremented every machine cycle. Therefore the count rate is $f_{\text {osc }} / 12$.
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 }} / 24$. External inputs $\overline{N T T}$ and $\overline{\mathrm{NT} 1}$ (P3.2, P3.3) can be programmed to function as a gate to facilitate pulse width measurements. Figure 9 illustrates the input clock logic.


Figure 9
Timer/Counter 0 and 1 Input Clock Logic

## Timer/Counter 2 with Compare/Capture/Reload

The timer 2 of the C515 provides additional compare/capture/reload features. which allow the selection of the following operating modes:

- Compare : up to 4 PWM signals with 16 -bit/500 ns resolution
- Capture : up to 4 high speed capture inputs with 500 ns resolution
- Reload : modulation of timer 2 cycle time

The block diagram in figure 10 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 10

## 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 / 12$ or $1 / 24$ 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. $\mathrm{T} 2=0$ stops the counting procedure. This facilitates pulse width measurements. The external gate signal is sampled once every machine cycle.
Event Counter Mode: In the event counter function. the timer 2 is incremented in response to a 1 -to-0 transition at its corresponding external input pin T2 (P1.7). In this function, the external input is sampled every machine cycle. Since it takes two machine cycles ( 24 oscillator periods) to recognize a 1 -to-0 transition, the maximum count rate is $1 / 24$ 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 11 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 11

## 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 chosen 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 12) 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 12

## 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 5. The possible baudrates can be calculated using the formulas given in table 5.

Table 5
USART Operating Modes

| Mode | SCON |  | Description |
| :--- | :---: | :---: | :--- |
|  | SM0 | SM1 |  |
| 0 | 0 | 0 | Shift register mode <br> Serial data enters and exits through $\mathrm{R} \times \mathrm{D} / \mathrm{T} \times \mathrm{D}$ outputs the shift <br> clock; 8-bit are transmitted/received (LSB first); fixed baud rate |
| 1 | 0 | 1 | 8 -bit UART, variable baud rate <br> 10 bits are transmitted (through $T \times \mathrm{D}$ ) or received (at $\mathrm{R} \times \mathrm{D}$ ) |
| 2 | 1 | 0 | 9-bit UART, fixed baud rate <br> 11 bits are transmitted (through $T \times \mathrm{D}$ ) or received (at $\mathrm{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 13 to the serial interface which - there divided by 16 - results in the actual "baud rate". Further, the abbrevation $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 from either timer 1 or from the system clock (see figure 13).


Figure 13
Block Diagram of Baud Rate Generation for the Serial Interface

Table 6 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 6
Serial Interface - Baud Rate Dependencies

| Serial Interface 0 <br> Operating Modes | Active Control Bits |  | Baud Rate Calculation |
| :--- | :--- | :--- | :--- |
|  | BD | SMOD |  |
| Mode 0 (Shift Register) | - | - | $f_{\text {osc }} / 12$ |
| 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 system clock divider circuits : <br> $\left(2^{\text {sMoD }} \times f_{\text {osc }}\right) / 2496$ |
| Mode 2 (9-bit UART) | - | 0 | $f_{\text {osc }} / 64$ <br> $f_{\text {osc }} / 32$ |

## 8-Bit A/D Converter

The C515 provides an A/D converter with the following features:

- Eight multiplexed input channels
- The possibility of using the analog inputs (port 6) also as digital inputs
- Programmable internal reference voltages (16 steps each) via resistor array
- 8-bit resolution within the selected reference voltage range
- Internal start-of-conversion trigger
- Interrupt request generation after each conversion

For the A/D conversion, the method of successive approximation via capacitor array is used. The externally applied reference voltage range has to be held on a fixed value within the specifications (see section "A/D Converter Characteristics" in this data sheet). The internal reference voltages can be varied to reduce the reference voltage range of the A/D converter and thus to achieve a higher resolution. Figure 14 shows a block diagram of the A/D converter.


Figure 14 A/D Converter Block Diagram

## Interrupt System

The C515 provides 12 interrupt sources with four priority levels. Five interrupts can be generated by the on-chip peripherals (timer 0, timer 1, timer 2, A/D converter, and serial interface) and seven interrupts may be triggered externally (P3.2/INT0, P3.3/INT1, P1.4/INT2, P1.0/INT3, P1.1/INT4, P1.2/INT5, P1.3/INT6).

This chapter shows the interrupt structure, the interrupt vectors and the interrupt related special function registers. Figure 15 and 16 give a general overview of the interrupt sources and illustrate the request and the control flags which are described in the next sections.


Figure 15
Interrupt Request Sources (Part 1)


Figure 16
Interrupt Request Sources (Part 2)

Table 7
Interrupt Source and Vectors

| Interrupt Source | Interrupt Vector Address | Interrupt Request Flags |
| :--- | :--- | :--- |
| External Interrupt 0 | $0003_{\mathrm{H}}$ | IE0 |
| 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 |

## Fail Save Mechanisms

As a means of graceful recovery from software or hardware upset a watchdog timer is provided in the C515. If the software fails to clear the watchdog timer at least every $65532 \mu \mathrm{~s}$ (at 12 MHz clock rate), an internal hardware reset will be initiated. The software can be designed such that the watchdog times out if the program does not progress properly. The watchdog will also time out if the software error was due to hardware-related problems. This prevents the controller from malfunctioning for longer than 65 ms if a $12-\mathrm{MHz}$ oscillator is used. Figure 17 shows the block diagram of the watchdog timer unit.


Figure 17

## Block Diagram of the Watchdog Timer

The watchdog timer can be started by software (bit SWDT) but it cannot be stopped during active mode of the C515. If the software fails to clear the watchdog in time, an internally generated watchdog reset is entered at the counter state FFFC $_{H}$ and lasts four instruction cycles. This internal reset differs from an external reset only to the extent that the watchdog timer is not disabled. Bit WDTS (was set by starting WDT) allows the software to examine from which source the reset was initiated. If it is set, the reset was caused by a watchdog timer overflow.

## Power Saving Modes

The C515 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 C515 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. Power down mode is entered by software and can be left by reset or by a short low pulse at pin P3.2/INT0.

- Slow-down mode

The controller keeps up the full operating functionality, but its normal clock frequency is internally divided by 8 . This slows down all parts of the controller, the CPU and all peripherals, to $1 / 8$ th of their normal operating frequency. Slowing down the frequency significantly reduces power consumption.
Table 8 gives a general overview of the entry and exit procedures of the power saving modes.
Table 8
Power Saving Modes Overview

| Mode | Entering <br> 2-Instruction <br> Example | Leaving by | Remarks |
| :--- | :--- | :--- | :--- |
| Idle mode | ORL PCON, \#01H <br> ORL PCON, \#20H | 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 |  |  |

In the power down mode of operation, $V_{\mathrm{CC}}$ can be reduced to minimize power consumption. It must be ensured, however, that $V_{\mathrm{CC}}$ is not reduced before the power down mode is invoked, and that $V_{\mathrm{CC}}$ is restored to its normal operating level, before the power down mode is terminated.

## Absolute Maximum Ratings

Ambient temperature under bias $\left(T_{\mathrm{A}}\right)$
Storage temperature $\left(T_{\text {stg }}\right)$......................................................................... $-65^{\circ} \mathrm{C}$ to $150{ }^{\circ} \mathrm{C}$
Voltage on $V_{\mathrm{CC}}$ pins with respect to ground ( $V_{\mathrm{SS}}$ ) ....................................... -0.5 V to 6.5 V
Voltage on any pin with respect to ground $\left(V_{\mathrm{SS}}\right)$........................................ -0.5 V to $V_{\mathrm{CC}}+0.5 \mathrm{~V}$
Input current on any pin during overload condition. -10 mA to 10 mA
Absolute sum of all input currents during overload condition 1100 mA I
Power dissipation TBD
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 overload conditions ( $V_{I N}>V_{C C}$ or $V_{I N}<V_{S S}$ ) the Voltage on $V_{c c}$ pins with respect to ground ( $V_{S S}$ ) must not exceed the values defined by the absolute maximum ratings.

DC Characteristics
$\begin{array}{ll}V_{\mathrm{CC}}=5 \mathrm{~V}+10 \%,-15 \% ; V_{\mathrm{SS}}=0 \mathrm{~V} & T_{\mathrm{A}}=0 \text { to } 70^{\circ} \mathrm{C} \\ & T_{\mathrm{A}}=-40 \text { to } 85^{\circ} \mathrm{C} \\ & T_{\mathrm{A}}=-40 \text { to } 110^{\circ} \mathrm{C}\end{array}$
for the SAB-C515-1RM for the SAF-C515-1RM for the SAH-C515-1RM

| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |  |
| Input low voltages all except EA EA pin | $\begin{aligned} & V_{\mathrm{lL}} \\ & V_{\mathrm{LL} 1} \end{aligned}$ | $\left\lvert\, \begin{aligned} & -0.5 \\ & -0.5 \end{aligned}\right.$ | $\begin{aligned} & 0.2 V_{\mathrm{CC}}-0.1 \\ & 0.2 V_{\mathrm{CC}}-0.3 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | - |
| Input high voltages all except XTAL2 and RESET XTAL2 pin RESET pin | $\begin{aligned} & V_{\mathrm{IH}} \\ & V_{\mathrm{IH} 1} \\ & V_{\mathrm{IH} 2} \end{aligned}$ | $\begin{array}{\|l} 0.2 V_{\mathrm{CC}}+0.9 \\ 0.7 V_{\mathrm{CC}} \\ 0.6 V_{\mathrm{CC}} \end{array}$ | $\begin{aligned} & V_{\mathrm{CC}}+0.5 \\ & V_{\mathrm{CC}}+0.5 \\ & V_{\mathrm{CC}}+0.5 \end{aligned}$ | $\begin{array}{\|l} \mathrm{V} \\ \mathrm{~V} \\ \mathrm{~V} \end{array}$ | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ |
| Output low voltages <br> Ports 1, 2, 3, 4, 5 <br> Port 0, ALE, PSEN | $\begin{aligned} & V_{\mathrm{OL}} \\ & V_{\mathrm{OL} 1} \\ & \hline \end{aligned}$ | \|- | $\begin{aligned} & 0.45 \\ & 0.45 \end{aligned}$ | $\begin{array}{\|l} \mathrm{V} \\ \mathrm{~V} \end{array}$ | $\begin{aligned} & I_{\mathrm{OL}}=1.6 \mathrm{~mA}^{1)} \\ & I_{\mathrm{OL}}=3.2 \mathrm{~mA}^{11} \end{aligned}$ |
| Output high voltages <br> Ports 1, 2, 3, 4, 5 <br> Port 0 in external bus mode, ALE, $\overline{\text { PSEN }}$ | $\begin{aligned} & V_{\mathrm{OH}} \\ & V_{\mathrm{OH} 2} \end{aligned}$ | $\begin{array}{\|l} 2.4 \\ 0.9 V_{\mathrm{CC}} \\ 2.4 \\ 0.9 V_{\mathrm{CC}} \\ \hline \end{array}$ | - - - - | $\begin{array}{\|l\|} \hline \mathrm{V} \\ \mathrm{~V} \\ \mathrm{~V} \\ \mathrm{~V} \\ \hline \end{array}$ | $\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)} \end{aligned}$ |
| Logic 0 input current Ports 1, 2, 3, 4, 5 | $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 | $I_{\text {TL }}$ | -65 | -650 | $\mu \mathrm{A}$ | $V_{\text {IN }}=2 \mathrm{~V}$ |
| Input leakage current <br> Port 0, AINO-7 (Port 6), EA | $I_{\text {LI }}$ | - | $\pm 1$ | $\mu \mathrm{A}$ | $0.45<V_{\text {IN }}<V_{\text {CC }}$ |
| Input low current to RESET for reset XTAL2 PE | $\begin{aligned} & I_{\mathrm{LL} 2} \\ & I_{\mathrm{LL} 3} \\ & I_{\mathrm{LL} 4} \end{aligned}$ |  | $\begin{aligned} & -100 \\ & -15 \\ & -20 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=0.45 \mathrm{~V} \\ & V_{\text {IN }}=0.45 \mathrm{~V} \\ & V_{\text {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 | 7) 8) |

Notes on next page

Power Supply Current

| Parameter |  | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | typ. ${ }^{\text {9 }}$ | max. ${ }^{10}$ |  |  |
| Active mode | $\begin{aligned} & 16 \mathrm{MHz} \\ & 24 \mathrm{MHz} \end{aligned}$ |  | $\begin{array}{\|l\|l} \hline I_{\mathrm{CC}} \\ I_{\mathrm{CC}} \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 13.7 \\ 19.6 \end{array}$ | $\begin{aligned} & 18.2 \\ & 25 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | 4) |
| Idle mode | $\begin{aligned} & 16 \mathrm{MHz} \\ & 24 \mathrm{MHz} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{CC}} \\ & I_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & 6.9 \\ & 9.1 \end{aligned}$ | $\begin{array}{\|l\|} \hline 9.6 \\ 12.8 \end{array}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | 5) |
| Active mode with slow-down enabled | $\begin{aligned} & 16 \mathrm{MHz} \\ & 24 \mathrm{MHz} \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline I_{\mathrm{CC}} \\ I_{\mathrm{CC}} \\ \hline \end{array}$ | $\begin{aligned} & 4.9 \\ & 6.5 \end{aligned}$ | $\begin{aligned} & 7.0 \\ & 8.8 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | 6) |
| Power-down mode |  | $I_{\text {PD }}$ | 10 | 30 | $\mu \mathrm{A}$ | $V_{\mathrm{CC}}=2 \ldots 5.5 \mathrm{~V}^{3}$ |

1) Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the $V_{\mathrm{OL}}$ of ALE and ports $1,3,4$, and 5 . 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 schmitttrigger, 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_{\text {CC }}$ specification when the address lines are stabilizing.
3) $I_{P D}$ (power-down mode) is measured under following conditions:
$\overline{\mathrm{EA}}=$ Port $0=$ Port $6=V_{\mathrm{CC}} ; \overline{\mathrm{RESET}}=V_{\mathrm{CC}} ; \mathrm{XTAL} 1=\mathrm{N} . \mathrm{C} . ; \overline{\mathrm{PE}}=\mathrm{XTAL} 2=V_{\mathrm{SS}} ; V_{\mathrm{AGND}}=V_{\mathrm{SS}} ; V_{\mathrm{AREF}}=V_{\mathrm{CC}} ;$ all other pins are disconnected. The typical $I_{\mathrm{PD}}$ current is measured at $V_{\mathrm{CC}}=5 \mathrm{~V}$.
4) $I_{\mathrm{CC}}$ (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{CC}}-0.5 \mathrm{~V} ; \mathrm{XTAL} 1=\mathrm{N} . \mathrm{C} . ;$
$\overline{\mathrm{EA}}=$ Port $0=$ Port $6=V_{\mathrm{CC}} ; \mathrm{RESET}=V_{\mathrm{SS}} ;$ all other pins are disconnected.
5) $I_{\mathrm{CC}}$ (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{CC}}-0.5 \mathrm{~V}$; XTAL1 $=\mathrm{N} . \mathrm{C}$.;
$\overline{\mathrm{EA}}=$ Port $0=$ Port $6=V_{\mathrm{CC}} ; \operatorname{RESET}=V_{\mathrm{CC}} ;$ all other pins are disconnected;
6) $I_{\mathrm{CC}}$ (active mode with slow-down mode) is measured: TBD
7) $I_{\mathrm{CC}}$ (active mode with slow-down mode) is measured: TBD
8) Overload conditions occur if the standard operating conditions are exceeded, ie. the voltage on any pin exceeds the specified range (i.e. $V_{\mathrm{OV}}>V_{\mathrm{CC}}+0.5 \mathrm{~V}$ or $V_{\mathrm{OV}}<V_{\mathrm{SS}}-0.5 \mathrm{~V}$ ). The supply voltage $V_{\mathrm{CC}}$ and $V_{\mathrm{SS}}$ must remain within the specified limits. The absolute sum of input currents on all port pins may not exceed 50 mA .
9) Not $100 \%$ tested, guaranteed by design characterization
10)The typical $I_{\mathrm{CC}}$ values are periodically measured at $T_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ but not $100 \%$ tested.
$\qquad$


Active mode

$$
: I_{\mathrm{CC} \text { typ }}=0.68 \times f_{\mathrm{OSC}}+2.8
$$

$$
: I_{\mathrm{CC} \max }=0.85 \times f_{\mathrm{OSC}}+4.6
$$

Idle mode

$$
: I_{\mathrm{CC} \text { typ }}=0.28 \times f_{\mathrm{OSC}}+2.4
$$

$$
: I_{\mathrm{CC} \max }=0.39 \times f_{\mathrm{OSC}}+3.4
$$

Active mode with slow-down: $I_{\mathrm{CC} \text { typ }}=0.18 \times f_{\mathrm{OSC}}+2.0$

$$
: I_{\mathrm{CC} \max }=0.23 \times f_{\mathrm{OSC}}+3.3
$$

$f_{\text {OSC }}$ is the oscillator frequency in MHz . $I_{\mathrm{CC}}$ values are given in mA . MCD03282

Figure 18
ICC Diagram

## A/D Converter Characteristics

$$
\begin{array}{llr}
V_{\mathrm{CC}}=5 \mathrm{~V}+10 \%,-15 \% ; V_{\mathrm{SS}}=0 \mathrm{~V} & T_{\mathrm{A}}=0 \text { to } 70^{\circ} \mathrm{C} & \text { for the SAB-C515-1RM } \\
T_{\mathrm{A}}=-40 \text { to } 85^{\circ} \mathrm{C} & \text { for the SAF-C515-1RM } \\
& T_{\mathrm{A}}=-40 \text { to } 110^{\circ} \mathrm{C} & \text { for the SAH-C515-1RM } \\
V_{\mathrm{CC}}-0.25 \mathrm{~V} \leq V_{\text {AREF }} \leq V_{\mathrm{CC}}+0.25 \mathrm{~V} ; \\
V & V_{\mathrm{SS}}-0.2 \mathrm{~V} \leq V_{\text {AGND }} \leq \mathrm{V}_{\text {SS }}+0.2 \mathrm{~V} ; V_{\text {IntAREF }}-V_{\text {IntAGND }} \geq 1 \mathrm{~V} ;
\end{array}
$$

| Parameter | Symbol | Limit Values |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | min. | max. |  |  |
| Analog input voltage | $V_{\text {AIN }}$ | $\begin{aligned} & V_{\text {AGND }}- \\ & 0.2 \end{aligned}$ | $\begin{aligned} & V_{\text {AREF }}+ \\ & 0.2 \end{aligned}$ | V | 1) |
| A/D converter input clock | $t_{\text {IN }}$ | - | $2 \times t_{\text {CLCL }}$ | ns |  |
| Sample time | $t_{\text {s }}$ | - | $16 \times t_{\text {IN }}$ | ns | 2) |
| Conversion cycle time | $t_{\text {ADCC }}$ | - | $80 \times t_{\text {IN }}$ | ns | 3) |
| Total unadjusted error | $T_{\text {UE }}$ | - | $\pm 1$ | LSB | $\begin{aligned} & V_{\text {IntAREF }}=V_{\text {AREF }}=\mathrm{V}_{\mathrm{CC}} \\ & V_{\text {IntAGND }}=V_{\text {AGND }}=\mathrm{V}_{\mathrm{SS}}{ }^{4)} \end{aligned}$ |
| Internal resistance of reference voltage source | $R_{\text {AREF }}$ | - | $\begin{aligned} & 8 \times t_{\text {IN }} / 500 \\ & -1 \end{aligned}$ | $\mathrm{k} \Omega$ | $t_{\text {IN }}$ in [ns] ${ }^{\text {5) 6) }}$ |
| Internal resistance of analog source | $R_{\text {ASRC }}$ | - | $t_{\mathrm{s}} / 500-1$ | $\mathrm{k} \Omega$ | $t_{\mathrm{S}}$ in [ns] 2) 6 ) |
| ADC input capacitance | $C_{\text {AIN }}$ | - | 45 | pF | 6) |

## Notes:

1) $V_{\text {AIN }}$ may exceed $V_{\text {AGND }}$ or $V_{\text {AREF }}$ up to the absolute maximum ratings. However, the conversion result in these cases will be $00_{\mathrm{H}}$ or $\mathrm{FF}_{\mathrm{H}}$, respectively.
2) During the sample time the input capacitance $\mathrm{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_{s}$. After the end of the sample time ts, changes of the analog input voltage have no effect on the conversion result.
3) This parameter includes the sample time $\mathrm{t}_{\mathrm{S}}$ and the conversion time $\mathrm{t}_{\mathrm{C}}$. The values for the conversion clock $\mathrm{t}_{\mathrm{ADC}}$ is always $8 \times \mathrm{t}_{\mathrm{IN}}$.
4) $\mathrm{T}_{\mathrm{UE}}$ is tested at $\mathrm{V}_{\text {AREF }}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {AGND }}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=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.

AC Characteristics ( $\mathbf{1 6} \mathbf{~ M H z )}$
$V_{\mathrm{CC}}=5 \mathrm{~V}+10 \%,-15 \% ; V_{\mathrm{SS}}=0 \mathrm{~V} \quad T_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C} \quad$ for the SAB-C515-1RM

$$
\begin{array}{ll}
T_{\mathrm{A}}=-40 \text { to } 85^{\circ} \mathrm{C} & \text { for the SAF-C515-1RM } \\
T_{\mathrm{A}}=-40 \text { to } 110^{\circ} \mathrm{C} & \text { for the SAH-C515-1RM }
\end{array}
$$

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

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 16 MHz Clock |  | Variable Clock <br> $1 / t_{\mathrm{CLCL}}=1 \mathrm{MHz}$ to 16 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| ALE pulse width | $t_{\text {LHLL }}$ | 85 | - | $2 t_{\text {CLCL }}-40$ | - | ns |
| Address setup to ALE | $t_{\text {AVLL }}$ | 33 | - | $t_{\text {CLCL }}-30$ | - | ns |
| Address hold after ALE | $t_{\text {LLAX }}$ | 28 | - | $t_{\text {CLCL }}-35$ | - | ns |
| ALE low to valid instr in | $t_{\text {LuIV }}$ | - | 150 | - | $4 t_{\text {CLCL }}-100$ | ns |
| ALE to PSEN | $t_{\text {LLPL }}$ | 38 | - | $t_{\text {CLCL }}-25$ | - | ns |
| PSEN pulse width | $t_{\text {PLPH }}$ | 153 | - | $3 t_{\text {CLCL }}-35$ | - | ns |
| PSEN to valid instr in | $t_{\text {PLIV }}$ | - | 88 | - | $3 t_{\text {CLCL }}-100$ | ns |
| Input instruction hold after PSEN | $t_{\text {PXIX }}$ | 0 | - | 0 | - | ns |
| Input instruction float after PSEN | $t_{\text {PXIZ }}{ }^{*}$ | - | 43 | - | $t_{\text {CLCL }}-20$ | ns |
| Address valid after PSEN | $t_{\text {PXAV }}{ }^{\text { }}$ | 55 | - | $t_{\text {CLCL }}-8$ | - | ns |
| Address to valid instr in | $t_{\text {AVIV }}$ | - | 198 | - | $5 t_{\text {CLCL }}-115$ | ns |
| Address float to PSEN | $t_{\text {AZPL }}$ | 0 | - | 0 | - | ns |

*) Interfacing the C515 to devices with float times up to 75 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers.

## CLKOUT Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 16 MHz Clock |  | Variable Clock <br> $1 / t_{\mathrm{CLCL}}=1 \mathrm{MHz}$ to 16 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| ALE to CLKOUT | $t_{\text {LLSH }}$ | 398 | - | $7 t_{\text {CLCL }}-40$ | - | ns |
| CLKOUT high time | $t_{\text {SHSL }}$ | 85 | - | $2 t_{\text {CLCL }}-40$ | - | ns |
| CLKOUT low time | $t_{\text {SLSH }}$ | 585 | - | $10 t_{\text {CLCL }}-40$ | - | ns |
| CLKOUT low to ALE high | $t_{\text {SLLH }}$ | 23 | 103 | $t_{\text {CLCL }}-40$ | $t_{\text {CLCL }}+40$ | ns |

AC Characteristics ( 16 MHz ) (cont'd)
External Data Memory Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 16 MHz Clock |  | Variable Clock <br> $1 / t_{\mathrm{CLCL}}=1 \mathrm{MHz}$ to 16 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| $\overline{\mathrm{RD}}$ pulse width | $t_{\text {RLRH }}$ | 275 | - | $6 t_{\text {cLCL }}-100$ | - | ns |
| WR pulse width | $t_{\text {WLWH }}$ | 275 | - | $6 t_{\text {cLCL }}-100$ | - | ns |
| Address hold after ALE | $t_{\text {LLAX2 }}$ | 90 | - | $2 t_{\text {CLCL }}-35$ | - | ns |
| $\overline{\mathrm{RD}}$ to valid data in | $t_{\text {RLDV }}$ | - | 148 | - | $5 t_{\text {CLCL }}-165$ | ns |
| Data hold after $\overline{\mathrm{RD}}$ | $t_{\text {RHDX }}$ | 0 | - | 0 | - | ns |
| Data float after $\overline{\mathrm{RD}}$ | $t_{\text {RHDZ }}$ | - | 55 | - | $2 t_{\text {CLCL }}-70$ | ns |
| ALE to valid data in | $t_{\text {LLDV }}$ | - | 350 | - | $8 t_{\text {CLCL }}-150$ | ns |
| Address to valid data in | $t_{\text {AvDV }}$ | - | 398 | - | $9 t_{\text {CLCL }}-165$ | ns |
|  | $t_{\text {LLWL }}$ | 138 | 238 | $3 t_{\text {CLCL }}-50$ | $3 t_{\text {CLCL }}+50$ | ns |
| Address valid to WR or $\overline{\mathrm{RD}}$ | $t_{\text {AVWL }}$ | 120 | - | $4 t_{\text {cLCL }}-130$ | - | ns |
| $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ high to ALE high | $t_{\text {WHLH }}$ | 23 | 103 | $t_{\text {CLCL }}-40$ | $t_{\text {CLCL }}+40$ | ns |
| Data valid to $\overline{\mathrm{WR}}$ transition | $t_{\text {Quwx }}$ | 13 | - | $t_{\text {CLCL }}-50$ | - | ns |
| Data setup before WR | $t_{\text {Qvwh }}$ | 288 | - | $7 t_{\text {CLCL }}-150$ | - | ns |
| Data hold after WR | $t_{\text {WHax }}$ | 13 | - | $t_{\text {CLCL }}-50$ | - | ns |
| Address float after $\overline{\mathrm{RD}}$ | $t_{\text {RLAZ }}$ | - | 0 | - | 0 | ns |

## External Clock Drive Characteristics

| Parameter | Symbol | Limit Values |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Variable Clock <br> Freq. = 1 MHz to 16 MHz |  |  |
|  |  | min. | max. |  |
| Oscillator period | $t_{\text {cLCL }}$ | 62.5 | 1000 | ns |
| High time | $t_{\text {CHCX }}$ | 15 | $t_{\mathrm{CLCL}}-t_{\text {CLCX }}$ | ns |
| Low time | $t_{\text {CLCX }}$ | 15 | $t_{\mathrm{CLCL}}-t_{\text {CHCX }}$ | ns |
| Rise time | $t_{\text {CLCH }}$ | - | 15 | ns |
| Fall time | $t_{\text {CHCL }}$ | - | 15 | ns |

AC Characteristics ( $\mathbf{2 4} \mathbf{~ M H z )}$
$V_{\mathrm{CC}}=5 \mathrm{~V}+10 \%,-15 \% ; V_{\mathrm{SS}}=0 \mathrm{~V} \quad T_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C} \quad$ for the SAB-C515-1RM

$$
\begin{array}{ll}
T_{\mathrm{A}}=-40 \text { to } 85^{\circ} \mathrm{C} & \text { for the SAF-C515-1RM } \\
T_{\mathrm{A}}=-40 \text { to } 110^{\circ} \mathrm{C} & \text { for the SAH-C515-1RM }
\end{array}
$$

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

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 24 MHz Clock |  | Variable Clock <br> $1 / t_{\text {CLCL }}=1 \mathrm{MHz}$ to 24 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| ALE pulse width | $t_{\text {LHLL }}$ | 43 | - | $2 t_{\text {CLCL }}-40$ | - | ns |
| Address setup to ALE | $t_{\text {AVLL }}$ | 17 | - | $t_{\text {CLCL }}-25$ | - | ns |
| Address hold after ALE | $t_{\text {LLAX }}$ | 17 | - | $t_{\text {CLCL }}-25$ | - | ns |
| ALE low to valid instr in | $t_{\text {LuIV }}$ | - | 80 | - | $4 t_{\text {CLCL }}-87$ | ns |
| ALE to PSEN | $t_{\text {LLPL }}$ | 22 | - | $t_{\text {CLCL }}-20$ | - | ns |
| PSEN pulse width | $t_{\text {PLPH }}$ | 95 | - | $3 t_{\text {CLCL }}-30$ | - | ns |
| $\overline{\text { PSEN }}$ to valid instr in | $t_{\text {PLIV }}$ | - | 60 | - | $3 t_{\text {CLCL }}-65$ | ns |
| Input instruction hold after PSEN | $t_{\text {PXIX }}$ | 0 | - | 0 | - | ns |
| Input instruction float after PSEN | $t_{\text {PXIZ }}{ }^{*}$ | - | 32 | - | $t_{\text {CLCL }}-10$ | ns |
| Address valid after PSEN | $t_{\text {PXAV }}{ }^{\text { }}$ | 37 | - | $t_{\text {CLCL }}-5$ | - | ns |
| Address to valid instr in | $t_{\text {AVIV }}$ | - | 148 | - | $5 t_{\text {CLCL }}-60$ | ns |
| Address float to PSEN | $t_{\text {AzPL }}$ | 0 | - | 0 | - | ns |

*) Interfacing the C515 to devices with float times up to 37 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers.

## CLKOUT Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 24 MHz Clock |  | Variable Clock <br> $1 / t_{\mathrm{CLCL}}=1 \mathrm{MHz}$ to 24 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| ALE to CLKOUT | $t_{\text {LLSH }}$ | 252 | - | $7 t_{\text {CLCL }}-40$ | - | ns |
| CLKOUT high time | $t_{\text {SHSL }}$ | 43 | - | $2 t_{\text {CLCL }}-40$ | - | ns |
| CLKOUT low time | $t_{\text {SLSH }}$ | 377 | - | $10 t_{\text {CLCL }}-40$ | - | ns |
| CLKOUT low to ALE high | $t_{\text {SLLH }}$ | 2 | 82 | $t_{\text {CLCL }}-40$ | $t_{\text {CLCL }}+40$ | ns |

AC Characteristics ( $\mathbf{2 4} \mathbf{~ M H z ) ~ ( c o n t ' d ) ~}$
External Data Memory Characteristics

| Parameter | Symbol | Limit Values |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & 24 \mathrm{MHz} \\ & \text { Clock } \end{aligned}$ |  | Variable Clock <br> $1 / t_{\text {CLCL }}=1 \mathrm{MHz}$ to 24 MHz |  |  |
|  |  | min. | max. | min. | max. |  |
| $\overline{\mathrm{RD}}$ pulse width | $t_{\text {RLRH }}$ | 180 | - | $6 t_{\text {cLCL }}-70$ | - | ns |
| WR pulse width | $t_{\text {WLWH }}$ | 180 | - | $6 t_{\text {cLCL }}-70$ | - | ns |
| Address hold after ALE | $t_{\text {LLAX2 }}$ | 15 | - | $t_{\text {CLCL }}-27$ | - | ns |
| $\overline{\mathrm{RD}}$ to valid data in | $t_{\text {RLDV }}$ | - | 118 | - | $5 t_{\text {CLCL }}-90$ | ns |
| Data hold after $\overline{\mathrm{RD}}$ | $t_{\text {RHDX }}$ | 0 | - | 0 | - | ns |
| Data float after $\overline{\mathrm{RD}}$ | $t_{\text {RHDZ }}$ | - | 63 | - | $2 t_{\text {CLCL }}-20$ | ns |
| ALE to valid data in | $t_{\text {LLDV }}$ | - | 200 | - | $8 t_{\text {CLCL }}-133$ | ns |
| Address to valid data in | $t_{\text {AvDV }}$ | - | 220 | - | $9 t_{\text {CLCL }}-155$ | ns |
| ALE to $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ | $t_{\text {LLWL }}$ | 75 | 175 | $3 t_{\text {CLCL }}-50$ | $3 t_{\text {CLCL }}+50$ | ns |
| Address valid to WR or $\overline{\mathrm{RD}}$ | $t_{\text {AVWL }}$ | 67 | - | $4 t_{\text {CLCL }}-97$ | - | ns |
| $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ high to ALE high | $t_{\text {WHLH }}$ | 17 | 67 | $t_{\text {CLCL }}-25$ | $t_{\text {cLCL }}+25$ | ns |
| Data valid to $\overline{W R}$ transition | $t_{\text {avwx }}$ | 5 | - | $t_{\text {CLCL }}-37$ | - | ns |
| Data setup before WR | $t_{\text {Qvwh }}$ | 170 | - | $7 t_{\text {CLCL }}-122$ | - | ns |
| Data hold after WR | $t_{\text {WHax }}$ | 15 | - | $t_{\text {CLCL }}-27$ | - | ns |
| Address float after $\overline{\mathrm{RD}}$ | $t_{\text {RLAZ }}$ | - | 0 | - | 0 | ns |

## External Clock Drive Characteristics

| Parameter | Symbol | Limit Values |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Variable Clock <br> Freq. = 1 MHz to 24 MHz |  |  |
|  |  | min. | max. |  |
| Oscillator period | $t_{\text {CLCL }}$ | 41.7 | 1000 | ns |
| High time | $t_{\text {CHCX }}$ | 12 | $t_{\text {CLCL }}-t_{\text {CLCx }}$ | ns |
| Low time | $t_{\text {CLCX }}$ | 12 | $t_{\text {CLCL }}-t_{\text {CHCX }}$ | ns |
| Rise time | $t_{\text {CLCH }}$ | - | 12 | ns |
| Fall time | $t_{\text {CHCL }}$ | - | 12 | ns |



Figure 19
Program Memory Read Cycle


Figure 20
Data Memory Read Cycle


Figure 21
CLKOUT Timing


Figure 22 Data Memory Write Cycle


Figure 23

## External Clock Drive at XTAL2

ROM Verification Characteristics for the C515-1RM
ROM Verification Mode 1

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



Figure 24
ROM Verification Mode 1

ROM Verification Mode 2

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



Figure 25
ROM Verification Mode 2


AC Inputs during testing are driven at $V_{\mathrm{CC}}-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 26

## AC Testing: Input, Output Waveforms



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

Figure 27
AC Testing : Float Waveforms


Figure 28
Recommended Oscillator Circuits for Crystal Oscillator

## Plastic Package, P-MQFP-80-1 (SMD) <br> (Plastic Metric Quad Flat Package)



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

Figure 29
P-MQFP-80-1 Package Outlines

## Sorts of Packing

Package outlines for tubes, trays etc. are contained in our
Data Book "Package Information"
SMD = Surface Mounted Device


[^0]:    *) I = Input
    $\mathrm{O}=$ Output

[^1]:    1 "Enhanced Hooks Technology" is a trademark and patent of Metalink Corporation licensed to Siemens.

