



#### 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                      | 25MHz                                                                        |
| Connectivity               | EBI/EMI, SPI, UART/USART                                                     |
| Peripherals                | POR, PWM, WDT                                                                |
| Number of I/O              | 63                                                                           |
| Program Memory Size        | -                                                                            |
| Program Memory Type        | ROMIess                                                                      |
| EEPROM Size                | -                                                                            |
| RAM Size                   | 2K x 8                                                                       |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                                  |
| Data Converters            | -                                                                            |
| Oscillator Type            | External                                                                     |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                              |
| Mounting Type              | Surface Mount                                                                |
| Package / Case             | 80-QFP                                                                       |
| Supplier Device Package    | P-MQFP-80-1                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/infineon-technologies/c161ol25mhabxuma1 |
|                            |                                                                              |

Email: info@E-XFL.COM

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

Edition 2001-01

Published by Infineon Technologies AG, St.-Martin-Strasse 53, D-81541 München, Germany © Infineon Technologies AG 2001. All Rights Reserved.

#### Attention please!

The information herein is given to describe certain components and shall not be considered as warranted characteristics.

Terms of delivery and rights to technical change reserved.

We hereby disclaim any and all warranties, including but not limited to warranties of non-infringement, regarding circuits, descriptions and charts stated herein.

Infineon Technologies is an approved CECC manufacturer.

#### Information

For further information on technology, delivery terms and conditions and prices please contact your nearest Infineon Technologies Office in Germany or our Infineon Technologies Representatives worldwide.

#### Warnings

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

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



This document describes several derivatives of the C161 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> | Max. Oper.<br>Frequency | Operating<br>Voltage | IRAM<br>[KB] | Nr of<br>CSs | Ext.<br>Intr. | CAP<br>IN |
|--------------------------|-------------------------|----------------------|--------------|--------------|---------------|-----------|
| SAF-C161K-LM             | 20 MHz                  | 4.5 to 5.5 V         | 1            | 2            | 4             |           |
| SAB-C161K-LM             | 20 MHz                  | 4.5 to 5.5 V         | 1            | 2            | 4             |           |
| SAF-C161K-L25M           | 25 MHz                  | 4.5 to 5.5 V         | 1            | 2            | 4             |           |
| SAB-C161K-L25M           | 25 MHz                  | 4.5 to 5.5 V         | 1            | 2            | 4             |           |
| SAF-C161K-LM3V           | 20 MHz                  | 3.0 to 3.6 V         | 1            | 2            | 4             |           |
| SAB-C161K-LM3V           | 20 MHz                  | 3.0 to 3.6 V         | 1            | 2            | 4             |           |
| SAF-C161O-LM             | 20 MHz                  | 4.5 to 5.5 V         | 2            | 4            | 7             | Yes       |
| SAB-C161O-LM             | 20 MHz                  | 4.5 to 5.5 V         | 2            | 4            | 7             | Yes       |
| SAF-C161O-L25M           | 25 MHz                  | 4.5 to 5.5 V         | 2            | 4            | 7             | Yes       |
| SAB-C161O-L25M           | 25 MHz                  | 4.5 to 5.5 V         | 2            | 4            | 7             | Yes       |
| SAF-C161O-LM3V           | 20 MHz                  | 3.0 to 3.6 V         | 2            | 4            | 7             | Yes       |
| SAB-C161O-LM3V           | 20 MHz                  | 3.0 to 3.6 V         | 2            | 4            | 7             | Yes       |

 Table 1
 C161K/O Derivative Synopsis

<sup>1)</sup> This Data Sheet is valid for devices starting with and including design step HA.

For simplicity all versions are referred to by the term C161K/O throughout this document.

#### **Ordering Information**

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

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

For the available ordering codes for the C161K/O please refer to the "**Product Catalog Microcontrollers**", which summarizes all available microcontroller variants.

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



#### Introduction

The C161K/O is a derivative of the Infineon C166 Family of full featured single-chip CMOS microcontrollers. It combines high CPU performance (up to 12.5 million instructions per second) with peripheral functionality and enhanced IO-capabilities. The C161K/O is especially suited for cost sensitive applications.



Figure 1 Logic Symbol



