# **SIEMENS**

# Microcomputer Components

8-Bit CMOS Microcontroller

C515A

| C515A Data Sheet                         |                                 |                                              |  |  |  |  |  |  |
|------------------------------------------|---------------------------------|----------------------------------------------|--|--|--|--|--|--|
| Revision History: Current Version: 10.97 |                                 |                                              |  |  |  |  |  |  |
| Previous Vei                             | rsion:                          | none                                         |  |  |  |  |  |  |
| Page<br>(in previous<br>Version)         | Page<br>(in current<br>Version) | Subjects (major changes since last revision) |  |  |  |  |  |  |
|                                          |                                 |                                              |  |  |  |  |  |  |
|                                          |                                 |                                              |  |  |  |  |  |  |

#### Edition 10.97

Published by Siemens AG, Bereich Halbleiter, Marketing-Kommunikation, Balanstraße 73, 81541 München

© 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<sup>1</sup> of the Semiconductor Group of Siemens AG, may only be used in life-support devices or systems<sup>2</sup> 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.

#### **8-Bit CMOS Microcontroller**

C515A

#### **Advance Information**

- Full upward compatibility with SAB 80C515A/83C515A-5
- Up to 24 MHz external operating frequency
  - 500 ns instruction cycle at 24 MHz operation
- 32K byte on-chip ROM (with optional ROM protection)
  - alternatively up to 64K byte external program memory
- Up to 64K byte external data memory
- 256 byte on-chip RAM
- 1K byte on-chip RAM (XRAM)
- 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

(further features are on next page)



Figure 1 C515A Functional Units

#### Features (cont'd):

- 10-bit A/D converter
  - 8 multiplexed analog inputs
  - Built-in self calibration
- 16-bit watchdog timer
- Power saving modes
  - Slow down mode
  - Idle mode (can be combined with slow down mode)
  - Software power down mode with wake-up capability through INTO pin
  - Hardware power down mode
- 12 interrupt sources (7 external, 5 internal) selectable at 4 priority levels
- ALE switch-off capability
- On-chip emulation support logic (Enhanced Hooks Technology TM)
- P-MQFP-80-1 package
- Temperature Ranges: SAB-C515A T<sub>A</sub> = 0 to 70 °C

SAF-C515A  $T_A = -40$  to 85 °C SAH-C515A  $T_A = -40$  to 85 °C

SAK-C515  $T_A = -40$  to 110 °C (max. operating frequency: 18 MHz)

The C515A is an upward compatible version of the SAB 80C515A/83C515A-5 8-bit microcontroller which additionally provides an improved 10-bit A/D converter, ALE switch-off capability, on-chip emulation support, ROM protection, and enhanced power saving mode capabilities. With a maximum external clock rate of 24 MHz it achieves a 500 ns instruction cycle time (1  $\mu$ s at 12 MHz). The C515A is mounted in a P-MQFP-80 package.

#### Ordering Information

| Туре            | Ordering Code | Package     | Description (8-Bit CMOS microcontroller)                        |  |
|-----------------|---------------|-------------|-----------------------------------------------------------------|--|
| SAB-C515A-4RM   | Q67121-DXXXX  | P-MQFP-80-1 | with mask programmable ROM (18 MHz)                             |  |
| SAF-C515A-4RM   | Q67121-DXXXX  | P-MQFP-80-1 | with mask programmable ROM (18 MHz) ext. temp. – 40 °C to 85 °C |  |
| SAB-C515A-4R24M | Q67121-DXXXX  | P-MQFP-80-1 | with mask programmable ROM (24 MHz)                             |  |
| SAF-C515A-4R24M | Q67121-DXXXX  | P-MQFP-80-1 | with mask programmable ROM (24 MHz) ext. temp. – 40 °C to 85 °C |  |
| SAB-C515A-LM    | Q67121-C1068  | P-MQFP-80-1 | for external memory (18 MHz)                                    |  |
| SAF-C515A-LM    | Q67121-C1069  | P-MQFP-80-1 | for external memory (18 MHz) ext. temp. – 40 °C to 85 °C        |  |
| SAB-C515A-L24M  | Q67121-C1070  | P-MQFP-80-1 | for external memory (24 MHz)                                    |  |
| SAF-C515A-L24M  | Q67127-C2020  | P-MQFP-80-1 | for external memory (24 MHz) ext. temp. – 40 °C to 85 °C        |  |

**Note:** Versions for extended temperature ranges – 40 °C to 110 °C and – 40 °C to 125 °C (SAH-C515A and SAK-C515A) 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 C515A the following literature is available:

| Title                                                                      | Ordering Number     |
|----------------------------------------------------------------------------|---------------------|
| C515A 8-Bit CMOS Microcontroller User's Manual                             | B158-H7051-X-X-7600 |
| C500 Microcontroller Family Architecture and Instruction Set User's Manual | B158-H6987-X-X-7600 |
| C500 Microcontroller Family - Pocket Guide                                 | B158-H6986-X-X-7600 |



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

1997-10-01

Table 1
Pin Definitions and Functions

| Symbol    | Pin Number<br>(P-MQFP-80) | I/O*) | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|-----------|---------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| P4.0-P4.7 | 72-74,<br>76-80           | I/O   | 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>I</i> <sub>IL</sub> , in the DC characteristics) because of the internal pull-up resistors. P4 also contains the external A/D converter control pin. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. The secondary function is assigned to port 6 as follows:  P4.0 / ADST external A/D converter start pin |  |
| PE/SWD    | 75                        | I     | Power Saving Mode Enable / Start Watchdog Timer A low level on this pin allows the software to enter the power down, idle, and slow down mode. In case the low level is also seen during reset, the watchdog timer function is off on default.  Use of the software controlled power saving modes is blocked when this pin is held on high level. A high level during reset performs an automatic start of the watchdog timer immediately after reset.  When left unconnected this pin is pulled high by a weak internal pull-up resistor.  Note: If PE/SWD is low and VAREF is low the oscillator watchdog is disabled (testmode)!                                          |  |
| RESET     | 1                         | I     | RESET  A low level on this pin for the duration of two machine cycles while the oscillator is running resets the C515A.  A small internal pullup resistor permits power-on reset using only a capacitor connected to V <sub>SS</sub> .                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| VAREF     | 3                         | _     | Reference Voltage for the A/D converter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| VAGND     | 4                         | _     | Reference Ground for the A/D converter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| P6.0-P6.7 | 12-5                      | I     | 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 for high/low input voltages and for the eight multiplexed analog inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                |  |

<sup>\*)</sup> I = Input O = Output

Table 1
Pin Definitions and Functions (cont'd)

| Symbol    | Pin Number<br>(P-MQFP-80) | I/O*) | Function                                         |                                                                                             |  |  |
|-----------|---------------------------|-------|--------------------------------------------------|---------------------------------------------------------------------------------------------|--|--|
| P3.0-P3.7 | 15-22                     | I/O   | Port 3                                           |                                                                                             |  |  |
|           |                           |       | 1                                                | si-bidirectional I/O port with internal pullup                                              |  |  |
|           |                           |       |                                                  | 3 pins that have 1's written to them are                                                    |  |  |
|           |                           |       | 1.                                               | the internal pullup resistors, and in that                                                  |  |  |
|           |                           |       |                                                  | sed as inputs. As inputs, port 3 pins being                                                 |  |  |
|           |                           |       | 1 .                                              | ed low will source current ( $I_{IL}$ , in the DC because of the internal pullup resistors. |  |  |
|           |                           |       |                                                  | ntains the interrupt, timer, serial port and                                                |  |  |
|           |                           |       |                                                  | ory strobe pins that are used by various                                                    |  |  |
|           |                           |       |                                                  | utput latch corresponding to a secondary                                                    |  |  |
|           |                           |       | function must be programmed to a one (1) for the |                                                                                             |  |  |
|           |                           |       | function to ope                                  | erate. The secondary functions are                                                          |  |  |
|           |                           |       | _                                                | e pins of port 3, as follows:                                                               |  |  |
|           | 15                        |       | P3.0 / RxD                                       | Receiver data input (asynch.)                                                               |  |  |
|           |                           |       |                                                  | or data input/output (synch.)                                                               |  |  |
|           | 40                        |       | D2 4 / TvD                                       | of serial interface                                                                         |  |  |
|           | 16                        |       | P3.1 / TxD                                       | Transmitter data output (asynch.) or clock output                                           |  |  |
|           |                           |       |                                                  | (synch.) of serial interface                                                                |  |  |
|           | 17                        |       | P3.2 / INT0                                      | External interrupt 0 input /                                                                |  |  |
|           |                           |       | 0.27                                             | timer 0 gate control input                                                                  |  |  |
|           | 18                        |       | P3.3 / ĪNT1                                      | 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 / WR                                        | WR control output; latches                                                                  |  |  |
|           |                           |       |                                                  | the data byte from port 0 into                                                              |  |  |
|           | 22                        |       | P3.7 / RD                                        | the external data memory                                                                    |  |  |
|           | 22                        |       | F3.1 / KD                                        | RD control output; enables the external data memory                                         |  |  |
|           |                           |       |                                                  | ine external data memory                                                                    |  |  |

8

1997-10-01

<sup>\*)</sup> I = Input O = Output

