

#### Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

### Details

| Product Status             | Discontinued at Digi-Key                                                        |
|----------------------------|---------------------------------------------------------------------------------|
| Core Processor             | C166SV2                                                                         |
| Core Size                  | 16-Bit                                                                          |
| Speed                      | 40MHz                                                                           |
| Connectivity               | CANbus, EBI/EMI, SPI, UART/USART                                                |
| Peripherals                | PWM, WDT                                                                        |
| Number of I/O              | 79                                                                              |
| Program Memory Size        | 256KB (256K x 8)                                                                |
| Program Memory Type        | FLASH                                                                           |
| EEPROM Size                | -                                                                               |
| RAM Size                   | 12K x 8                                                                         |
| Voltage - Supply (Vcc/Vdd) | 2.35V ~ 2.7V                                                                    |
| Data Converters            | -                                                                               |
| Oscillator Type            | Internal                                                                        |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                               |
| Mounting Type              | Surface Mount                                                                   |
| Package / Case             | 100-LQFP                                                                        |
| Supplier Device Package    | PG-TQFP-100-5                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/infineon-technologies/saf-xc164d-32f40f-bb |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

Data Sheet, V1.0, Aug. 2006

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

# Microcontrollers



Never stop thinking



# XC164D Revision History: V1.0, 2006-08

Previous Version(s):

| <b></b> |                                              |
|---------|----------------------------------------------|
| Page    | Subjects (major changes since last revision) |
|         |                                              |
|         |                                              |
|         |                                              |
|         |                                              |
|         |                                              |
|         |                                              |
|         |                                              |
|         |                                              |
|         |                                              |
|         |                                              |
|         |                                              |

# 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





# 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  $\times$  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 up to 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)<sup>1)</sup>
  - 6 Kbytes On-Chip Program/Data SRAM (PSRAM)
  - 256 Kbytes On-Chip Program Memory (Flash Memory or Mask ROM)<sup>1)</sup>
- On-Chip Peripheral Modules
  - 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
- Up to 12 Mbytes External Address Space for Code and Data

<sup>1)</sup> Depends on the respective derivative. The derivatives are listed in Table 1.



# **Summary of Features**

| Table 1     XC164D Derivative Synopsis |                    |                               |                                                      |                                                  |
|----------------------------------------|--------------------|-------------------------------|------------------------------------------------------|--------------------------------------------------|
| Derivative <sup>1)</sup>               | Temp.<br>Range     | Program On-Chip RAM<br>Memory |                                                      | Interfaces                                       |
| Standard Devices <sup>2)</sup>         |                    |                               |                                                      |                                                  |
| SAF-XC164D-32F40F<br>SAF-XC164D-32F20F | -40 °C to<br>85 °C | 256 Kbytes<br>Flash           | 2 Kbytes DPRAM,<br>4 Kbytes DSRAM,<br>6 Kbytes PSRAM | ASC0, ASC1,<br>SSC0, SSC1,<br>CAN0, CAN1,<br>CC6 |
| ROM Devices                            |                    |                               |                                                      |                                                  |
| SAF-XC164D-32R40F<br>SAF-XC164D-32R20F | -40 °C to<br>85 °C | 256 Kbytes<br>ROM             | 2 Kbytes DPRAM,<br>4 Kbytes DSRAM,<br>6 Kbytes PSRAM | ASC0, ASC1,<br>SSC0, SSC1,<br>CAN0, CAN1,<br>CC6 |
| 1) This Data Sheet is valid for d      | evices starting    | with and includir             | ng design step BB.                                   | •                                                |

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



# **General Device Information**

# 2.2 Pin Configuration and Definition

The pins of the XC164D 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 2 Pin Configuration (top view)



# **General Device Information**

| Table 2         | Pi          | n Definit      | ions and Functions                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol          | 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 XC164D.<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.                                                                                           |
|                 |             |                | Note: The reset duration must be sufficient to let the<br>hardware configuration signals settle.<br><u>External</u> circuitry must guarantee low level at the<br>RSTIN pin at least until both power supply voltages<br>have reached the operating range.                                                                                                                                                           |
| P20.12          | 2           | 10             | 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 XC164D 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 | 47          | 10             | For details, please refer to the description of <b>PORT0</b> .                                                                                                                                                                                                                                                                                                                                                      |



# **General Device Information**

