



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             | Obsolete                                                                     |
|----------------------------|------------------------------------------------------------------------------|
| Core Processor             | C166                                                                         |
| Core Size                  | 16-Bit                                                                       |
| Speed                      | 20MHz                                                                        |
| Connectivity               | CANbus, EBI/EMI, SPI, SSC, UART/USART                                        |
| Peripherals                | POR, PWM, WDT                                                                |
| Number of I/O              | 59                                                                           |
| Program Memory Size        | 64KB (64K x 8)                                                               |
| Program Memory Type        | OTP                                                                          |
| EEPROM Size                | -                                                                            |
| RAM Size                   | 4K x 8                                                                       |
| Voltage - Supply (Vcc/Vdd) | 4.75V ~ 5.5V                                                                 |
| Data Converters            | A/D 8x10b                                                                    |
| Oscillator Type            | External                                                                     |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                                |
| Package / Case             | 80-QFP                                                                       |
| Supplier Device Package    | PG-MQFP-80-7                                                                 |
| Purchase URL               | https://www.e-xfl.com/product-detail/infineon-technologies/c164ci8emdbkxuma1 |

Email: info@E-XFL.COM

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

# C164CI/SI C164CL/SL

16-Bit Single-Chip Microcontroller

# Microcontrollers



Never stop thinking.



- Supported by a Large Range of Development Tools like C-Compilers, Macro-Assembler Packages, Emulators, Evaluation Boards, HLL-Debuggers, Simulators, Logic Analyzer Disassemblers, Programming Boards
- On-Chip Bootstrap Loader
- 80-Pin MQFP Package, 0.65 mm pitch

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

| Derivative <sup>1)</sup>                 | Program<br>Memory | CAPCOM6       | CAN Interf. | Operating<br>Frequency |
|------------------------------------------|-------------------|---------------|-------------|------------------------|
| SAK-C164CI-8R[25]M<br>SAF-C164CI-8R[25]M | 64 KByte ROM      | Full function | CAN1        | 20 MHz,<br>[25 MHz]    |
| SAK-C164SI-8R[25]M<br>SAF-C164SI-8R[25]M | 64 KByte ROM      | Full function |             | 20 MHz,<br>[25 MHz]    |
| SAK-C164CL-8R[25]M<br>SAF-C164CL-8R[25]M | 64 KByte ROM      | Reduced fct.  | CAN1        | 20 MHz,<br>[25 MHz]    |
| SAK-C164SL-8R[25]M<br>SAF-C164SL-8R[25]M | 64 KByte ROM      | Reduced fct.  |             | 20 MHz,<br>[25 MHz]    |
| SAK-C164CL-6R[25]M<br>SAF-C164CL-6R[25]M | 48 KByte ROM      | Reduced fct.  | CAN1        | 20 MHz,<br>[25 MHz]    |
| SAK-C164SL-6R[25]M<br>SAF-C164SL-6R[25]M | 48 KByte ROM      | Reduced fct.  |             | 20 MHz,<br>[25 MHz]    |
| SAK-C164CI-L[25]M<br>SAF-C164CI-L[25]M   |                   | Full function | CAN1        | 20 MHz,<br>[25 MHz]    |
| SAK-C164CI-8EM<br>SAF-C164CI-8EM         | 64 KByte OTP      | Full function | CAN1        | 20 MHz                 |

#### Table 1C164CI Derivative Synopsis

<sup>1)</sup> This Data Sheet is valid for ROM(less) devices starting with and including design step AB, and for OTP devices starting with and including design step DA.

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