| Table 2              | Pi         | n Definit      | ions and Functions (cont'd)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------|------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol               | Pin<br>Num | Input<br>Outp. | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RSTIN                | 65         | Ι/Ο            | Reset Input with Schmitt-Trigger characteristics. A low level<br>at this pin while the oscillator is running resets the C161K/O.<br>An internal pullup resistor permits power-on reset using only<br>a capacitor connected to $V_{SS}$ . A spike filter suppresses input<br>pulses < 10 ns. Input pulses >100 ns safely pass the filter.<br>The minimum duration for a safe recognition should be<br>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. |
|                      |            |                | Note: To let the reset configuration of PORT0 settle a reset duration of ca. 1 ms is recommended.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RST<br>OUT           | 66         | 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                  | 67         | 1              | Non-Maskable Interrupt Input. A high to low transition at this<br>pin causes the CPU to vector to the NMI trap routine. When<br>the PWRDN (power down) instruction is executed, the NMI<br>pin must be low in order to force the C161K/O to go into<br>power down mode. If NMI is high, when PWRDN is<br>executed, the part will continue to run in normal mode.<br>If not used, pin NMI should be pulled high externally.                                                                                                                                                                                                                                                     |
| <b>P6</b> .0<br>P6.1 | 68<br>69   | 10<br>0<br>0   | Port 6 is a 4-bit bidirectional I/O port. It is bit-wise<br>programmable for input or output via direction bits. For a pin<br>configured as input, the output driver is put into high-<br>impedance state. Port 6 outputs can be configured as push/<br>pull or open drain drivers.The Port 6 pins also serve for alternate functions: $\overline{CS0}$<br>$\overline{CS1}$ Chip Select 0 Output<br>$\overline{CS1}$                                                                                                                                                                                                                                                           |
| P6.2<br>P6.3         | 70<br>71   | 0              | CS2Chip Select 2 OutputCS3Chip Select 3 OutputThese chip select outputs are only available in the C1610.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |



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

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

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

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

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



 $2C_{H}$ 

 $2D_{H}$ 

2E<sub>H</sub>

 $2F_{H}$ 

00'00B0<sub>H</sub>

00'00B4<sub>H</sub>

00'00B8<sub>H</sub>

00'00BC<sub>H</sub>

| Table 3 C161K/O                            | Interrupt No    | odes           |                     |                      |                 |
|--------------------------------------------|-----------------|----------------|---------------------|----------------------|-----------------|
| Source of Interrupt or PEC Service Request | Request<br>Flag | Enable<br>Flag | Interrupt<br>Vector | Vector<br>Location   | Trap<br>Number  |
| External Interrupt 1                       | CC9IR           | CC9IE          | CC9INT              | 00'0064 <sub>H</sub> | 19 <sub>H</sub> |
| External Interrupt 2                       | CC10IR          | CC10IE         | CC10INT             | 00'0068 <sub>H</sub> | 1A <sub>H</sub> |
| External Interrupt 3                       | CC11IR          | CC11IE         | CC11INT             | 00'006C <sub>H</sub> | 1B <sub>H</sub> |
| External Interrupt 4                       | CC12IR          | CC12IE         | CC12INT             | 00'0070 <sub>H</sub> | 1C <sub>H</sub> |
| External Interrupt 5                       | CC13IR          | CC13IE         | CC13INT             | 00'0074 <sub>H</sub> | 1D <sub>H</sub> |
| External Interrupt 6                       | CC14IR          | CC14IE         | CC14INT             | 00'0078 <sub>H</sub> | 1E <sub>H</sub> |
| External Interrupt 7                       | CC15IR          | CC15IE         | CC15INT             | 00'007C <sub>H</sub> | 1F <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> |
| GPT2 Timer 5                               | T5IR            | T5IE           | T5INT               | 00'0094 <sub>H</sub> | 25 <sub>H</sub> |
| GPT2 Timer 6                               | T6IR            | T6IE           | T6INT               | 00'0098 <sub>H</sub> | 26 <sub>H</sub> |
| GPT2 CAPREL Reg.                           | CRIR            | CRIE           | CRINT               | 00'009C <sub>H</sub> | 27 <sub>H</sub> |
| ASC0 Transmit                              | S0TIR           | S0TIE          | SOTINT              | 00'00A8 <sub>H</sub> | 2A <sub>H</sub> |
| ASC0 Transmit Buffer                       | S0TBIR          | SOTBIE         | SOTBINT             | 00'011C <sub>H</sub> | 47 <sub>H</sub> |
| ASC0 Receive                               | S0RIR           | SORIE          | SORINT              | 00'00AC <sub>H</sub> | 2B <sub>H</sub> |

S0EIR

**SCTIR** 

**SCRIR** 

**SCEIR** 

#### C161K/O Interrupt Nodes Table 3

Note: The shaded interrupt nodes are only available in the C1610, not in the C161K.

S0EIE

SCTIE

SCRIE

SCEIE

**SOEINT** 

SCTINT

SCRINT

SCEINT

SSC Transmit

**SSC** Receive

SSC Error

ASC0 Error



## 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 five 16-bit timers which are organized in two separate modules, GPT1 and GPT2. Each timer in each module may operate independently in a number of different modes, or may be concatenated with another timer of the same module.

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 output on pin T3OUT e.g. for time out monitoring of external hardware components, or 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. When both T2 and T4 are configured to alternately reload T3 on opposite state transitions of T3OTL with the low and high times of a PWM signal, this signal can be constantly generated without software intervention.



## Serial Channels

Serial communication with other microcontrollers, processors, terminals or external peripheral components is provided by two serial interfaces with different functionality, an Asynchronous/Synchronous Serial Channel (**ASC0**) and a High-Speed Synchronous Serial Channel (**SSC**).

**The ASC0** is upward compatible with the serial ports of the Infineon 8-bit microcontroller families and supports full-duplex asynchronous communication at up to 781 kBaud and half-duplex synchronous communication at up to 3.1 MBaud (@ 25 MHz CPU clock).

A dedicated baud rate generator allows to set up all standard baud rates without oscillator tuning. For transmission, reception and error handling 4 separate interrupt vectors are provided. In asynchronous mode, 8- or 9-bit data frames are transmitted or received, preceded by a start bit and terminated by one or two stop bits. For multiprocessor communication, a mechanism to distinguish address from data bytes has been included (8-bit data plus wake up bit mode).

In synchronous mode, the ASC0 transmits or receives bytes (8 bits) synchronously to a shift clock which is generated by the ASC0. The ASC0 always shifts the LSB first. A loop back option is available for testing purposes.

A number of optional hardware error detection capabilities has been included to increase the reliability of data transfers. A parity bit can automatically be generated on transmission or be checked on reception. Framing error detection allows to recognize data frames with missing stop bits. An overrun error will be generated, if the last character received has not been read out of the receive buffer register at the time the reception of a new character is complete.

**The SSC** supports full-duplex synchronous communication at up to 6.25 MBaud (@ 25 MHz CPU clock). It may be configured so it interfaces with serially linked peripheral components. 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 and receive error supervise the correct handling of the data buffer. Phase and baudrate error detect incorrect serial data.



#### **Instruction Set Summary**

 Table 5 lists the instructions of the C161K/O in a condensed way.

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

This document also provides a detailed description of each instruction.

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

#### Table 5Instruction Set Summary



| Table 5Instruction Set Summary (cont'd) |                                                                                     |       |  |  |  |  |  |
|-----------------------------------------|-------------------------------------------------------------------------------------|-------|--|--|--|--|--|
| Mnemonic                                | Description                                                                         | Bytes |  |  |  |  |  |
| MOV(B)                                  | Move word (byte) data                                                               | 2/4   |  |  |  |  |  |
| MOVBS                                   | Move byte operand to word operand with sign extension                               | 2/4   |  |  |  |  |  |
| MOVBZ                                   | Move byte operand to word operand. with zero extension                              | 2/4   |  |  |  |  |  |
| JMPA, JMPI,<br>JMPR                     | Jump absolute/indirect/relative if condition is met                                 | 4     |  |  |  |  |  |
| JMPS                                    | Jump absolute to a code segment                                                     | 4     |  |  |  |  |  |
| J(N)B                                   | Jump relative if direct bit is (not) set                                            | 4     |  |  |  |  |  |
| JBC                                     | Jump relative and clear bit if direct bit is set                                    | 4     |  |  |  |  |  |
| JNBS                                    | Jump relative and set bit if direct bit is not set                                  | 4     |  |  |  |  |  |
| CALLA, CALLI,<br>CALLR                  | Call absolute/indirect/relative subroutine if condition is met                      | 4     |  |  |  |  |  |
| CALLS                                   | Call absolute subroutine in any code segment                                        | 4     |  |  |  |  |  |
| PCALL                                   | Push direct word register onto system stack and call absolute subroutine            | 4     |  |  |  |  |  |
| TRAP                                    | Call interrupt service routine via immediate trap number                            | 2     |  |  |  |  |  |
| PUSH, POP                               | Push/pop direct word register onto/from system stack                                | 2     |  |  |  |  |  |
| SCXT                                    | Push direct word register onto system stack and update register with word operand   | 4     |  |  |  |  |  |
| RET                                     | Return from intra-segment subroutine                                                | 2     |  |  |  |  |  |
| RETS                                    | Return from inter-segment subroutine                                                | 2     |  |  |  |  |  |
| RETP                                    | Return from intra-segment subroutine and pop direct word register from system stack | 2     |  |  |  |  |  |
| RETI                                    | Return from interrupt service subroutine                                            | 2     |  |  |  |  |  |
| SRST                                    | Software Reset                                                                      | 4     |  |  |  |  |  |
| IDLE                                    | Enter Idle Mode                                                                     | 4     |  |  |  |  |  |
| PWRDN                                   | Enter Power Down Mode (supposes NMI-pin being low)                                  | 4     |  |  |  |  |  |
| SRVWDT                                  | Service Watchdog Timer                                                              | 4     |  |  |  |  |  |
| DISWDT                                  | Disable Watchdog Timer                                                              | 4     |  |  |  |  |  |
| EINIT                                   | Signify End-of-Initialization on RSTOUT-pin                                         | 4     |  |  |  |  |  |
| ATOMIC                                  | Begin ATOMIC sequence                                                               | 2     |  |  |  |  |  |
| EXTR                                    | Begin EXTended Register sequence                                                    | 2     |  |  |  |  |  |
| EXTP(R)                                 | Begin EXTended Page (and Register) sequence                                         | 2/4   |  |  |  |  |  |
| EXTS(R)                                 | Begin EXTended Segment (and Register) sequence                                      | 2/4   |  |  |  |  |  |
| NOP                                     | Null operation                                                                      | 2     |  |  |  |  |  |



| Table 6 | C161K/O Registers, Ordered by Name (cont'd) |
|---------|---------------------------------------------|
|---------|---------------------------------------------|

| Name Physical<br>Address |   | -                 |   |                 | Description                             | Reset<br>Value    |
|--------------------------|---|-------------------|---|-----------------|-----------------------------------------|-------------------|
| DP0H                     | b | F102 <sub>H</sub> | Е | 81 <sub>H</sub> | P0H Direction Control Register          | 00 <sub>H</sub>   |
| DP0L                     | b | F100 <sub>H</sub> | Ε | 80 <sub>H</sub> | P0L Direction Control Register          | 00 <sub>H</sub>   |
| DP1H                     | b | F106 <sub>H</sub> | Ε | 83 <sub>H</sub> | P1H Direction Control Register          | 00 <sub>H</sub>   |
| DP1L                     | b | F104 <sub>H</sub> | Ε | 82 <sub>H</sub> | P1L Direction Control Register          | 00 <sub>H</sub>   |
| DP2                      | b | FFC2 <sub>H</sub> |   | E1 <sub>H</sub> | Port 2 Direction Control Register       | 0000 <sub>H</sub> |
| DP3                      | b | FFC6 <sub>H</sub> |   | E3 <sub>H</sub> | Port 3 Direction Control Register       | 0000 <sub>H</sub> |
| DP4                      | b | FFCA <sub>H</sub> |   | E5 <sub>H</sub> | Port 4 Direction Control Register       | 00 <sub>H</sub>   |
| DP6                      | b | FFCE <sub>H</sub> |   | E7 <sub>H</sub> | Port 6 Direction Control Register       | 00 <sub>H</sub>   |
| DPP0                     |   | FE00 <sub>H</sub> |   | 00 <sub>H</sub> | CPU Data Page Pointer 0 Reg. (10 bits)  | 0000 <sub>H</sub> |
| DPP1                     |   | FE02 <sub>H</sub> |   | 01 <sub>H</sub> | CPU Data Page Pointer 1 Reg. (10 bits)  | 0001 <sub>H</sub> |
| DPP2                     |   | FE04 <sub>H</sub> |   | 02 <sub>H</sub> | CPU Data Page Pointer 2 Reg. (10 bits)  | 0002 <sub>H</sub> |
| DPP3                     |   | FE06 <sub>H</sub> |   | 03 <sub>H</sub> | CPU Data Page Pointer 3 Reg. (10 bits)  | 0003 <sub>H</sub> |
| EXICON                   | b | F1C0 <sub>H</sub> | Ε | E0 <sub>H</sub> | External Interrupt Control Register     | 0000 <sub>H</sub> |
| IDCHIP                   |   | F07C <sub>H</sub> | Ε | 3E <sub>H</sub> | Identifier                              | 05XX <sub>H</sub> |
| IDMANUF                  |   | F07E <sub>H</sub> | Ε | 3F <sub>H</sub> | Identifier                              | 1820 <sub>H</sub> |
| IDMEM                    |   | F07A <sub>H</sub> | Ε | 3D <sub>H</sub> | Identifier                              | 0000 <sub>H</sub> |
| IDMEM2                   |   | F076 <sub>H</sub> | Ε | 3B <sub>H</sub> | Identifier                              | 0000 <sub>H</sub> |
| IDPROG                   |   | F078 <sub>H</sub> | Ε | 3C <sub>H</sub> | Identifier                              | 0000 <sub>H</sub> |
| MDC                      | b | FF0E <sub>H</sub> |   | 87 <sub>H</sub> | CPU Multiply Divide Control Register    | 0000 <sub>H</sub> |
| MDH                      |   | FE0C <sub>H</sub> |   | 06 <sub>H</sub> | CPU Multiply Divide Reg. – High Word    | 0000 <sub>H</sub> |
| MDL                      |   | FE0E <sub>H</sub> |   | 07 <sub>H</sub> | CPU Multiply Divide Reg. – Low Word     | 0000 <sub>H</sub> |
| ODP2                     | b | F1C2 <sub>H</sub> | Ε | E1 <sub>H</sub> | Port 2 Open Drain Control Register      | 0000 <sub>H</sub> |
| ODP3                     | b | F1C6 <sub>H</sub> | Ε | E3 <sub>H</sub> | Port 3 Open Drain Control Register      | 0000 <sub>H</sub> |
| ODP6                     | b | F1CE <sub>H</sub> | Ε | E7 <sub>H</sub> | Port 6 Open Drain Control Register      | 00 <sub>H</sub>   |
| ONES                     | b | FF1E <sub>H</sub> |   | 8F <sub>H</sub> | Constant Value 1's Register (read only) | FFFF <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>   |
| P2                       | b | FFC0 <sub>H</sub> |   | E0 <sub>H</sub> | Port 2 Register                         | 0000 <sub>H</sub> |



# **Operating Conditions**

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

| Parameter                          | Symbol            | Lim               | it Values | Unit | Notes                                         |  |
|------------------------------------|-------------------|-------------------|-----------|------|-----------------------------------------------|--|
|                                    |                   | min.              | max.      |      |                                               |  |
| Standard<br>digital supply voltage | V <sub>DD</sub>   | 4.5               | 5.5       | V    | Active mode,<br>$f_{CPUmax} = 25 \text{ MHz}$ |  |
| (5 V versions)                     |                   | 2.5 <sup>1)</sup> | 5.5       | V    | Power Down mode                               |  |
| Reduced<br>digital supply voltage  | V <sub>DD</sub>   | 3.0               | 3.6       | V    | Active mode,<br>$f_{CPUmax} = 20 \text{ MHz}$ |  |
| (3 V versions)                     |                   | 2.5 <sup>1)</sup> | 3.6       | V    | Power Down mode                               |  |
| Digital ground voltage             | V <sub>SS</sub>   |                   | 0         | 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   | -                                             |  |
| Ambient temperature                | T <sub>A</sub>    | 0                 | 70        | °C   | SAB-C161K/O                                   |  |
|                                    |                   | -40               | 85        | °C   | SAF-C161K/O                                   |  |
|                                    |                   | -40               | 125       | °C   | SAK-C161K/O                                   |  |

# Table 8Operating 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 such as XTAL1, RD, WR, etc.

<sup>3)</sup> Not 100% tested, guaranteed by design and characterization.