| Table 2 | Pir         | n Definit      | tions and Functions (cont'd)                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|---------|-------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Symbol  | Pin<br>Num. | Input<br>Outp. | Function                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| PORT0   |             | Ю              | PORT0 consists of the two 8-bit bidirectional I/O ports P0L and P0H. Each pin can be programmed for input (output                                                                                                                                                                                                                                                                   |  |  |  |  |
| P0L.0 - | 67 -        |                | driver in high-impedance state) or output.                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| P0L.7   | 74          |                | In case of an external bus configuration, PORT0 serves as<br>the address (A) and address/data (AD) bus in multiplexed                                                                                                                                                                                                                                                               |  |  |  |  |
| P0H.0 - | 4 -         |                | bus modes and as the data (D) bus in demultiplexed bus                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| P0L.3   | 7           |                | modes.                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|         |             |                | Demultiplexed bus modes:                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| P0H.4 - | 75 -        |                | 8-bit data bus: $POH = I/O$ , $POL = D7 - D0$                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| P0L.7   | 78          |                | 16-bit data bus: $POH = D15 - D8$ , $POL = D7 - D0$                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|         |             |                | Nultiplexed bus modes:                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|         |             |                | 16  bit data bus:  POH = AD5 - A0, POL = AD7 - AD0                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|         |             |                | 10-bit  data bus. For = AD13 - AD6, For = AD1 - AD0                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|         |             |                | Note: At the end of an external reset (EA = 0) PORTO also<br>may input configuration values                                                                                                                                                                                                                                                                                         |  |  |  |  |
| PORT1   |             | IO             | PORT1 consists of the two 8-bit bidirectional I/O ports P1L<br>and P1H. Each pin can be programmed for input (output<br>driver in high-impedance state) or output.<br>PORT1 is used as the 16-bit address bus (A) in<br>demultiplexed bus modes (also after switching from a<br>demultiplexed to a multiplexed bus mode).<br>The following PORT1 pins also serve for alt_functions: |  |  |  |  |
| P1L.0   | 79          | I/O            | CC60 CAPCOM6: Input / Output of Channel 0                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| P1L.1   | 80          | 0              | COUT60 CAPCOM6: Output of Channel 0                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| P1L.2   | 81          | I/O            | CC61 CAPCOM6: Input / Output of Channel 1                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| P1L.3   | 82          | 0              | COUT61 CAPCOM6: Output of Channel 1                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| P1L.4   | 83          | I/O            | CC62 CAPCOM6: Input / Output of Channel 2                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| P1L.5   | 84          | 0              | COUT62 CAPCOM6: Output of Channel 2                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| P1L.6   | 85          | 0              | <u>COUT63</u> Output of 10-bit Compare Channel                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| P1L.7   | 86          | 1              | CTRAP CAPCOM6: Trap Input                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|         |             |                | CTRAP is an input pin with an internal pull-up resistor. A low                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|         |             |                | level on this pin switches the CAPCOM6 compare outputs to                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|         |             |                | The logic level defined by software (if enabled).                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|         |             | 1/0            | CC22IO CAPCOIVIZ: CC22 Capture Inp./Compare Outp.                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|         |             |                |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |



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



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 onchip 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 XC164D 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.



# Table 4XC164D Interrupt Nodes