Table 1
Pin Definitions and Functions (cont'd)

| Symbol      | Pin Number<br>(P-MQFP-80) | I/O*) | Function                                |                                                                   |  |  |
|-------------|---------------------------|-------|-----------------------------------------|-------------------------------------------------------------------|--|--|
| P1.0 - P1.7 | 31-24                     | I/O   | Port 1                                  |                                                                   |  |  |
|             |                           |       | is an 8-bit quasi-bidir                 | rectional I/O port with internal pullup                           |  |  |
|             |                           |       | resistors. Port 1 pins                  | s that have 1's written to them are                               |  |  |
|             |                           |       | pulled high by the in                   | ternal pullup resistors, and in that                              |  |  |
|             |                           |       |                                         | s inputs. As inputs, port 1 pins being                            |  |  |
|             |                           |       | 1                                       | will source current (I <sub>IL</sub> , in the DC                  |  |  |
|             |                           |       | 1                                       | ause of the internal pullup resistors.                            |  |  |
|             |                           |       | 1                                       | the low-order address byte during                                 |  |  |
|             |                           |       | · •                                     | . Port 1 also contains the interrupt,                             |  |  |
|             |                           |       | · ·                                     | and compare pins that are used by output latch corresponding to a |  |  |
|             |                           |       |                                         | nust be programmed to a one (1) for                               |  |  |
|             |                           |       | -                                       | ate (except when used for the                                     |  |  |
|             |                           |       |                                         | The secondary functions are                                       |  |  |
|             |                           |       | assigned to the port 1 pins as follows: |                                                                   |  |  |
|             | 31                        |       | P1.0 / INT3 / CC0 Interrupt 3 input /   |                                                                   |  |  |
|             |                           |       |                                         | compare 0 output /                                                |  |  |
|             |                           |       |                                         | capture 0 input                                                   |  |  |
|             | 30                        |       | P1.1 / INT4 / CC1                       | Interrupt 4 input /                                               |  |  |
|             |                           |       |                                         | compare 1 output /                                                |  |  |
|             |                           |       |                                         | capture 1 input                                                   |  |  |
|             | 29                        |       | P1.2 / INT5 / CC2                       | Interrupt 5 input /                                               |  |  |
|             |                           |       |                                         | compare 2 output /                                                |  |  |
|             | 20                        |       | D4 2 / INITC / CC2                      | capture 2 input                                                   |  |  |
|             | 28                        |       | P1.3 / INT6 / CC3                       | Interrupt 6 input / compare 3 output /                            |  |  |
|             |                           |       |                                         | capture 3 input                                                   |  |  |
|             | 27                        |       | P1.4 / ĪNT2                             | Interrupt 2 input                                                 |  |  |
|             | 26                        |       | P1.5 / T2EX                             | Timer 2 external reload /                                         |  |  |
|             |                           |       |                                         | trigger input                                                     |  |  |
|             | 25                        |       | P1.6 / CLKOUT                           | System clock output                                               |  |  |
|             | 24                        |       | P1.7 / T2                               | Counter 2 input                                                   |  |  |
| $V_{CC}$    | 32, 33                    | _     | Supply Voltage                          |                                                                   |  |  |
|             |                           |       | during normal, idle,                    | and power down mode.                                              |  |  |
| $V_{SS}$    | 34, 35                    | -     | Ground (0V)                             |                                                                   |  |  |
|             |                           |       | during normal, idle,                    | and power down operation.                                         |  |  |

<sup>\*)</sup> I = Input O = Output

Table 1
Pin Definitions and Functions (cont'd)

| Symbol    | Pin Number<br>(P-MQFP-80) | I/O*) | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|---------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XTAL2     | 36                        | -     | XTAL2 Input to the inverting oscillator amplifier and input to the internal clock generator circuits. 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 Output of the inverting oscillator amplifier.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| P2.0-P2.7 | 38-45                     | I/O   | 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>I</i> <sub>IL</sub> , 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. |
| 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. ALE can be switched off when the program is executed internally.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

<sup>\*)</sup> I = Input O = Output

Table 1
Pin Definitions and Functions (cont'd)

| Symbol    | Pin Number<br>(P-MQFP-80)                   | I/O*) | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|-----------|---------------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| ĒĀ        | 49                                          | I     | External Access Enable  When held high, the C515A executes instructions from the internal ROM (C515A-4R) as long as the PC is less than 8000 <sub>H</sub> . When held low, the C515A fetches all instructions from external program memory. For the C515A-L this pin must be tied low.                                                                                                                                                                                                                               |  |
| P0.0-P0.7 | 52-59                                       | I/O   | Port 0 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 C515A-4R. External pullup resistors are required during program verification. |  |
| P5.0-P5.7 | 67-60                                       | I/O   | Port 5 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>I</i> <sub>IL</sub> , in the DC characteristics) because of the internal pullup resistors.                                                                                                                          |  |
| HWPD      | 69                                          | I     | Hardware Power Down A low level on this pin for the duration of one machine cycle while the oscillator is running resets the C515A. A low level for a longer period will force the C515A into Hardware Power Down Mode with the pins floating.                                                                                                                                                                                                                                                                       |  |
| N.C.      | 2, 13, 14, 23,<br>46, 50, 51, 68,<br>70, 71 | _     | Not connected These pins of the P-MQFP-80 package need not be connected.                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |

<sup>\*)</sup> I = Input O = Output



Figure 4
Block Diagram of the C515A

Reset Value: 00H

#### CPU

The C515A 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 18 MHz crystal, 58% of the instructions are executed in 666 ns (24 MHz: 500 ns).

## Special Function Register PSW (Address D0<sub>H</sub>)

| Bit No.         | MSB |    |    |     |     |                 |       | LSB |     |
|-----------------|-----|----|----|-----|-----|-----------------|-------|-----|-----|
|                 |     |    |    |     |     | D2 <sub>H</sub> | • • • |     | _   |
| D0 <sub>H</sub> | CY  | AC | F0 | RS1 | RS0 | OV              | F1    | Р   | PSW |

| Bit        | Function                | Function                                                                                                                                      |                                                                |  |  |  |  |  |
|------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--|--|--|--|--|
| CY         | Carry Flag<br>Used by a | g<br>arithmetic in                                                                                                                            | struction.                                                     |  |  |  |  |  |
| AC         |                         | Carry Flag<br>nstructions                                                                                                                     | which execute BCD operations.                                  |  |  |  |  |  |
| F0         | General F               | urpose Fla                                                                                                                                    | 9                                                              |  |  |  |  |  |
| RS1<br>RS0 | ~                       | Register Bank select control bits These bits are used to select one of the four register banks.                                               |                                                                |  |  |  |  |  |
|            | RS1                     | RS0                                                                                                                                           | Function                                                       |  |  |  |  |  |
|            | 0                       | 0                                                                                                                                             | Bank 0 selected, data address 00 <sub>H</sub> -07 <sub>H</sub> |  |  |  |  |  |
|            | 0                       | 1                                                                                                                                             | Bank 1 selected, data address 08 <sub>H</sub> -0F <sub>H</sub> |  |  |  |  |  |
|            | 1                       | 0                                                                                                                                             | Bank 2 selected, data address 10 <sub>H</sub> -17 <sub>H</sub> |  |  |  |  |  |
|            | 1                       | 1                                                                                                                                             | Bank 3 selected, data address 18 <sub>H</sub> -1F <sub>H</sub> |  |  |  |  |  |
| OV         |                         | Overflow Flag Used by arithmetic instruction.                                                                                                 |                                                                |  |  |  |  |  |
| F1         | General F               | General Purpose Flag                                                                                                                          |                                                                |  |  |  |  |  |
| Р          | Set/clear               | Parity Flag Set/cleared by hardware after each instruction to indicate an odd/even number of "one" bits in the accumulator, i.e. even parity. |                                                                |  |  |  |  |  |

#### **Memory Organization**

The C515A CPU manipulates operands in the following five address spaces:

- up to 64 Kbyte of program memory (32K on-chip program memory for C515A-4R)
- up to 64 Kbyte of external data memory
- 256 bytes of internal data memory
- 1K bytes of internal XRAM data memory
- a 128 byte special function register area

Figure 5 illustrates the memory address spaces of the C515A.



Figure 5 C515A Memory Map

#### **Reset and System Clock**