#### Parameter Interpretation

The parameters listed in the following partly represent the characteristics of the C161K/ O and partly its demands on the system. To aid in interpreting the parameters right, when evaluating them for a design, they are marked in column "Symbol":

CC (Controller Characteristics):

The logic of the C161K/O will provide signals with the respective timing characteristics.

#### SR (System Requirement):

The external system must provide signals with the respective timing characteristics to the C161K/O.

## DC Characteristics (Standard Supply Voltage Range)

(Operating Conditions apply)<sup>1)</sup>

| Parameter                                                                                          | Symbol                          | Limit                        | Values                       | Unit | <b>Test Condition</b>                           |  |
|----------------------------------------------------------------------------------------------------|---------------------------------|------------------------------|------------------------------|------|-------------------------------------------------|--|
|                                                                                                    |                                 | min.                         | max.                         |      |                                                 |  |
| Input low voltage (TTL,<br>all except XTAL1)                                                       | V <sub>IL</sub> SR              | -0.5                         | 0.2 V <sub>DD</sub><br>- 0.1 | V    | _                                               |  |
| Input low voltage XTAL1                                                                            | $V_{IL2}$ SR                    | -0.5                         | 0.3 V <sub>DD</sub>          | V    | -                                               |  |
| Input high voltage (TTL,<br>all except RSTIN and XTAL1)                                            | V <sub>IH</sub> SR              | 0.2 V <sub>DD</sub><br>+ 0.9 | V <sub>DD</sub> +<br>0.5     | V    | _                                               |  |
| Input high voltage RSTIN<br>(when operated as input)                                               | V <sub>IH1</sub> SR             | 0.6 V <sub>DD</sub>          | V <sub>DD</sub> + 0.5        | V    | _                                               |  |
| Input high voltage XTAL1                                                                           | V <sub>IH2</sub> SR             | 0.7 V <sub>DD</sub>          | V <sub>DD</sub> +<br>0.5     | V    | _                                               |  |
| Output low voltage<br>(PORT0, PORT1, Port 4, ALE,<br>RD, WR, BHE, RSTOUT,<br>RSTIN <sup>2)</sup> ) | V <sub>OL</sub> CC              | _                            | 0.45                         | V    | I <sub>OL</sub> = 2.4 mA                        |  |
| Output low voltage<br>(all other outputs)                                                          | V <sub>OL1</sub> CC             | _                            | 0.45                         | V    | <i>I</i> <sub>OL</sub> = 1.6 mA                 |  |
| Output high voltage <sup>3)</sup>                                                                  | V <sub>OH</sub> CC              | 2.4                          | _                            | V    | I <sub>OH</sub> = -2.4 mA                       |  |
| (PORT0, PORT1, Port 4, ALE,<br>RD, WR, BHE, RSTOUT)                                                |                                 | 0.9 V <sub>DD</sub>          | _                            | V    | I <sub>OH</sub> = -0.5 mA                       |  |
| Output high voltage <sup>3)</sup>                                                                  | V <sub>OH1</sub> CC             | 2.4                          | _                            | V    | I <sub>OH</sub> = -1.6 mA                       |  |
| (all other outputs)                                                                                |                                 | 0.9 V <sub>DD</sub>          | _                            | V    | I <sub>OH</sub> = -0.5 mA                       |  |
| Input leakage current (Port 5)                                                                     | I <sub>OZ1</sub> CC             | -                            | ±200                         | nA   | $0 V < V_{IN} < V_{DD}$                         |  |
| Input leakage current (all other)                                                                  | I <sub>OZ2</sub> CC             | -                            | ±500                         | nA   | $0.45 \text{ V} < V_{\text{IN}} < V_{\text{C}}$ |  |
| RSTIN inactive current <sup>4)</sup>                                                               | I <sub>RSTH</sub> <sup>5)</sup> | _                            | -10                          | μA   | $V_{\rm IN} = V_{\rm IH1}$                      |  |