| Source of Interrupt or PEC<br>Service Request | Control<br>Register | Vector<br>Location <sup>1)</sup> | Trap<br>Number                    |
|-----------------------------------------------|---------------------|----------------------------------|-----------------------------------|
| CAPCOM Register 0                             | CC1_CC0IC           | xx'0040 <sub>H</sub>             | 10 <sub>H</sub> / 16 <sub>D</sub> |
| CAPCOM Register 1                             | CC1_CC1IC           | xx'0044 <sub>H</sub>             | 11 <sub>H</sub> / 17 <sub>D</sub> |
| CAPCOM Register 2                             | CC1_CC2IC           | xx'0048 <sub>H</sub>             | 12 <sub>H</sub> / 18 <sub>D</sub> |
| CAPCOM Register 3                             | CC1_CC3IC           | xx'004C <sub>H</sub>             | 13 <sub>H</sub> / 19 <sub>D</sub> |
| CAPCOM Register 4                             | CC1_CC4IC           | xx'0050 <sub>H</sub>             | 14 <sub>H</sub> / 20 <sub>D</sub> |
| CAPCOM Register 5                             | CC1_CC5IC           | xx'0054 <sub>H</sub>             | 15 <sub>H</sub> / 21 <sub>D</sub> |
| CAPCOM Register 6                             | CC1_CC6IC           | xx'0058 <sub>H</sub>             | 16 <sub>H</sub> / 22 <sub>D</sub> |
| CAPCOM Register 7                             | CC1_CC7IC           | xx'005C <sub>H</sub>             | 17 <sub>H</sub> / 23 <sub>D</sub> |
| CAPCOM Register 8                             | CC1_CC8IC           | xx'0060 <sub>H</sub>             | 18 <sub>H</sub> / 24 <sub>D</sub> |
| CAPCOM Register 9                             | CC1_CC9IC           | xx'0064 <sub>H</sub>             | 19 <sub>H</sub> / 25 <sub>D</sub> |
| CAPCOM Register 10                            | CC1_CC10IC          | xx'0068 <sub>H</sub>             | 1A <sub>H</sub> / 26 <sub>D</sub> |
| CAPCOM Register 11                            | CC1_CC11IC          | xx'006C <sub>H</sub>             | 1B <sub>H</sub> / 27 <sub>D</sub> |
| CAPCOM Register 12                            | CC1_CC12IC          | xx'0070 <sub>H</sub>             | 1C <sub>H</sub> / 28 <sub>D</sub> |
| CAPCOM Register 13                            | CC1_CC13IC          | xx'0074 <sub>H</sub>             | 1D <sub>H</sub> / 29 <sub>D</sub> |
| CAPCOM Register 14                            | CC1_CC14IC          | xx'0078 <sub>H</sub>             | 1E <sub>H</sub> / 30 <sub>D</sub> |
| CAPCOM Register 15                            | CC1_CC15IC          | xx'007C <sub>H</sub>             | 1F <sub>H</sub> / 31 <sub>D</sub> |
| CAPCOM Register 16                            | CC2_CC16IC          | xx'00C0 <sub>H</sub>             | 30 <sub>H</sub> / 48 <sub>D</sub> |
| CAPCOM Register 17                            | CC2_CC17IC          | xx'00C4 <sub>H</sub>             | 31 <sub>H</sub> / 49 <sub>D</sub> |
| CAPCOM Register 18                            | CC2_CC18IC          | xx'00C8 <sub>H</sub>             | 32 <sub>H</sub> / 50 <sub>D</sub> |
| CAPCOM Register 19                            | CC2_CC19IC          | xx'00CC <sub>H</sub>             | 33 <sub>H</sub> / 51 <sub>D</sub> |
| CAPCOM Register 20                            | CC2_CC20IC          | xx'00D0 <sub>H</sub>             | 34 <sub>H</sub> / 52 <sub>D</sub> |
| CAPCOM Register 21                            | CC2_CC21IC          | xx'00D4 <sub>H</sub>             | 35 <sub>H</sub> / 53 <sub>D</sub> |
| CAPCOM Register 22                            | CC2_CC22IC          | xx'00D8 <sub>H</sub>             | 36 <sub>H</sub> / 54 <sub>D</sub> |
| CAPCOM Register 23                            | CC2_CC23IC          | xx'00DC <sub>H</sub>             | 37 <sub>H</sub> / 55 <sub>D</sub> |
| CAPCOM Register 24                            | CC2_CC24IC          | xx'00E0 <sub>H</sub>             | 38 <sub>H</sub> / 56 <sub>D</sub> |
| CAPCOM Register 25                            | CC2_CC25IC          | xx'00E4 <sub>H</sub>             | 39 <sub>H</sub> / 57 <sub>D</sub> |
| CAPCOM Register 26                            | CC2_CC26IC          | xx'00E8 <sub>H</sub>             | 3A <sub>H</sub> / 58 <sub>D</sub> |
| CAPCOM Register 27                            | CC2_CC27IC          | xx'00EC <sub>H</sub>             | 3B <sub>H</sub> / 59 <sub>D</sub> |
| CAPCOM Register 28                            | CC2_CC28IC          | xx'00F0 <sub>H</sub>             | 3C <sub>H</sub> / 60 <sub>D</sub> |



compare function.

12 registers of the CAPCOM2 module have each one port pin associated with it which serves as an input pin for triggering the capture function, or as an output pin to indicate the occurrence of a compare event.

