# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China



Data Sheet, V1.1, Aug. 2006

# XC164CS-32F/32R 16-Bit Single-Chip Microcontroller with C166SV2 Core

Microcontrollers



Never stop thinking

Edition 2006-08 Published by Infineon Technologies AG 81726 München, Germany © Infineon Technologies AG 2006. All Rights Reserved.

#### Legal Disclaimer

The information given in this document shall in no event be regarded as a guarantee of conditions or characteristics ("Beschaffenheitsgarantie"). With respect to any examples or hints given herein, any typical values stated herein and/or any information regarding the application of the device, Infineon Technologies hereby disclaims any and all warranties and liabilities of any kind, including without limitation warranties of non-infringement of intellectual property rights of any third party.

#### Information

For further information on technology, delivery terms and conditions and prices please contact your nearest Infineon Technologies Office (www.infineon.com).

#### Warnings

Due to technical requirements components may contain dangerous substances. For information on the types in question please contact your nearest Infineon Technologies Office.

Infineon Technologies Components may only be used in life-support devices or systems with the express written approval of Infineon Technologies, if a failure of such components can reasonably be expected to cause the failure of that life-support device or system, or to affect the safety or effectiveness of that device or system. Life support devices or systems are intended to be implanted in the human body, or to support and/or maintain and sustain and/or protect human life. If they fail, it is reasonable to assume that the health of the user or other persons may be endangered.

Data Sheet, V1.1, Aug. 2006

# XC164CS-32F/32R 16-Bit Single-Chip Microcontroller with C166SV2 Core

# Microcontrollers



Never stop thinking



#### XC164CS Revision History: V1.1, 2006-08

Previous Version(s): V1.0, 2005-06 (XC164-32F)

| Page | Subjects (major changes since last revision)                                                                                                                                                                                                                                         |  |  |  |  |  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 6    | New derivatives added.                                                                                                                                                                                                                                                               |  |  |  |  |  |
| 51   | Footnote at XTAL1 input pin.                                                                                                                                                                                                                                                         |  |  |  |  |  |
| 55   | Footnote on leakage of P3.15 added.                                                                                                                                                                                                                                                  |  |  |  |  |  |
| 76   | Green Package added.                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| 75   | Thermal Resistance: $R_{\text{THA}}$ replaced by $R_{\Theta \text{JC}}$ and $R_{\Theta \text{JL}}$ because $R_{\text{THA}}$ strongly depends on the external system (PCB, environment). $P_{\text{DISS}}$ removed, because no static parameter, but derived from thermal resistance. |  |  |  |  |  |

#### We Listen to Your Comments

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



#### **Table of Contents**

## **Table of Contents**

| 1                                                                                                                                               | Summary of Features                                                                                         | . 4                                                                                          |
|-------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| <b>2</b><br>2.1<br>2.2                                                                                                                          | General Device Information                                                                                  | . 7                                                                                          |
| <b>3</b><br>3.1<br>3.2<br>3.3<br>3.4<br>3.5<br>3.6<br>3.7<br>3.8<br>3.9<br>3.10<br>3.11<br>3.12<br>3.13<br>3.14<br>3.15<br>3.16<br>3.17<br>3.18 | -, , ,                                                                                                      | 18<br>20<br>21<br>23<br>29<br>32<br>33<br>37<br>39<br>40<br>41<br>42<br>44<br>45<br>45<br>47 |
| <b>4</b><br>4.1<br>4.2<br>4.3<br>4.4<br>4.4.1<br>4.4.2<br>4.4.3<br>4.4.3<br>4.4.4<br>4.4.5                                                      | Definition of Internal Timing<br>On-chip Flash Operation<br>External Clock Drive XTAL1<br>Testing Waveforms | 51<br>54                                                                                     |
| <b>5</b><br>5.1<br>5.2                                                                                                                          | Package and Reliability         Packaging         Flash Memory Parameters                                   |                                                                                              |



# 16-Bit Single-Chip Microcontroller with C166SV2 Core XC166 Family

### **1** Summary of Features

- High Performance 16-bit CPU with 5-Stage Pipeline
  - 25 ns Instruction Cycle Time at 40 MHz CPU Clock (Single-Cycle Execution)
  - 1-Cycle Multiplication (16 × 16 bit), Background Division (32 / 16 bit) in 21 Cycles
  - 1-Cycle Multiply-and-Accumulate (MAC) Instructions
  - Enhanced Boolean Bit Manipulation Facilities
  - Zero-Cycle Jump Execution
  - Additional Instructions to Support HLL and Operating Systems
  - Register-Based Design with Multiple Variable Register Banks
  - Fast Context Switching Support with Two Additional Local Register Banks
  - 16 Mbytes Total Linear Address Space for Code and Data
  - 1024 Bytes On-Chip Special Function Register Area (C166 Family Compatible)
- 16-Priority-Level Interrupt System with 75 Sources, Sample-Rate down to 50 ns
- 8-Channel Interrupt-Driven Single-Cycle Data Transfer Facilities via Peripheral Event Controller (PEC), 24-Bit Pointers Cover Total Address Space
- Clock Generation via on-chip PLL (factors 1:0.15 ... 1:10), or via Prescaler (factors 1:1 ... 60:1)
- On-Chip Memory Modules
  - 2 Kbytes On-Chip Dual-Port RAM (DPRAM)
  - 4 Kbytes On-Chip Data SRAM (DSRAM)
  - 6 Kbytes On-Chip Program/Data SRAM (PSRAM)
  - 256 Kbytes On-Chip Program Memory (Flash Memory or Mask ROM)
- On-Chip Peripheral Modules
  - 14-Channel A/D Converter with Programmable Resolution (10-bit or 8-bit) and Conversion Time (down to 2.55  $\mu s$  or 2.15  $\mu s)$
  - Two 16-Channel General Purpose Capture/Compare Units (12 Input/Output Pins)
  - Capture/Compare Unit for flexible PWM Signal Generation (CAPCOM6) (3/6 Capture/Compare Channels and 1 Compare Channel)
  - Multi-Functional General Purpose Timer Unit with 5 Timers
  - Two Synchronous/Asynchronous Serial Channels (USARTs)
  - Two High-Speed-Synchronous Serial Channels
  - On-Chip TwinCAN Interface (Rev. 2.0B active) with 32 Message Objects (Full CAN/Basic CAN) on Two CAN Nodes, and Gateway Functionality
  - On-Chip Real Time Clock