# DC Characteristics (Standard Supply Voltage Range) (cont'd)

(Operating Conditions apply)<sup>1)</sup>

| Parameter                                                 | Symbol                          | Limit Values |      | Unit | <b>Test Condition</b>               |
|-----------------------------------------------------------|---------------------------------|--------------|------|------|-------------------------------------|
|                                                           |                                 | min.         | max. |      |                                     |
| RSTIN active current <sup>4)</sup>                        | I <sub>RSTL</sub> <sup>6)</sup> | -100         | -    | μA   | $V_{\rm IN} = V_{\rm IL}$           |
| RD/WR inact. current <sup>7)</sup>                        | I <sub>RWH</sub> <sup>5)</sup>  | -            | -40  | μA   | $V_{OUT}$ = 2.4 V                   |
| RD/WR active current <sup>7)</sup>                        | I <sub>RWL</sub> <sup>6)</sup>  | -500         | -    | μA   | $V_{OUT} = V_{OLmax}$               |
| ALE inactive current <sup>7)</sup>                        | $I_{ALEL}^{5)}$                 | _            | 40   | μA   | $V_{OUT} = V_{OLmax}$               |
| ALE active current <sup>7)</sup>                          | I <sub>ALEH</sub> <sup>6)</sup> | 500          | -    | μA   | $V_{OUT}$ = 2.4 V                   |
| Port 6 inactive current <sup>7)</sup>                     | I <sub>P6H</sub> <sup>5)</sup>  | -            | -40  | μA   | $V_{OUT}$ = 2.4 V                   |
| Port 6 active current <sup>7)</sup>                       | I <sub>P6L</sub> <sup>6)</sup>  | -500         | -    | μA   | $V_{OUT} = V_{OL1max}$              |
| PORT0 configuration current <sup>7)</sup>                 | I <sub>P0H</sub> <sup>5)</sup>  | —            | -10  | μA   | $V_{\rm IN} = V_{\rm IHmin}$        |
|                                                           | $I_{POL}^{6)}$                  | -100         | -    | μA   | $V_{\rm IN} = V_{\rm ILmax}$        |
| XTAL1 input current                                       | I <sub>IL</sub> CC              | -            | ±20  | μA   | $0 V < V_{IN} < V_{DD}$             |
| Pin capacitance <sup>8)</sup><br>(digital inputs/outputs) | C <sub>IO</sub> CC              | -            | 10   | pF   | f = 1  MHz<br>$T_A = 25 \text{ °C}$ |