The reset input is an active low input at pin  $\overline{\text{RESET}}$ . Since the reset is synchronized internally, the  $\overline{\text{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_{\text{CC}}$  to allow a power-up reset with an external capacitor only. An automatic reset can be obtained when  $V_{\text{CC}}$  is applied by connecting the  $\overline{\text{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<sup>™ 1)</sup>, which requires embedded logic in the C500 allows the C500 together with an EH-IC to function similar to a bond-out chip. This simplifies the design and reduces costs of an ICE-system. ICE-systems using an EH-IC and a compatible C500 are able to emulate all operating modes of the different versions of the C500 microcontrollers. This includes emulation of ROM, ROM with code rollover and ROMless modes of operation. It is also able to operate in single step mode and to read the SFRs after a break.



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

<sup>1 &</sup>quot;Enhanced Hooks Technology" is a trademark and patent of Metalink Corporation licensed to Siemens.

Reset Value: XX10XX01B

#### **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. One special function register of the C515A (PCON1) is located in the mapped special function register area. For accessing this mapped special function register, 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").

#### Special Function Register SYSCON (Address B1H)



The functions of the shaded bits are not described in this section.

| Bit  | Function                                                                                                                                                                                               |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RMAP | Special function register map bit RMAP = 0: The access to the non-mapped (standard) special function register area is enabled. RMAP = 1: The access to the mapped special function register area (SFR) |
|      | PCON1) is enabled.  Reserved bits for future use. Read by CPU returns undefined values.                                                                                                                |

As long as bit RMAP is set, the mapped special function register area (SFR PCON1) 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 respectively by software.

The 49 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. All SFRs with addresses where address bits 0-2 are 0 (e.g. 80<sub>H</sub>, 88<sub>H</sub>, 90<sub>H</sub>, 98<sub>H</sub>, ..., F8<sub>H</sub>, FF<sub>H</sub>) are bitaddressable. The SFRs of the C515A are listed in **table 2** and **table 3**. In **table 2** they are organized in groups which refer to the functional blocks of the C515A. **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 <sup>2)</sup>                                                                               | Accumulator B-Register Data Pointer, High Byte Data Pointer, Low Byte Program Status Word Register Stack Pointer System/XRAM Control Register                                                                                                                                                                                                                                    | E0H <sup>1)</sup> F0H <sup>1)</sup> 83H 82H D0H <sup>1)</sup> 81H B1H                                                                                                                           | 00H<br>00H<br>00H<br>00H<br>00H<br>07H<br>XX10 XX01B <sup>3)</sup>                                                 |
| A/D-<br>Converter                        | ADCON0 <sup>2)</sup><br>ADCON1<br>ADDATH<br>ADDATL                                                                                        | A/D Converter Control Register 0 A/D Converter Control Register 1 A/D Converter Data Register, High Byte A/D Converter Data Register, low Byte                                                                                                                                                                                                                                   | D8 <sub>H</sub> 1)<br>DC <sub>H</sub><br>D9 <sub>H</sub><br>DA <sub>H</sub> 4)                                                                                                                  | 00 <sub>H</sub><br>0XXX X000 <sub>B</sub> <sup>3)</sup><br>00 <sub>H</sub><br>00XX XXXX <sub>B</sub> <sup>3)</sup> |
| Interrupt<br>System                      | IEN0 <sup>2)</sup> IEN1 <sup>2)</sup> IP0 <sup>2)</sup> IP1 <sup>2)</sup> IRCON TCON <sup>2)</sup> T2CON <sup>2)</sup> SCON <sup>2)</sup> | 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                                                                                                                                           | A8H <sup>1)</sup> B8H <sup>1)</sup> A9H B9H C0H <sup>1)</sup> 88H <sup>1)</sup> C8H <sup>1)</sup>                                                                                               | 00H<br>00H<br>00H<br>XX00 0000B <sup>3)</sup><br>00H<br>00H<br>00H                                                 |
| Timer 0/<br>Timer 1                      | TCON <sup>2)</sup> TH0 TH1 TL0 TL1 TMOD                                                                                                   | Timer 0/1 Control Register Timer 0, High Byte Timer 1, High Byte Timer 0, Low Byte Timer 1, Low Byte Timer Mode Register                                                                                                                                                                                                                                                         | 88 <sub>H</sub> 1)<br>8C <sub>H</sub><br>8D <sub>H</sub><br>8A <sub>H</sub><br>8B <sub>H</sub><br>89 <sub>H</sub>                                                                               | 00H<br>00H<br>00H<br>00H<br>00H<br>00H                                                                             |
| 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 <sup>2)</sup>                                 | Comp./Capture Enable Reg. Comp./Capture Reg. 1, High Byte Comp./Capture Reg. 2, High Byte Comp./Capture Reg. 3, High Byte Comp./Capture Reg. 1, Low Byte Comp./Capture Reg. 2, Low Byte Comp./Capture Reg. 3, Low Byte Comp./Capture Reg. 3, Low Byte Com./Rel./Capt. Reg. High Byte Com./Rel./Capt. Reg. Low Byte Timer 2, High Byte Timer 2, Low Byte Timer 2 Control Register | C1 <sub>H</sub> C3 <sub>H</sub> C5 <sub>H</sub> C7 <sub>H</sub> C2 <sub>H</sub> C4 <sub>H</sub> C6 <sub>H</sub> C6 <sub>H</sub> CA <sub>H</sub> CC <sub>H</sub> CC <sub>H</sub> CC <sub>H</sub> | 00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>00H                                                 |

<sup>1)</sup> Bit-addressable special function registers

<sup>2)</sup> 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                    | P0<br>P1<br>P2<br>P3<br>P4<br>P5<br>P6                                            | Port 0 Port 1 Port 2 Port 3 Port 4 Port 5 Port 6, Analog/Digital Input                                                                                                                                  | 80H <sup>1)</sup><br>90H <sup>1)</sup><br>A0H <sup>1)</sup><br>B0H <sup>1</sup><br>E8H <sup>1)</sup><br>F8H <sup>1)</sup>                               | FF <sub>H</sub> FF <sub>H</sub> FF <sub>H</sub> FF <sub>H</sub> FF <sub>H</sub> FF <sub>H</sub>                                       |
| XRAM                     | XPAGE<br>SYSCON <sup>2)</sup>                                                     | Page Address Register for Extended<br>On-Chip RAM<br>System/XRAM Control Register                                                                                                                       | 91 <sub>H</sub><br>B1 <sub>H</sub>                                                                                                                      | 00 <sub>H</sub><br>XX10 XX01 <sub>B</sub> <sup>3)</sup>                                                                               |
| Serial<br>Channel        | ADCON0 <sup>2)</sup> PCON <sup>2)</sup> SBUF SCON <sup>2)</sup> SRELL SRELH       | A/D Converter Control Register Power Control Register Serial Channel Buffer Register Serial Channel Control Register Serial Channel Reload Register, Low Byte Serial Channel Reload Register, High Byte | <b>D8</b> <sub>H</sub> <sup>1</sup><br>87 <sub>H</sub><br>99 <sub>H</sub><br><b>98</b> <sub>H</sub> <sup>1)</sup><br>AA <sub>H</sub><br>BA <sub>H</sub> | 00 <sub>H</sub><br>00 <sub>H</sub><br>XXH <sup>3)</sup><br>00 <sub>H</sub><br>D9 <sub>H</sub><br>XXXX XX11 <sub>B</sub> <sup>3)</sup> |
| Watchdog                 | IEN0 <sup>2)</sup> IEN1 <sup>2)</sup> IP0 <sup>2))</sup> IP1 <sup>2)</sup> WDTREL | Interrupt Enable Register 0 Interrupt Enable Register 1 Interrupt Priority Register 0 Interrupt Priority Register 1 Watchdog Timer Reload Register                                                      | <b>A8<sub>H</sub></b> <sup>1)</sup><br><b>B8<sub>H</sub></b> <sup>1)</sup><br>A9 <sub>H</sub><br>B9 <sub>H</sub><br>86 <sub>H</sub>                     | 00H<br>00H<br>00H<br>00H<br>00H<br>00H                                                                                                |
| Power<br>Saving<br>Modes | PCON <sup>2)</sup><br>PCON1 <sup>4)</sup>                                         | Power Control Register Power Control Register 1                                                                                                                                                         | 87 <sub>H</sub><br>88 <sub>H</sub>                                                                                                                      | 00H<br>0XXX XXXXB                                                                                                                     |

<sup>1)</sup> Bit-addressable special function registers

<sup>2)</sup> This special function register is listed repeatedly since some bits of it also belong to other functional blocks.

<sup>3) &</sup>quot;X" means that the value is undefined and the location is reserved.

<sup>4)</sup> SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set.

Table 3 Contents of the SFRs, SFRs in numeric order of their addresses