| Table 2        | PI         | n Definit      | tions and Functions (cont d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol         | Pin<br>No. | Input<br>Outp. | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| XTAL2<br>XTAL1 | 54<br>55   | O<br>I         | <ul> <li>XTAL2: Output of the oscillator amplifier circuit.</li> <li>XTAL1: Input to the oscillator amplifier and input to<br/>the internal clock generator</li> <li>To clock the device from an external source, drive XTAL1,<br/>while leaving XTAL2 unconnected. Minimum and maximum<br/>high/low and rise/fall times specified in the AC<br/>Characteristics must be observed.</li> </ul>                                                                                                                                                                                                                                                                                |
| RSTIN          | 69         | I/O            | Reset Input with Schmitt-Trigger characteristics. A low level<br>at this pin while the oscillator is running resets the C164CI.<br>An internal pullup resistor permits power-on reset using only<br>a capacitor connected to $V_{SS}$ .<br>A spike filter suppresses input pulses <10 ns. Input pulses<br>>100 ns safely pass the filter. The minimum duration for a<br>safe recognition should be 100 ns + 2 CPU clock cycles.<br>In bidirectional reset mode (enabled by setting bit BDRSTEN<br>in register SYSCON) the RSTIN line is internally pulled low<br>for the duration of the internal reset sequence upon any reset<br>(HW, SW, WDT). See note below this table. |
| RST<br>OUT     | 70         | 0              | Internal Reset Indication Output. This pin is set to a low level<br>when the part is executing either a hardware-, a software- or<br>a watchdog timer reset. RSTOUT remains low until the EINIT<br>(end of initialization) instruction is executed.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| NMI            | 71         | I              | Non-Maskable Interrupt Input. A high to low transition at this pin causes the CPU to vector to the NMI trap routine. When the PWRDN (power down) instruction is executed, the $\overline{\text{NMI}}$ pin must be low in order to force the C164CI to go into power down mode. If $\overline{\text{NMI}}$ is high, when PWRDN is executed, the part will continue to run in normal mode.                                                                                                                                                                                                                                                                                     |

#### Table 2Pin Definitions and Functions (cont'd)

If not used, pin  $\overline{\text{NMI}}$  should be pulled high externally.



#### **Central Processing Unit (CPU)**

The main core of the CPU consists of a 4-stage instruction pipeline, a 16-bit arithmetic and logic unit (ALU) and dedicated SFRs. Additional hardware has been spent for a separate multiply and divide unit, a bit-mask generator and a barrel shifter.

Based on these hardware provisions, most of the C164CI's instructions can be executed in just one machine cycle which requires 2 CPU clocks (4 TCL). For example, shift and rotate instructions are always processed during one machine cycle independent of the number of bits to be shifted. All multiple-cycle instructions have been optimized so that they can be executed very fast as well: branches in 2 cycles, a  $16 \times 16$  bit multiplication in 5 cycles and a 32-/16-bit division in 10 cycles. Another pipeline optimization, the so-called 'Jump Cache', reduces the execution time of repeatedly performed jumps in a loop from 2 cycles to 1 cycle.



Figure 4

**CPU Block Diagram** 



#### **Interrupt System**

With an interrupt response time within a range from just 5 to 12 CPU clocks (in case of internal program execution), the C164CI is capable of reacting very fast to the occurrence of non-deterministic events.

The architecture of the C164CI 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. An individual PEC transfer counter is implicity 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 C164CI 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 sources. Via its related register, each source 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 sources 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 3** shows all of the possible C164CI interrupt sources and the corresponding hardware-related interrupt flags, vectors, vector locations and trap (interrupt) numbers.

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



# Table 3 C164CI Interrupt Nodes

| Source of Interrupt or<br>PEC Service Request | Request<br>Flag | Enable<br>Flag | Interrupt<br>Vector | Vector<br>Location   | Trap<br>Number  |
|-----------------------------------------------|-----------------|----------------|---------------------|----------------------|-----------------|
| Fast External Interrupt 0                     | CC8IR           | CC8IE          | CC8INT              | 00'0060 <sub>H</sub> | 18 <sub>H</sub> |
| Fast External Interrupt 1                     | CC9IR           | CC9IE          | CC9INT              | 00'0064 <sub>H</sub> | 19 <sub>H</sub> |
| Fast External Interrupt 2                     | CC10IR          | CC10IE         | CC10INT             | 00'0068 <sub>H</sub> | 1A <sub>H</sub> |
| Fast External Interrupt 3                     | CC11IR          | CC11IE         | CC11INT             | 00'006C <sub>H</sub> | 1B <sub>H</sub> |
| GPT1 Timer 2                                  | T2IR            | T2IE           | T2INT               | 00'0088 <sub>H</sub> | 22 <sub>H</sub> |
| GPT1 Timer 3                                  | T3IR            | T3IE           | T3INT               | 00'008C <sub>H</sub> | 23 <sub>H</sub> |
| GPT1 Timer 4                                  | T4IR            | T4IE           | T4INT               | 00'0090 <sub>H</sub> | 24 <sub>H</sub> |
| A/D Conversion<br>Complete                    | ADCIR           | ADCIE          | ADCINT              | 00'00A0 <sub>H</sub> | 28 <sub>H</sub> |
| A/D Overrun Error                             | ADEIR           | ADEIE          | ADEINT              | 00'00A4 <sub>H</sub> | 29 <sub>H</sub> |
| ASC0 Transmit                                 | S0TIR           | S0TIE          | SOTINT              | 00'00A8 <sub>H</sub> | 2A <sub>H</sub> |
| ASC0 Transmit Buffer                          | S0TBIR          | S0TBIE         | <b>S0TBINT</b>      | 00'011C <sub>H</sub> | 47 <sub>H</sub> |
| ASC0 Receive                                  | SORIR           | SORIE          | SORINT              | 00'00AC <sub>H</sub> | 2B <sub>H</sub> |
| ASC0 Error                                    | S0EIR           | S0EIE          | S0EINT              | 00'00B0 <sub>H</sub> | 2C <sub>H</sub> |
| SSC Transmit                                  | SCTIR           | SCTIE          | SCTINT              | 00'00B4 <sub>H</sub> | 2D <sub>H</sub> |
| SSC Receive                                   | SCRIR           | SCRIE          | SCRINT              | 00'00B8 <sub>H</sub> | 2E <sub>H</sub> |
| SSC Error                                     | SCEIR           | SCEIE          | SCEINT              | 00'00BC <sub>H</sub> | 2F <sub>H</sub> |
| CAPCOM Register 16                            | CC16IR          | CC16IE         | CC16INT             | 00'00C0 <sub>H</sub> | 30 <sub>H</sub> |
| CAPCOM Register 17                            | CC17IR          | CC17IE         | CC17INT             | 00'00C4 <sub>H</sub> | 31 <sub>H</sub> |
| CAPCOM Register 18                            | CC18IR          | CC18IE         | CC18INT             | 00'00C8 <sub>H</sub> | 32 <sub>H</sub> |
| CAPCOM Register 19                            | CC19IR          | CC19IE         | CC19INT             | 00'00CC <sub>H</sub> | 33 <sub>H</sub> |
| CAPCOM Register 24                            | CC24IR          | CC24IE         | CC24INT             | 00'00E0 <sub>H</sub> | 38 <sub>H</sub> |
| CAPCOM Register 25                            | CC25IR          | CC25IE         | CC25INT             | 00'00E4 <sub>H</sub> | 39 <sub>H</sub> |
| CAPCOM Register 26                            | CC26IR          | CC26IE         | CC26INT             | 00'00E8 <sub>H</sub> | 3A <sub>H</sub> |
| CAPCOM Register 27                            | CC27IR          | CC27IE         | CC27INT             | 00'00EC <sub>H</sub> | 3B <sub>H</sub> |
| CAPCOM Timer 7                                | T7IR            | T7IE           | T7INT               | 00'00F4 <sub>H</sub> | 3D <sub>H</sub> |
| CAPCOM Timer 8                                | T8IR            | T8IE           | T8INT               | 00'00F8 <sub>H</sub> | 3E <sub>H</sub> |
| CAPCOM6 Interrupt                             | CC6IR           | CC6IE          | CC6INT              | 00'00FC <sub>H</sub> | 3F <sub>H</sub> |
| CAN Interface 1                               | XP0IR           | XP0IE          | XP0INT              | 00'0100 <sub>H</sub> | 40 <sub>H</sub> |
| PLL/OWD and RTC                               | XP3IR           | XP3IE          | XP3INT              | 00'010C <sub>H</sub> | 43 <sub>H</sub> |



#### General Purpose Timer (GPT) Unit

The GPT unit represents a very flexible multifunctional timer/counter structure which may be used for many different time related tasks such as event timing and counting, pulse width and duty cycle measurements, pulse generation, or pulse multiplication.

The GPT unit incorporates three 16-bit timers. Each timer may operate independently in a number of different modes, or may be concatenated with another timer.

Each of the three timers T2, T3, T4 of **module GPT1** can be configured individually for one of four basic modes of operation, which are Timer, Gated Timer, Counter, and Incremental Interface Mode. In Timer Mode, the input clock for a timer is derived from the CPU clock, divided by a programmable prescaler, while Counter Mode allows a timer to be clocked in reference to external events.

Pulse width or duty cycle measurement is supported in Gated Timer Mode, where the operation of a timer is controlled by the 'gate' level on an external input pin. For these purposes, each timer has one associated port pin (TxIN) which serves as gate or clock input. The maximum resolution of the timers in module GPT1 is 16 TCL.

The count direction (up/down) for each timer is programmable by software or may additionally be altered dynamically by an external signal on a port pin (TxEUD) to facilitate e.g. position tracking.

In Incremental Interface Mode the GPT1 timers (T2, T3, T4) can be directly connected to the incremental position sensor signals A and B via their respective inputs TxIN and TxEUD. Direction and count signals are internally derived from these two input signals, so the contents of the respective timer Tx corresponds to the sensor position. The third position sensor signal TOP0 can be connected to an interrupt input.

Timer T3 has an output toggle latch (T3OTL) which changes its state on each timer overflow/underflow. The state of this latch may be used internally to clock timers T2 and T4 for measuring long time periods with high resolution.

In addition to their basic operating modes, timers T2 and T4 may be configured as reload or capture registers for timer T3. When used as capture or reload registers, timers T2 and T4 are stopped. The contents of timer T3 is captured into T2 or T4 in response to a signal at their associated input pins (TxIN). Timer T3 is reloaded with the contents of T2 or T4 triggered either by an external signal or by a selectable state transition of its toggle latch T3OTL.



#### A/D Converter

For analog signal measurement, a 10-bit A/D converter with 8 multiplexed input channels and a sample and hold circuit has been integrated on-chip. It uses the method of successive approximation. The sample time (for loading the capacitors) and the conversion time is programmable and can so be adjusted to the external circuitry.

Overrun error detection/protection is provided for the conversion result register (ADDAT): either an interrupt request will be generated when the result of a previous conversion has not been read from the result register at the time the next conversion is complete, or the next conversion is suspended in such a case until the previous result has been read.

For applications which require less than 8 analog input channels, the remaining channel inputs can be used as digital input port pins.

The A/D converter of the C164CI supports four different conversion modes. In the standard Single Channel conversion mode, the analog level on a specified channel is sampled once and converted to a digital result. In the Single Channel Continuous mode, the analog level on a specified channel is repeatedly sampled and converted without software intervention. In the Auto Scan mode, the analog levels on a prespecified number of channels (standard or extension) are sequentially sampled and converted. In the Auto Scan Continuous mode, the number of prespecified channels is repeatedly sampled and converted. In the Auto Scan Continuous mode, the conversion of a specific channel can be inserted (injected) into a running sequence without disturbing this sequence. This is called Channel Injection Mode.

The Peripheral Event Controller (PEC) may be used to automatically store the conversion results into a table in memory for later evaluation, without requiring the overhead of entering and exiting interrupt routines for each data transfer.

After each reset and also during normal operation the ADC automatically performs calibration cycles. This automatic self-calibration constantly adjusts the converter to changing operating conditions (e.g. temperature) and compensates process variations.

These calibration cycles are part of the conversion cycle, so they do not affect the normal operation of the A/D converter.

In order to decouple analog inputs from digital noise and to avoid input trigger noise those pins used for analog input can be disconnected from the digital IO or input stages under software control. This can be selected for each pin separately via register P5DIDIS (Port 5 Digital Input Disable).



#### **CAN-Module**

The integrated CAN-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 CAN-Modules can receive and transmit standard frames with 11-bit identifiers as well as extended frames with 29-bit identifiers.

The module provides Full CAN functionality on up to 15 message objects. Message object 15 may be configured for Basic CAN functionality. Both modes provide separate masks for acceptance filtering which allows to accept a number of identifiers in Full CAN mode and also allows to disregard a number of identifiers in Basic CAN mode. All message objects can be updated independent from the other objects and are equipped for the maximum message length of 8 bytes.

The bit timing is derived from the XCLK and is programmable up to a data rate of 1 Mbit/ s. Each CAN-Module uses two pins of Port 4 or Port 8 to interface to an external bus transceiver. The interface pins are assigned via software.

Note: When the CAN interface is assigned to Port 4, the respective segment address lines on Port 4 cannot be used. This will limit the external address space.

#### Watchdog Timer

The Watchdog Timer represents one of the fail-safe mechanisms which have been implemented to prevent the controller from malfunctioning for longer periods of time.

The Watchdog Timer is always enabled after a reset of the chip, and can only be disabled in the time interval until the EINIT (end of initialization) instruction has been executed. Thus, the chip's start-up procedure is always monitored. The software has to be designed to service the Watchdog Timer before it overflows. If, due to hardware or software related failures, the software fails to do so, the Watchdog Timer overflows and generates an internal hardware reset and pulls the RSTOUT pin low in order to allow external hardware components to be reset.

The Watchdog Timer is a 16-bit timer, clocked with the system clock divided by 2/4/128/256. The high byte of the Watchdog Timer register can be set to a prespecified reload value (stored in WDTREL) in order to allow further variation of the monitored time interval. Each time it is serviced by the application software, the high byte of the Watchdog Timer is reloaded. Thus, time intervals between 20  $\mu$ s and 336 ms can be monitored (@ 25 MHz).

The default Watchdog Timer interval after reset is 5.24 ms (@ 25 MHz).



## Table 7C164Cl Registers, Ordered by Name (cont'd)

| Name    |   | Physica<br>Address | I<br>S | 8-Bit<br>Addr.  | Description                                         | Reset<br>Value    |
|---------|---|--------------------|--------|-----------------|-----------------------------------------------------|-------------------|
| C1MCFGn |   | EFn6 <sub>H</sub>  | X      |                 | CAN Message Configuration Register (msg. <b>n</b> ) | UU <sub>H</sub>   |
| C1MCRn  |   | EFn0 <sub>H</sub>  | X      |                 | CAN Message Control Register (msg. n)               | UUUU <sub>H</sub> |
| C1PCIR  |   | EF02 <sub>H</sub>  | Χ      |                 | CAN1 Port Control / Interrupt Register              | XXXX <sub>H</sub> |
| C1UARn  |   | EFn2 <sub>H</sub>  | Χ      |                 | CAN Upper Arbitration Register (msg. n)             | UUUU <sub>H</sub> |
| C1UGML  |   | EF08 <sub>H</sub>  | Χ      |                 | CAN Upper Global Mask Long                          | UUUU <sub>H</sub> |
| C1UMLM  |   | EF0C <sub>H</sub>  | Χ      |                 | CAN Upper Mask of Last Message                      | UUUU <sub>H</sub> |
| CC10IC  | b | FF8C <sub>H</sub>  |        | C6 <sub>H</sub> | External Interrupt 2 Control Register               | 0000 <sub>H</sub> |
| CC11IC  | b | FF8E <sub>H</sub>  |        | C7 <sub>H</sub> | External Interrupt 3 Control Register               | 0000 <sub>H</sub> |
| CC16    |   | FE60 <sub>H</sub>  |        | 30 <sub>H</sub> | CAPCOM Register 16                                  | 0000 <sub>H</sub> |
| CC16IC  | b | F160 <sub>H</sub>  | Ε      | B0 <sub>H</sub> | CAPCOM Reg. 16 Interrupt Ctrl. Reg.                 | 0000 <sub>H</sub> |
| CC17    |   | FE62 <sub>H</sub>  |        | 31 <sub>H</sub> | CAPCOM Register 17                                  | 0000 <sub>H</sub> |
| CC17IC  | b | F162 <sub>H</sub>  | Ε      | B1 <sub>H</sub> | CAPCOM Reg. 17 Interrupt Ctrl. Reg.                 | 0000 <sub>H</sub> |
| CC18    |   | FE64 <sub>H</sub>  |        | 32 <sub>H</sub> | CAPCOM Register 18                                  | 0000 <sub>H</sub> |
| CC18IC  | b | F164 <sub>H</sub>  | Ε      | B2 <sub>H</sub> | CAPCOM Reg. 18 Interrupt Ctrl. Reg.                 | 0000 <sub>H</sub> |
| CC19    |   | FE66 <sub>H</sub>  |        | 33 <sub>H</sub> | CAPCOM Register 19                                  | 0000 <sub>H</sub> |
| CC19IC  | b | F166 <sub>H</sub>  | Ε      | B3 <sub>H</sub> | CAPCOM Reg. 19 Interrupt Ctrl. Reg.                 | 0000 <sub>H</sub> |
| CC20    |   | FE68 <sub>H</sub>  |        | 34 <sub>H</sub> | CAPCOM Register 20                                  | 0000 <sub>H</sub> |
| CC20IC  | b | F168 <sub>H</sub>  | Ε      | B4 <sub>H</sub> | CAPCOM Reg. 20 Interrupt Ctrl. Reg.                 | 0000 <sub>H</sub> |
| CC21    |   | FE6A <sub>H</sub>  |        | 35 <sub>H</sub> | CAPCOM Register 21                                  | 0000 <sub>H</sub> |
| CC21IC  | b | F16A <sub>H</sub>  | Ε      | B5 <sub>H</sub> | CAPCOM Reg. 21 Interrupt Ctrl. Reg.                 | 0000 <sub>H</sub> |
| CC22    |   | FE6C <sub>H</sub>  |        | 36 <sub>H</sub> | CAPCOM Register 22                                  | 0000 <sub>H</sub> |
| CC22IC  | b | F16C <sub>H</sub>  | Ε      | B6 <sub>H</sub> | CAPCOM Reg. 22 Interrupt Ctrl. Reg.                 | 0000 <sub>H</sub> |
| CC23    |   | FE6E <sub>H</sub>  |        | 37 <sub>H</sub> | CAPCOM Register 23                                  | 0000 <sub>H</sub> |
| CC23IC  | b | F16E <sub>H</sub>  | Ε      | B7 <sub>H</sub> | CAPCOM Reg. 23 Interrupt Ctrl. Reg.                 | 0000 <sub>H</sub> |
| CC24    |   | FE70 <sub>H</sub>  |        | 38 <sub>H</sub> | CAPCOM Register 24                                  | 0000 <sub>H</sub> |
| CC24IC  | b | F170 <sub>H</sub>  | Ε      | B8 <sub>H</sub> | CAPCOM Reg. 24 Interrupt Ctrl. Reg.                 | 0000 <sub>H</sub> |
| CC25    |   | FE72 <sub>H</sub>  |        | 39 <sub>H</sub> | CAPCOM Register 25                                  | 0000 <sub>H</sub> |
| CC25IC  | b | F172 <sub>H</sub>  | Ε      | B9 <sub>H</sub> | CAPCOM Reg. 25 Interrupt Ctrl. Reg.                 | 0000 <sub>H</sub> |
| CC26    |   | FE74 <sub>H</sub>  |        | ЗА <sub>Н</sub> | CAPCOM Register 26                                  | 0000 <sub>H</sub> |



## Table 7C164Cl Registers, Ordered by Name (cont'd)

| Name    |   | Physica<br>Addres | al<br>S | 8-Bit<br>Addr.  | Description                            | Reset<br>Value    |
|---------|---|-------------------|---------|-----------------|----------------------------------------|-------------------|
| OPDAT   |   | EDC4 <sub>H</sub> | Χ       |                 | OTP Progr. Interface Data Register     | 0000 <sub>H</sub> |
| P0H     | b | FF02 <sub>H</sub> |         | 81 <sub>H</sub> | Port 0 High Reg. (Upper half of PORT0) | 00 <sub>H</sub>   |
| P0L     | b | FF00 <sub>H</sub> |         | 80 <sub>H</sub> | Port 0 Low Reg. (Lower half of PORT0)  | 00 <sub>H</sub>   |
| P1H     | b | FF06 <sub>H</sub> |         | 83 <sub>H</sub> | Port 1 High Reg. (Upper half of PORT1) | 00 <sub>H</sub>   |
| P1L     | b | FF04 <sub>H</sub> |         | 82 <sub>H</sub> | Port 1 Low Reg. (Lower half of PORT1)  | 00 <sub>H</sub>   |
| P3      | b | FFC4 <sub>H</sub> |         | E2 <sub>H</sub> | Port 3 Register                        | 0000 <sub>H</sub> |
| P4      | b | FFC8 <sub>H</sub> |         | E4 <sub>H</sub> | Port 4 Register (7 bits)               | 00 <sub>H</sub>   |
| P5      | b | FFA2 <sub>H</sub> |         | D1 <sub>H</sub> | Port 5 Register (read only)            | XXXX <sub>H</sub> |
| P5DIDIS | b | FFA4 <sub>H</sub> |         | D2 <sub>H</sub> | Port 5 Digital Input Disable Register  | 0000 <sub>H</sub> |
| P8      | b | FFD4 <sub>H</sub> |         | EA <sub>H</sub> | Port 8 Register (8 bits)               | 00 <sub>H</sub>   |
| PECC0   |   | FEC0 <sub>H</sub> |         | 60 <sub>H</sub> | PEC Channel 0 Control Register         | 0000 <sub>H</sub> |
| PECC1   |   | FEC2 <sub>H</sub> |         | 61 <sub>H</sub> | PEC Channel 1 Control Register         | 0000 <sub>H</sub> |
| PECC2   |   | FEC4 <sub>H</sub> |         | 62 <sub>H</sub> | PEC Channel 2 Control Register         | 0000 <sub>H</sub> |
| PECC3   |   | FEC6 <sub>H</sub> |         | 63 <sub>H</sub> | PEC Channel 3 Control Register         | 0000 <sub>H</sub> |
| PECC4   |   | FEC8 <sub>H</sub> |         | 64 <sub>H</sub> | PEC Channel 4 Control Register         | 0000 <sub>H</sub> |
| PECC5   |   | $FECA_{H}$        |         | 65 <sub>H</sub> | PEC Channel 5 Control Register         | 0000 <sub>H</sub> |
| PECC6   |   | $FECC_{H}$        |         | 66 <sub>H</sub> | PEC Channel 6 Control Register         | 0000 <sub>H</sub> |
| PECC7   |   | $FECE_H$          |         | 67 <sub>H</sub> | PEC Channel 7 Control Register         | 0000 <sub>H</sub> |
| PICON   | b | F1C4 <sub>H</sub> | Ε       | E2 <sub>H</sub> | Port Input Threshold Control Register  | 0000 <sub>H</sub> |
| POCON0H |   | F082 <sub>H</sub> | Ε       | 41 <sub>H</sub> | Port P0H Output Control Register       | 0011 <sub>H</sub> |
| POCON0L |   | F080 <sub>H</sub> | Ε       | 40 <sub>H</sub> | Port P0L Output Control Register       | 0011 <sub>H</sub> |
| POCON1H |   | F086 <sub>H</sub> | Ε       | 43 <sub>H</sub> | Port P1H Output Control Register       | 0011 <sub>H</sub> |
| POCON1L |   | F084 <sub>H</sub> | Ε       | 42 <sub>H</sub> | Port P1L Output Control Register       | 0011 <sub>H</sub> |
| POCON20 |   | F0AA <sub>H</sub> | Ε       | 55 <sub>H</sub> | Dedicated Pin Output Control Register  | 0000 <sub>H</sub> |
| POCON3  |   | F08A <sub>H</sub> | Ε       | 45 <sub>H</sub> | Port P3 Output Control Register        | 2222 <sub>H</sub> |
| POCON4  |   | F08C <sub>H</sub> | Ε       | 46 <sub>H</sub> | Port P4 Output Control Register        | 0010 <sub>H</sub> |
| POCON8  |   | F092 <sub>H</sub> | Ε       | 49 <sub>H</sub> | Port P8 Output Control Register        | 0022 <sub>H</sub> |
| PSW     | b | FF10 <sub>H</sub> |         | 88 <sub>H</sub> | CPU Program Status Word                | 0000 <sub>H</sub> |
| RP0H    | b | F108 <sub>H</sub> | Ε       | 84 <sub>H</sub> | System Startup Config. Reg. (Rd. only) | XX <sub>H</sub>   |
| RSTCON  | b | F1E0 <sub>H</sub> | m       |                 | Reset Control Register                 | 00XX <sub>H</sub> |



#### **Operating Conditions**

The following operating conditions must not be exceeded in order to ensure correct operation of the C164CI. 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            | V <sub>DD</sub>   | 4.75              | 5.5    | V    | Active mode,<br>$f_{CPUmax} = 25 \text{ MHz}$      |
|                                   |                   | 2.5 <sup>1)</sup> | 5.5    | V    | PowerDown mode                                     |
| Digital ground voltage            | V <sub>SS</sub>   | (                 | )      | V    | Reference voltage                                  |
| Overload current                  | I <sub>OV</sub>   | _                 | ±5     | mA   | Per pin <sup>2)3)</sup>                            |
| Absolute sum of overload currents | $\Sigma  I_{OV} $ | -                 | 50     | mA   | 3)                                                 |
| External Load<br>Capacitance      | CL                | -                 | 100    | pF   | Pin drivers in <b>default</b> mode <sup>4)5)</sup> |
| Ambient temperature               | T <sub>A</sub>    | 0                 | 70     | °C   | SAB-C164CI                                         |
|                                   |                   | -40               | 85     | °C   | SAF-C164CI                                         |
|                                   |                   | -40               | 125    | °C   | SAK-C164CI                                         |

