## E·XFL



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               | CANbus, EBI/EMI, SPI, UART/USART                                            |
| Peripherals                | POR, PWM, WDT                                                               |
| Number of I/O              | 111                                                                         |
| Program Memory Size        | -                                                                           |
| Program Memory Type        | ROMIess                                                                     |
| EEPROM Size                | -                                                                           |
| RAM Size                   | 11K × 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                                 |
| Data Converters            | A/D 24x10b                                                                  |
| Oscillator Type            | External                                                                    |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                             |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 144-BQFP                                                                    |
| Supplier Device Package    | P-MQFP-144-8                                                                |
| Purchase URL               | https://www.e-xfl.com/product-detail/infineon-technologies/c167cslmcabxuma2 |

Email: info@E-XFL.COM

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

Edition 2001-08

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.

Data Sheet, V2.2, Aug. 2001

# C167CS-4R C167CS-L

16-Bit Single-Chip Microcontroller

## Microcontrollers



Never stop thinking.



#### **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 C167CS 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 C167CS derivatives are high performance derivatives of the Infineon C166 Family of full featured single-chip CMOS microcontrollers. They combine high CPU performance (up to 20 million instructions per second) with high peripheral functionality and enhanced IO-capabilities. They also provide clock generation via PLL and various on-chip memory modules such as program ROM, internal RAM, and extension RAM.



Figure 1 Logic Symbol