| Addr                         | Register | Content<br>after<br>Reset <sup>1)</sup> | Bit 7       | Bit 6       | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------------------------------|----------|-----------------------------------------|-------------|-------------|-------|-------|-------|-------|-------|-------|
| 80H <sup>2)</sup>            | P0       | FFH                                     | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| 81 <sub>H</sub>              | SP       | 07 <sub>H</sub>                         | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| 82 <sub>H</sub>              | DPL      | 00 <sub>H</sub>                         | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| 83 <sub>H</sub>              | DPH      | 00 <sub>H</sub>                         | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| 86 <sub>H</sub>              | WDTREL   | 00H                                     | WDT<br>PSEL | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| 87 <sub>H</sub>              | PCON     | 00 <sub>H</sub>                         | SMOD        | PDS         | IDLS  | SD    | GF1   | GF0   | PDE   | IDLE  |
| 88H <sup>2)</sup>            | TCON     | 00 <sub>H</sub>                         | TF1         | TR1         | TF0   | TR0   | IE1   | IT1   | IE0   | IT0   |
| 88H <sup>3)</sup>            | PCON1    | 0XXX-<br>XXXX <sub>B</sub>              | EWPD        | -           | -     | -     | -     | -     | -     | _     |
| 89 <sub>H</sub>              | TMOD     | 00 <sub>H</sub>                         | GATE        | C/T         | M1    | MO    | GATE  | C/T   | M1    | MO    |
| 8A <sub>H</sub>              | TL0      | 00 <sub>H</sub>                         | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| 8B <sub>H</sub>              | TL1      | 00 <sub>H</sub>                         | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| 8C <sub>H</sub>              | TH0      | 00 <sub>H</sub>                         | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| 8D <sub>H</sub>              | TH1      | 00 <sub>H</sub>                         | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| 90H <sup>2)</sup>            | P1       | FF <sub>H</sub>                         | T2          | CLK-<br>OUT | T2EX  | ĪNT2  | INT6  | INT5  | INT4  | ĪNT3  |
| 91 <sub>H</sub>              | XPAGE    | 00 <sub>H</sub>                         | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| 98H <sup>2)</sup>            | SCON     | 00 <sub>H</sub>                         | SM0         | SM1         | SM2   | REN   | TB8   | RB8   | TI    | RI    |
| 99 <sub>H</sub>              | SBUF     | хх <sub>Н</sub>                         | T2          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| A0 <sub>H<sup>2)</sup></sub> | P2       | FFH                                     | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| A8H <sup>2)</sup>            | IEN0     | 00 <sub>H</sub>                         | EAL         | WDT         | ET2   | ES    | ET1   | EX1   | ET0   | EX0   |
| A9 <sub>H</sub>              | IP0      | 00 <sub>H</sub>                         | OWDS        | WDTS        | .5    | .4    | .3    | .2    | .1    | .0    |
| $AA_H$                       | SRELL    | D9 <sub>H</sub>                         | .7          | .6          | .5    | .4    | .3    | .2    | .1    | .0    |
| B0H <sup>2)</sup>            | P3       | FFH                                     | RD          | WR          | T1    | T0    | INT1  | INT0  | TxD   | RxD   |
| B1 <sub>H</sub>              | SYSCON   | XX10-<br>XX01 <sub>B</sub>              | _           | _           | EALE  | RMAP  | _     | _     | XMAP1 | XMAP0 |
| B8H <sup>2)</sup>            | IEN1     | 00 <sub>H</sub>                         | EXEN2       | SWDT        | EX6   | EX5   | EX4   | EX3   | EX2   | EADC  |
| B9 <sub>H</sub>              | IP1      | XX00-<br>0000B                          | _           | _           | .5    | .4    | .3    | .2    | .1    | .0    |

<sup>1)</sup> X means that the value is undefined and the location is reserved

<sup>2)</sup> Bit-addressable special function registers3) SFR is located in the mapped SFR area. For accessing this SFR, bit RMAP in SFR SYSCON must be set.

Table 3 Contents of the SFRs, SFRs in numeric order of their addresses (cont'd)

| Addr                         | Register | Content<br>after<br>Reset <sup>1)</sup> | Bit 7      | Bit 6      | Bit 5      | Bit 4      | Bit 3      | Bit 2      | Bit 1      | Bit 0      |
|------------------------------|----------|-----------------------------------------|------------|------------|------------|------------|------------|------------|------------|------------|
| BA <sub>H</sub>              | SRELH    | XXXX-<br>XX11 <sub>B</sub>              | _          | _          | _          | _          | _          | _          | .1         | .0         |
| C0H <sup>2)</sup>            | IRCON    | 00 <sub>H</sub>                         | EXF2       | TF2        | IEX6       | IEX5       | IEX4       | IEX3       | IEX2       | IADC       |
| C1 <sub>H</sub>              | CCEN     | 00 <sub>H</sub>                         | COCA<br>H3 | COCAL<br>3 | COCA<br>H2 | COCAL<br>2 | COCA<br>H1 | COCAL<br>1 | COCA<br>H0 | COCAL<br>0 |
| C2 <sub>H</sub>              | CCL1     | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| C3 <sub>H</sub>              | CCH1     | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| C4 <sub>H</sub>              | CCL2     | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| C5 <sub>H</sub>              | CCH2     | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| C6 <sub>H</sub>              | CCL3     | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| C7 <sub>H</sub>              | ССН3     | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| C8H <sup>2)</sup>            | T2CON    | 00 <sub>H</sub>                         | T2PS       | I3FR       | I2FR       | T2R1       | T2R0       | T2CM       | T2I1       | T2I0       |
| CAH                          | CRCL     | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| СВН                          | CRCH     | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| CCH                          | TL2      | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| CDH                          | TH2      | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| D0 <sub>H<sup>2)</sup></sub> | PSW      | 00 <sub>H</sub>                         | CY         | AC         | F0         | RS1        | RS0        | OV         | F1         | Р          |
| D8 <sub>H<sup>2)</sup></sub> | ADCON0   | 00 <sub>H</sub>                         | BD         | CLK        | ADEX       | BSY        | ADM        | MX2        | MX1        | MX0        |
| D9 <sub>H</sub>              | ADDATH   | 00 <sub>H</sub>                         | .9         | .8         | .7         | .6         | .5         | .4         | .3         | .2         |
| DA <sub>H</sub>              | ADDATL   | 00XX-<br>XXXX <sub>B</sub>              | .1         | .0         | _          | _          | _          | _          | _          | _          |
| DBH                          | P6       | _                                       | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| DCH                          | ADCON1   | 0XXX-<br>X000 <sub>B</sub>              | ADCL       | _          | _          | _          | _          | MX2        | MX1        | MX0        |
| E0H <sup>2)</sup>            | ACC      | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| E8H <sup>2)</sup>            | P4       | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| F0H <sup>2)</sup>            | В        | 00 <sub>H</sub>                         | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |
| F8H <sup>2)</sup>            | P5       | FFH                                     | .7         | .6         | .5         | .4         | .3         | .2         | .1         | .0         |

<sup>1)</sup> X means that the value is undefined and the location is reserved 2) Bit-addressable special function registers

#### **Digital I/O Ports**