#### Table 9 Operating Condition Parameters

<sup>1)</sup> Output voltages and output currents will be reduced when  $V_{\text{DD}}$  leaves the range defined for active mode.

- <sup>2)</sup> Overload conditions occur if the standard operatings conditions are exceeded, i.e. the voltage on any pin exceeds the specified range (i.e. V<sub>OV</sub> > V<sub>DD</sub> + 0.5 V or V<sub>OV</sub> < V<sub>SS</sub> 0.5 V). The absolute sum of input overload currents on all pins may not exceed **50 mA**. The supply voltage must remain within the specified limits. Proper operation is not guaranteed if overload conditions occur on functional pins line XTAL1, RD, WR, etc.
- <sup>3)</sup> Not 100% tested, guaranteed by design and characterization.
- <sup>4)</sup> The timing is valid for pin drivers operating in default current mode (selected after reset). Reducing the output current may lead to increased delays or reduced driving capability (*C*<sub>L</sub>).
- <sup>5)</sup> The current ROM-version of the C164CI is equipped with port drivers, which provide reduced driving capability and reduced control. Please refer to the actual errata sheet for details.



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

#### Table 10 Current Limits for Port Output Drivers

<sup>1)</sup> An output current above II<sub>OXnom</sub>I 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 (ΣI<sub>OL</sub> and Σ-I<sub>OH</sub>) must remain below 50 mA.