| Table 2 | Pin Definitions and Functions (cont'd) |                |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|---------|----------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Symbol  | Pin<br>Num.                            | Input<br>Outp. | Function                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| Ρ7      |                                        | IO             | Port 7 is an 8-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 7 outputs can be configured as push/<br>pull or open drain drivers. The input threshold of Port 7 is<br>selectable (TTL or special). |  |  |  |  |  |  |
| P7.0    | 19                                     | 0              | The following Port 7 pins also serve for alternate functions:<br>POUT0 PWM Channel 0 Output                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| P7.1    | 20                                     | 0              | POUT1 PWM Channel 1 Output                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| P7.2    | 21                                     | 0              | POUT2 PWM Channel 2 Output                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| P7.3    | 22                                     | 0              | POUT3 PWM Channel 3 Output                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| P7.4    | 23                                     | I/O            | CC28IO CAPCOM2: CC28 Capture Inp./Compare Outp.                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| P7.5    | 24                                     | I/O            | CC29IO CAPCOM2: CC29 Capture Inp./Compare Outp.                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| P7.6    | 25                                     | I/O            | CC30IO CAPCOM2: CC30 Capture Inp./Compare Outp.                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| P7.7    | 26                                     | I/O            | CC31IO CAPCOM2: CC31 Capture Inp./Compare Outp.                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| P5      |                                        | I              | Port 5 is a 16-bit input-only port with Schmitt-Trigger char.<br>The pins of Port 5 also serve as analog input channels for the A/D converter, or they serve as timer inputs:                                                                                                                                                                         |  |  |  |  |  |  |
| P5.0    | 27                                     | 1              | ANO                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.1    | 28                                     | 1              | AN1                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.2    | 29                                     | 1              | AN2                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.3    | 30                                     | 1              | AN3                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.4    | 31                                     | 1              | AN4                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.5    | 32                                     | 1              | AN5                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.6    | 33                                     | 1              | AN6                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.7    | 34                                     | 1              | AN7                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.8    | 35                                     | 1              | AN8                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.9    | 36                                     | 1              | AN9                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.10   | 39                                     | 1              | AN10, T6EUD GPT2 Timer T6 Ext. Up/Down Ctrl. Inp.                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| P5.11   | 40                                     | 1              | AN11, T5EUD GPT2 Timer T5 Ext. Up/Down Ctrl. Inp.                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| P5.12   | 41                                     |                | AN12, T6IN GPT2 Timer T6 Count Inp.                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.13   | 42                                     |                | AN13, T5IN GPT2 Timer T5 Count Inp.                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| P5.14   | 43                                     |                | AN14, T4EUD GPT1 Timer T4 Ext. Up/Down Ctrl. Inp.                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| P5.15   | 44                                     |                | AN15, T2EUD GPT1 Timer T2 Ext. Up/Down Ctrl. Inp.                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |



Note: When one or both of the on-chip CAN Modules are used with the interface lines assigned to Port 4, the CAN lines override the segment address lines and the segment address output on Port 4 is therefore limited to 6/4 bits i.e. address lines A21/A19 ... A16. CS lines can be used to increase the total amount of addressable external memory.

#### **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 C167CS's instructions can be executed in just one machine cycle which requires 50 ns at 40 MHz CPU clock. For example, shift and rotate instructions are always processed during one machine cycle independent of the number of bits to be shifted. 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', allows reducing the execution time of repeatedly performed jumps in a loop from 2 cycles to 1 cycle.







| Table 3 | C167CS Interrupt Nodes (cont'd) |
|---------|---------------------------------|
|---------|---------------------------------|

| Source of Interrupt or PEC Service Request | Request<br>Flag | Enable<br>Flag | Interrupt<br>Vector | Vector<br>Location   | Trap<br>Number  |
|--------------------------------------------|-----------------|----------------|---------------------|----------------------|-----------------|
| CAPCOM Register 30                         | CC30IR          | CC30IE         | CC30INT             | 00'0114 <sub>H</sub> | 45 <sub>H</sub> |
| CAPCOM Register 31                         | CC31IR          | CC31IE         | CC31INT             | 00'0118 <sub>H</sub> | 46 <sub>H</sub> |
| CAPCOM Timer 0                             | T0IR            | TOIE           | TOINT               | 00'0080 <sub>H</sub> | 20 <sub>H</sub> |
| CAPCOM Timer 1                             | T1IR            | T1IE           | T1INT               | 00'0084 <sub>H</sub> | 21 <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> |
| 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> |
| 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           | SOTIE          | 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                               | SORIR           | SORIE          | SORINT              | 00'00AC <sub>H</sub> | 2B <sub>H</sub> |
| ASC0 Error                                 | S0EIR           | SOEIE          | SOEINT              | 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> |
| PWM Channel 0 3                            | PWMIR           | PWMIE          | PWMINT              | 00'00FC <sub>H</sub> | 3F <sub>H</sub> |
| CAN Interface 1                            | XP0IR           | XP0IE          | XP0INT              | 00'0100 <sub>H</sub> | 40 <sub>H</sub> |
| CAN Interface 2                            | XP1IR           | XP1IE          | XP1INT              | 00'0104 <sub>H</sub> | 41 <sub>H</sub> |
| Unassigned node                            | XP2IR           | XP2IE          | XP2INT              | 00'0108 <sub>H</sub> | 42 <sub>H</sub> |
| PLL/OWD and RTC                            | XP3IR           | XP3IE          | XP3INT              | 00'010C <sub>H</sub> | 43 <sub>H</sub> |



The C167CS also provides an excellent mechanism to identify and to process exceptions or error conditions that arise during run-time, so-called 'Hardware Traps'. Hardware traps cause immediate non-maskable system reaction which is similar to a standard interrupt service (branching to a dedicated vector table location). The occurrence of a hardware trap is additionally signified by an individual bit in the trap flag register (TFR). Except when another higher prioritized trap service is in progress, a hardware trap will interrupt any actual program execution. In turn, hardware trap services can normally not be interrupted by standard or PEC interrupts.

**Table 4** shows all of the possible exceptions or error conditions that can arise during runtime:

| Exception Condition                                                                          | Trap<br>Flag          | Trap<br>Vector                | Vector<br>Location                                                                      | Trap<br>Number                                        | Trap<br>Priority           |
|----------------------------------------------------------------------------------------------|-----------------------|-------------------------------|-----------------------------------------------------------------------------------------|-------------------------------------------------------|----------------------------|
| Reset Functions:<br>– Hardware Reset<br>– Software Reset<br>– W-dog Timer Overflow           | -                     | RESET<br>RESET<br>RESET       | 00'0000 <sub>H</sub><br>00'0000 <sub>H</sub><br>00'0000 <sub>H</sub>                    | 00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub> |                            |
| Class A Hardware Traps:<br>– Non-Maskable Interrupt<br>– Stack Overflow<br>– Stack Underflow | NMI<br>STKOF<br>STKUF | NMITRAP<br>STOTRAP<br>STUTRAP | 00'0008 <sub>H</sub><br>00'0010 <sub>H</sub><br>00'0018 <sub>H</sub>                    | 02 <sub>H</sub><br>04 <sub>H</sub><br>06 <sub>H</sub> | <br>  <br>                 |
| Class B Hardware Traps:<br>– Undefined Opcode<br>– Protected Instruction<br>Fault            | UNDOPC<br>PRTFLT      | BTRAP<br>BTRAP                | 00'0028 <sub>H</sub><br>00'0028 <sub>H</sub>                                            | 0A <sub>H</sub><br>0A <sub>H</sub>                    |                            |
| <ul> <li>Illegal Word Operand<br/>Access</li> </ul>                                          | ILLOPA                | BTRAP                         | 00'0028 <sub>H</sub>                                                                    | 0A <sub>H</sub>                                       | I                          |
| <ul> <li>Illegal Instruction<br/>Access</li> </ul>                                           | ILLINA                | BTRAP                         | 00'0028 <sub>H</sub>                                                                    | 0A <sub>H</sub>                                       | I                          |
| <ul> <li>Illegal External Bus<br/>Access</li> </ul>                                          | ILLBUS                | BTRAP                         | 00'0028 <sub>H</sub>                                                                    | 0A <sub>H</sub>                                       | I                          |
| Reserved                                                                                     | _                     | _                             | [2C <sub>H</sub> –<br>3C <sub>H</sub> ]                                                 | [0B <sub>H</sub> –<br>0F <sub>H</sub> ]               | -                          |
| Software Traps <ul> <li>TRAP Instruction</li> </ul>                                          | -                     | _                             | Any<br>[00'0000 <sub>H</sub><br>00'01FC <sub>H</sub> ]<br>in steps<br>of 4 <sub>H</sub> | Any<br>[00 <sub>H</sub> –<br>7F <sub>H</sub> ]        | Current<br>CPU<br>Priority |

#### Table 4Hardware Trap Summary



#### A/D Converter

For analog signal measurement, a 10-bit A/D converter with 24 multiplexed input channels (16 standard channels and 8 extension 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 24 analog input channels, the remaining channel inputs can be used as digital input port pins.

The A/D converter of the C167CS 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 registers P5DIDIS (Port 5 Digital Input Disable) and P1DIDIS (PORT1 Digital Input Disable).



#### **Parallel Ports**

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

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

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

PORT0 and PORT1 may be used as address and data lines when accessing external memory, while Port 4 outputs the additional segment address bits A23/19/17 ... A16 in systems where segmentation is enabled to access more than 64 KBytes of memory.

Port 2, Port 8 and Port 7 (and parts of PORT1) are associated with the capture inputs or compare outputs of the CAPCOM units and/or with the outputs of the PWM module.

Port 6 provides optional bus arbitration signals (BREQ, HLDA, HOLD) and chip select signals.

Port 3 includes alternate functions of timers, serial interfaces, the optional bus control signal BHE/WRH, and the system clock output CLKOUT (or the programmable frequency output FOUT).

Port 5 (and parts of PORT1) is used for the analog input channels to the A/D converter or timer control signals.

The edge characteristics (transition time) and driver characteristics (output current) of the C167CS's port drivers can be selected via the Port Output Control registers (POCONx).



#### **Special Function Registers Overview**

**Table 7** lists all SFRs which are implemented in the C167CS in alphabetical order. **Bit-addressable** SFRs are marked with the letter "**b**" in column "Name". SFRs within the **Extended SFR-Space** (ESFRs) are marked with the letter "**E**" in column "Physical Address". Registers within on-chip X-peripherals are marked with the letter "**X**" in column "Physical Address".

An SFR can be specified via its individual mnemonic name. Depending on the selected addressing mode, an SFR can be accessed via its physical address (using the Data Page Pointers), or via its short 8-bit address (without using the Data Page Pointers).

| Name     |                                                                             | Physica<br>Addres |                                | 8-Bit<br>Addr.    | Description                                                   | Reset<br>Value    |
|----------|-----------------------------------------------------------------------------|-------------------|--------------------------------|-------------------|---------------------------------------------------------------|-------------------|
| ADCIC    | b                                                                           | FF98 <sub>H</sub> |                                | CCH               | A/D Converter End of Conversion<br>Interrupt Control Register | 0000 <sub>H</sub> |
| ADCON    | <b>N b</b> FFA0 <sub>H</sub> D0 <sub>H</sub> A/D Converter Control Register |                   | A/D Converter Control Register | 0000 <sub>H</sub> |                                                               |                   |
| ADDAT    |                                                                             | FEA0 <sub>H</sub> |                                | 50 <sub>H</sub>   | A/D Converter Result Register                                 | 0000 <sub>H</sub> |
| ADDAT2   |                                                                             | F0A0 <sub>H</sub> | Ε                              | 50 <sub>H</sub>   | A/D Converter 2 Result Register                               | 0000 <sub>H</sub> |
| ADDRSEL1 |                                                                             | FE18 <sub>H</sub> |                                | 0C <sub>H</sub>   | Address Select Register 1                                     | 0000 <sub>H</sub> |
| ADDRSEL2 | 2                                                                           | FE1A <sub>H</sub> |                                | 0D <sub>H</sub>   | Address Select Register 2                                     | 0000 <sub>H</sub> |
| ADDRSEL3 | 3                                                                           | FE1C <sub>H</sub> |                                | 0E <sub>H</sub>   | Address Select Register 3                                     | 0000 <sub>H</sub> |
| ADDRSEL4 | ŀ                                                                           | FE1E <sub>H</sub> |                                | 0F <sub>H</sub>   | Address Select Register 4                                     | 0000 <sub>H</sub> |
| ADEIC    | b                                                                           | FF9A <sub>H</sub> |                                | CD <sub>H</sub>   | A/D Converter Overrun Error Interrupt<br>Control Register     | 0000 <sub>H</sub> |
| BUSCON0  | b                                                                           | FF0C <sub>H</sub> |                                | 86 <sub>H</sub>   | Bus Configuration Register 0                                  | 0XX0 <sub>H</sub> |
| BUSCON1  | b                                                                           | FF14 <sub>H</sub> |                                | 8A <sub>H</sub>   | Bus Configuration Register 1                                  | 0000 <sub>H</sub> |
| BUSCON2  | b                                                                           | FF16 <sub>H</sub> |                                | 8B <sub>H</sub>   | Bus Configuration Register 2                                  | 0000 <sub>H</sub> |
| BUSCON3  | b                                                                           | FF18 <sub>H</sub> |                                | 8C <sub>H</sub>   | Bus Configuration Register 3                                  | 0000 <sub>H</sub> |
| BUSCON4  | b                                                                           | FF1A <sub>H</sub> |                                | 8D <sub>H</sub>   | Bus Configuration Register 4                                  | 0000 <sub>H</sub> |
| C1BTR    |                                                                             | EF04 <sub>H</sub> | Χ                              |                   | CAN1 Bit Timing Register                                      | UUUU <sub>H</sub> |
| C1CSR    |                                                                             | EF00 <sub>H</sub> | Χ                              |                   | CAN1 Control/Status Register                                  | XX01 <sub>H</sub> |
| C1GMS    |                                                                             | EF06 <sub>H</sub> | Χ                              |                   | CAN1 Global Mask Short                                        | UFUU <sub>H</sub> |
| C1PCIR   |                                                                             | EF02 <sub>H</sub> | Χ                              |                   | CAN1 Port Control/Interrupt Register                          | XXXX <sub>H</sub> |
| C1LGML   |                                                                             | EF0A <sub>H</sub> | Χ                              |                   | CAN1 Lower Global Mask Long                                   | UUUU <sub>H</sub> |
| C1LMLM   |                                                                             | EF0E <sub>H</sub> | Χ                              |                   | CAN1 Lower Mask of Last Message                               | UUUU <sub>H</sub> |

#### Table 7 C167CS Registers, Ordered by Name



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

| Name   |   | Physica<br>Addres |   | 8-Bit<br>Addr.  | Description                          | Reset<br>Value    |
|--------|---|-------------------|---|-----------------|--------------------------------------|-------------------|
| C1UAR  |   | EFn2 <sub>H</sub> | X |                 | CAN1 Upper Arbitration Reg. (msg. n) | UUUU <sub>H</sub> |
| C1UGML |   | EF08 <sub>H</sub> | X |                 | CAN1 Upper Global Mask Long          | UUUU <sub>H</sub> |
| C1UMLM |   | EF0C <sub>H</sub> | X |                 | CAN1 Upper Mask of Last Message      | UUUU <sub>H</sub> |
| C2BTR  |   | EE04 <sub>H</sub> | X |                 | CAN2 Bit Timing Register             | UUUU <sub>H</sub> |
| C2CSR  |   | EE00 <sub>H</sub> | X |                 | CAN2 Control/Status Register         | XX01 <sub>H</sub> |
| C2GMS  |   | EE06 <sub>H</sub> | X |                 | CAN2 Global Mask Short               | UFUU <sub>H</sub> |
| C2PCIR |   | EE02 <sub>H</sub> | X |                 | CAN2 Port Control/Interrupt Register | XXXX <sub>H</sub> |
| C2LGML |   | EE0A <sub>H</sub> | X |                 | CAN2 Lower Global Mask Long          | UUUU <sub>H</sub> |
| C2LMLM |   | EE0E <sub>H</sub> | X |                 | CAN2 Lower Mask of Last Message      | UUUU <sub>H</sub> |
| C2UAR  |   | EEn2 <sub>H</sub> | X |                 | CAN2 Upper Arbitration Reg. (msg. n) | UUUU <sub>H</sub> |
| C2UGML |   | EE08 <sub>H</sub> | X |                 | CAN2 Upper Global Mask Long          | UUUU <sub>H</sub> |
| C2UMLM |   | EE0C <sub>H</sub> | X |                 | CAN2 Upper Mask of Last Message      | UUUU <sub>H</sub> |
| CAPREL |   | FE4A <sub>H</sub> |   | 25 <sub>H</sub> | GPT2 Capture/Reload Register         | 0000 <sub>H</sub> |
| CC0    |   | FE80 <sub>H</sub> |   | 40 <sub>H</sub> | CAPCOM Register 0                    | 0000 <sub>H</sub> |
| CC0IC  | b | FF78 <sub>H</sub> |   | BC <sub>H</sub> | CAPCOM Reg. 0 Interrupt Ctrl. Reg.   | 0000 <sub>H</sub> |
| CC1    |   | FE82 <sub>H</sub> |   | 41 <sub>H</sub> | CAPCOM Register 1                    | 0000 <sub>H</sub> |
| CC10   |   | FE94 <sub>H</sub> |   | 4A <sub>H</sub> | CAPCOM Register 10                   | 0000 <sub>H</sub> |
| CC10IC | b | FF8C <sub>H</sub> |   | C6 <sub>H</sub> | CAPCOM Reg. 10 Interrupt Ctrl. Reg.  | 0000 <sub>H</sub> |
| CC11   |   | FE96 <sub>H</sub> |   | 4B <sub>H</sub> | CAPCOM Register 11                   | 0000 <sub>H</sub> |
| CC11IC | b | FF8E <sub>H</sub> |   | C7 <sub>H</sub> | CAPCOM Reg. 11 Interrupt Ctrl. Reg.  | 0000 <sub>H</sub> |
| CC12   |   | FE98 <sub>H</sub> |   | 4C <sub>H</sub> | CAPCOM Register 12                   | 0000 <sub>H</sub> |
| CC12IC | b | FF90 <sub>H</sub> |   | C8 <sub>H</sub> | CAPCOM Reg. 12 Interrupt Ctrl. Reg.  | 0000 <sub>H</sub> |
| CC13   |   | FE9A <sub>H</sub> |   | 4D <sub>H</sub> | CAPCOM Register 13                   | 0000 <sub>H</sub> |
| CC13IC | b | FF92 <sub>H</sub> |   | C9 <sub>H</sub> | CAPCOM Reg. 13 Interrupt Ctrl. Reg.  | 0000 <sub>H</sub> |
| CC14   |   | FE9C <sub>H</sub> |   | 4E <sub>H</sub> | CAPCOM Register 14                   | 0000 <sub>H</sub> |
| CC14IC | b | FF94 <sub>H</sub> |   | CA <sub>H</sub> | CAPCOM Reg. 14 Interrupt Ctrl. Reg.  | 0000 <sub>H</sub> |
| CC15   |   | FE9E <sub>H</sub> |   | 4F <sub>H</sub> | CAPCOM Register 15                   | 0000 <sub>H</sub> |
| CC15IC | b | FF96 <sub>H</sub> |   | CB <sub>H</sub> | CAPCOM Reg. 15 Interrupt Ctrl. Reg.  | 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> |



| Table 7 | C167CS Registers. | , Ordered by Name (cont'd) |
|---------|-------------------|----------------------------|
|         |                   |                            |

| Name Physical |   |                   |   | 8-Bit           | Description                            | Reset             |
|---------------|---|-------------------|---|-----------------|----------------------------------------|-------------------|
|               |   | Addres            |   | Addr.           |                                        | Value             |
| DP1L          | b | F104 <sub>H</sub> | Ε | 82 <sub>H</sub> | P1L 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>   |
| 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>   |
| DP7           | b | FFD2 <sub>H</sub> |   | E9 <sub>H</sub> | Port 7 Direction Control Register      | 00 <sub>H</sub>   |
| DP8           | b | FFD6 <sub>H</sub> |   | EB <sub>H</sub> | Port 8 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> |
| EXISEL        | b | F1DA <sub>H</sub> | Ε | ED <sub>H</sub> | External Interrupt Source Select Reg.  | 0000 <sub>H</sub> |
| FOCON         | b | FFAA <sub>H</sub> |   | D5 <sub>H</sub> | Frequency Output Control Register      | 0000 <sub>H</sub> |
| IDCHIP        |   | F07C <sub>H</sub> | Ε | 3E <sub>H</sub> | Identifier                             | 0CXX <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                             | X040 <sub>H</sub> |
| IDMEM2        |   | F076 <sub>H</sub> | Ε | 3B <sub>H</sub> | Identifier                             | XXXX <sub>H</sub> |
| IDPROG        |   | F078 <sub>H</sub> | Ε | 3C <sub>H</sub> | Identifier                             | XXXX <sub>H</sub> |
| ISNC          | b | F1DE <sub>H</sub> | Ε | EF <sub>H</sub> | Interrupt Subnode Control Register     | 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> |
| ODP4          | b | F1CA <sub>H</sub> | Ε | E5 <sub>H</sub> | Port 4 Open Drain Control Register     | 00 <sub>H</sub>   |
| ODP6          | b | F1CE <sub>H</sub> | Ε | E7 <sub>H</sub> | Port 6 Open Drain Control Register     | 00 <sub>H</sub>   |
| ODP7          | b | F1D2 <sub>H</sub> | Ε | E9 <sub>H</sub> | Port 7 Open Drain Control Register     | 00 <sub>H</sub>   |
| ODP8          | b | F1D6 <sub>H</sub> | Ε | EB <sub>H</sub> | Port 8 Open Drain Control Register     | 00 <sub>H</sub>   |



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

| Name   |   | Physical<br>Address |   | 8-Bit<br>Addr.  | Description                             | Reset<br>Value                  |
|--------|---|---------------------|---|-----------------|-----------------------------------------|---------------------------------|
| T14    |   | F0D2 <sub>H</sub>   | Ε | 69 <sub>H</sub> | RTC Timer 14 Register                   | XXXX <sub>H</sub>               |
| T14REL |   | F0D0 <sub>H</sub>   | Ε | 68 <sub>H</sub> | RTC Timer 14 Reload Register            | XXXX <sub>H</sub>               |
| T2     |   | FE40 <sub>H</sub>   |   | 20 <sub>H</sub> | GPT1 Timer 2 Register                   | 0000 <sub>H</sub>               |
| T2CON  | b | FF40 <sub>H</sub>   |   | A0 <sub>H</sub> | GPT1 Timer 2 Control Register           | 0000 <sub>H</sub>               |
| T2IC   | b | FF60 <sub>H</sub>   |   | B0 <sub>H</sub> | GPT1 Timer 2 Interrupt Control Register | 0000 <sub>H</sub>               |
| Т3     |   | FE42 <sub>H</sub>   |   | 21 <sub>H</sub> | GPT1 Timer 3 Register                   | 0000 <sub>H</sub>               |
| T3CON  | b | FF42 <sub>H</sub>   |   | A1 <sub>H</sub> | GPT1 Timer 3 Control Register           | 0000 <sub>H</sub>               |
| T3IC   | b | FF62 <sub>H</sub>   |   | B1 <sub>H</sub> | GPT1 Timer 3 Interrupt Control Register | 0000 <sub>H</sub>               |
| T4     |   | FE44 <sub>H</sub>   |   | 22 <sub>H</sub> | GPT1 Timer 4 Register                   | 0000 <sub>H</sub>               |
| T4CON  | b | FF44 <sub>H</sub>   |   | A2 <sub>H</sub> | GPT1 Timer 4 Control Register           | 0000 <sub>H</sub>               |
| T4IC   | b | FF64 <sub>H</sub>   |   | B2 <sub>H</sub> | GPT1 Timer 4 Interrupt Control Register | 0000 <sub>H</sub>               |
| Т5     |   | FE46 <sub>H</sub>   |   | 23 <sub>H</sub> | GPT2 Timer 5 Register                   | 0000 <sub>H</sub>               |
| T5CON  | b | FF46 <sub>H</sub>   |   | A3 <sub>H</sub> | GPT2 Timer 5 Control Register           | 0000 <sub>H</sub>               |
| T5IC   | b | FF66 <sub>H</sub>   |   | B3 <sub>H</sub> | GPT2 Timer 5 Interrupt Control Register | 0000 <sub>H</sub>               |
| Т6     |   | FE48 <sub>H</sub>   |   | 24 <sub>H</sub> | GPT2 Timer 6 Register                   | 0000 <sub>H</sub>               |
| T6CON  | b | FF48 <sub>H</sub>   |   | A4 <sub>H</sub> | GPT2 Timer 6 Control Register           | 0000 <sub>H</sub>               |
| T6IC   | b | FF68 <sub>H</sub>   |   | B4 <sub>H</sub> | GPT2 Timer 6 Interrupt Control Register | 0000 <sub>H</sub>               |
| T7     |   | F050 <sub>H</sub>   | Ε | 28 <sub>H</sub> | CAPCOM Timer 7 Register                 | 0000 <sub>H</sub>               |
| T78CON | b | FF20 <sub>H</sub>   |   | 90 <sub>H</sub> | CAPCOM Timer 7 and 8 Control Reg.       | 0000 <sub>H</sub>               |
| T7IC   | b | F17A <sub>H</sub>   | Ε | BE <sub>H</sub> | CAPCOM Timer 7 Interrupt Ctrl. Reg.     | 0000 <sub>H</sub>               |
| T7REL  |   | F054 <sub>H</sub>   | Ε | 2A <sub>H</sub> | CAPCOM Timer 7 Reload Register          | 0000 <sub>H</sub>               |
| Т8     |   | F052 <sub>H</sub>   | Ε | 29 <sub>H</sub> | CAPCOM Timer 8 Register                 | 0000 <sub>H</sub>               |
| T8IC   | b | F17C <sub>H</sub>   | Ε | BF <sub>H</sub> | CAPCOM Timer 8 Interrupt Ctrl. Reg.     | 0000 <sub>H</sub>               |
| T8REL  |   | F056 <sub>H</sub>   | Ε | 2B <sub>H</sub> | CAPCOM Timer 8 Reload Register          | 0000 <sub>H</sub>               |
| TFR    | b | FFAC <sub>H</sub>   |   | D6 <sub>H</sub> | Trap Flag Register                      | 0000 <sub>H</sub>               |
| WDT    |   | FEAE <sub>H</sub>   |   | 57 <sub>H</sub> | Watchdog Timer Register (read only)     | 0000 <sub>H</sub>               |
| WDTCON | b | FFAE <sub>H</sub>   |   | D7 <sub>H</sub> | Watchdog Timer Control Register         | <sup>2)</sup> 00XX <sub>H</sub> |
| XP0IC  | b | F186 <sub>H</sub>   | Ε | C3 <sub>H</sub> | CAN1 Module Interrupt Control Register  | 0000 <sub>H</sub>               |
| XP1IC  | b | F18E <sub>H</sub>   | Ε | C7 <sub>H</sub> | CAN2 Module Interrupt Control Register  | 0000 <sub>H</sub>               |
| XP2IC  | b | F196 <sub>H</sub>   | Ε | CB <sub>H</sub> | Unassigned Interrupt Control Register   | 0000 <sub>H</sub>               |





Figure 9 Idle and Power Down Supply Current as a Function of Oscillator Frequency





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



P0.15-13 (P0H.7-5). Register RP0H can be loaded from the upper half of register RSTCON under software control.

**Table 11** associates the combinations of these three bits with the respective clock generation mode.

| CLKCFG<br>(RP0H.7-5) | <b>CPU Frequency</b> $f_{CPU} = f_{OSC} \times F$ | External Clock<br>Input Range <sup>1)</sup> | Notes                      |
|----------------------|---------------------------------------------------|---------------------------------------------|----------------------------|
| 1 1 1                | $f_{OSC} \times 4$                                | 2.5 to 10 MHz                               | Default configuration      |
| 1 1 0                | $f_{OSC} \times 3$                                | 3.33 to 13.33 MHz                           | -                          |
| 101                  | $f_{OSC} \times 2$                                | 5 to 20 MHz                                 | -                          |
| 1 0 0                | $f_{OSC} \times 5$                                | 2 to 8 MHz                                  | -                          |
| 0 1 1                | $f_{OSC} \times 1$                                | 1 to 40 MHz                                 | Direct drive <sup>2)</sup> |
| 0 1 0                | $f_{\rm OSC} 	imes$ 1.5                           | 6.66 to 26.66 MHz                           | -                          |
| 0 0 1                | f <sub>OSC</sub> / 2                              | 2 to 50 MHz <sup>3)</sup>                   | CPU clock via prescaler    |
| 0 0 0                | $f_{OSC} \times 2.5$                              | 4 to 16 MHz                                 | -                          |

 Table 11
 C167CS Clock Generation Modes