The C515A 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, 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 ADCON0. 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_{\rm IL}/V_{\rm 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.

#### 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   | МО | internal              | external (max) |  |
| 0    | 8-bit timer/counter with a divide-by-32 prescaler                                          | 0    | 0  | $f_{ m OSC}/_{12x32}$ | fosc/24x32     |  |
| 1    | 16-bit timer/counter                                                                       | 1    | 1  |                       |                |  |
| 2    | 8-bit timer/counter with 8-bit autoreload                                                  | 1    | 0  | fosc/ <sub>12</sub>   | fosc/24        |  |
| 3    | Timer/counter 0 used as one<br>8-bit timer/counter and one<br>8-bit timer<br>Timer 1 stops | 1    | 1  | 7030 12               | 7030 24        |  |

In the "timer" function (C/T = '0') the register is incremented every machine cycle. Therefore the count rate is  $f_{\rm 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_{\rm OSC}/24$ . External inputs INT0 and INT1 (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 C515A 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.

<u>Timer Mode:</u> In timer function, the count rate is derived from the oscillator frequency. A prescaler offers the possibility of selecting a count rate of 1/12 or 1/24 of the oscillator frequency.

<u>Gated Timer Mode:</u> In gated timer function, the external input pin T2 (P1.7) functions as a gate to the input of timer 2. If T2 is high, the internal clock input is gated to the timer. T2 = 0 stops the counting procedure. This facilitates pulse width measurements. The external gate signal is sampled once every machine cycle.

Event Counter Mode: In the event counter function, the timer 2 is incremented in response to a 1-to-0 transition at its corresponding external input pin T2 (P1.7). In this function, the external input is sampled every machine cycle. Since it takes two machine cycles (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 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 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

| Mada | SC  | ON  | Description                                                                                                                                           |  |
|------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Mode | SM0 | SM1 |                                                                                                                                                       |  |
| 0    | 0   | 0   | Shift register mode Serial data enters and exits through R×D/T×D outputs the shift clock; 8-bit are transmitted/received (LSB first); fixed baud rate |  |
| 1    | 0   | 1   | 8-bit UART, variable baud rate 10 bits are transmitted (through T×D) or received (at R×D)                                                             |  |
| 2    | 1   | 0   | 9-bit UART, fixed baud rate 11 bits are transmitted (through T×D) or received (at R×D)                                                                |  |
| 3    | 1   | 1   | 9-bit UART, variable baud rate<br>Like mode 2                                                                                                         |  |

For clarification some terms regarding the difference between "baud rate clock" and "baud rate" should be mentioned. In the <u>asynchronous modes</u> the serial interfaces require a clock rate which is 16 times the baud rate for internal synchronization. Therefore, the baud rate generators/timers have to provide a "baud rate clock" (output signal in **figure 13** to the serial interface which - there divided by 16 - results in the actual "baud rate". Further, the abbreviation f<sub>OSC</sub> 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 a dedicated baud rate generator (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                         | <b>Active Control Bits</b> |   | Baud Rate Calculation                                                                                                                |  |
|--------------------------------------------|----------------------------|---|--------------------------------------------------------------------------------------------------------------------------------------|--|
| Operating Modes                            | BD SMOD                    |   |                                                                                                                                      |  |
| Mode 0 (Shift Register)                    | _                          | _ | f <sub>osc</sub> / 12                                                                                                                |  |
| Mode 1 (8-bit UART)<br>Mode 3 (9-bit UART) | 0                          | X | Controlled by timer 1 overflow:<br>(2 <sup>SMOD</sup> × timer 1 overflow rate) / 32                                                  |  |
|                                            | 1                          | X | Controlled by baud rate generator $(2^{\text{SMOD}} \times f_{\text{OSC}})$ / $(64 \times \text{baud rate generator overflow rate})$ |  |
| Mode 2 (9-bit UART)                        | _                          | 0 | $f_{ m OSC}$ / 64 $f_{ m OSC}$ / 32                                                                                                  |  |

#### 10-Bit A/D Converter

The C515A provides an A/D converter with 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 A/D converter operates with a successive approximation technique and uses self calibration mechanisms for reduction and compensation of offset and linearity errors. The externally applied reference voltage range has to be held on a fixed value within the specifications. The main functional blocks of the A/D converter are shown in **figure 14**.



Figure 14 A/D Converter Block Diagram

### **Interrupt System**

The C515A 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). 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/INT0.

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 <sub>H</sub>        | IE0                     |
| Timer 0 Overflow               | 000B <sub>H</sub>        | TF0                     |
| External Interrupt 1           | 0013 <sub>H</sub>        | IE1                     |
| Timer 1 Overflow               | 001B <sub>H</sub>        | TF1                     |
| Serial Channel                 | 0023 <sub>H</sub>        | RI/TI                   |
| Timer 2 Overflow / Ext. Reload | 002B <sub>H</sub>        | TF2 / EXF2              |
| A/D Converter                  | 0043 <sub>H</sub>        | IADC                    |
| External Interrupt 2           | 004B <sub>H</sub>        | IEX2                    |
| External Interrupt 3           | 0053 <sub>H</sub>        | IEX3                    |
| External Interrupt 4           | 005B <sub>H</sub>        | IEX4                    |
| External Interrupt 5           | 0063 <sub>H</sub>        | IEX5                    |
| External Interrupt 6           | 006B <sub>H</sub>        | IEX6                    |
| Wake-up from power-down mode   | 007B <sub>H</sub>        | _                       |

#### **Fail Save Mechanisms**

The C515A offers enhanced fail safe mechanisms, which allow an automatic recovery from software upset or hardware failure:

- a programmable watchdog timer (WDT), with variable time-out period from 512  $\mu$ s up to approx. 1.1 s at 12 MHz (256  $\mu$ s up to approx. 0.65 s at 24 MHz)
- an oscillator watchdog (OWD) which monitors the on-chip oscillator and forces the microcontroller into reset state in case the on-chip oscillator fails; it also provides the clock for a fast internal reset after power-on.

The watchdog timer in the C515A is a 15-bit timer, which is incremented by a count rate of  $f_{\rm OSC}/24$  up to  $f_{\rm OSC}/384$ . The system clock of the C515A is divided by two prescalers, a divide-by-two and a divide-by-16 prescaler. For programming of the watchdog timer overflow rate, the upper 7 bit of the watchdog timer can be written. **Figure 15** 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) or by hardware through pin  $\overline{PE}/SWD$ , but it cannot be stopped during active mode of the C515A. 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/INTO 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 18
Block Diagram of the Oscillator Watchdog

## **Power Saving Modes**

The C515A 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.

#### - 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/8th of their normal operating frequency and also reduces power consumption.

### Software 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. This power down mode is entered by software and can be left by reset or by a short low pulse at pin P3.2/INTO.

# - Hardware Power down mode

If pin HWPD gets active (low level) the part enters the hardware power down mode and starts a complete internal reset sequence. Thereafter, both oscillators of the chip are stopped and the port pins and several control lines enter a floating state.

In the power down mode of operation,  $V_{\rm CC}$  can be reduced to minimize power consumption. It must be ensured, however, that  $V_{\rm CC}$  is not reduced before the power down mode is invoked, and that  $V_{\rm CC}$  is restored to its normal operating level, before the power down mode is terminated. **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 interrupt from a peripheral unit | CPU clock is stopped;<br>CPU maintains their data;<br>peripheral units are active (if |
|                             |                                                    | Hardware Reset                                    | enabled) and provided with clock                                                      |
| Slow Down Mode              | In normal mode:<br>ORL PCON,#10H                   | ANL PCON,#0EFH<br>or<br>Hardware Reset            | Internal clock rate is reduced to 1/8 of its nominal frequency                        |
|                             | With idle mode:<br>ORL PCON,#01H<br>ORL PCON, #30H | Occurrence of an interrupt from a peripheral unit | CPU clock is stopped;<br>CPU maintains their data;<br>peripheral units are active (if |
|                             |                                                    | Hardware reset                                    | enabled) and provided with 1/8 of its nominal frequency                               |
| Software                    | ORL PCON, #02H                                     | Hardware Reset                                    | Oscillator is stopped;                                                                |
| Power Down Mode             | ORL PCON, #40H                                     | Short low pulse at pin P3.2/INT0                  | contents of on-chip RAM and SFR's are maintained;                                     |
| Hardware<br>Power Down Mode | HWPD = 0                                           | HWPD = 1                                          | Oscillator is stopped; internal reset is executed;                                    |

## **Absolute Maximum Ratings**

| Ambient temperature under bias $(T_A)$                               | – 40 to + 125 °C                   |
|----------------------------------------------------------------------|------------------------------------|
| Storage temperature ( $T_{\text{stq}}$ )                             | − 65 °C to 150 °C                  |
| Voltage on $V_{\tt CC}$ pins with respect to ground ( $V_{\tt SS}$ ) | - 0.5 V to 6.5 V                   |
| Voltage on any pin with respect to ground $(V_{SS})$                 | $-$ 0.5 V to $V_{\rm CC}$ +0.5 V   |
| Input current on any pin during overload condition                   | <ul><li>– 10 mA to 10 mA</li></ul> |
| Absolute sum of all input currents during overload condition         | I 100 mA I                         |
| Power dissipation of package                                         | 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_{IN} > V_{CC} \text{ or } V_{IN} < V_{SS})$  the Voltage on  $V_{CC}$  pins with respect to ground  $(V_{SS})$  must not exceed the values defined by the absolute maximum ratings.

# **DC Characteristics**

 $V_{\rm CC}$  = 5 V + 10%, - 15%;  $V_{\rm SS}$  = 0 V

 $T_{\rm A}$  = 0 to 70 °C  $T_{\rm A}$  = -40 to 85 °C for the SAB-C515A for the SAF-C515A for the SAH-C515A

 $T_{\rm A} = -40 \text{ to } 110 \,^{\circ}\text{C}$  $T_{\rm A} = -40 \text{ to } 125 \,^{\circ}\text{C}$ 

for the SAK-C515A

| Parameter                                                                         | Symbol                                                           | Limit                                                            | Values                                                         | Unit           | Test Condition                                                                                                       |
|-----------------------------------------------------------------------------------|------------------------------------------------------------------|------------------------------------------------------------------|----------------------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------|
|                                                                                   |                                                                  | min.                                                             | max.                                                           |                |                                                                                                                      |
| Input low voltage Pins except EA,RESET,HWPD EA pin HWPD and RESET pins            | $egin{array}{c} V_{ m IL} \ V_{ m IL1} \ V_{ m IL2} \end{array}$ | - 0.5<br>- 0.5<br>- 0.5                                          | $0.2 V_{CC} - 0.1$ $0.2 V_{CC} - 0.3$ $0.2 V_{CC} + 0.1$       | V<br>V         | -<br>-<br>-                                                                                                          |
| Input high voltage pins except RESET, XTAL2 and HWPD XTAL2 pin RESET and HWPD pin | $V_{IH}$ $V_{IH1}$ $V_{IH2}$                                     | $0.2 \ V_{\rm CC}$ + $0.9$ $0.7 \ V_{\rm CC}$ $0.6 \ V_{\rm CC}$ | $V_{\rm cc}$ + 0.5<br>$V_{\rm cc}$ + 0.5<br>$V_{\rm cc}$ + 0.5 | V<br>V<br>V    | -<br>-<br>-                                                                                                          |
| Output low voltage Ports 1, 2, 3, 4, 5 Port 0, ALE, PSEN                          | $V_{ m OL} \ V_{ m OL1}$                                         | -                                                                | 0.45<br>0.45                                                   | V<br>V         | $I_{OL} = 1.6 \text{ mA}^{-1}$<br>$I_{OL} = 3.2 \text{ mA}^{-1}$                                                     |
| Output high voltage Ports 1, 2, 3, 4, 5  Port 0 in external bus mode, ALE, PSEN   | $V_{OH}$                                                         | 2.4<br>0.9 V <sub>CC</sub><br>2.4<br>0.9 V <sub>CC</sub>         | -<br>-<br>-                                                    | V<br>V<br>V    | $I_{OH} = -80 \mu\text{A}$ $I_{OH} = -10 \mu\text{A}$ $I_{OH} = -800 \mu\text{A}^{2}$ $I_{OH} = -80 \mu\text{A}^{2}$ |
| Logic 0 input current<br>Ports 1, 2, 3, 4, 5                                      | $I_{LI}$                                                         | <b>– 10</b>                                                      | - 70                                                           | μΑ             | $V_{\rm IN} = 0.45  \rm V$                                                                                           |
| Logical 0-to-1 transition current,<br>Ports 1, 2, 3, 4, 5                         | $I_{TL}$                                                         | <b>–</b> 65                                                      | - 650                                                          | μΑ             | V <sub>IN</sub> = 2 V                                                                                                |
| Input leakage current Port 0 and 6, EA, HWPD                                      | $I_{LI}$                                                         | _                                                                | ± 1                                                            | μΑ             | $0.45 < V_{\rm IN} < V_{\rm CC}$                                                                                     |
| Input low current to RESET for reset XTAL2 PE/SWD                                 | $I_{\text{IL2}}$ $I_{\text{IL3}}$ $I_{\text{IL4}}$               | - 10<br>-<br>-                                                   | - 100<br>- 15<br>- 20                                          | μΑ<br>μΑ<br>μΑ | $V_{IN} = 0.45 \text{ V}$<br>$V_{IN} = 0.45 \text{ V}$<br>$V_{IN} = 0.45 \text{ V}$                                  |
| Pin capacitance                                                                   | $C_{10}$                                                         | _                                                                | 10                                                             | pF             | $f_{\rm C}$ = 1 MHz,<br>$T_{\rm A}$ = 25 °C                                                                          |
| Overload current                                                                  | $I_{OV}$                                                         | _                                                                | ± 5                                                            | mA             | 8) 9)                                                                                                                |

