

#### 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             | C1665V2                                                                        |
| Core Size                  | 16-Bit                                                                         |
| Speed                      | 20MHz                                                                          |
| Connectivity               | EBI/EMI, SPI, UART/USART                                                       |
| Peripherals                | PWM, WDT                                                                       |
| Number of I/O              | 79                                                                             |
| Program Memory Size        | 64KB (64K x 8)                                                                 |
| Program Memory Type        | FLASH                                                                          |
| EEPROM Size                |                                                                                |
| RAM Size                   | 6K x 8                                                                         |
| Voltage - Supply (Vcc/Vdd) | 2.35V ~ 2.7V                                                                   |
| Data Converters            | A/D 14x8/10b                                                                   |
| 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-xc164s-8f20f-bb |

Email: info@E-XFL.COM

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

# XC164S-16F/16R XC164S-8F/8R

16-Bit Single-Chip Microcontroller with C166SV2 Core

# Microcontrollers



Never stop thinking



# **General Device Information**

# 2.2 Pin Configuration and Definition

The pins of the XC164S are described in detail in **Table 3**, including all their alternate functions. **Figure 2** summarizes all pins in a condensed way, showing their location on the package. E\*) mark pins to be used as alternate external interrupt inputs.



Figure 2Pin Configuration (top view)



# 3 Functional Description

The architecture of the XC164S 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 XC164S.

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



Figure 3 Block Diagram



bank can consist of up to 16 wordwide (R0 to R15) and/or bytewide (RL0, RH0, ..., RL7, 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.

| Start Loc.           | End Loc.                                                                                                                                                                                                                                                             | Area Size <sup>2)</sup>                                                                                                                                                                                                                                                                                                | Notes                                                                                                            |  |  |  |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| FF'F000 <sub>H</sub> | FF'FFFF <sub>H</sub>                                                                                                                                                                                                                                                 | 4 Kbytes                                                                                                                                                                                                                                                                                                               | Flash only <sup>3)</sup>                                                                                         |  |  |  |  |
| F8'0000 <sub>H</sub> | FF'EFFF <sub>H</sub>                                                                                                                                                                                                                                                 | < 0.5 Mbytes                                                                                                                                                                                                                                                                                                           | Minus Flash register space                                                                                       |  |  |  |  |
| E0'0800 <sub>H</sub> | F7'FFFF <sub>H</sub>                                                                                                                                                                                                                                                 | < 1.5 Mbytes                                                                                                                                                                                                                                                                                                           | Minus PSRAM                                                                                                      |  |  |  |  |
| E0'0000 <sub>H</sub> | E0'07FF <sub>H</sub>                                                                                                                                                                                                                                                 | 2 Kbytes                                                                                                                                                                                                                                                                                                               | Maximum                                                                                                          |  |  |  |  |
| C2'0000 <sub>H</sub> | DF'FFFF <sub>H</sub>                                                                                                                                                                                                                                                 | < 2 Mbytes                                                                                                                                                                                                                                                                                                             | Minus Flash                                                                                                      |  |  |  |  |
| C0'0000 <sub>H</sub> | C1'FFFF <sub>H</sub>                                                                                                                                                                                                                                                 | 128 Kbytes                                                                                                                                                                                                                                                                                                             | 4)                                                                                                               |  |  |  |  |
| BF'0000 <sub>H</sub> | BF'FFFF <sub>H</sub>                                                                                                                                                                                                                                                 | 64 Kbytes                                                                                                                                                                                                                                                                                                              | -                                                                                                                |  |  |  |  |
| 40'0000 <sub>H</sub> | BE'FFFF <sub>H</sub>                                                                                                                                                                                                                                                 | < 8 Mbytes                                                                                                                                                                                                                                                                                                             | Minus reserved segment                                                                                           |  |  |  |  |
| 20'0800 <sub>H</sub> | 3F'FFFF <sub>H</sub>                                                                                                                                                                                                                                                 | < 2 Mbytes                                                                                                                                                                                                                                                                                                             | Minus 2 Kbytes                                                                                                   |  |  |  |  |
| 20'0000 <sub>H</sub> | 20'07FF <sub>H</sub>                                                                                                                                                                                                                                                 | 2 Kbytes                                                                                                                                                                                                                                                                                                               | -                                                                                                                |  |  |  |  |
| 01'0000 <sub>H</sub> | 1F'FFFF <sub>H</sub>                                                                                                                                                                                                                                                 | < 2 Mbytes                                                                                                                                                                                                                                                                                                             | Minus segment 0                                                                                                  |  |  |  |  |
| 00'8000 <sub>H</sub> | 00'FFFF <sub>H</sub>                                                                                                                                                                                                                                                 | 32 Kbytes                                                                                                                                                                                                                                                                                                              | Partly used <sup>4)</sup>                                                                                        |  |  |  |  |
| 00'0000 <sub>H</sub> | 00'7FFF <sub>H</sub>                                                                                                                                                                                                                                                 | 32 Kbytes                                                                                                                                                                                                                                                                                                              | -                                                                                                                |  |  |  |  |
|                      | FF'F000 <sub>H</sub><br>F8'0000 <sub>H</sub><br>E0'0800 <sub>H</sub><br>E0'0000 <sub>H</sub><br>C2'0000 <sub>H</sub><br>C2'0000 <sub>H</sub><br>BF'0000 <sub>H</sub><br>40'0000 <sub>H</sub><br>20'0800 <sub>H</sub><br>20'0800 <sub>H</sub><br>01'0000 <sub>H</sub> | $FF'F000_H$ $FF'FFF_H$ $F8'0000_H$ $FF'EFFF_H$ $E0'0800_H$ $F7'FFFF_H$ $E0'0000_H$ $E0'07FF_H$ $E0'0000_H$ $E0'07FF_H$ $C2'0000_H$ $DF'FFFF_H$ $C0'0000_H$ $C1'FFFF_H$ $BF'0000_H$ $BF'FFFF_H$ $40'0000_H$ $BE'FFFF_H$ $20'0800_H$ $3F'FFFF_H$ $20'0000_H$ $1F'FFFF_H$ $01'0000_H$ $1F'FFFF_H$ $00'FFFF_H$ $00'FFFF_H$ | FF'F000 <sub>H</sub> FF'FFF <sub>H</sub> 4 Kbytes         F8'0000 <sub>H</sub> FF'EFFF <sub>H</sub> < 0.5 Mbytes |  |  |  |  |