<sup>2)</sup> The current ROM-version of the C164CI (step Ax) is equipped with port drivers, which provide reduced driving capability and reduced control. Please refer to the actual errata sheet for details.

#### Power Consumption C164CI (ROM)

(Operating Conditions apply)

| Parameter                                                                                 | Sym-                           | - Limit Values |                                      | Unit | Test                                                                                     |
|-------------------------------------------------------------------------------------------|--------------------------------|----------------|--------------------------------------|------|------------------------------------------------------------------------------------------|
|                                                                                           | bol                            | min.           | max.                                 |      | Conditions                                                                               |
| Power supply current (active) with all peripherals active                                 | I <sub>DD</sub>                | _              | 1 +<br>2.5 × f <sub>CPU</sub>        | mA   | $\overline{\text{RSTIN}} = V_{\text{IL}}$ $f_{\text{CPU}} \text{ in } [\text{MHz}]^{1)}$ |
| Idle mode supply current<br>with all peripherals active                                   | I <sub>IDX</sub>               | _              | 1 +<br>1.1 × <i>f</i> <sub>CPU</sub> | mA   | $\overline{\text{RSTIN}} = V_{\text{IH1}}$ $f_{\text{CPU}} \text{ in [MHz]}^{1)}$        |
| Idle mode supply current<br>with all peripherals deactivated,<br>PLL off, SDD factor = 32 | I <sub>IDO</sub> <sup>2)</sup> | _              | 500 +<br>50 × f <sub>OSC</sub>       | μA   | $\overline{\text{RSTIN}} = V_{\text{IH1}}$<br>$f_{\text{OSC}}$ in [MHz] <sup>1)</sup>    |
| Sleep and Power-down mode supply current with RTC running                                 | I <sub>PDR</sub> <sup>2)</sup> | _              | 200 +<br>25 × f <sub>OSC</sub>       | μA   | $V_{\text{DD}} = V_{\text{DDmax}}$<br>$f_{\text{OSC}}$ in [MHz] <sup>3)</sup>            |
| Sleep and Power-down mode supply current with RTC disabled                                | I <sub>PDO</sub>               | _              | 50                                   | μA   | $V_{\rm DD} = V_{\rm DDmax}^{3)}$                                                        |

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