| Compare Modes           | Function                                                                                                                        |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Mode 0                  | Interrupt-only compare mode;<br>several compare interrupts per timer period are possible                                        |
| Mode 1                  | Pin toggles on each compare match;<br>several compare events per timer period are possible                                      |
| Mode 2                  | Interrupt-only compare mode;<br>only one compare interrupt per timer period is generated                                        |
| Mode 3                  | Pin set '1' on match; pin reset '0' on compare timer overflow;<br>only one compare event per timer period is generated          |
| Double Register<br>Mode | Two registers operate on one pin;<br>pin toggles on each compare match;<br>several compare events per timer period are possible |
| Single Event Mode       | Generates single edges or pulses;<br>can be used with any compare mode                                                          |

Table 6Compare Modes (CAPCOM1/2)

When a capture/compare register has been selected for capture mode, the current contents of the allocated timer will be latched ('captured') into the capture/compare register in response to an external event at the port pin which is associated with this register. In addition, a specific interrupt request for this capture/compare register is generated. Either a positive, a negative, or both a positive and a negative external signal transition at the pin can be selected as the triggering event.

The contents of all registers which have been selected for one of the five compare modes are continuously compared with the contents of the allocated timers.

When a match occurs between the timer value and the value in a capture/compare register, specific actions will be taken based on the selected compare mode.









# 3.12 TwinCAN Module

The integrated TwinCAN module handles the completely autonomous transmission and reception of CAN frames in accordance with the CAN specification V2.0 part B (active), i.e. the on-chip TwinCAN module can receive and transmit standard frames with 11-bit identifiers as well as extended frames with 29-bit identifiers.

Two Full-CAN nodes share the TwinCAN module's resources to optimize the CAN bus traffic handling and to minimize the CPU load. The module provides up to 32 message objects, which can be assigned to one of the CAN nodes and can be combined to FIFO-structures. Each object provides separate masks for acceptance filtering.

The flexible combination of Full-CAN functionality and FIFO architecture reduces the efforts to fulfill the real-time requirements of complex embedded control applications. Improved CAN bus monitoring functionality as well as the number of message objects permit precise and comfortable CAN bus traffic handling.

Gateway functionality allows automatic data exchange between two separate CAN bus systems, which reduces CPU load and improves the real time behavior of the entire system.

The bit timing for both CAN nodes is derived from the master clock and is programmable up to a data rate of 1 Mbit/s. Each CAN node uses two pins of Port 4 or Port 9 to interface to an external bus transceiver. The interface pins are assigned via software.



Figure 10 TwinCAN Module Block Diagram



# 3.14 Clock Generation

The Clock Generation Unit uses a programmable on-chip PLL with multiple prescalers to generate the clock signals for the XC164D with high flexibility. The master clock  $f_{MC}$  is the reference clock signal, and is used for TwinCAN and is output to the external system. The CPU clock  $f_{CPU}$  and the system clock  $f_{SYS}$  are derived from the master clock either directly (1:1) or via a 2:1 prescaler ( $f_{SYS} = f_{CPU} = f_{MC} / 2$ ). See also Section 4.3.1.

The on-chip oscillator can drive an external crystal or accepts an external clock signal. The oscillator clock frequency can be multiplied by the on-chip PLL (by a programmable factor) or can be divided by a programmable prescaler factor.

If the bypass mode is used (direct drive or prescaler) the PLL can deliver an independent clock to monitor the clock signal generated by the on-chip oscillator. This PLL clock is independent from the XTAL1 clock. When the expected oscillator clock transitions are missing the Oscillator Watchdog (OWD) activates the PLL Unlock/OWD interrupt node and supplies the CPU with an emergency clock, the PLL clock signal. Under these circumstances the PLL will oscillate with its basic frequency.

The oscillator watchdog can be disabled by switching the PLL off. This reduces power consumption, but also no interrupt request will be generated in case of a missing oscillator clock.

Note: At the end of an external reset ( $\overline{EA} = '0'$ ) the oscillator watchdog may be disabled via hardware by (externally) pulling the  $\overline{RD}$  line low upon a reset, similar to the standard reset configuration.

# 3.15 Parallel Ports