# Table 3XC164S Memory Map<sup>1)</sup>

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) Depends on the respective derivative. The derivatives are listed in Table 1.

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 XC164S's instructions can be executed in just one machine cycle which requires 25 ns at 40 MHz CPU clock. For



# 3.4 Interrupt System

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

The architecture of the XC164S 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 XC164S 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 XC164S 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).



# Table 4XC164S 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> |



# Table 4XC164S Interrupt Nodes (cont'd)

| Source of Interrupt or PEC<br>Service Request | Control<br>Register | Vector<br>Location <sup>1)</sup> | Trap<br>Number                    |
|-----------------------------------------------|---------------------|----------------------------------|-----------------------------------|
| CAPCOM Register 29                            | CC2_CC29IC          | xx'0110 <sub>H</sub>             | 44 <sub>H</sub> / 68 <sub>D</sub> |
| CAPCOM Register 30                            | <br>CC2_CC30IC      | xx'0114 <sub>H</sub>             | 45 <sub>H</sub> / 69 <sub>D</sub> |
| CAPCOM Register 31                            | <br>CC2_CC31IC      | xx'0118 <sub>H</sub>             | 46 <sub>H</sub> / 70 <sub>D</sub> |
| CAPCOM Timer 0                                | <br>CC1_T0IC        | xx'0080 <sub>H</sub>             | 20 <sub>H</sub> / 32 <sub>D</sub> |
| CAPCOM Timer 1                                | CC1_T1IC            | xx'0084 <sub>H</sub>             | 21 <sub>H</sub> / 33 <sub>D</sub> |
| CAPCOM Timer 7                                | CC2_T7IC            | xx'00F4 <sub>H</sub>             | 3D <sub>H</sub> / 61 <sub>D</sub> |
| CAPCOM Timer 8                                | CC2_T8IC            | xx'00F8 <sub>H</sub>             | 3E <sub>H</sub> / 62 <sub>D</sub> |
| GPT1 Timer 2                                  | GPT12E_T2IC         | xx'0088 <sub>H</sub>             | 22 <sub>H</sub> / 34 <sub>D</sub> |
| GPT1 Timer 3                                  | GPT12E_T3IC         | xx'008C <sub>H</sub>             | 23 <sub>H</sub> / 35 <sub>D</sub> |
| GPT1 Timer 4                                  | GPT12E_T4IC         | xx'0090 <sub>H</sub>             | 24 <sub>H</sub> / 36 <sub>D</sub> |
| GPT2 Timer 5                                  | GPT12E_T5IC         | xx'0094 <sub>H</sub>             | 25 <sub>H</sub> / 37 <sub>D</sub> |
| GPT2 Timer 6                                  | GPT12E_T6IC         | xx'0098 <sub>H</sub>             | 26 <sub>H</sub> / 38 <sub>D</sub> |
| GPT2 CAPREL Register                          | GPT12E_CRIC         | xx'009C <sub>H</sub>             | 27 <sub>H</sub> / 39 <sub>D</sub> |
| A/D Conversion Complete                       | ADC_CIC             | xx'00A0 <sub>H</sub>             | 28 <sub>H</sub> / 40 <sub>D</sub> |
| A/D Overrun Error                             | ADC_EIC             | xx'00A4 <sub>H</sub>             | 29 <sub>H</sub> / 41 <sub>D</sub> |
| ASC0 Transmit                                 | ASC0_TIC            | xx'00A8 <sub>H</sub>             | 2A <sub>H</sub> / 42 <sub>D</sub> |
| ASC0 Transmit Buffer                          | ASC0_TBIC           | xx'011C <sub>H</sub>             | 47 <sub>H</sub> / 71 <sub>D</sub> |
| ASC0 Receive                                  | ASC0_RIC            | xx'00AC <sub>H</sub>             | 2B <sub>H</sub> / 43 <sub>D</sub> |
| ASC0 Error                                    | ASC0_EIC            | xx'00B0 <sub>H</sub>             | 2C <sub>H</sub> / 44 <sub>D</sub> |
| ASC0 Autobaud                                 | ASC0_ABIC           | xx'017C <sub>H</sub>             | 5F <sub>H</sub> / 95 <sub>D</sub> |
| SSC0 Transmit                                 | SSC0_TIC            | xx'00B4 <sub>H</sub>             | 2D <sub>H</sub> / 45 <sub>D</sub> |
| SSC0 Receive                                  | SSC0_RIC            | xx'00B8 <sub>H</sub>             | 2E <sub>H</sub> / 46 <sub>D</sub> |
| SSC0 Error                                    | SSC0_EIC            | xx'00BC <sub>H</sub>             | 2F <sub>H</sub> / 47 <sub>D</sub> |
| PLL/OWD                                       | PLLIC               | xx'010C <sub>H</sub>             | 43 <sub>H</sub> / 67 <sub>D</sub> |
| ASC1 Transmit                                 | ASC1_TIC            | xx'0120 <sub>H</sub>             | 48 <sub>H</sub> / 72 <sub>D</sub> |
| ASC1 Transmit Buffer                          | ASC1_TBIC           | xx'0178 <sub>H</sub>             | 5E <sub>H</sub> / 94 <sub>D</sub> |
| ASC1 Receive                                  | ASC1_RIC            | xx'0124 <sub>H</sub>             | 49 <sub>H</sub> / 73 <sub>D</sub> |
| ASC1 Error                                    | ASC1_EIC            | xx'0128 <sub>H</sub>             | 4A <sub>H</sub> / 74 <sub>D</sub> |
| ASC1 Autobaud                                 | ASC1_ABIC           | xx'0108 <sub>H</sub>             | 42 <sub>H</sub> / 66 <sub>D</sub> |
| End of PEC Subchannel                         | EOPIC               | xx'0130 <sub>H</sub>             | 4C <sub>H</sub> / 76 <sub>D</sub> |