<sup>2)</sup> This parameter is determined mainly by the current consumed by the oscillator (see Figure 8). This current, however, is influenced by the external oscillator circuitry (crystal, capacitors). The values given refer to a typical circuitry and may change in case of a not optimized external oscillator circuitry.

<sup>3)</sup> This parameter is tested including leakage currents. All inputs (including pins configured as inputs) at 0 V to 0.1 V or at  $V_{DD}$  - 0.1 V to  $V_{DD}$ ,  $V_{REF}$  = 0 V, all outputs (including pins configured as outputs) disconnected.



<sup>8)</sup> During the sample time the input capacitance  $C_{AIN}$  can be charged/discharged by the external source. The internal resistance of the analog source must allow the capacitance to reach its final voltage level within  $t_S$ . After the end of the sample time  $t_S$ , changes of the analog input voltage have no effect on the conversion result. Values for the sample time  $t_S$  depend on programming and can be taken from Table 14.

Sample time and conversion time of the C164CI's A/D Converter are programmable. Table 14 should be used to calculate the above timings.

The limit values for  $f_{BC}$  must not be exceeded when selecting ADCTC.

| ADCON.15 14<br>(ADCTC) | A/D Converter Basic Clock $f_{\rm BC}$ | ADCON.13 12<br>(ADSTC) | Sample time<br>t <sub>S</sub> |
|------------------------|----------------------------------------|------------------------|-------------------------------|
| 00                     | <i>f</i> <sub>СРU</sub> / 4            | 00                     | $t_{\rm BC} 	imes 8$          |
| 01                     | <i>f</i> <sub>CPU</sub> / 2            | 01                     | $t_{\rm BC} 	imes$ 16         |
| 10                     | <i>f</i> <sub>СРU</sub> / 16           | 10                     | $t_{\rm BC} 	imes 32$         |
| 11                     | f <sub>CPU</sub> / 8                   | 11                     | $t_{\rm BC} 	imes 64$         |