- Idle, Sleep, and Power Down Modes with Flexible Power Management
- Programmable Watchdog Timer and Oscillator Watchdog



#### Summary of Features

- Up to 12 Mbytes External Address Space for Code and Data
  - Programmable External Bus Characteristics for Different Address Ranges
  - Multiplexed or Demultiplexed External Address/Data Buses
  - Selectable Address Bus Width
  - 16-Bit or 8-Bit Data Bus Width
  - Four Programmable Chip-Select Signals
- Up to 79 General Purpose I/O Lines, partly with Selectable Input Thresholds and Hysteresis
- On-Chip Bootstrap Loader
- Supported by a Large Range of Development Tools like C-Compilers, Macro-Assembler Packages, Emulators, Evaluation Boards, HLL-Debuggers, Simulators, Logic Analyzer Disassemblers, Programming Boards
- On-Chip Debug Support via JTAG Interface
- 100-Pin Green TQFP Package, 0.5 mm (19.7 mil) pitch (RoHS compliant)

#### **Ordering Information**

The ordering code for Infineon microcontrollers provides an exact reference to the required product. This ordering code identifies:

- the derivative itself, i.e. its function set, the temperature range, and the supply voltage
- the package and the type of delivery.

For the available ordering codes for the XC164CS please refer to your responsible sales representative or your local distributor.

Note: The ordering codes for Mask-ROM versions are defined for each product after verification of the respective ROM code.

This document describes several derivatives of the XC164CS group. **Table 1** enumerates these derivatives and summarizes the differences. As this document refers to all of these derivatives, some descriptions may not apply to a specific product.

For simplicity all versions are referred to by the term **XC164CS** throughout this document.



#### **Summary of Features**

| Derivative <sup>1)</sup>                 | Temp.<br>Range      | Program<br>Memory   | On-Chip RAM                        | Interfaces                 |  |
|------------------------------------------|---------------------|---------------------|------------------------------------|----------------------------|--|
| Standard Devices <sup>2)</sup>           |                     |                     |                                    | I.                         |  |
| SAK-XC164CS-32F40F<br>SAK-XC164CS-32F20F | -40 °C to<br>125 °C | 256 Kbytes<br>Flash | 2 Kbytes DPRAM,<br>4 Kbytes DSRAM, | ASC0, ASC1,<br>SSC0, SSC1, |  |
| SAF-XC164CS-32F40F<br>SAF-XC164CS-32F20F | -40 °C to<br>85 °C  |                     | 6 Kbytes PSRAM                     | CAN0, CAN1,<br>CC6         |  |
| Grade A Devices <sup>2)</sup>            |                     |                     |                                    |                            |  |
| SAK-XC164CS-32F40F<br>SAK-XC164CS-32F20F | -40 °C to<br>125 °C | 256 Kbytes<br>Flash | 2 Kbytes DPRAM,<br>4 Kbytes DSRAM, | ASC0, ASC1<br>SSC0, SSC1   |  |
| SAF-XC164CS-32F40F<br>SAF-XC164CS-32F20F | -40 °C to<br>85 °C  |                     | 6 Kbytes PSRAM                     | CAN0, CAN1<br>CC6          |  |
| ROM Devices                              |                     |                     |                                    | -                          |  |
| SAK-XC164CS-32R40F<br>SAK-XC164CS-32R20F | -40 °C to<br>125 °C | 256 Kbytes<br>ROM   | 2 Kbytes DPRAM,<br>4 Kbytes DSRAM, | ASC0, ASC1,<br>SSC0, SSC1, |  |
| SAF-XC164CS-32R40F<br>SAF-XC164CS-32R20F | -40 °C to<br>85 °C  | 1                   | 6 Kbytes PSRAM                     | CAN0, CAN1<br>CC6          |  |

#### . . . .. .

This Data Sheet is valid for devices starting with and including design step BA.

2) The Flash speed grading indicates the access time to the on-chip Flash module. According to this access time Flash waitstates must be selected (bitfield WSFLASH in register IMBCTRL) according to the intended operating frequency. For more details, please refer to Section 4.4.2.

Grade A devices are identified by "Grade A" in the fourth line of the chip marking.



### 2 General Device Information

#### 2.1 Introduction

The XC164CS derivatives are high-performance members of the Infineon XC166 Family of full featured single-chip CMOS microcontrollers. These devices extend the functionality and performance of the C166 Family in terms of instructions (MAC unit), peripherals, and speed. They combine high CPU performance (up to 40 million instructions per second) with high peripheral functionality and enhanced IO-capabilities. They also provide clock generation via PLL and various on-chip memory modules such as program Flash, program RAM, and data RAM.



Figure 1 Logic Symbol



#### 2.2 Pin Configuration and Definition

The pins of the XC164CS are described in detail in **Table 2**, including all their alternate functions. **Figure 2** summarizes all pins in a condensed way, showing their location on the 4 sides of the package. E\*) and C\*) mark pins to be used as alternate external interrupt inputs, C\*) marks pins that can have CAN interface lines assigned to them.



Figure 2Pin Configuration (top view)



| Table 2          | 2 Pin Definitions and Functions |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|------------------|---------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Sym-<br>bol      | Pin<br>Num.                     | Input<br>Outp. | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| RSTIN            | 1                               | 1              | Reset Input with Schmitt-Trigger characteristics. A low level<br>at this pin while the oscillator is running resets the XC164CS.<br>A spike filter suppresses input pulses < 10 ns. Input pulses<br>> 100 ns safely pass the filter. The minimum duration for a<br>safe recognition should be 100 ns + 2 CPU clock cycles.<br><i>Note: The reset duration must be sufficient to let the<br/>hardware configuration signals settle.</i><br><u>External circuitry must guarantee low level at the<br/>RSTIN pin at least until both power supply voltages<br/>have reached the operating range.</u> |  |  |  |
| P20.12           | 2                               | Ю              | For details, please refer to the description of <b>P20</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| NMI              | 3                               | 1              | Non-Maskable Interrupt Input. A high to low transition at this<br>pin causes the CPU to vector to the NMI trap routine. When<br>the PWRDN (power down) instruction is executed, the NMI<br>pin must be low in order to force the XC164CS into power<br>down mode. If NMI is high, when PWRDN is executed, the<br>part will continue to run in normal mode.<br>If not used, pin NMI should be pulled high externally.                                                                                                                                                                              |  |  |  |
| P0H.0 -<br>P0H.3 | 4 7                             | Ю              | For details, please refer to the description of <b>PORT0</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |



| Table 2        | Pin Definitions and Functions (cont'd) |                    |                                                                                                                                                                                                                                                                   |  |  |  |  |
|----------------|----------------------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Sym-<br>bol    | Pin<br>Num.                            | Input<br>Outp.     | Function                                                                                                                                                                                                                                                          |  |  |  |  |
| P9             |                                        | IO                 | Port 9 is a 6-bit bidirectional I/O port. Each pin can be<br>programmed for input (output driver in high-impedance<br>state) or output (configurable as push/pull or open drain<br>driver). The input threshold of Port 9 is selectable (standard<br>or special). |  |  |  |  |
| P9.0           | 10                                     | I/O<br>I           | The following Port 9 pins also serve for alternate functions: <sup>1)</sup><br>CC16IO CAPCOM2: CC16 Capture Inp./Compare Outp.,<br>CAN1_RxD CAN Node B Receive Data Input,                                                                                        |  |  |  |  |
| P9.1           | 11                                     | I<br>I/O<br>O<br>I | EX7INFast External Interrupt 7 Input (alternate pin B)CC17IOCAPCOM2: CC17 Capture Inp./Compare Outp.,CAN1_TxDCAN Node B Transmit Data Output,EX6INFast External Interrupt 6 Input (alternate pin B)                                                               |  |  |  |  |
| P9.2           | 12                                     | I/O<br>I<br>I      | CC18IO CAPCOM2: CC18 Capture Inp./Compare Outp.,<br>CAN0_RxD CAN Node A Receive Data Input,<br>EX7IN Fast External Interrupt 7 Input (alternate pin A)                                                                                                            |  |  |  |  |
| P9.3           | 13                                     | I/O<br>O<br>I      | CC19IO CAPCOM2: CC19 Capture Inp./Compare Outp.,<br>CAN0_TxD CAN Node A Transmit Data Output,<br>EX6IN Fast External Interrupt 6 Input (alternate pin A)                                                                                                          |  |  |  |  |
| P9.4<br>P9.5   | 14<br>15                               | I/O<br>I/O         | CC20IOCAPCOM2: CC20 Capture Inp./Compare Outp.CC21IOCAPCOM2: CC21 Capture Inp./Compare Outp.                                                                                                                                                                      |  |  |  |  |
| P5             |                                        | I                  | Port 5 is a 14-bit input-only port.<br>The pins of Port 5 also serve as analog input channels for the A/D converter, or they serve as timer inputs:                                                                                                               |  |  |  |  |
| P5.0           | 18                                     | 1                  | ANO                                                                                                                                                                                                                                                               |  |  |  |  |
| P5.1           | 19                                     | 1                  | AN1                                                                                                                                                                                                                                                               |  |  |  |  |
| P5.2           | 20                                     | I                  | AN2                                                                                                                                                                                                                                                               |  |  |  |  |
| P5.3           | 21                                     |                    | AN3                                                                                                                                                                                                                                                               |  |  |  |  |
| P5.4           | 22                                     |                    | AN4                                                                                                                                                                                                                                                               |  |  |  |  |
| P5.5           | 23                                     |                    |                                                                                                                                                                                                                                                                   |  |  |  |  |
| P5.10          | 24                                     |                    | AN10, T6EUD GPT2 Timer T6 Ext. Up/Down Ctrl. Inp.                                                                                                                                                                                                                 |  |  |  |  |
| P5.11          | 25                                     |                    | AN11, T5EUD GPT2 Timer T5 Ext. Up/Down Ctrl. Inp.                                                                                                                                                                                                                 |  |  |  |  |
| P5.6<br>P5.7   | 26<br>27                               |                    | AN6<br>AN7                                                                                                                                                                                                                                                        |  |  |  |  |
| P5.7<br>P5.12  | 30                                     |                    | AN7<br>AN12, T6IN GPT2 Timer T6 Count/Gate Input                                                                                                                                                                                                                  |  |  |  |  |
| P5.12<br>P5.13 | 31                                     |                    | AN13, T5IN GPT2 Timer T5 Count/Gate Input                                                                                                                                                                                                                         |  |  |  |  |
| P5.14          | 32                                     |                    | AN14, T4EUD GPT1 Timer T4 Ext. Up/Down Ctrl. Inp.                                                                                                                                                                                                                 |  |  |  |  |
| P5.15          | 33                                     | ı<br>I             | AN15, T2EUD GPT1 Timer T2 Ext. Up/Down Ctrl. Inp.                                                                                                                                                                                                                 |  |  |  |  |