The XC164D provides up to 79 I/O lines which are organized into six input/output ports and one input port. All port lines are bit-addressable, and all input/output lines are individually (bit-wise) programmable as inputs or outputs via direction registers. The I/O ports are true bidirectional ports which are switched to high impedance state when configured as inputs. The output drivers of some I/O ports can be configured (pin by pin) for push/pull operation or open-drain operation via control registers. During the internal reset, all port pins are configured as inputs (except for pin RSTOUT).

The edge characteristics (shape) and driver characteristics (output current) of the port drivers can be selected via registers POCONx.

The input threshold of some ports is selectable (TTL or CMOS like), where the special CMOS like input threshold reduces noise sensitivity due to the input hysteresis. The input threshold may be selected individually for each byte of the respective ports.

All port lines have programmable alternate input or output functions associated with them. All port lines that are not used for these alternate functions may be used as general purpose IO lines.



# 3.17 Instruction Set Summary

 Table 8 lists the instructions of the XC164D in a condensed way.

The various addressing modes that can be used with a specific instruction, the operation of the instructions, parameters for conditional execution of instructions, and the opcodes for each instruction can be found in the "**Instruction Set Manual**".

This document also provides a detailed description of each instruction.

| Mnemonic      | Description                                                                                       | Bytes |
|---------------|---------------------------------------------------------------------------------------------------|-------|
| ADD(B)        | Add word (byte) operands                                                                          | 2/4   |
| ADDC(B)       | Add word (byte) operands with Carry                                                               | 2/4   |
| SUB(B)        | Subtract word (byte) operands                                                                     | 2/4   |
| SUBC(B)       | Subtract word (byte) operands with Carry                                                          | 2/4   |
| MUL(U)        | (Un)Signed multiply direct GPR by direct GPR (16- $\times$ 16-bit)                                | 2     |
| DIV(U)        | (Un)Signed divide register MDL by direct GPR (16-/16-bit)                                         | 2     |
| DIVL(U)       | (Un)Signed long divide reg. MD by direct GPR (32-/16-bit)                                         | 2     |
| CPL(B)        | Complement direct word (byte) GPR                                                                 | 2     |
| NEG(B)        | Negate direct word (byte) GPR                                                                     | 2     |
| AND(B)        | Bitwise AND, (word/byte operands)                                                                 | 2/4   |
| OR(B)         | Bitwise OR, (word/byte operands)                                                                  | 2/4   |
| XOR(B)        | Bitwise exclusive OR, (word/byte operands)                                                        | 2/4   |
| BCLR/BSET     | Clear/Set direct bit                                                                              | 2     |
| BMOV(N)       | Move (negated) direct bit to direct bit                                                           | 4     |
| BAND/BOR/BXOR | AND/OR/XOR direct bit with direct bit                                                             | 4     |
| BCMP          | Compare direct bit to direct bit                                                                  | 4     |
| BFLDH/BFLDL   | Bitwise modify masked high/low byte of bit-addressable direct word memory with immediate data     | 4     |
| CMP(B)        | Compare word (byte) operands                                                                      | 2/4   |
| CMPD1/2       | Compare word data to GPR and decrement GPR by 1/2                                                 | 2/4   |
| CMPI1/2       | Compare word data to GPR and increment GPR by 1/2                                                 | 2/4   |
| PRIOR         | Determine number of shift cycles to normalize direct word GPR and store result in direct word GPR | 2     |
| SHL/SHR       | Shift left/right direct word GPR                                                                  | 2     |

# Table 8 Instruction Set Summary