Notes see next page

#### **Power Supply Current**

| Parameter                          |                  | Symbol                    | Limit               | Values       | Unit     | <b>Test Condition</b>               |
|------------------------------------|------------------|---------------------------|---------------------|--------------|----------|-------------------------------------|
|                                    |                  |                           | typ. <sup>10)</sup> | max. 11)     |          |                                     |
| Active mode                        | 18 MHz<br>24 MHz | $I_{\rm CC}$ $I_{\rm CC}$ | 16.9<br>21.7        | 23.1<br>29.4 | mA<br>mA | 4)                                  |
| Idle mode                          | 18 MHz<br>24 MHz | $I_{\rm CC}$ $I_{\rm CC}$ | 8.5<br>11.0         | 12.1<br>15.0 | mA<br>mA | 5)                                  |
| Active mode with slow-down enabled | 18 MHz<br>24 MHz | $I_{\rm CC}$ $I_{\rm CC}$ | 5.6<br>6.6          | 8.0<br>9.6   | mA<br>mA | 6)                                  |
| Active mode with slow-down enabled | 18 MHz<br>24 MHz | $I_{\rm CC}$ $I_{\rm CC}$ | 3.0<br>3.3          | 4.1<br>4.7   | mA<br>mA | 7)                                  |
| Power-down mode                    |                  | $I_{PD}$                  | 10                  | 50           | μΑ       | $V_{\rm CC}$ = 25.5 V <sup>3)</sup> |

#### Notes:

- 1) Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the  $V_{\rm OL}$  of ALE and port 3. The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1-to-0 transitions during bus operation. In the worst case (capacitive loading > 100 pF), the noise pulse on ALE line may exceed 0.8 V. In such cases it may be desirable to qualify ALE with a schmitt-trigger, or use an address latch with a schmitt-trigger strobe input.
- 2) Capacitive loading on ports 0 and 2 may cause the  $V_{\rm OH}$  on ALE and PSEN to momentarily fall below the 0.9  $V_{\rm CC}$  specification when the address lines are stabilizing.
- 3)  $I_{PD}$  (software power-down mode) is measured under following conditions: EA =  $\overline{RESET}$  = Port 0 = Port 6 =  $V_{CC}$ ; XTAL1 = N.C.; XTAL2 =  $V_{SS}$ ;  $\overline{PE}/SWD = V_{SS}$ ;  $\overline{HWPD} = V_{CC}$ ;  $V_{AGND} = V_{SS}$ ;  $V_{AREF} = V_{CC}$ ; all other pins are disconnected.  $I_{PD}$  (hardware power-down mode): independent from any particular pin connection.
- 4)  $I_{\rm CC}$  (active mode) is measured with: XTAL2 driven with  $t_{\rm CLCH}$ ,  $t_{\rm CHCL}$  = 5 ns ,  $V_{\rm IL}$  =  $V_{\rm SS}$  + 0.5 V,  $V_{\rm IH}$  =  $V_{\rm CC}$  0.5 V; XTAL1 = N.C.; EA =  $\overline{\rm PE}/{\rm SWD}$  = Port 0 = Port 6 =  $V_{\rm CC}$ ;  $\overline{\rm HWPD}$  =  $V_{\rm CC}$ ;  $\overline{\rm RESET}$  =  $V_{\rm SS}$ ; all other pins are disconnected.  $I_{\rm CC}$  would be slightly higher if a crystal oscillator is used (appr. 1 mA).
- 5)  $I_{\text{CC}}$  (idle mode) is measured with all output pins disconnected and with all peripherals disabled; XTAL2 driven with  $t_{\text{CLCH}}$ ,  $t_{\text{CHCL}} = 5$  ns,  $V_{\text{IL}} = V_{\text{SS}} + 0.5$  V,  $V_{\text{IH}} = V_{\text{CC}} 0.5$  V; XTAL1 = N.C.;  $\overline{\text{RESET}} = V_{\text{CC}}$ ;  $\overline{\text{HWPD}} = \text{Port 0} = \text{Port 6} = V_{\text{CC}}$ ;  $\overline{\text{EA}} = \overline{\text{PE}}/\text{SWD} = V_{\text{SS}}$ ; all other pins are disconnected;
- 6)  $I_{\rm CC}$  (active mode with slow-down mode) is measured with all output pins disconnected and with all peripherals disabled; XTAL2 driven with  $t_{\rm CLCH}$ ,  $t_{\rm CHCL}$  = 5 ns,  $V_{\rm IL}$  =  $V_{\rm SS}$  + 0.5 V,  $V_{\rm IH}$  =  $V_{\rm CC}$  0.5 V; XTAL1 = N.C.;  $\overline{\rm RESET} = V_{\rm CC}$ ;  $\overline{\rm HWPD}$  = Port 6 =  $V_{\rm CC}$ ;  $\overline{\rm EA}$  =  $\overline{\rm PE}/{\rm SWD}$  =  $V_{\rm SS}$ ; all other pins are disconnected; the microcontroller is put into slow-down mode by software;
- 7)  $I_{\text{CC}}$  (idle mode with slow-down mode) is measured with all output pins disconnected and with all peripherals disabled; XTAL2 driven with  $t_{\text{CLCH}}$ ,  $t_{\text{CHCL}} = 5$  ns,  $V_{\text{IL}} = V_{\text{SS}} + 0.5$  V,  $V_{\text{IH}} = V_{\text{CC}} 0.5$  V; XTAL1 = N.C.; RESET =  $V_{\text{CC}}$ ; HWPD = Port 6 =  $V_{\text{CC}}$ ; EA =  $\overline{\text{PE}}/\text{SWD} = V_{\text{SS}}$ ; all other pins are disconnected; the microcontroller is put into idle mode with slow-down mode enabled by software;
- 8) Overload conditions occur if the standard operating conditions are exceeded, i.e. the voltage on any pin exceeds the specified range (i.e.  $V_{\rm OV} > V_{\rm CC} + 0.5$  V or  $V_{\rm OV} < V_{\rm SS}$  0.5 V). The supply voltage  $V_{\rm CC}$  and  $V_{\rm 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_{CC}$  values are periodically measured at  $T_A$  = +25 °C and  $V_{CC}$  = 5 V but not 100% tested.
- 11)The maximum  $I_{\rm CC}$  values are measured under worst case conditions ( $T_{\rm A}$  = 0  $^{\circ}{\rm C}$  or -40  $^{\circ}{\rm C}$  and  $V_{\rm CC}$  = 5.5 V)