| Table 2     | ble 2 Pin Definitions and Functions (cont'd) |                    |                                                          |                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|-------------|----------------------------------------------|--------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Sym-<br>bol | Pin<br>Num.                                  | Input<br>Outp.     | Function                                                 |                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| TRST        | 36                                           | I                  | the XC164                                                | Test-System Reset Input. A high level at this pin activates the $\underline{XC164CS}$ 's debug system. For normal system operation, pin TRST should be held low.                                                                                                                                                                    |  |  |  |
| Ρ3          |                                              | IO                 | programme<br>state) or ou<br>driver). The<br>or special) | Port 3 is a 14-bit bidirectional I/O port. Each pin can be<br>programmed for input (output driver in high-impedance<br>state) or output (configurable as push/pull or open drain<br>driver). The input threshold of Port 3 is selectable (standard<br>or special).<br>The following Port 3 pins also serve for alternate functions: |  |  |  |
| P3.1        | 39                                           | 0<br>I/O<br>I<br>I | T6OUT<br>RxD1<br>EX1IN<br>TCK                            | GPT2 Timer T6 Toggle Latch Output,<br>ASC1 Data Input (Async.) or Inp./Outp. (Sync.),<br>Fast External Interrupt 1 Input (alternate pin A),<br>Debug System: JTAG Clock Input                                                                                                                                                       |  |  |  |
| P3.2        | 40                                           | 1                  | CAPIN<br>TDI                                             | GPT2 Register CAPREL Capture Input,<br>Debug System: JTAG Data In                                                                                                                                                                                                                                                                   |  |  |  |
| P3.3        | 41                                           | 0<br>0             | T3OUT<br>TDO                                             | GPT1 Timer T3 Toggle Latch Output,<br>Debug System: JTAG Data Out                                                                                                                                                                                                                                                                   |  |  |  |
| P3.4        | 42                                           | 1                  | T3EUD<br>TMS                                             | GPT1 Timer T3 External Up/Down Control Input,<br>Debug System: JTAG Test Mode Selection                                                                                                                                                                                                                                             |  |  |  |
| P3.5        | 43                                           | <br> 0<br> 0       | T4IN<br>TxD1<br>BRKOUT                                   | GPT1 Timer T4 Count/Gate/Reload/Capture In.,<br>ASC0 Clock/Data Output (Async./Sync.),<br>Debug System: Break Out                                                                                                                                                                                                                   |  |  |  |
| P3.6        | 44                                           | 1                  | T3IN                                                     | GPT1 Timer T3 Count/Gate Input                                                                                                                                                                                                                                                                                                      |  |  |  |
| P3.7        | 45                                           | 1                  | T2IN<br>BRKIN                                            | T2IN GPT1 Timer T2 Count/Gate/Reload/Capture In.,                                                                                                                                                                                                                                                                                   |  |  |  |
| P3.8        | 46                                           | I/O                | MRST0                                                    | SSC0 Master-Receive/Slave-Transmit In/Out.                                                                                                                                                                                                                                                                                          |  |  |  |
| P3.9        | 47                                           | I/O                | MTSR0                                                    | SSC0 Master-Transmit/Slave-Receive Out/In.                                                                                                                                                                                                                                                                                          |  |  |  |
| P3.10       | 48                                           | 0<br>I             | TxD0<br>EX2IN                                            | ASC0 Clock/Data Output (Async./Sync.),<br>Fast External Interrupt 2 Input (alternate pin B)                                                                                                                                                                                                                                         |  |  |  |
| P3.11       | 49                                           | I/O<br>I           | RxD0<br>EX2IN                                            | ASC0 Data Input (Async.) or Inp./Outp. (Sync.),<br>Fast External Interrupt 2 Input (alternate pin A)                                                                                                                                                                                                                                |  |  |  |
| P3.12       | 50                                           | 0<br>0<br>I        | BHE<br>WRH<br>EX3IN                                      | External Memory High Byte Enable Signal,<br>External Memory High Byte Write Strobe,<br>Fast External Interrupt 3 Input (alternate pin B)                                                                                                                                                                                            |  |  |  |
| P3.13       | 51                                           | I/O<br>I           | SCLK0<br>EX3IN                                           | SSC0 Master Clock Output / Slave Clock Input,<br>Fast External Interrupt 3 Input (alternate pin A)                                                                                                                                                                                                                                  |  |  |  |
| P3.15       | 52                                           | 0<br>0             | CLKOUT<br>FOUT                                           | System Clock Output (= CPU Clock),<br>Programmable Frequency Output                                                                                                                                                                                                                                                                 |  |  |  |