#### Table 14 A/D Converter Computation Table

#### **Converter Timing Example:**

| Assumptions:    | ∫cpu            | = 25 MHz (i.e. <i>t</i> <sub>CPU</sub> = 40 ns), ADCTC = '00', ADSTC = '00'.           |
|-----------------|-----------------|----------------------------------------------------------------------------------------|
| Basic clock     | f <sub>BC</sub> | = f <sub>CPU</sub> /4 = 6.25 MHz, i.e. t <sub>BC</sub> = 160 ns.                       |
| Sample time     | ts              | $= t_{\rm BC} \times 8 = 1280$ ns.                                                     |
| Conversion time | t <sub>C</sub>  | $= t_{S} + 40 t_{BC} + 2 t_{CPU} = (1280 + 6400 + 80) \text{ ns} = 7.8 \ \mu\text{s}.$ |





Figure 19 External Memory Cycle: Multiplexed Bus, No Read/Write Delay, Extended ALE



## Demultiplexed Bus (cont'd)

(Operating Conditions apply)

ALE cycle time = 4 TCL +  $2t_A$  +  $t_C$  +  $t_F$  (80 ns at 25 MHz CPU clock without waitstates)

| Parameter                                                                              |                        | nbol | Max. CPU Clock<br>= 25 MHz  |                            | Variable (<br>1 / 2TCL =             | Unit                                                           |    |
|----------------------------------------------------------------------------------------|------------------------|------|-----------------------------|----------------------------|--------------------------------------|----------------------------------------------------------------|----|
|                                                                                        |                        |      | min.                        | max.                       | min.                                 | max.                                                           |    |
| Data valid to $\overline{WR}$                                                          | t <sub>22</sub>        | CC   | $20 + t_{\rm C}$            | _                          | 2TCL - 20<br>+ <i>t</i> <sub>C</sub> | _                                                              | ns |
| Data hold after WR                                                                     | t <sub>24</sub>        | CC   | 10 + <i>t</i> <sub>F</sub>  | -                          | TCL - 10<br>+ <i>t</i> <sub>F</sub>  | _                                                              | ns |
| ALE rising edge after $\overline{RD}$ , WR                                             | t <sub>26</sub>        | CC   | -10 + <i>t</i> <sub>F</sub> | _                          | -10 + <i>t</i> <sub>F</sub>          | _                                                              | ns |
| Address hold after $\overline{WR}^{2)}$                                                | t <sub>28</sub>        | CC   | $0 + t_{F}$                 | -                          | $0 + t_{F}$                          | _                                                              | ns |
| ALE falling edge to $\overline{CS}^{3)}$                                               | t <sub>38</sub>        | CC   | -4 - t <sub>A</sub>         | 10 - <i>t</i> <sub>A</sub> | -4 - t <sub>A</sub>                  | 10 - <i>t</i> <sub>A</sub>                                     | ns |
| CS low to Valid Data In <sup>3)</sup>                                                  | t <sub>39</sub>        | SR   | _                           | $40 + t_{C} + 2t_{A}$      | _                                    | 3TCL - 20<br>+ <i>t</i> <sub>C</sub> + 2 <i>t</i> <sub>A</sub> | ns |
| $\overline{\text{CS}}$ hold after $\overline{\text{RD}}$ , $\overline{\text{WR}}^{3)}$ | <i>t</i> <sub>41</sub> | CC   | 6 + <i>t</i> <sub>F</sub>   | _                          | TCL - 14<br>+ <i>t</i> <sub>F</sub>  | _                                                              | ns |
| ALE falling edge to $\overline{RdCS}$ ,<br>WrCS (with RW-delay)                        | t <sub>42</sub>        | CC   | $16 + t_A$                  | _                          | TCL - 4<br>+ <i>t</i> <sub>A</sub>   | _                                                              | ns |
| ALE falling edge to RdCS,<br>WrCS (no RW-delay)                                        | t <sub>43</sub>        | CC   | $-4 + t_{A}$                | _                          | -4<br>+ t <sub>A</sub>               | _                                                              | ns |
| RdCS to Valid Data In (with RW-delay)                                                  | t <sub>46</sub>        | SR   | _                           | 16 + <i>t</i> <sub>C</sub> | _                                    | 2TCL - 24<br>+ <i>t</i> <sub>C</sub>                           | ns |
| RdCS to Valid Data In (no RW-delay)                                                    | t <sub>47</sub>        | SR   | _                           | $36 + t_{\rm C}$           | _                                    | 3TCL - 24<br>+ <i>t</i> <sub>C</sub>                           | ns |
| RdCS, WrCS Low Time<br>(with RW-delay)                                                 | t <sub>48</sub>        | CC   | $30 + t_{\rm C}$            | _                          | 2TCL - 10<br>+ <i>t</i> <sub>C</sub> | -                                                              | ns |
| RdCS, WrCS Low Time<br>(no RW-delay)                                                   | t <sub>49</sub>        | CC   | $50 + t_{\rm C}$            | _                          | 3TCL - 10<br>+ <i>t</i> <sub>C</sub> | -                                                              | ns |
| Data valid to $\overline{WrCS}$                                                        | t <sub>50</sub>        | CC   | $26 + t_{\rm C}$            | _                          | 2TCL - 14<br>+ <i>t</i> <sub>C</sub> | -                                                              | ns |
| Data hold after RdCS                                                                   | <i>t</i> <sub>51</sub> | SR   | 0                           | -                          | 0                                    | _                                                              | ns |
| Data float after RdCS<br>(with RW-delay) <sup>1)</sup>                                 | t <sub>53</sub>        | SR   | _                           | $20 + t_{\rm F}$           | _                                    | $2\text{TCL} - 20 + 2t_A + t_F^{(1)}$                          | ns |