<sup>1)</sup> The external clock input range refers to a CPU clock range of 10 ... 40 MHz.

<sup>2)</sup> The maximum frequency depends on the duty cycle of the external clock signal.

<sup>3)</sup> In prescaler mode the full CPU clock range cannot be used.

#### **Prescaler Operation**

When prescaler operation is configured (CLKCFG =  $001_B$ ) the CPU clock is derived from the internal oscillator (input clock signal) by a 2:1 prescaler.

The frequency of  $f_{CPU}$  is half the frequency of  $f_{OSC}$  and the high and low time of  $f_{CPU}$  (i.e. the duration of an individual TCL) is defined by the period of the input clock  $f_{OSC}$ .

The timings listed in the AC Characteristics that refer to TCLs therefore can be calculated using the period of  $f_{OSC}$  for any TCL.

#### Phase Locked Loop

When PLL operation is configured (via CLKCFG) the on-chip phase locked loop is enabled and provides the CPU clock (see **Table 11**). The PLL multiplies the input frequency by the factor **F** which is selected via the combination of pins P0.15-13 (i.e.  $f_{CPU} = f_{OSC} \times F$ ). With every **F**'th transition of  $f_{OSC}$  the PLL circuit synchronizes the CPU clock to the input clock. This synchronization is done smoothly, i.e. the CPU clock frequency does not change abruptly.