| Table 2     | 2 Pin Definitions and Functions (cont'd) |                  |                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|-------------|------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Sym-<br>bol | Pin<br>Num.                              | Input<br>Outp.   | Function                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| P4          |                                          | IO               | Port 4 is an 8-bit bidirectional I/O port. Each pin can be<br>programmed for input (output driver in high-impedance<br>state) or output (configurable as push/pull or open drain<br>driver). The input threshold of Port 4 is selectable (standard<br>or special).<br>Port 4 can be used to output the segment address lines, the<br>optional chip select lines, and for serial interface lines: <sup>1)</sup> |  |  |
| P4.0        | 53                                       | 0                | <u>A16</u> Least Significant Segment Address Line,<br>CS3 Chip Select 3 Output                                                                                                                                                                                                                                                                                                                                 |  |  |
| P4.1        | 54                                       | 0<br>0           | A17Segment Address Line,CS2Chip Select 2 Output                                                                                                                                                                                                                                                                                                                                                                |  |  |
| P4.2        | 55                                       | 0                | A18Segment Address Line,CS1Chip Select 1 Output                                                                                                                                                                                                                                                                                                                                                                |  |  |
| P4.3        | 56                                       | 0                | A19Segment Address Line,CS0Chip Select 0 Output                                                                                                                                                                                                                                                                                                                                                                |  |  |
| P4.4        | 57                                       | 0<br> <br>       | A20 Segment Address Line,<br>CAN1_RxD CAN Node B Receive Data Input,<br>EX5IN Fast External Interrupt 5 Input (alternate pin B)                                                                                                                                                                                                                                                                                |  |  |
| P4.5        | 58                                       | O<br>I           | A21Segment Address Line,CAN0_RxD CAN Node A Receive Data Input,EX4INFast External Interrupt 4 Input (alternate pin B)                                                                                                                                                                                                                                                                                          |  |  |
| P4.6        | 59                                       | 0<br>0<br>I      | A22 Segment Address Line,<br>CAN0_TxD CAN Node A Transmit Data Output,<br>EX5IN Fast External Interrupt 5 Input (alternate pin A)                                                                                                                                                                                                                                                                              |  |  |
| P4.7        | 60                                       | 0<br>I<br>0<br>I | A23 Most Significant Segment Address Line,<br>CAN0_RxD CAN Node A Receive Data Input,<br>CAN1_TxD CAN Node B Transmit Data Output,<br>EX4IN Fast External Interrupt 4 Input (alternate pin A)                                                                                                                                                                                                                  |  |  |



| Table 2     | Pi          | n Definit      | tions and F                              | unctions (cont'd)                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|-------------|-------------|----------------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Sym-<br>bol | Pin<br>Num. | Input<br>Outp. | Function                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| P20         |             | IO             | programme<br>state) or ou<br>(standard o | Port 20 is a 5-bit bidirectional I/O port. Each pin can be programmed for input (output driver in high-impedance state) or output. The input threshold of Port 20 is selectable (standard or special).                                                                                                                                                                                                                                                           |  |  |  |
| P20.0       | 63          | 0              | RD                                       | ing Port 20 pins also serve for alternate functions:<br>External Memory Read Strobe, activated for<br>every external instruction or data read access.                                                                                                                                                                                                                                                                                                            |  |  |  |
| P20.1       | 64          | 0              | WR/WRL                                   | External Memory Write Strobe.<br>In WR-mode this pin is activated for every<br>external data write access.<br>In WRL-mode this pin is activated for low byte<br>data write accesses on a 16-bit bus, and for<br>every data write access on an 8-bit bus.                                                                                                                                                                                                         |  |  |  |
| P20.4       | 65          | 0              | ALE                                      | Address Latch Enable Output.<br>Can be used for latching the address into<br>external memory or an address latch in the<br>multiplexed bus modes.                                                                                                                                                                                                                                                                                                                |  |  |  |
| P20.5       | 66          | 1              | ĒĀ                                       | <ul> <li>External Access Enable pin.</li> <li>A low level at this pin during and after Reset forces the XC164CS to latch the configuration from PORT0 and pin RD, and to begin instruction execution out of external memory.</li> <li>A high level forces the XC164CS to latch the configuration from pins RD, ALE, and WR, and to begin instruction execution out of the internal program memory. "ROMless" versions must have this pin tied to '0'.</li> </ul> |  |  |  |
| P20.12      | 2           | 0              | RSTOUT                                   | Internal Reset Indication Output.<br><b>Is activated</b> asynchronously with an external<br>hardware reset. It may also be activated<br>(selectable) synchronously with an internal<br>software or watchdog reset.<br><b>Is deactivated</b> upon the execution of the EINIT<br>instruction, optionally at the end of reset, or at<br>any time (before EINIT) via user software.<br>20 pins may input configuration values (see EA).                              |  |  |  |



| Table 2                                                           | Piı                              | n Definit                 | Definitions and Functions (cont'd)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|-------------------------------------------------------------------|----------------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Sym-<br>bol                                                       | Pin<br>Num.                      | Input<br>Outp.            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| PORT0<br>POL.0 -<br>POL.7<br>POH.0 -<br>POH.3<br>POH.4 -<br>POH.7 | 67 - 74<br>4 - 7<br>75 - 78      | IO                        | <ul> <li>PORT0 consists of the two 8-bit bidirectional I/O ports P0L and P0H. Each pin can be programmed for input (output driver in high-impedance state) or output.</li> <li>In case of an external bus configuration, PORT0 serves as the address (A) and address/data (AD) bus in multiplexed bus modes and as the data (D) bus in demultiplexed bus modes.</li> <li>Demultiplexed bus modes:</li> <li>8-bit data bus: P0H = I/O, P0L = D7 - D0</li> <li>16-bit data bus: P0H = D15 - D8, P0L = D7 - D0</li> <li>Multiplexed bus modes:</li> <li>8-bit data bus: P0H = A15 - A8, P0L = AD7 - AD0</li> <li>16-bit data bus: P0H = AD15 - AD8, P0L = AD7 - AD0</li> </ul> |  |  |  |  |
|                                                                   |                                  |                           | Note: At the end of an external reset (EA = 0) PORT0 also<br>may input configuration values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| PORT1                                                             | 79                               | 10                        | PORT1 consists of the two 8-bit bidirectional I/O ports P1Land P1H. Each pin can be programmed for input (outputdriver in high-impedance state) or output.PORT1 is used as the 16-bit address bus (A) indemultiplexed bus modes (also after switching from ademultiplexed to a multiplexed bus mode).The following PORT1 pins also serve for alt. functions:CC60CAPCOM6: Input / Output of Channel 0                                                                                                                                                                                                                                                                        |  |  |  |  |
| P1L.0                                                             | 80                               | 0                         | COUT60 CAPCOM6: Output of Channel 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| P1L.2<br>P1L.3<br>P1L.4<br>P1L.5<br>P1L.6<br>P1L.7                | 81<br>82<br>83<br>84<br>85<br>86 | I/O<br>O<br>I/O<br>O<br>I | CC61CAPCOM6: Input / Output of Channel 1COUT61CAPCOM6: Output of Channel 1CC62CAPCOM6: Input / Output of Channel 2COUT62CAPCOM6: Output of Channel 2COUT63Output of 10-bit Compare ChannelCTRAPCAPCOM6: Trap InputCTRAP is an input pin with an internal pull-up resistor. A lowlevel on this pin switches the CAPCOM6 compare outputs tothe logic level defined by software (if enabled).CC22IOCAPCOM2: CC22 Capture Inp./Compare Outp.                                                                                                                                                                                                                                    |  |  |  |  |
| P1H                                                               |                                  |                           | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |



| Table 2     | Pi          | n Defini       | tions and Functions (cont'd)                                                       |  |  |  |
|-------------|-------------|----------------|------------------------------------------------------------------------------------|--|--|--|
| Sym-<br>bol | Pin<br>Num. | Input<br>Outp. | Function                                                                           |  |  |  |
| PORT1       |             | 10             | continued                                                                          |  |  |  |
| (cont'd)    |             |                |                                                                                    |  |  |  |
| P1H.0       | 89          | 1              | CC6POS0 CAPCOM6: Position 0 Input,                                                 |  |  |  |
|             |             | I              | EX0IN Fast External Interrupt 0 Input (default pin),                               |  |  |  |
|             |             | I/O            | CC23IO CAPCOM2: CC23 Capture Inp./Compare Outp.                                    |  |  |  |
| P1H.1       | 90          |                | CC6POS1 CAPCOM6: Position 1 Input,                                                 |  |  |  |
|             |             |                | EX1IN Fast External Interrupt 1 Input (default pin),                               |  |  |  |
| DALLO       | 0.4         | I/O            | MRST1 SSC1 Master-Receive/Slave-Transmit In/Out.                                   |  |  |  |
| P1H.2       | 91          |                | CC6POS2 CAPCOM6: Position 2 Input,                                                 |  |  |  |
|             |             |                | EX2IN Fast External Interrupt 2 Input (default pin),                               |  |  |  |
| P1H.3       | 92          | I/O            | MTSR1SSC1 Master-Transmit/Slave-Receive Out/Inp.T7INCAPCOM2: Timer T7 Count Input, |  |  |  |
| г п.э       | 92          | 1/O            | SCLK1 SSC1 Master Clock Output / Slave Clock Input,                                |  |  |  |
|             |             |                | EX3IN Fast External Interrupt 3 Input (default pin),                               |  |  |  |
|             |             |                | EX0IN Fast External Interrupt 0 Input (alternate pin A)                            |  |  |  |
| P1H.4       | 93          | I/O            | CC24IO CAPCOM2: CC24 Capture Inp./Compare Outp.,                                   |  |  |  |
| 1 111.4     | 00          |                | EX4IN Fast External Interrupt 4 Input (default pin)                                |  |  |  |
| P1H.5       | 94          | I/O            | CC25IO CAPCOM2: CC25 Capture Inp./Compare Outp.,                                   |  |  |  |
|             |             |                | EX5IN Fast External Interrupt 5 Input (default pin)                                |  |  |  |
| P1H.6       | 95          | I/O            | CC26IO CAPCOM2: CC26 Capture Inp./Compare Outp.,                                   |  |  |  |
|             |             | 1              | EX6IN Fast External Interrupt 6 Input (default pin)                                |  |  |  |
| P1H.7       | 96          | I/O            | CC27IO CAPCOM2: CC27 Capture Inp./Compare Outp.,                                   |  |  |  |
|             |             | I              | EX7IN Fast External Interrupt 7 Input (default pin)                                |  |  |  |
| XTAL2       | 99          | 0              | XTAL2: Output of the oscillator amplifier circuit                                  |  |  |  |
| XTAL1       | 100         | 1              | XTAL1: Input to the oscillator amplifier and input to the                          |  |  |  |
|             |             |                | internal clock generator                                                           |  |  |  |
|             |             |                | To clock the device from an external source, drive XTAL1,                          |  |  |  |
|             |             |                | while leaving XTAL2 unconnected. Minimum and maximum                               |  |  |  |
|             |             |                | high/low and rise/fall times specified in the AC.                                  |  |  |  |
|             |             |                | Characteristics must be observed.                                                  |  |  |  |
|             |             |                | Note: Input pin XTAL1 belongs to the core voltage domain.                          |  |  |  |
|             |             |                | Therefore, input voltages must be within the range                                 |  |  |  |
|             |             |                | defined for $V_{DDI}$ .                                                            |  |  |  |
| $V_{AREF}$  | 28          | -              | Reference voltage for the A/D converter.                                           |  |  |  |
| $V_{AGND}$  | 29          | _              | Reference ground for the A/D converter.                                            |  |  |  |



#### **General Device Information**

| Table 2          | Table 2 Pin Definitions and Functions (cont'd) |                |                                                                                                                                                                                                     |  |  |  |
|------------------|------------------------------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Sym-<br>bol      | Pin<br>Num.                                    | Input<br>Outp. | Function                                                                                                                                                                                            |  |  |  |
| V <sub>DDI</sub> | 35, 97                                         | _              | Digital Core Supply Voltage (On-Chip Modules):<br>+2.5 V during normal operation and idle mode.<br>Please refer to the <b>Operating Condition Parameters</b> .                                      |  |  |  |
| V <sub>DDP</sub> | 9, 17,<br>38, 61,<br>87                        | _              | Digital Pad Supply Voltage (Pin Output Drivers):<br>+5 V during normal operation and idle mode.<br>Please refer to the <b>Operating Condition Parameters</b> .                                      |  |  |  |
| V <sub>SSI</sub> | 34, 98                                         | _              | Digital Ground                                                                                                                                                                                      |  |  |  |
| V <sub>SSP</sub> | 8, 16,<br>37, 62,<br>88                        | -              | Connect decoupling capacitors to adjacent $V_{\rm DD}/V_{\rm SS}$ pin pairs<br>as close as possible to the pins.<br>All $V_{\rm SS}$ pins must be connected to the ground-line or ground-<br>plane. |  |  |  |

1) The CAN interface lines are assigned to ports P4 and P9 under software control.



### 3 Functional Description

The architecture of the XC164CS combines advantages of RISC, CISC, and DSP processors with an advanced peripheral subsystem in a very well-balanced way. In addition, the on-chip memory blocks allow the design of compact systems-on-silicon with maximum performance (computing, control, communication).

The on-chip memory blocks (program code-memory and SRAM, dual-port RAM, data SRAM) and the set of generic peripherals are connected to the CPU via separate buses. Another bus, the LXBus, connects additional on-chip resources as well as external resources (see Figure 3).

This bus structure enhances the overall system performance by enabling the concurrent operation of several subsystems of the XC164CS.

The following block diagram gives an overview of the different on-chip components and of the advanced, high bandwidth internal bus structure of the XC164CS.



Figure 3 Block Diagram



#### 3.1 Memory Subsystem and Organization

The memory space of the XC164CS is configured in a Von Neumann architecture, which means that all internal and external resources, such as code memory, data memory, registers and I/O ports, are organized within the same linear address space. This common memory space includes 16 Mbytes and is arranged as 256 segments of 64 Kbytes each, where each segment consists of four data pages of 16 Kbytes each. The entire memory space can be accessed bytewise or wordwise. Portions of the on-chip DPRAM and the register spaces (E/SFR) have additionally been made directly bitaddressable.

The internal data memory areas and the Special Function Register areas (SFR and ESFR) are mapped into segment 0, the system segment.

The Program Management Unit (PMU) handles all code fetches and, therefore, controls accesses to the program memories, such as Flash memory and PSRAM.

The Data Management Unit (DMU) handles all data transfers and, therefore, controls accesses to the DSRAM and the on-chip peripherals.

Both units (PMU and DMU) are connected via the high-speed system bus to exchange data. This is required if operands are read from program memory, code or data is written to the PSRAM, code is fetched from external memory, or data is read from or written to external resources, including peripherals on the LXBus (such as TwinCAN). The system bus allows concurrent two-way communication for maximum transfer performance.

**256 Kbytes of on-chip Flash memory** store code or constant data. The on-chip Flash memory is organized as four 8-Kbyte sectors, one 32-Kbyte sector, and three 64-Kbyte sectors. Each sector can be separately write protected<sup>1)</sup>, erased and programmed (in blocks of 128 bytes). The complete Flash area can be read-protected. A password sequence temporarily unlocks protected areas. The Flash module combines very fast 64-bit one-cycle read accesses with protected and efficient writing algorithms for programming and erasing. Thus, program execution out of the internal Flash results in maximum performance. Dynamic error correction provides extremely high read data security for all read accesses.

For timing characteristics, please refer to **Section 4.4.2**.

**6 Kbytes of on-chip Program SRAM (PSRAM)** are provided to store user code or data. The PSRAM is accessed via the PMU and is therefore optimized for code fetches.

**4 Kbytes of on-chip Data SRAM (DSRAM)** are provided as a storage for general user data. The DSRAM is accessed via the DMU and is therefore optimized for data accesses.

**2 Kbytes of on-chip Dual-Port RAM (DPRAM)** are provided as a storage for user defined variables, for the system stack, and general purpose register banks. A register bank can consist of up to 16 wordwide (R0 to R15) and/or bytewide (RL0, RH0, ..., RL7,

<sup>1)</sup> Each two 8-Kbyte sectors are combined for write-protection purposes.



RH7) so-called General Purpose Registers (GPRs).

The upper 256 bytes of the DPRAM are directly bitaddressable. When used by a GPR, any location in the DPRAM is bitaddressable.

**1024 bytes (2**  $\times$  **512 bytes)** of the address space are reserved for the Special Function Register areas (SFR space and ESFR space). SFRs are wordwide registers which are used for controlling and monitoring functions of the different on-chip units. Unused SFR addresses are reserved for future members of the XC166 Family. Therefore, they should either not be accessed, or written with zeros, to ensure upward compatibility.

In order to meet the needs of designs where more memory is required than is provided on chip, up to 12 Mbytes (approximately, see **Table 3**) of external RAM and/or ROM can be connected to the microcontroller. The External Bus Interface also provides access to external peripherals.

| Address Area                        | Start Loc.           | End Loc.             | Area Size <sup>2)</sup> | Notes                        |
|-------------------------------------|----------------------|----------------------|-------------------------|------------------------------|
| Flash register space                | FF'F000 <sub>H</sub> | FF'FFFF <sub>H</sub> | 4 Kbytes                | 3)                           |
| Reserved (Acc. trap)                | FE'0000 <sub>H</sub> | FF'EFFF <sub>H</sub> | 60 Kbytes               | -                            |
| Reserved for EPSRAM                 | F8'1800 <sub>H</sub> | FD'FFFF <sub>H</sub> | 378 Kbytes              | -                            |
| Emul. Program<br>SRAM <sup>4)</sup> | F8'0000 <sub>H</sub> | F8'17FF <sub>H</sub> | 6 Kbytes                | 2 <sup>nd</sup> way to PSRAM |
| Reserved for PSRAM                  | E0'1800 <sub>H</sub> | F7'FFFF <sub>H</sub> | < 1.5 Mbytes            | Minus PSRAM                  |
| Program SRAM                        | E0'0000 <sub>H</sub> | E0'17FF <sub>H</sub> | 6 Kbytes                | Maximum                      |
| Reserved for program memory         | C4'0000 <sub>H</sub> | DF'FFFF <sub>H</sub> | < 2 Mbytes              | Minus Flash                  |
| Program Flash/ROM                   | C0'0000 <sub>H</sub> | C3'FFFF <sub>H</sub> | 256 Kbytes              | -                            |
| Reserved                            | BF'0000 <sub>H</sub> | BF'FFFF <sub>H</sub> | 64 Kbytes               | -                            |
| External memory area                | 40'0000 <sub>H</sub> | BE'FFFF <sub>H</sub> | < 8 Mbytes              | Minus reserved segment       |
| External IO area <sup>5)</sup>      | 20'0800 <sub>H</sub> | 3F'FFFF <sub>H</sub> | < 2 Mbytes              | Minus TwinCAN                |
| TwinCAN registers                   | 20'0000 <sub>H</sub> | 20'07FF <sub>H</sub> | 2 Kbytes                | -                            |
| External memory area                | 01'0000 <sub>H</sub> | 1F'FFFF <sub>H</sub> | < 2 Mbytes              | Minus segment 0              |
| Data RAMs and SFRs                  | 00'8000 <sub>H</sub> | 00'FFFF <sub>H</sub> | 32 Kbytes               | Partly used                  |
| External memory area                | 00'000 <sub>H</sub>  | 00'7FFF <sub>H</sub> | 32 Kbytes               | -                            |