Figure 19 ICC Diagram

**Table 9 Power Supply Current Calculation Formulas** 

| Parameter                          | Symbol                            | Formula                                          |
|------------------------------------|-----------------------------------|--------------------------------------------------|
| Active mode                        | $I_{ m CC\ typ}$ $I_{ m CC\ max}$ | $0.79 * f_{OSC} + 2.7$<br>$1.04 * f_{OSC} + 4.4$ |
| Idle mode                          | $I_{ m CC\ typ} \ I_{ m CC\ max}$ | $0.43 * f_{OSC} + 0.7$<br>$0.48 * f_{OSC} + 3.5$ |
| Active mode with slow-down enabled | $I_{ m CC\ typ}$ $I_{ m CC\ max}$ | $0.17 * f_{OSC} + 2.5$<br>$0.28 * f_{OSC} + 2.9$ |
| Idle mode with slow-down enabled   | $I_{ m CC\ typ}$ $I_{ m CC\ max}$ | $0.06 * f_{OSC} + 1.9$<br>$0.09 * f_{OSC} + 2.5$ |

**Note**:  $f_{\rm osc}$  is the oscillator frequency in MHz.  $I_{\rm CC}$  values are given in mA.

### A/D Converter Characteristics

 $V_{\mathrm{CC}}$  = 5 V + 10%, - 15%;  $V_{\mathrm{SS}}$  = 0 V

 $T_{\rm A}$  = 0 to 70 °C  $T_{\rm A} = -40 \text{ to } 85 \,^{\circ}\text{C}$ 

for the SAB-C515A for the SAF-C515A

 $T_{\rm A}$  = - 40 to 110 °C

for the SAH-C515A

 $T_{\rm A}$  = -40 to 125 °C

for the SAK-C515A

4 V 
$$\leq V_{\mathsf{AREF}} \leq V_{\mathsf{CC}}$$
 + 0.1 V;  $V_{\mathsf{SS}}$  – 0.1 V  $\leq V_{\mathsf{AGND}} \leq V_{\mathsf{SS}}$  + 0.2 V

| Parameter                                       | Symbol      | ol Limit Values |                                                | Unit | Test Condition                                                               |  |
|-------------------------------------------------|-------------|-----------------|------------------------------------------------|------|------------------------------------------------------------------------------|--|
|                                                 |             | min.            | max.                                           |      |                                                                              |  |
| Analog input voltage                            | $V_{AIN}$   | $V_{AGND}$      | $V_{AREF}$                                     | V    | 1)                                                                           |  |
| Sample time                                     | $t_{\rm S}$ | _               | $16 \times t_{\rm IN} \\ 8 \times t_{\rm IN}$  | ns   | Prescaler ÷ 8 Prescaler ÷ 4 <sup>2)</sup>                                    |  |
| Conversion cycle time                           | $t_{ADCC}$  | _               | $96 \times t_{\rm IN} $ $48 \times t_{\rm IN}$ | ns   | Prescaler ÷ 8 Prescaler ÷ 4 <sup>3)</sup>                                    |  |
| Total unadjusted error                          | TUE         | _               | ± 2                                            | LSB  | $V_{\rm SS}$ + 0.5 V $\leq$ $V_{\rm IN}$ $\leq$ $V_{\rm CC}$ - 0.5 V $^{4)}$ |  |
| Internal resistance of reference voltage source | $R_{AREF}$  | _               | <i>t</i> <sub>ADC</sub> / 250 – 1              | kΩ   | t <sub>ADC</sub> in [ns] <sup>5) 6)</sup>                                    |  |
| Internal resistance of analog source            | $R_{ASRC}$  | _               | <i>t</i> <sub>S</sub> / 500 – 0.8              | kΩ   | t <sub>S</sub> in [ns] <sup>2) 6)</sup>                                      |  |
| ADC input capacitance                           | $C_{AIN}$   | _               | 50                                             | pF   | 6)                                                                           |  |

Notes see next page.

# **Clock calculation table:**

| Clock Prescaler<br>Ratio | ADCL | $t_{ADC}$                | $t_{\rm S}$               | $t_{ADCC}$                |
|--------------------------|------|--------------------------|---------------------------|---------------------------|
| ÷ 8                      | 1    | $8 \times t_{\text{IN}}$ | $16 \times t_{\text{IN}}$ | $96 \times t_{\text{IN}}$ |
| ÷ 4                      | 0    | $4 \times t_{IN}$        | $8 \times t_{\text{IN}}$  | $48 \times t_{\text{IN}}$ |

Further timing conditions:  $t_{ADC} \min = 500 \text{ ns}$ 

 $t_{\text{IN}} = 2 / f_{\text{OSC}} = 2 t_{\text{CLCL}}$ 

#### Notes:

- 1)  $V_{AIN}$  may exceed  $V_{AGND}$  or  $V_{AREF}$  up to the absolute maximum ratings. However, the conversion result in these cases will be  $X000_H$  or  $X3FF_H$ , respectively.
- 2) During the sample time the input capacitance  $C_{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  $t_{S}$ , changes of the analog input voltage have no effect on the conversion result.
- 3) This parameter includes the sample time  $t_S$ , the time for determining the digital result and the time for the calibration. Values for the conversion clock  $t_{ADC}$  depend on programming and can be taken from the table on the previous page.
- 4) T<sub>UE</sub> is tested at V<sub>AREF</sub> = 5.0 V, V<sub>AGND</sub> = 0 V, V<sub>CC</sub> = 4.9 V. It is guaranteed by design characterization for all other voltages within the defined voltage range.
  If an overload condition occurs on maximum 2 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 (18 MHz)**

 $V_{\rm CC}$  = 5 V + 10%, - 15%;  $V_{\rm SS}$  = 0 V  $T_{\rm A}$  = 0 to 70 °C for the SAB-C515A  $T_{\rm A}$  = - 40 to 85 °C for the SAF-C515A  $T_{\rm A}$  = - 40 to 110 °C for the SAH-C515A  $T_{\rm A}$  = - 40 to 125 °C for the SAK-C515A

\_\_\_\_\_

( $C_L$  for port 0, ALE and PSEN outputs = 100 pF;  $C_L$  for all other outputs = 80 pF)

# **Program Memory Characteristics**

| Parameter                          | Symbol              | Limit Values    |      |                                                                  |                               |    |
|------------------------------------|---------------------|-----------------|------|------------------------------------------------------------------|-------------------------------|----|
|                                    |                     | 18 MHz<br>Clock |      | Variable Clock $1/t_{CLCL} = 3.5 \text{ MHz to } 18 \text{ MHz}$ |                               |    |
|                                    |                     | min.            | max. | min.                                                             | max.                          |    |
| ALE pulse width                    | $t_{LHLL}$          | 71              | _    | 2 t <sub>CLCL</sub> - 40                                         | _                             | ns |
| Address setup to ALE               | t <sub>AVLL</sub>   | 26              | _    | $t_{\text{CLCL}} - 30$                                           | _                             | ns |
| Address hold after ALE             | $t_{LLAX}$          | 26              | _    | $t_{\rm CLCL} - 30$                                              | _                             | ns |
| ALE low to valid instruction in    | t <sub>LLIV</sub>   | _               | 122  | _                                                                | 4 t <sub>CLCL</sub> - 100     | ns |
| ALE to PSEN                        | $t_{LLPL}$          | 31              | _    | t <sub>CLCL</sub> - 25                                           | _                             | ns |
| PSEN pulse width                   | $t_{PLPH}$          | 132             | _    | 3 t <sub>CLCL</sub> - 35                                         | _                             | ns |
| PSEN to valid instruction in       | $t_{PLIV}$          | _               | 92   | _                                                                | 3 t <sub>CLCL</sub> - 75      | ns |
| Input instruction hold after PSEN  | $t_{PXIX}$          | 0               | _    | 0                                                                | _                             | ns |
| Input instruction float after PSEN | $t_{PXIZ}^{*)}$     | _               | 46   | _                                                                | <i>t</i> <sub>CLCL</sub> – 10 | ns |
| Address valid after PSEN           | $t_{PXAV}^{\star)}$ | 48              | _    | $t_{\rm CLCL} - 8$                                               | _                             | ns |
| Address to valid instr in          | t <sub>AVIV</sub>   | _               | 180  | _                                                                | 5 t <sub>CLCL</sub> - 98      | ns |
| Address float to PSEN              | $t_{AZPL}$          | 0               | _    | 0                                                                | _                             | ns |

<sup>\*)</sup> Interfacing the C515A to devices with float times up to 48 ns is permissible. This limited bus contention will not cause any damage to port 0 drivers.