# Table 4XC164S Interrupt Nodes (cont'd)

| Source of Interrupt or PEC<br>Service Request | Control<br>Register | Vector<br>Location <sup>1)</sup> | Trap<br>Number                    |
|-----------------------------------------------|---------------------|----------------------------------|-----------------------------------|
| CAPCOM6 Timer T12                             | CCU6_T12IC          | xx'0134 <sub>H</sub>             | 4D <sub>H</sub> / 77 <sub>D</sub> |
| CAPCOM6 Timer T13                             | CCU6_T13IC          | xx'0138 <sub>H</sub>             | 4E <sub>H</sub> / 78 <sub>D</sub> |
| CAPCOM6 Emergency                             | CCU6_EIC            | xx'013C <sub>H</sub>             | 4F <sub>H</sub> / 79 <sub>D</sub> |
| CAPCOM6                                       | CCU6_IC             | xx'0140 <sub>H</sub>             | 50 <sub>H</sub> / 80 <sub>D</sub> |
| SSC1 Transmit                                 | SSC1_TIC            | xx'0144 <sub>H</sub>             | 51 <sub>H</sub> / 81 <sub>D</sub> |
| SSC1 Receive                                  | SSC1_RIC            | xx'0148 <sub>H</sub>             | 52 <sub>H</sub> / 82 <sub>D</sub> |
| SSC1 Error                                    | SSC1_EIC            | xx'014C <sub>H</sub>             | 53 <sub>H</sub> / 83 <sub>D</sub> |
| Unassigned node                               | -                   | xx'0150 <sub>H</sub>             | 54 <sub>H</sub> / 84 <sub>D</sub> |
| Unassigned node                               | -                   | xx'0154 <sub>H</sub>             | 55 <sub>H</sub> / 85 <sub>D</sub> |
| Unassigned node                               | -                   | xx'0158 <sub>H</sub>             | 56 <sub>H</sub> / 86 <sub>D</sub> |
| Unassigned node                               | -                   | xx'015C <sub>H</sub>             | 57 <sub>H</sub> / 87 <sub>D</sub> |
| Unassigned node                               | -                   | xx'0164 <sub>H</sub>             | 59 <sub>H</sub> / 89 <sub>D</sub> |
| Unassigned node                               | -                   | xx'0168 <sub>H</sub>             | 5A <sub>H</sub> / 90 <sub>D</sub> |
| Unassigned node                               | -                   | xx'016C <sub>H</sub>             | 5B <sub>H</sub> / 91 <sub>D</sub> |
| Unassigned node                               | -                   | xx'0170 <sub>H</sub>             | 5C <sub>H</sub> / 92 <sub>D</sub> |
| Unassigned node                               | -                   | xx'0174 <sub>H</sub>             | 5D <sub>H</sub> / 93 <sub>D</sub> |
| Unassigned node                               | -                   | xx'0100 <sub>H</sub>             | 40 <sub>H</sub> / 64 <sub>D</sub> |
| Unassigned node                               | -                   | xx'0104 <sub>H</sub>             | 41 <sub>H</sub> / 65 <sub>D</sub> |
| Unassigned node                               | -                   | xx'012C <sub>H</sub>             | 4B <sub>H</sub> / 75 <sub>D</sub> |
| Unassigned node                               | -                   | xx'00FC <sub>H</sub>             | 3F <sub>H</sub> / 63 <sub>D</sub> |
| Unassigned node                               | -                   | xx'0160 <sub>H</sub>             | 58 <sub>H</sub> / 88 <sub>D</sub> |
|                                               |                     |                                  |                                   |