#### Table 3XC164CS Memory Map1)

1) Accesses to the shaded areas generate external bus accesses.

2) The areas marked with "<" are slightly smaller than indicated, see column "Notes".

3) Not defined register locations return a trap code.

4) The Emulation PSRAM (EPSRAM) realizes a 2<sup>nd</sup> access path to the PSRAM with a different timing.



5) Several pipeline optimizations are not active within the external IO area. This is necessary to control external peripherals properly.

### 3.2 External Bus Controller

All of the external memory accesses are performed by a particular on-chip External Bus Controller (EBC). It can be programmed either to Single Chip Mode when no external memory is required, or to one of four different external memory access modes<sup>1)</sup>, which are as follows:

- 16 ... 24-bit Addresses, 16-bit Data, Demultiplexed
- 16 ... 24-bit Addresses, 16-bit Data, Multiplexed
- 16 ... 24-bit Addresses, 8-bit Data, Multiplexed
- 16 ... 24-bit Addresses, 8-bit Data, Demultiplexed

In the demultiplexed bus modes, addresses are output on PORT1 and data is input/output on PORT0 or P0L, respectively. In the multiplexed bus modes both addresses and data use PORT0 for input/output. The high order address (segment) lines use Port 4. The number of active segment address lines is selectable, restricting the external address space to 8 Mbytes ... 64 Kbytes. This is required when interface lines are assigned to Port 4.