| Table 8Instruction Set Summary (cont'd) |                                     |       |  |
|-----------------------------------------|-------------------------------------|-------|--|
| Mnemonic                                | Description                         | Bytes |  |
| NOP                                     | Null operation                      | 2     |  |
| CoMUL/CoMAC                             | Multiply (and accumulate)           | 4     |  |
| CoADD/CoSUB                             | Add/Subtract                        | 4     |  |
| Co(A)SHR                                | (Arithmetic) Shift right            | 4     |  |
| CoSHL                                   | Shift left                          | 4     |  |
| CoLOAD/STORE                            | Load accumulator/Store MAC register | 4     |  |
| CoCMP                                   | Compare                             | 4     |  |
| CoMAX/MIN                               | Maximum/Minimum                     | 4     |  |
| CoABS/CoRND                             | Absolute value/Round accumulator    | 4     |  |
| CoMOV                                   | Data move                           | 4     |  |
| CoNEG/NOP                               | Negate accumulator/Null operation   | 4     |  |



# **Operating Conditions**

The following operating conditions must not be exceeded to ensure correct operation of the XC164D. All parameters specified in the following sections refer to these operating conditions, unless otherwise noticed.

| Parameter                                 | Symbol              | Limit Values |                        | Unit | Notes                                            |
|-------------------------------------------|---------------------|--------------|------------------------|------|--------------------------------------------------|
|                                           |                     | Min.         | Max.                   |      |                                                  |
| Digital supply voltage for the core       | V <sub>DDI</sub>    | 2.35         | 2.7                    | V    | Active mode,<br>$f_{CPU} = f_{CPUmax}^{1)2)}$    |
| Digital supply voltage for IO pads        | $V_{DDP}$           | 4.4          | 5.5                    | V    | Active mode <sup>2)3)</sup>                      |
| Supply Voltage Difference                 | $\Delta V_{\rm DD}$ | -0.5         | _                      | V    | $V_{\rm DDP}$ - $V_{\rm DDI}^{4)}$               |
| Digital ground voltage                    | V <sub>SS</sub>     | (            | )                      | V    | Reference voltage                                |
| Overload current                          | I <sub>OV</sub>     | -5           | 5                      | mA   | Per IO pin <sup>5)6)</sup>                       |
|                                           |                     | -2           | 5                      | mA   | Per Port 5 input pin <sup>5)6)</sup>             |
| Overload current coupling                 | K <sub>OVA</sub>    | -            | 1.0 × 10 <sup>-4</sup> | -    | <i>I</i> <sub>OV</sub> > 0                       |
| factor for Port 5 inputs <sup>()</sup>    |                     | _            | 1.5 × 10 <sup>-3</sup> | -    | <i>I</i> <sub>OV</sub> < 0                       |
| Overload current coupling                 | K <sub>OVD</sub>    | -            | 5.0 × 10 <sup>-3</sup> | _    | <i>I</i> <sub>OV</sub> > 0                       |
| factor for digital I/O pins <sup>7)</sup> |                     | _            | 1.0 × 10 <sup>-2</sup> | _    | <i>I</i> <sub>OV</sub> < 0                       |
| Absolute sum of overload currents         | $\Sigma  I_{OV} $   | -            | 50                     | mA   | 6)                                               |
| External Load<br>Capacitance              | CL                  | -            | 50                     | pF   | Pin drivers in <b>default</b> mode <sup>8)</sup> |
| Ambient temperature                       | T <sub>A</sub>      | _            | _                      | °C   | see Table 1                                      |

# Table 10 Operating Condition Parameters

1)  $f_{CPUmax}$  = 40 MHz for devices marked ... 40F,  $f_{CPUmax}$  = 20 MHz for devices marked ... 20F.

2) External circuitry must guarantee low-level at the RSTIN pin at least until both power supply voltages have reached the operating range.

- 3) The specified voltage range is allowed for operation. The range limits may be reached under extreme operating conditions. However, specified parameters, such as leakage currents, refer to the standard operating voltage range of  $V_{\text{DDP}}$  = 4.75 V to 5.25 V.
- 4) This limitation must be fulfilled under all operating conditions including power-ramp-up, power-ramp-down, and power-save modes.





Figure 12 Sleep and Power Down Supply Current due to RTC and Oscillator Running, as a Function of Oscillator Frequency



Figure 13 Sleep and Power Down Leakage Supply Current as a Function of Temperature



# 4.3 AC Parameters

# 4.3.1 Definition of Internal Timing

The internal operation of the XC164D is controlled by the internal master clock  $f_{MC}$ .

The master clock signal  $f_{\rm MC}$  can be generated from the oscillator clock signal  $f_{\rm OSC}$  via different mechanisms. The duration of master clock periods (TCMs) and their variation (and also the derived external timing) depend on the used mechanism to generate  $f_{\rm MC}$ . This influence must be regarded when calculating the timings for the XC164D.



Figure 14 Generation Mechanisms for the Master Clock

Note: The example for PLL operation shown in **Figure 14** refers to a PLL factor of 1:4, the example for prescaler operation refers to a divider factor of 2:1.

The used mechanism to generate the master clock is selected by register PLLCON.



# 4.3.4 Testing Waveforms



# Figure 17 Input Output Waveforms



# Figure 18 Float Waveforms