1) Register VECSEG defines the segment where the vector table is located to.

Bitfield VECSC in register CPUCON1 defines the distance between two adjacent vectors. This table represents the default setting, with a distance of 4 (two words) between two vectors.



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 High Speed Synchronous Serial Channels (SSC0/SSC1)

The High Speed Synchronous Serial Channels SSC0/SSC1 support full-duplex and halfduplex synchronous communication. It may be configured so it interfaces with serially linked peripheral components, full SPI functionality is supported.

A dedicated baud rate generator allows to set up all standard baud rates without oscillator tuning. For transmission, reception and error handling three separate interrupt vectors are provided.

The SSC transmits or receives characters of 2 ... 16 bits length synchronously to a shift clock which can be generated by the SSC (master mode) or by an external master (slave mode). The SSC can start shifting with the LSB or with the MSB and allows the selection of shifting and latching clock edges as well as the clock polarity.

A number of optional hardware error detection capabilities has been included to increase the reliability of data transfers. Transmit error and receive error supervise the correct handling of the data buffer. Phase error and baudrate error detect incorrect serial data.

# Summary of Features

- Master or Slave mode operation
- Full-duplex or Half-duplex transfers
- Baudrate generation from 20 Mbit/s to 305.18 bit/s (@ 40 MHz)
- Flexible data format
  - Programmable number of data bits: 2 to 16 bits
  - Programmable shift direction: LSB-first or MSB-first
  - Programmable clock polarity: idle low or idle high
  - Programmable clock/data phase: data shift with leading or trailing clock edge