### AC Characteristics External Clock Drive XTAL1

(Operating Conditions apply)

| Parameter Syr           |                       | bol | Direct Drive<br>1:1 |      | Prescaler<br>2:1 |      | PLL<br>1:N       |                   | Unit |
|-------------------------|-----------------------|-----|---------------------|------|------------------|------|------------------|-------------------|------|
|                         |                       |     | min.                | max. | min.             | max. | min.             | max.              | ]    |
| Oscillator period       | t <sub>OSC</sub>      | SR  | 25                  | _    | 20               | _    | 37 <sup>1)</sup> | 500 <sup>1)</sup> | ns   |
| High time <sup>2)</sup> | <i>t</i> <sub>1</sub> | SR  | 12 <sup>3)</sup>    | _    | 5                | _    | 10               | _                 | ns   |
| Low time <sup>2)</sup>  | <i>t</i> <sub>2</sub> | SR  | 12 <sup>3)</sup>    | _    | 5                | _    | 10               | _                 | ns   |
| Rise time <sup>2)</sup> | t <sub>3</sub>        | SR  | -                   | 8    | -                | 5    | -                | 10                | ns   |
| Fall time <sup>2)</sup> | <i>t</i> <sub>4</sub> | SR  | _                   | 8    | -                | 5    | -                | 10                | ns   |