Up to 4 external  $\overline{CS}$  signals (3 windows plus default) can be generated in order to save external glue logic. External modules can directly be connected to the common address/data bus and their individual select lines.

Important timing characteristics of the external bus interface have been made programmable (via registers TCONCSx/FCONCSx) to allow the user the adaption of a wide range of different types of memories and external peripherals.

In addition, up to 4 independent address windows may be defined (via registers ADDRSELx) which control the access to different resources with different bus characteristics. These address windows are arranged hierarchically where window 4 overrides window 3, and window 2 overrides window 1. All accesses to locations not covered by these 4 address windows are controlled by TCONCS0/FCONCS0. The currently active window can generate a chip select signal.

Note: The chip select signal of address window 4 is not available on a pin.

The external bus timing is related to the rising edge of the reference clock output CLKOUT. The external bus protocol is compatible with that of the standard C166 Family.

The EBC also controls accesses to resources connected to the on-chip LXBus. The LXBus is an internal representation of the external bus and allows accessing integrated peripherals and modules in the same way as external components.

The TwinCAN module is connected and accessed via the LXBus.

<sup>1)</sup> Bus modes are switched dynamically if several address windows with different mode settings are used.



### 3.3 Central Processing Unit (CPU)

The main core of the CPU consists of a 5-stage execution pipeline with a 2-stage instruction-fetch pipeline, a 16-bit arithmetic and logic unit (ALU), a 32-bit/40-bit multiply and accumulate unit (MAC), a register-file providing three register banks, and dedicated SFRs. The ALU features a multiply and divide unit, a bit-mask generator, and a barrel shifter.