# AC Characteristics (18 MHz, cont'd)

# **External Data Memory Characteristics**

| Parameter                   | Symbol         | Limit Values    |      |                                                                     |                               |    |
|-----------------------------|----------------|-----------------|------|---------------------------------------------------------------------|-------------------------------|----|
|                             |                | 18 MHz<br>Clock |      | Variable Clock $1/t_{\rm CLCL} = 3.5 \ \rm MHz \ to \ 18 \ \rm MHz$ |                               |    |
|                             |                | min.            | max. | min.                                                                | max.                          |    |
| RD pulse width              | $t_{RLRH}$     | 233             | _    | 6 t <sub>CLCL</sub> - 100                                           | _                             | ns |
| WR pulse width              | $t_{WLWH}$     | 233             | _    | 6 t <sub>CLCL</sub> - 100                                           | _                             | ns |
| Address hold after ALE      | $t_{LLAX2}$    | 81              | _    | 2 t <sub>CLCL</sub> - 30                                            | _                             | ns |
| RD to valid data in         | $t_{RLDV}$     | _               | 128  | _                                                                   | 5 t <sub>CLCL</sub> - 150     | ns |
| Data hold after RD          | $t_{RHDX}$     | 0               | _    | 0                                                                   | _                             | ns |
| Data float after RD         | $t_{RHDZ}$     | _               | 51   | _                                                                   | 2 t <sub>CLCL</sub> - 60      | ns |
| ALE to valid data in        | $t_{LLDV}$     | _               | 294  | _                                                                   | 8 t <sub>CLCL</sub> - 150     | ns |
| Address to valid data in    | $t_{AVDV}$     | _               | 335  | _                                                                   | 9 t <sub>CLCL</sub> - 165     | ns |
| ALE to WR or RD             | $t_{\sf LLWL}$ | 117             | 217  | 3 t <sub>CLCL</sub> - 50                                            | 3 t <sub>CLCL</sub> + 50      | ns |
| Address valid to WR or RD   | $t_{AVWL}$     | 92              | _    | 4 t <sub>CLCL</sub> - 130                                           | _                             | ns |
| WR or RD high to ALE high   | $t_{WHLH}$     | 16              | 96   | $t_{\rm CLCL} - 40$                                                 | <i>t</i> <sub>CLCL</sub> + 40 | ns |
| Data valid to WR transition | $t_{QVWX}$     | 11              | _    | t <sub>CLCL</sub> - 45                                              | _                             | ns |
| Data setup before WR        | $t_{\sf QVWH}$ | 239             | _    | 7 t <sub>CLCL</sub> – 150                                           | _                             | ns |
| Data hold after WR          | $t_{WHQX}$     | 16              | _    | t <sub>CLCL</sub> - 40                                              | _                             | ns |
| Address float after RD      | $t_{RLAZ}$     | _               | 0    | _                                                                   | 0                             | ns |

# **External Clock Drive Characteristics**

| Parameter         | Symbol     |      | Unit                          |    |
|-------------------|------------|------|-------------------------------|----|
|                   |            | Freq |                               |    |
|                   |            | min. | max.                          |    |
| Oscillator period | $t_{CLCL}$ | 55.6 | 285.7                         | ns |
| High time         | $t_{CHCX}$ | 15   | $t_{CLCL} - t_{CLCX}$         | ns |
| Low time          | $t_{CLCX}$ | 15   | $t_{\rm CLCL} - t_{\rm CHCX}$ | ns |
| Rise time         | $t_{CLCH}$ | _    | 15                            | ns |
| Fall time         | $t_{CHCL}$ | _    | 15                            | ns |

# **AC Characteristics (24 MHz)**

 $V_{\rm CC}$  = 5 V + 10%, - 15%;  $V_{\rm SS}$  = 0 V

 $T_{\rm A}$  = 0 to 70 °C  $T_{\rm A} = 0$  to 70 °C  $T_{\rm A} = -40$  to 85 °C 40 to 110 °C for the SAB-C515A

 $T_{\rm A} = -40 \text{ to } 110 \,^{\circ}\text{C}$ 

for the SAF-C515A for the SAH-C515A

( $C_L$  for port 0, ALE and PSEN outputs = 100 pF;  $C_L$  for all other outputs = 80 pF)

# **Program Memory Characteristics**

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

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

# AC Characteristics (24 MHz, cont'd)

# **External Data Memory Characteristics**

| Parameter                   | Symbol             | Limit Values    |      |                                                                  |                               |    |
|-----------------------------|--------------------|-----------------|------|------------------------------------------------------------------|-------------------------------|----|
|                             |                    | 24 MHz<br>Clock |      | Variable Clock $1/t_{CLCL} = 3.5 \text{ MHz to } 24 \text{ MHz}$ |                               |    |
|                             |                    | min.            | max. | min.                                                             | max.                          |    |
| RD pulse width              | $t_{RLRH}$         | 180             | _    | 6 t <sub>CLCL</sub> - 70                                         | _                             | ns |
| WR pulse width              | t <sub>WLWH</sub>  | 180             | _    | 6 t <sub>CLCL</sub> - 70                                         | _                             | ns |
| Address hold after ALE      | t <sub>LLAX2</sub> | 56              | _    | 2 t <sub>CLCL</sub> - 27                                         | _                             | ns |
| RD to valid data in         | $t_{RLDV}$         | _               | 118  | _                                                                | 5 t <sub>CLCL</sub> - 90      | ns |
| Data hold after RD          | $t_{RHDX}$         | 0               | _    | 0                                                                | _                             | ns |
| Data float after RD         | $t_{RHDZ}$         | _               | 63   | _                                                                | 2 t <sub>CLCL</sub> – 20      | ns |
| ALE to valid data in        | $t_{LLDV}$         | _               | 200  | _                                                                | 8 t <sub>CLCL</sub> - 133     | ns |
| Address to valid data in    | $t_{AVDV}$         | _               | 220  | _                                                                | 9 t <sub>CLCL</sub> - 155     | ns |
| ALE to WR or RD             | $t_{LLWL}$         | 75              | 175  | 3 t <sub>CLCL</sub> - 50                                         | 3 t <sub>CLCL</sub> + 50      | ns |
| Address valid to WR or RD   | t <sub>AVWL</sub>  | 67              | _    | 4 t <sub>CLCL</sub> – 97                                         | _                             | ns |
| WR or RD high to ALE high   | $t_{WHLH}$         | 17              | 67   | t <sub>CLCL</sub> - 25                                           | <i>t</i> <sub>CLCL</sub> + 25 | ns |
| Data valid to WR transition | $t_{QVWX}$         | 5               | _    | t <sub>CLCL</sub> - 37                                           | _                             | ns |
| Data setup before WR        | $t_{\sf QVWH}$     | 170             | _    | 7 t <sub>CLCL</sub> – 122                                        | _                             | ns |
| Data hold after WR          | $t_{WHQX}$         | 15              | _    | t <sub>CLCL</sub> - 27                                           | _                             | ns |
| Address float after RD      | $t_{RLAZ}$         | _               | 0    | _                                                                | 0                             | ns |

# **External Clock Drive Characteristics**

| Parameter         | Symbol     |      | Unit                          |    |
|-------------------|------------|------|-------------------------------|----|
|                   |            | Freq |                               |    |
|                   |            | min. | max.                          |    |
| Oscillator period | $t_{CLCL}$ | 41.7 | 285.7                         | ns |
| High time         | $t_{CHCX}$ | 12   | $t_{\rm CLCL} - t_{\rm CLCX}$ | ns |
| Low time          | $t_{CLCX}$ | 12   | $t_{\rm CLCL} - t_{\rm CHCX}$ | ns |
| Rise time         | $t_{CLCH}$ | _    | 12                            | ns |
| Fall time         | $t_{CHCL}$ | _    | 12                            | ns |



Figure 20 Program Memory Read Cycle



Figure 21 Data Memory Read Cycle



Figure 22 Data Memory Write Cycle



Figure 23
External Clock Drive on XTAL2

# **ROM Verification Characteristics for the C515A-1RM**

# **ROM Verification Mode 1**

| Parameter             | Symbol            | Limit \ | Unit                 |    |
|-----------------------|-------------------|---------|----------------------|----|
|                       |                   | min.    | max.                 |    |
| Address to valid data | t <sub>AVQV</sub> | _       | 10 t <sub>CLCL</sub> | ns |



Figure 24 ROM Verification Mode 1

# **ROM Verification Mode 2**

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



Figure 25 ROM Verification Mode 2



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

Figure 26
AC Testing: Input, Output Waveforms



Figure 27 AC Testing : Float Waveforms



Figure 28
Recommended Oscillator Circuits for Crystal Oscillator



Figure 29 P-MQFP-80-1 Package Outline

# **Sorts of Packing**

Package outlines for tubes, trays etc. are contained in our Data Book "Package Information"

SMD = Surface Mounted Device

Dimensions in mm