#### Table 12 External Clock Drive Characteristics

 The minimum and maximum oscillator periods for PLL operation depend on the selected CPU clock generation mode. Please see respective table above.

<sup>2)</sup> The clock input signal must reach the defined levels  $V_{\text{IL2}}$  and  $V_{\text{IH2}}$ .

<sup>3)</sup> The minimum high and low time refers to a duty cycle of 50%. The maximum operating frequency ( $f_{CPU}$ ) in direct drive mode depends on the duty cycle of the clock input signal.



#### Figure 13 External Clock Drive XTAL1

Note: If the on-chip oscillator is used together with a crystal, the oscillator frequency is limited to a range of 4 MHz to 40 MHz.

It is strongly recommended to measure the oscillation allowance (or margin) in the final target system (layout) to determine the optimum parameters for the oscillator operation. Please refer to the limits specified by the crystal supplier.

When driven by an external clock signal it will accept the specified frequency range. Operation at lower input frequencies is possible but is guaranteed by design only (not 100% tested).





Figure 17 Demultiplexed Bus, Write Access





Figure 19 Multiplexed Bus, Write Access





Figure 22 External Bus Arbitration, Releasing the Bus

- Notes <sup>1)</sup> The C167CS will complete the currently running bus cycle before granting bus access.
- <sup>2)</sup> This is the first possibility for BREQ to get active.
- <sup>3)</sup> The  $\overline{CS}$  outputs will be resistive high (pullup) after  $t_{33}$ . Latched  $\overline{CS}$  outputs are driven high for 1 TCL before the output drivers are switched off.