#### Demultiplexed Bus (cont'd)

(Operating Conditions apply)

ALE cycle time = 4 TCL +  $2t_A$  +  $t_C$  +  $t_F$  (80 ns at 25 MHz CPU clock without waitstates)

| Parameter                                            | Symbol                    | Max. CPU Clock<br>= 25 MHz |             | Variable CPU Clock<br>1 / 2TCL = 1 to 25 MHz |                                  | Unit |
|------------------------------------------------------|---------------------------|----------------------------|-------------|----------------------------------------------|----------------------------------|------|
|                                                      |                           | min.                       | max.        | min.                                         | max.                             |      |
| Data float after RdCS<br>(no RW-delay) <sup>1)</sup> | <i>t</i> <sub>68</sub> SR | _                          | $0 + t_{F}$ | -                                            | TCL - 20<br>+ $2t_A + t_F^{(1)}$ | ns   |
| Address hold after<br>RdCS, WrCS                     | <i>t</i> <sub>55</sub> CC | -6 + <i>t</i> <sub>F</sub> | _           | -6 + <i>t</i> <sub>F</sub>                   | _                                | ns   |
| Data hold after WrCS                                 | <i>t</i> <sub>57</sub> CC | $6 + t_{F}$                | _           | TCL - 14 +<br><i>t</i> <sub>F</sub>          | _                                | ns   |