<sup>1)</sup> Keeping signal levels within the levels 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}$ .

<sup>2)</sup> Valid in bidirectional reset mode only.

<sup>3)</sup> 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.

- <sup>4)</sup> These parameters describe the  $\overline{\text{RSTIN}}$  pullup, which equals a resistance of ca. 50 to 250 k $\Omega$ .
- <sup>5)</sup> The maximum current may be drawn while the respective signal line remains inactive.
- <sup>6)</sup> The minimum current must be drawn in order to drive the respective signal line active.
- <sup>7)</sup> This specification is valid during Reset and during Adapt-mode.
- <sup>8)</sup> Not 100% tested, guaranteed by design and characterization.





#### gure 13 External Memory Cycle: Multiplexed Bus, With Read/Write Delay, Extended ALE





#### re 14 External Memory Cycle: Multiplexed Bus, No Read/Write Delay, Normal ALE



# Demultiplexed Bus (Reduced Supply Voltage Range) (cont'd)

(Operating Conditions apply)

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

| Parameter                                              | Symbol          |    | Max. CPU Clock<br>= 20 MHz  |                           | Variable (<br>1 / 2TCL =            | Unit                              |    |
|--------------------------------------------------------|-----------------|----|-----------------------------|---------------------------|-------------------------------------|-----------------------------------|----|
|                                                        |                 |    | min.                        | max.                      | min.                                | max.                              |    |
| Data float after RdCS<br>(with RW-delay) <sup>1)</sup> | t <sub>53</sub> | SR | _                           | $30 + t_{\rm F}$          | _                                   | 2TCL - 20<br>+ $2t_A + t_F$<br>1) | ns |
| Data float after RdCS<br>(no RW-delay) <sup>1)</sup>   | t <sub>68</sub> | SR | _                           | 5 + <i>t</i> <sub>F</sub> | -                                   | TCL - 20<br>+ $2t_A + t_F$<br>1)  | ns |
| Address hold after<br>RdCS, WrCS                       | t <sub>55</sub> | CC | -16 + <i>t</i> <sub>F</sub> | -                         | -16 + <i>t</i> <sub>F</sub>         | -                                 | ns |
| Data hold after WrCS                                   | t <sub>57</sub> | CC | 9 + <i>t</i> <sub>F</sub>   | _                         | TCL - 16<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).





# Demultiplexed Bus, With Read/Write Delay, Normal ALE





#### Figure 18 External Memory Cycle: Demultiplexed Bus, No Read/Write Delay, Normal ALE



## **Package Outlines**



# Sorts of Packing Package outlines for tubes, trays etc. are contained in our Data Book "Package Information". SMD = Surface Mounted Device

Dimensions in mm