#### Figure 4 CPU Block Diagram

Based on these hardware provisions, most of the XC164CS's instructions can be executed in just one machine cycle which requires 25 ns at 40 MHz CPU clock. For



example, shift and rotate instructions are always processed during one machine cycle independent of the number of bits to be shifted. Also multiplication and most MAC instructions execute in one single cycle. All multiple-cycle instructions have been optimized so that they can be executed very fast as well: for example, a division algorithm is performed in 18 to 21 CPU cycles, depending on the data and division type. Four cycles are always visible, the rest runs in the background. Another pipeline optimization, the branch target prediction, allows eliminating the execution time of branch instructions if the prediction was correct.

The CPU has a register context consisting of up to three register banks with 16 wordwide GPRs each at its disposal. The global register bank is physically allocated within the on-chip DPRAM area. A Context Pointer (CP) register determines the base address of the active global register bank to be accessed by the CPU at any time. The number of register banks is only restricted by the available internal RAM space. For easy parameter passing, a register bank may overlap others.

A system stack of up to 32 Kwords is provided as a storage for temporary data. The system stack can be allocated to any location within the address space (preferably in the on-chip RAM area), and it is accessed by the CPU via the stack pointer (SP) register. Two separate SFRs, STKOV and STKUN, are implicitly compared against the stack pointer value upon each stack access for the detection of a stack overflow or underflow.

The high performance offered by the hardware implementation of the CPU can efficiently be utilized by a programmer via the highly efficient XC164CS instruction set which includes the following instruction classes:

- Standard Arithmetic Instructions
- DSP-Oriented Arithmetic Instructions
- Logical Instructions
- Boolean Bit Manipulation Instructions
- Compare and Loop Control Instructions
- Shift and Rotate Instructions
- Prioritize Instruction
- Data Movement Instructions
- System Stack Instructions
- Jump and Call Instructions
- Return Instructions
- System Control Instructions
- Miscellaneous Instructions

The basic instruction length is either 2 or 4 bytes. Possible operand types are bits, bytes and words. A variety of direct, indirect or immediate addressing modes are provided to specify the required operands.



#### 3.4 Interrupt System

With an interrupt response time of typically 8 CPU clocks (in case of internal program execution), the XC164CS is capable of reacting very fast to the occurrence of non-deterministic events.

The architecture of the XC164CS supports several mechanisms for fast and flexible response to service requests that can be generated from various sources internal or external to the microcontroller. Any of these interrupt requests can be programmed to being serviced by the Interrupt Controller or by the Peripheral Event Controller (PEC).

In contrast to a standard interrupt service where the current program execution is suspended and a branch to the interrupt vector table is performed, just one cycle is 'stolen' from the current CPU activity to perform a PEC service. A PEC service implies a single byte or word data transfer between any two memory locations with an additional increment of either the PEC source, or the destination pointer, or both. An individual PEC transfer counter is implicitly decremented for each PEC service except when performing in the continuous transfer mode. When this counter reaches zero, a standard interrupt is performed to the corresponding source related vector location. PEC services are very well suited, for example, for supporting the transmission or reception of blocks of data. The XC164CS has 8 PEC channels each of which offers such fast interrupt-driven data transfer capabilities.

A separate control register which contains an interrupt request flag, an interrupt enable flag and an interrupt priority bitfield exists for each of the possible interrupt nodes. Via its related register, each node can be programmed to one of sixteen interrupt priority levels. Once having been accepted by the CPU, an interrupt service can only be interrupted by a higher prioritized service request. For the standard interrupt processing, each of the possible interrupt nodes has a dedicated vector location.

Fast external interrupt inputs are provided to service external interrupts with high precision requirements. These fast interrupt inputs feature programmable edge detection (rising edge, falling edge, or both edges).

Software interrupts are supported by means of the 'TRAP' instruction in combination with an individual trap (interrupt) number.

**Table 4** shows all of the possible XC164CS interrupt sources and the corresponding hardware-related interrupt flags, vectors, vector locations and trap (interrupt) numbers.

Note: Interrupt nodes which are not assigned to peripherals (unassigned nodes), may be used to generate software controlled interrupt requests by setting the respective interrupt request bit (xIR).