- Loop back option available for testing purposes
- Interrupt generation on transmitter buffer empty condition, receive buffer full condition, error condition (receive, phase, baudrate, transmit error)
- Three pin interface with flexible SSC pin configuration



| Table 11 | DC Characteristics ( | Operating | Conditions | apply) <sup>1)</sup> | (cont'd) |
|----------|----------------------|-----------|------------|----------------------|----------|
|----------|----------------------|-----------|------------|----------------------|----------|

| Parameter                                                  | Symbol                                 |    | Limit Values |      | Unit | <b>Test Condition</b>               |
|------------------------------------------------------------|----------------------------------------|----|--------------|------|------|-------------------------------------|
|                                                            |                                        |    | Min.         | Max. |      |                                     |
| Level inactive hold current <sup>13)</sup>                 | <i>I</i> <sub>LHI</sub> <sup>10)</sup> |    | _            | -10  | μA   | $V_{\rm OUT}$ = 0.5 × $V_{\rm DDP}$ |
| Level active hold current <sup>13)</sup>                   | $I_{\rm LHA}^{11)}$                    |    | -100         | -    | μA   | V <sub>OUT</sub> = 0.45 V           |
| XTAL1 input current                                        | I <sub>IL</sub>                        | CC | -            | ±20  | μA   | $0 V < V_{IN} < V_{DDI}$            |
| Pin capacitance <sup>14)</sup><br>(digital inputs/outputs) | C <sub>IO</sub>                        | CC | -            | 10   | pF   | -                                   |

1) Keeping signal levels within the limits specified in this table, ensures operation without overload conditions. For signal levels outside these specifications, also refer to the specification of the overload current  $I_{OV}$ .

2) If XTAL1 is driven by a crystal, reaching an amplitude (peak to peak) of  $0.4 \times V_{DDI}$  is sufficient.

3) This parameter is tested for P3, P4, P9.

4) The maximum deliverable output current of a port driver depends on the selected output driver mode, see Table 12, Current Limits for Port Output Drivers. The limit for pin groups must be respected.