<sup>1)</sup> RW-delay and  $t_A$  refer to the next following bus cycle (including an access to an on-chip X-Peripheral).

<sup>2)</sup> Read data are latched with the same clock edge that triggers the address change and the rising RD edge. Therefore address changes before the end of RD have no impact on read cycles.

<sup>3)</sup> These parameters refer to the latched chip select signals (CSxL). The early chip select signals (CSxE) are specified together with the address and signal BHE (see figures below).





#### Figure 20 External Memory Cycle: Demultiplexed Bus, With Read/Write Delay, Normal ALE





#### Figure 21 External Memory Cycle: Demultiplexed Bus, With Read/Write Delay, Extended ALE



#### **AC Characteristics**

#### CLKOUT

(Operating Conditions apply)

| Parameter                                 | Symbol                    | Max. CPU Clock<br>= 25 MHz |              | Variable CPU Clock<br>1 / 2TCL = 1 to 25 MHz |              | Unit |
|-------------------------------------------|---------------------------|----------------------------|--------------|----------------------------------------------|--------------|------|
|                                           |                           | min.                       | max.         | min.                                         | max.         |      |
| CLKOUT cycle time                         | t <sub>29</sub> CC        | 40                         | 40           | 2TCL                                         | 2TCL         | ns   |
| CLKOUT high time                          | t <sub>30</sub> CC        | 14                         | -            | TCL - 6                                      | -            | ns   |
| CLKOUT low time                           | t <sub>31</sub> CC        | 10                         | -            | TCL - 10                                     | -            | ns   |
| CLKOUT rise time                          | t <sub>32</sub> CC        | -                          | 4            | _                                            | 4            | ns   |
| CLKOUT fall time                          | t <sub>33</sub> CC        | -                          | 4            | _                                            | 4            | ns   |
| CLKOUT rising edge to<br>ALE falling edge | <i>t</i> <sub>34</sub> CC | $0 + t_A$                  | $10 + t_{A}$ | $0 + t_A$                                    | $10 + t_{A}$ | ns   |



#### Figure 24 CLKOUT Timing

#### Notes

- <sup>1)</sup> Cycle as programmed, including MCTC waitstates (Example shows 0 MCTC WS).
- <sup>2)</sup> The leading edge of the respective command depends on RW-delay.
- <sup>3)</sup> Multiplexed bus modes have a MUX waitstate added after a bus cycle, and an additional MTTC waitstate may be inserted here.

For a multiplexed bus with MTTC waitstate this delay is 2 CLKOUT cycles, for a demultiplexed bus without MTTC waitstate this delay is zero.

<sup>4)</sup> The next external bus cycle may start here.