- 5) As a rule, with decreasing output current the output levels approach the respective supply level ( $V_{OL} \rightarrow V_{SS}$ ,  $V_{OH} \rightarrow V_{DDP}$ ). However, only the levels for nominal output currents are guaranteed.
- 6) This specification is not valid for outputs which are switched to open drain mode. In this case the respective output will float and the voltage results from the external circuitry.
- 7) An additional error current ( $I_{INJ}$ ) will flow if an overload current flows through an adjacent pin. Please refer to the definition of the overload coupling factor  $K_{OV}$ .
- 8) The driver of P3.15 is designed for faster switching, because this pin can deliver the reference clock for the bus interface (CLKOUT). The maximum leakage current for P3.15 is, therefore, increased to 1  $\mu$ A.
- 9) This specification is valid during Reset for configuration on RD, WR, EA, PORTO
- 10) The maximum current may be drawn while the respective signal line remains inactive.
- 11) The minimum current must be drawn to drive the respective signal line active.
- 12) This specification is valid during Reset for configuration on ALE.
- 13) This specification is valid during Reset for pins P4.3-0, which can act as  $\overline{CS}$  outputs, and for P3.12.
- 14) Not subject to production test verified by design/characterization.

| Port Output Driver<br>Mode | Maximum Output Current $(I_{OLmax}, -I_{OHmax})^{1}$ | Nominal Output Current<br>( <i>I</i> <sub>OLnom</sub> , - <i>I</i> <sub>OHnom</sub> ) |  |  |
|----------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------|--|--|
| Strong driver              | 10 mA                                                | 2.5 mA                                                                                |  |  |
| Medium driver              | 4.0 mA                                               | 1.0 mA                                                                                |  |  |
| Weak driver                | 0.5 mA                                               | 0.1 mA                                                                                |  |  |

## Table 12 Current Limits for Port Output Drivers



1) An output current above  $|I_{OXnom}|$  may be drawn from up to three pins at the same time. For any group of 16 neighboring port output pins the total output current in each direction ( $\Sigma I_{OL}$  and  $\Sigma - I_{OH}$ ) must remain below 50 mA.

| Table 13 | <b>Power Consumption XC164S</b> (Operating Conditions apply) |
|----------|--------------------------------------------------------------|
|          |                                                              |

| Sym-                                  | Limit Values                                                                                      |                                                             | Unit                                                                                                                                                                                                                                                                              | Test Condition                                                                                                                                                                                                                                                                                    |
|---------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bol                                   | Min.                                                                                              | Max.                                                        |                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                   |
| $I_{DDI}$                             | -                                                                                                 | 15 +<br>2.6 × f <sub>CPU</sub>                              | mA                                                                                                                                                                                                                                                                                | f <sub>CPU</sub> in [MHz] <sup>1)2)</sup>                                                                                                                                                                                                                                                         |
| $I_{DDP}$                             | _                                                                                                 | 5                                                           | mA                                                                                                                                                                                                                                                                                | 3)                                                                                                                                                                                                                                                                                                |
| I <sub>IDX</sub>                      | _                                                                                                 | 15 +<br>1.2 × f <sub>CPU</sub>                              | mA                                                                                                                                                                                                                                                                                | $f_{\rm CPU}$ in [MHz] <sup>2)</sup>                                                                                                                                                                                                                                                              |
| I <sub>PDL</sub> <sup>5)</sup>        | -                                                                                                 | 128,000<br>× e <sup>-α</sup>                                | mA                                                                                                                                                                                                                                                                                | $V_{\rm DDI} = V_{\rm DDImax}^{6)}$<br>$T_{\rm J}$ in [°C]<br>$\alpha =$<br>4670 / (273 + $T_{\rm J}$ )                                                                                                                                                                                           |
| <i>I</i> <sub>PDM</sub> <sup>7)</sup> | _                                                                                                 | 0.6 +<br>0.02 × $f_{OSC}$<br>+ $I_{PDL}$                    | mA                                                                                                                                                                                                                                                                                | $V_{\text{DDI}} = V_{\text{DDImax}}$<br>$f_{\text{OSC}}$ in [MHz]                                                                                                                                                                                                                                 |
|                                       | bol<br>I <sub>DDI</sub><br>I <sub>DDP</sub><br>I <sub>IDX</sub><br>I <sub>PDL</sub> <sup>5)</sup> | bolMin. $I_{DDI}$ - $I_{DDP}$ - $I_{IDX}$ - $I_{PDL}^{5}$ - | bol         Min.         Max. $I_{DDI}$ -         15 + $I_{DDP}$ -         5 $I_{IDX}$ -         15 + $I_{IDX}$ -         5 $I_{PDL}^{5}$ -         15 + $I_{PDL}^{5}$ -         128,000 $\times e^{-\alpha}$ -         0.6 + $0.02 \times f_{OSC}$ -         0.02 \times f_{OSC} | bol         Min.         Max. $I_{DDI}$ -         15 +<br>2.6 × f_{CPU}         mA $I_{DDP}$ -         5         mA $I_{IDX}$ -         15 +<br>1.2 × f_{CPU}         mA $I_{PDL}^{5)}$ -         128,000<br>× e^{-\alpha}         mA $I_{PDM}^{7)}$ -         0.6 +<br>0.02 × f_{OSC}         mA |

1) During Flash programming or erase operations the supply current is increased by max. 5 mA.

2) The supply current is a function of the operating frequency. This dependency is illustrated in Figure 10. These parameters are tested at V<sub>DDImax</sub> and maximum CPU clock frequency with all outputs disconnected and all inputs at V<sub>IL</sub> or V<sub>IH</sub>.

- 3) The pad supply voltage pins ( $V_{\text{DDP}}$ ) mainly provides the current consumed by the pin output drivers. A small amount of current is consumed even though no outputs are driven, because the drivers' input stages are switched and also the Flash module draws some power from the  $V_{\text{DDP}}$  supply.
- 4) The total supply current in Sleep and Power down mode is the sum of the temperature dependent leakage current and the frequency dependent current for RTC and main oscillator (if active).
- 5) This parameter is determined mainly by the transistor leakage currents. This current heavily depends on the junction temperature (see Figure 12). The junction temperature  $T_J$  is the same as the ambient temperature  $T_A$  if no current flows through the port output drivers. Otherwise, the resulting temperature difference must be taken into account.
- 6) All inputs (including pins configured as inputs) at 0 V to 0.1 V or at  $V_{\text{DDP}}$  0.1 V to  $V_{\text{DDP}}$ , all outputs (including pins configured as outputs) disconnected. This parameter is tested at 25 °C and is valid for  $T_{\text{J}} \ge$  25 °C.
- 7) This parameter is determined mainly by the current consumed by the oscillator switched to low gain mode (see Figure 11). This current, however, is influenced by the external oscillator circuitry (crystal, capacitors). The given values refer to a typical circuitry and may change in case of a not optimized external oscillator circuitry.





Figure 10 Supply/Idle Current as a Function of Operating Frequency



- 3) The limit values for  $f_{BC}$  must not be exceeded when selecting the peripheral frequency and the ADCTC setting.
- 4) This parameter includes the sample time t<sub>S</sub>, the time for determining the digital result and the time to load the result register with the conversion result (t<sub>SYS</sub> = 1/f<sub>SYS</sub>). Values for the basic clock t<sub>BC</sub> depend on programming and can be taken from Table 15. When the post-calibration is switched off, the conversion time is reduced by 12 × t<sub>BC</sub>.
- 5) The actual duration of the reset calibration depends on the noise on the reference signal. Conversions executed during the reset calibration increase the calibration time. The TUE for those conversions may be increased.
- 6) Not subject to production test verified by design/characterization. The given parameter values cover the complete operating range. Under relaxed operating conditions (temperature, supply voltage) reduced values can be used for calculations. At room temperature and nominal supply voltage the following typical values can be used:

 $C_{AINTtyp}$  = 12 pF,  $C_{AINStyp}$  = 7 pF,  $R_{AINtyp}$  = 1.5 k $\Omega$ ,  $C_{AREFTtyp}$  = 15 pF,  $C_{AREFStyp}$  = 13 pF,  $R_{AREFtyp}$  = 0.7 k $\Omega$ .



Figure 13 Equivalent Circuitry for Analog Inputs



# 4.4.4 Testing Waveforms



# Figure 17 Input Output Waveforms



# Figure 18 Float Waveforms



# Package and Reliability

# **Package Outlines**



Figure 22 PG-TQFP-100-5 (Plastic Green Thin Quad Flat Package)

www.infineon.com