

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

E·XFI

| Product Status             | Obsolete                                                                      |
|----------------------------|-------------------------------------------------------------------------------|
| Core Processor             | XC800                                                                         |
| Core Size                  | 8-Bit                                                                         |
| Speed                      | 86MHz                                                                         |
| Connectivity               | LINbus, SSI, UART/USART                                                       |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                         |
| Number of I/O              | 19                                                                            |
| Program Memory Size        | 8KB (8K x 8)                                                                  |
| Program Memory Type        | FLASH                                                                         |
| EEPROM Size                | -                                                                             |
| RAM Size                   | 768 x 8                                                                       |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                                   |
| Data Converters            | A/D 8x10b                                                                     |
| Oscillator Type            | Internal                                                                      |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                                 |
| Package / Case             | 38-TFSOP (0.173", 4.40mm Width)                                               |
| Supplier Device Package    | PG-TSSOP-38                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/infineon-technologies/sak-xc866l-2fri-bc |

Email: info@E-XFL.COM

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



## 8-Bit Single-Chip Microcontroller XC800 Family

#### 1 **Summary of Features**

- High-performance XC800 Core •
  - compatible with standard 8051 processor
  - two clocks per machine cycle architecture (for memory access without wait state)
  - two data pointers
- On-chip memory
  - 8 Kbytes of Boot ROM
  - 256 bytes of RAM
  - 512 bytes of XRAM
  - 4/8/16 Kbytes of Flash; or 8/16 Kbytes of ROM, with additional 4 Kbytes of Flash (includes memory protection strategy)
- I/O port supply at 3.3 V/5.0 V and core logic supply at 2.5 V (generated by embedded voltage regulator)

(further features are on next page)







## XC866

#### **General Device Information**

| Symbol            | Pin<br>Number | Туре | Reset<br>State | Function                                                              |
|-------------------|---------------|------|----------------|-----------------------------------------------------------------------|
| V <sub>DDP</sub>  | 18            | -    | -              | I/O Port Supply (3.3 V/5.0 V)<br>Also used by EVR and analog modules. |
| V <sub>SSP</sub>  | 19            | -    | -              | I/O Port Ground                                                       |
| V <sub>DDC</sub>  | 8             | -    | -              | Core Supply Monitor (2.5 V)                                           |
| V <sub>ssc</sub>  | 7             | -    | -              | Core Supply Ground                                                    |
| VAREF             | 25            | -    | -              | ADC Reference Voltage                                                 |
| V <sub>AGND</sub> | 24            | -    | -              | ADC Reference Ground                                                  |
| XTAL1             | 6             | I    | Hi-Z           | External Oscillator Input<br>(NC if not needed)                       |
| XTAL2             | 5             | 0    | Hi-Z           | External Oscillator Output<br>(NC if not needed)                      |
| TMS               | 11            | I    | PD             | Test Mode Select                                                      |
| RESET             | 38            | I    | PU             | Reset Input                                                           |
| MBC <sup>1)</sup> | 1             | I    | PU             | Monitor & BootStrap Loader Control                                    |

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

<sup>1)</sup> An external pull-up device in the range of 4.7 k $\Omega$  to 100 k $\Omega$  is required to enter user mode. Alternatively MBC can be tied to high if alternate functions (for debugging) of the pin are not utilized.



## 3.2.2 Special Function Register

The Special Function Registers (SFRs) occupy direct internal data memory space in the range  $80_H$  to FF<sub>H</sub>. All registers, except the program counter, reside in the SFR area. The SFRs include pointers and registers that provide an interface between the CPU and the on-chip peripherals. As the 128-SFR range is less than the total number of registers required, address extension mechanisms are required to increase the number of addressable SFRs. The address extension mechanisms include:

- Mapping
- Paging

## 3.2.2.1 Address Extension by Mapping

Address extension is performed at the system level by mapping. The SFR area is extended into two portions: the standard (non-mapped) SFR area and the mapped SFR area. Each portion supports the same address range  $80_H$  to FF<sub>H</sub>, bringing the number of addressable SFRs to 256. The extended address range is not directly controlled by the CPU instruction itself, but is derived from bit RMAP in the system control register SYSCON0 at address  $8F_H$ . To access SFRs in the mapped area, bit RMAP in SFR SYSCON0 must be set. Alternatively, the SFRs in the standard area can be accessed by clearing bit RMAP. The SFR area can be selected as shown in **Figure 8**.

#### SYSCON0 System Control Register 0 Reset Value: 00<sub>H</sub> 2 1 0 7 6 5 4 3 0 1 0 RMAP r rw r rw

| Field | Bits    | Туре | Description                                                                                                                                                               |  |  |  |  |
|-------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| RMAP  | 0       | rw   | <ul> <li>Special Function Register Map Control</li> <li>The access to the standard SFR area is enabled.</li> <li>The access to the mapped SFR area is enabled.</li> </ul> |  |  |  |  |
| 1     | 2       | rw   | <b>Reserved</b><br>Returns the last value if read; should be written<br>with 1.                                                                                           |  |  |  |  |
| 0     | 1,[7:3] | r    | <b>Reserved</b><br>Returns 0 if read; should be written with 0.                                                                                                           |  |  |  |  |



## 3.2.4 XC866 Register Overview

The SFRs of the XC866 are organized into groups according to their functional units. The contents (bits) of the SFRs are summarized in **Table 7** to **Table 15**, with the addresses of the bitaddressable SFRs appearing in bold typeface.

The CPU SFRs can be accessed in both the standard and mapped memory areas (RMAP = 0 or 1).

| Addr            | Register Name                                       |                             | Bit       | 7           | 6          | 5          | 4          | 3     | 2    | 1     | 0    |  |
|-----------------|-----------------------------------------------------|-----------------------------|-----------|-------------|------------|------------|------------|-------|------|-------|------|--|
| RMAP =          | 0 or 1                                              |                             |           |             | 1          | 1          | 1          | 1     | 1    | 1     |      |  |
| 81 <sub>H</sub> | SP                                                  | Reset: 07 <sub>H</sub>      | Bit Field |             |            |            | S          | P     |      |       |      |  |
|                 | Stack Pointer Register                              |                             | Туре      |             |            |            | r          | w     |      |       |      |  |
| 82 <sub>H</sub> | DPL                                                 | Reset: 00 <sub>H</sub>      | Bit Field | DPL7        | DPL6       | DPL5       | DPL4       | DPL3  | DPL2 | DPL1  | DPL0 |  |
|                 | Data Pointer Register Lov                           | v                           | Туре      | rw          | rw         | rw         | rw         | rw    | rw   | rw    | rw   |  |
| 83 <sub>H</sub> | DPH                                                 | Reset: 00 <sub>H</sub>      | Bit Field | DPH7        | DPH6       | DPH5       | DPH4       | DPH3  | DPH2 | DPH1  | DPH0 |  |
|                 | Data Pointer Register Hig                           | h                           | Туре      | rw          | rw         | rw         | rw         | rw    | rw   | rw    | rw   |  |
| 87 <sub>H</sub> | PCON                                                | Reset: 00 <sub>H</sub>      | Bit Field | SMOD        |            | 0          |            | GF1   | GF0  | 0     | IDLE |  |
|                 | Power Control Register                              |                             | Туре      | rw          |            | r          |            | rw    | rw   | r     | rw   |  |
| 88 <sub>H</sub> | TCON                                                | Reset: 00 <sub>H</sub>      | Bit Field | TF1         | TR1        | TF0        | TR0        | IE1   | IT1  | IE0   | IT0  |  |
|                 | Timer Control Register                              |                             | Туре      | rwh         | rw         | rwh        | rw         | rwh   | rw   | rwh   | rw   |  |
| 89 <sub>H</sub> | TMOD                                                | Reset: 00 <sub>H</sub>      | Bit Field | GATE1       | 0          | Τ          | M          | GATE0 | 0    | TC    | M    |  |
|                 | Timer Mode Register                                 |                             | Туре      | rw          | r          | r          | w          | rw    | r    | r     | w    |  |
| 8A <sub>H</sub> | TL0                                                 | Reset: 00 <sub>H</sub>      | Bit Field |             |            |            | V          | AL    |      |       |      |  |
|                 | Timer 0 Register Low                                |                             | Туре      |             |            |            | rv         | vh    |      |       |      |  |
| 8B <sub>H</sub> | TL1                                                 | Reset: 00 <sub>H</sub>      | Bit Field |             | VAL        |            |            |       |      |       |      |  |
|                 | Timer 1 Register Low                                | Туре                        | rwh       |             |            |            |            |       |      |       |      |  |
| 8C <sub>H</sub> | TH0 Reset: 00 <sub>H</sub>                          |                             | Bit Field |             | VAL        |            |            |       |      |       |      |  |
|                 | Timer 0 Register High                               | Туре                        | rwh       |             |            |            |            |       |      |       |      |  |
| 8D <sub>H</sub> | TH1 Reset: 00 <sub>H</sub><br>Timer 1 Register High |                             | Bit Field | VAL         |            |            |            |       |      |       |      |  |
|                 |                                                     |                             | Туре      | rwh         |            |            |            |       |      |       |      |  |
| 98 <sub>H</sub> | SCON                                                | Reset: 00 <sub>H</sub>      | Bit Field | SM0         | SM1        | SM2        | REN        | TB8   | RB8  | TI    | RI   |  |
|                 | Serial Channel Control Re                           | egister                     | Туре      | rw          | rw         | rw         | rw         | rw    | rwh  | rwh   | rwh  |  |
| 99 <sub>H</sub> | SBUF                                                | Reset: 00 <sub>H</sub>      | Bit Field | VAL         |            |            |            |       |      |       |      |  |
|                 | Serial Data Buffer Registe                          | er                          | Туре      | rwh         |            |            |            |       |      |       |      |  |
| A2 <sub>H</sub> | EO                                                  | Reset: 00 <sub>H</sub>      | Bit Field | 0 TRAP_ 0   |            |            |            |       |      | DPSEL |      |  |
|                 | Extended Operation Regi                             | ster                        |           |             |            |            | EN         | (     |      |       | 0    |  |
|                 |                                                     |                             | Туре      |             | r          |            | rw         |       | r    |       | rw   |  |
| A8 <sub>H</sub> | IEN0<br>Interrupt Enable Register                   | Reset: 00 <sub>H</sub>      | Bit Field | EA          | 0          | ET2        | ES         | ET1   | EX1  | ET0   | EX0  |  |
|                 |                                                     |                             | Туре      | rw          | r          | rw         | rw         | rw    | rw   | rw    | rw   |  |
| B8 <sub>H</sub> | IP<br>Interrupt Priority Register                   | Reset: 00 <sub>H</sub>      | Bit Field |             | )          | PI2        | PS         | PI1   | PX1  | PIO   | PX0  |  |
|                 |                                                     |                             | Туре      |             | r          | rw         | rw         | rw    | rw   | rw    | rw   |  |
| В9 <sup>Н</sup> | IPH<br>Interrupt Priority Register                  | Reset: 00 <sub>H</sub>      | Bit Field |             | )          | PT2H       | PSH        | PI1H  | PX1H | PIOH  | РХОН |  |
|                 |                                                     |                             | Туре      | <b>e</b> 14 | r<br>I ta  | rw         | rw         | rw    | rw   | rw    | rw   |  |
| D0 <sub>H</sub> | PSW<br>Program Status Word Re                       | Reset: 00 <sub>H</sub>      | Bit Field | CY          | AC         | F0         | RS1        | RS0   | OV   | +1    | Р    |  |
|                 |                                                     |                             | Туре      | rw          | rwh        | rwh        | rw         | rw    | rwh  | rwh   | rh   |  |
| E0H             | ACC<br>Accumulator Register                         | Reset: 00 <sub>H</sub>      | Bit Field | ACC7        | ACC6       | ACC5       | ACC4       | ACC3  | ACC2 | ACC1  | ACC0 |  |
| =               |                                                     | <b>B</b> ( <b>A</b> C       | Туре      | rw          | rw         | rw         | rw         | rw    | rw   | rw    | rw   |  |
| E8 <sub>H</sub> | IEN1<br>Interrupt Enable Register                   | Reset: 00 <sub>H</sub><br>1 | Bit Field | ECCIP<br>3  | ECCIP<br>2 | ECCIP<br>1 | ECCIP<br>0 | EXM   | EX2  | ESSC  | EADC |  |
|                 |                                                     |                             | Туре      | rw          | rw         | rw         | rw         | rw    | rw   | rw    | rw   |  |

#### Table 7 CPU Register Overview



#### Table 11 ADC Register Overview (cont'd)

| Addr            | Register Name                                                        |                        | Bit       | 7            | 6              | 5    | 4     | 3        | 2    | 1    | 0         |
|-----------------|----------------------------------------------------------------------|------------------------|-----------|--------------|----------------|------|-------|----------|------|------|-----------|
| CA <sub>H</sub> | ADC_RESR0L                                                           | Reset: 00 <sub>H</sub> | Bit Field | RESU         | LT[1:0]        | 0    | VF    | DRC      |      | CHNR |           |
|                 | Result Register 0 Low                                                |                        | Туре      | r            | h              | r    | rh    | rh       |      | rh   |           |
| CBH             | ADC_RESR0H                                                           | Reset: 00 <sub>H</sub> | Bit Field |              |                |      | RESU  | LT[9:2]  |      |      |           |
|                 | Result Register 0 High                                               |                        | Туре      |              |                |      | r     | h        |      |      |           |
| CCH             | ADC_RESR1L                                                           | Reset: 00 <sub>H</sub> | Bit Field | RESU         | LT[1:0]        | 0    | VF    | DRC      |      | CHNR |           |
|                 | Result Register 1 Low                                                |                        | Туре      | r            | h              | r    | rh    | rh       |      | rh   |           |
| CD <sub>H</sub> | ADC_RESR1H                                                           | Reset: 00 <sub>H</sub> | Bit Field |              |                | 1    | RESU  | LT[9:2]  | 1    |      |           |
|                 | Result Register 1 High                                               |                        | Туре      |              |                |      | r     | h        |      |      |           |
| CEH             | ADC_RESR2L                                                           | Reset: 00 <sub>H</sub> | Bit Field | RESU         | LT[1:0]        | 0    | VF    | DRC      |      | CHNR |           |
|                 | Result Register 2 Low                                                |                        | Туре      | r            | h              | r    | rh    | rh       |      | rh   |           |
| CF <sub>H</sub> | ADC_RESR2H                                                           | Reset: 00 <sub>H</sub> | Bit Field |              |                | 1    | RESU  | LT[9:2]  | 1    |      |           |
|                 | Result Register 2 High                                               |                        | Туре      |              |                |      | r     | h        |      |      |           |
| D2 <sub>H</sub> | ADC_RESR3L                                                           | Reset: 00 <sub>H</sub> | Bit Field | RESU         | LT[1:0]        | 0    | VF    | DRC      |      | CHNR |           |
|                 | Result Register 3 Low                                                |                        | Туре      | r            | h              | r    | rh    | rh       |      | rh   |           |
| D3 <sub>H</sub> | ADC_RESR3H                                                           | Reset: 00 <sub>H</sub> | Bit Field |              |                |      | RESU  | LT[9:2]  |      |      |           |
|                 | Result Register 3 High                                               |                        | Туре      |              |                |      | r     | h        |      |      |           |
| RMAP =          | 0, Page 3                                                            |                        |           |              |                |      |       |          |      |      |           |
| CA <sub>H</sub> | ADC RESRAOL                                                          | Reset: 00 <sub>H</sub> | Bit Field | RE           | ESULT[2        | 2:01 | VF    | DRC      |      | CHNR |           |
|                 | Result Register 0, View A                                            | Low                    | Туре      |              | rh             | •    | rh    | rh       |      | rh   |           |
| СВн             | ADC RESRA0H                                                          | Reset: 00 <sub>H</sub> | Bit Field |              |                |      | RESUL | T[10:3]  |      |      |           |
|                 | Result Register 0, View A                                            | High                   | Туре      | rh           |                |      |       |          |      |      |           |
| ССн             | ADC_RESRA1L Reset: 00 <sub>H</sub><br>Result Register 1, View A Low  |                        | Bit Field | RE           | ESULT[2        | 2:01 | VF    | DRC CHNR |      |      |           |
|                 |                                                                      |                        | Туре      |              | rh             | •    | rh    | rh rh    |      |      |           |
| CDH             | ADC_RESRA1H Reset: 00 <sub>H</sub><br>Result Register 1, View A High |                        | Bit Field |              |                |      | RESUL | T[10:3]  |      |      |           |
|                 |                                                                      |                        | Туре      |              |                |      | r     | h        |      |      |           |
| CEH             | ADC_RESRA2L Reset: 00 <sub>H</sub><br>Result Register 2, View A Low  |                        | Bit Field | RE           | RESULT[2:0] VF |      |       | DRC      |      | CHNR |           |
|                 |                                                                      |                        | Туре      | rh rh        |                |      | rh rh |          |      |      |           |
| CF <sub>H</sub> | ADC RESRA2H                                                          | Reset: 00 <sub>H</sub> | Bit Field | RESULT[10:3] |                |      |       |          |      |      |           |
|                 | Result Register 2, View A                                            | High                   | Туре      |              |                |      | r     | <br>rh   |      |      |           |
| D2 <sub>H</sub> | ADC RESRA3L                                                          | Reset: 00 <sub>H</sub> | Bit Field | RE           | ESULT[2        | 2:01 | VF    | DRC      |      | CHNR |           |
|                 | Result Register 3, View A                                            | Low                    | Туре      |              | rh             | •    | rh    | rh       |      | rh   |           |
| D3 <sub>H</sub> | ADC RESRA3H                                                          | Reset: 00 <sub>H</sub> | Bit Field |              |                |      | RESUL | T[10:3]  |      |      |           |
|                 | Result Register 3, View A                                            | High                   | Туре      |              |                |      | r     | h -      |      |      |           |
| RMAP =          | 0, Page 4                                                            |                        |           |              |                |      |       |          |      |      |           |
| CA <sub>H</sub> | ADC_RCR0<br>Result Control Register 0                                | Reset: 00 <sub>H</sub> | Bit Field | VFCTR        | WFR            | 0    | IEN   |          | 0    |      | DRCT<br>R |
|                 |                                                                      |                        | Туре      | rw           | rw             | r    | rw    |          | r    |      | rw        |
| CB <sub>H</sub> | ADC_RCR1<br>Result Control Register 1                                | Reset: 00 <sub>H</sub> | Bit Field | VFCTR        | WFR            | 0    | IEN   |          | 0    |      | DRCT<br>R |
|                 |                                                                      |                        | Туре      | rw           | rw             | r    | rw    |          | r    |      | rw        |
| CCH             | ADC_RCR2<br>Result Control Register 2                                | Reset: 00 <sub>H</sub> | Bit Field | VFCTR        | WFR            | 0    | IEN   |          | 0    |      | DRCT<br>R |
|                 |                                                                      |                        | Туре      | rw           | rw             | r    | rw    |          | r    |      | rw        |
| CD <sub>H</sub> | ADC_RCR3<br>Result Control Register 3                                | Reset: 00 <sub>H</sub> | Bit Field | VFCTR        | WFR            | 0    | IEN   |          | 0    |      | DRCT<br>R |
|                 |                                                                      |                        | Туре      | rw           | rw             | r    | rw    |          | r    |      | rw        |
| CEH             | ADC_VFCR                                                             | Reset: 00 <sub>H</sub> | Bit Field |              |                | 0    |       | VFC3     | VFC2 | VFC1 | VFC0      |
|                 | Valid Flag Clear Register                                            |                        | Туре      |              |                | r    |       | w        | w    | w    | w         |
| RMAP =          | 0, Page 5                                                            |                        |           |              |                |      |       |          |      |      |           |

| Table 12 | Timer 2 Register Overview | (cont'd) | ) |
|----------|---------------------------|----------|---|
|          |                           | (cont u) | 1 |

| C1 <sub>H</sub> | T2_T2MOD<br>Timer 2 Mode Register                                        | Reset: 00 <sub>H</sub> | Bit Field | T2<br>REGS  | T2<br>RHEN | EDGE<br>SEL | PREN | T2PRE | DCEN |  |  |
|-----------------|--------------------------------------------------------------------------|------------------------|-----------|-------------|------------|-------------|------|-------|------|--|--|
|                 |                                                                          |                        | Туре      | rw          | rw         | rw          | rw   | rw    | rw   |  |  |
| C2 <sub>H</sub> | T2_RC2L                                                                  | Reset: 00 <sub>H</sub> | Bit Field | ld RC2[7:0] |            |             |      | [7:0] |      |  |  |
|                 | Timer 2 Reload/Capture Register Low                                      |                        | Туре      | rwh         |            |             |      |       |      |  |  |
| C3 <sub>H</sub> | H T2_RC2H Reset: 00 <sub>H</sub><br>Timer 2 Reload/Capture Register High |                        | Bit Field | RC2[15:8]   |            |             |      |       |      |  |  |
|                 |                                                                          |                        | Туре      | rwh         |            |             |      |       |      |  |  |
| C4 <sub>H</sub> | T2_T2L                                                                   | Reset: 00 <sub>H</sub> |           | THL2[7:0]   |            |             |      |       |      |  |  |
|                 | Timer 2 Register Low                                                     |                        | Туре      |             |            |             | rv   | vh    |      |  |  |
| C5 <sub>H</sub> | T2_T2H                                                                   | Reset: 00 <sub>H</sub> | Bit Field | THL2[15:8]  |            |             |      |       |      |  |  |
|                 | Timer 2 Register High                                                    |                        | Туре      |             |            |             | rv   | /h    |      |  |  |

The CCU6 SFRs can be accessed in the standard memory area (RMAP = 0).

## Table 13 CCU6 Register Overview

| Addr            | Register Name                                                                | Bit               | 7          | 6          | 5           | 4     | 3     | 2          | 1          | 0          |
|-----------------|------------------------------------------------------------------------------|-------------------|------------|------------|-------------|-------|-------|------------|------------|------------|
| RMAP =          | 0                                                                            |                   |            |            |             |       |       |            |            |            |
| A3 <sub>H</sub> | CCU6_PAGE Reset: 00 <sub>H</sub>                                             | Bit Field         | C          | P          | ST          | NR    | 0     | PAGE       |            |            |
|                 | Page Register for CCU6                                                       | Туре              | N N        | v          | v           | v     | r     |            | rwh        |            |
| RMAP =          | 0, Page 0                                                                    |                   |            |            |             |       |       |            |            |            |
| 9A <sub>H</sub> | CCU6_CC63SRL Reset: 00 <sub>H</sub><br>Capture/Compare Shadow Register for   | Bit Field         |            |            |             | CC6   | 3SL   |            |            |            |
|                 | Channel CC63 Low                                                             | Туре              |            |            |             | r     | w     |            |            |            |
| 9B <sub>H</sub> | CCU6_CC63SRH Reset: 00 <sub>H</sub><br>Capture/Compare Shadow Register for   | Bit Field         |            |            |             | CC6   | 3SH   |            |            |            |
|                 | Channel CC63 High                                                            | Туре              |            |            |             | r     | w     |            |            |            |
| 9C <sub>H</sub> | CCU6_TCTR4L         Reset: 00 <sub>H</sub> Timer Control Register 4 Low      | Bit Field         | T12<br>STD | T12<br>STR | (           | )     | DTRES | T12<br>RES | T12RS      | T12RR      |
|                 |                                                                              | Туре              | w          | w          | I           | r     | w     | w          | w          | w          |
| 9D <sub>H</sub> | CCU6_TCTR4H Reset: 00 <sub>H</sub><br>Timer Control Register 4 High          | Bit Field         | T13<br>STD | T13<br>STR | 0           |       |       | T13<br>RES | T13RS      | T13RR      |
|                 |                                                                              | Туре              | w          | w          |             | r     |       | w          | w          | w          |
| 9E <sub>H</sub> | CCU6_MCMOUTSL Reset: 00 <sub>H</sub><br>Multi-Channel Mode Output Shadow     | Bit Field         | STRM<br>CM | 0          | MCMPS       |       |       |            |            |            |
|                 | Register Low                                                                 | Туре              | w          | r          |             |       | r     | w          |            |            |
| 9F <sub>H</sub> | CCU6_MCMOUTSH Reset: 00 <sub>H</sub>                                         | Bit Field         | STRHP      | 0          | CURHS EXPHS |       |       |            |            |            |
|                 | Multi-Channel Mode Output Shadow<br>Register High                            | Туре              | w          | r          | rw          |       |       | rw         |            |            |
| A4 <sub>H</sub> | CCU6_ISRL Reset: 00 <sub>H</sub>                                             | Bit Field         | RT12P      | RT120      | RCC62       | RCC62 | RCC61 | RCC61      | RCC60      | RCC60      |
|                 | Capture/Compare Interrupt Status                                             | Turne             | M          | M          | F           | R     | F     | R          | F          | R          |
| A.E.            |                                                                              | Type<br>Dit Field | W          | W          | W           | W     | w     | W          | W          | W<br>DT12  |
| AoH             | Copture/Compare Interrupt Status                                             | BILFIEID          | ROIR       | RIDLE      | RWITE       | RCHE  | 0     | RIRPF      | PM         | CM         |
|                 | Reset Register High                                                          | Туре              | w          | w          | w           | w     | r     | w          | w          | w          |
| A6 <sub>H</sub> | CCU6_CMPMODIFL Reset: 00 <sub>H</sub><br>Compare State Modification Register | Bit Field         | 0          | MCC63<br>S |             | 0     |       | MCC62<br>S | MCC61<br>S | MCC60<br>S |
|                 | Low                                                                          | Туре              | r          | w          |             | r     |       | w          | w          | w          |
| A7 <sub>H</sub> | CCU6_CMPMODIFH Reset: 00 <sub>H</sub><br>Compare State Modification Register | Bit Field         | 0          | MCC63<br>R |             | 0     |       | MCC62<br>R | MCC61<br>R | MCC60<br>R |
|                 | High                                                                         | Туре              | r          | w          |             | r     |       | w          | w          | w          |
| FA <sub>H</sub> | CCU6_CC60SRL Reset: 00 <sub>H</sub><br>Capture/Compare Shadow Register for   | Bit Field         |            |            |             | CCE   | BOSL  |            |            |            |
|                 | Channel CC60 Low                                                             | Туре              |            |            |             | rv    | vh    |            |            |            |



| Sector 2: 128-byte   | Sector 9: 128-byte |
|----------------------|--------------------|
| Sector 1: 128-byte   | Sector 8: 128-byte |
|                      | Sector 7: 128-byte |
|                      | Sector 6: 128-byte |
|                      | Sector 5: 256-byte |
|                      | Sector 4: 256-byte |
|                      | Sector 3: 512-byte |
| Sector 0: 3.75-Kbyte | Sector 2: 512-byte |
|                      | Sector 1: 1-Kbyte  |
|                      | Sector 0: 1-Kbyte  |
| P-Flash              | D-Flash            |

#### Figure 11 Flash Bank Sectorization

İnfineon

The internal structure of each Flash bank represents a sector architecture for flexible erase capability. The minimum erase width is always a complete sector, and sectors can be erased separately or in parallel. Contrary to standard EPROMs, erased Flash memory cells contain 0s.

The D-Flash bank is divided into more physical sectors for extended erasing and reprogramming capability; even numbers for each sector size are provided to allow greater flexibility and the ability to adapt to a wide range of application requirements.





Figure 14 Interrupt Request Sources (Part 1)





Figure 16 Interrupt Request Sources (Part 3)



## 3.4.3 Interrupt Priority

Each interrupt source, except for NMI, can be individually programmed to one of the four possible priority levels. The NMI has the highest priority and supersedes all other interrupts. Two pairs of interrupt priority registers (IP and IPH, IP1 and IPH1) are available to program the priority level of each non-NMI interrupt vector.

A low-priority interrupt can be interrupted by a high-priority interrupt, but not by another interrupt of the same or lower priority. Further, an interrupt of the highest priority cannot be interrupted by any other interrupt source.

If two or more requests of different priority levels are received simultaneously, the request of the highest priority is serviced first. If requests of the same priority are received simultaneously, then an internal polling sequence determines which request is serviced first. Thus, within each priority level, there is a second priority structure determined by the polling sequence shown in **Table 18**.

| Source                                      | Level     |
|---------------------------------------------|-----------|
| Non-Maskable Interrupt (NMI)                | (highest) |
| External Interrupt 0                        | 1         |
| Timer 0 Interrupt                           | 2         |
| External Interrupt 1                        | 3         |
| Timer 1 Interrupt                           | 4         |
| UART Interrupt                              | 5         |
| Timer 2, Fractional Divider, LIN Interrupts | 6         |
| ADC Interrupt                               | 7         |
| SSC Interrupt                               | 8         |
| External Interrupt 2                        | 9         |
| External Interrupt [6:3]                    | 10        |
| CCU6 Interrupt Node Pointer 0               | 11        |
| CCU6 Interrupt Node Pointer 1               | 12        |
| CCU6 Interrupt Node Pointer 2               | 13        |
| CCU6 Interrupt Node Pointer 3               | 14        |

 Table 18
 Priority Structure within Interrupt Level





Figure 18 General Structure of Bidirectional Port



## 3.7 Reset Control

The XC866 has five types of reset: power-on reset, hardware reset, watchdog timer reset, power-down wake-up reset, and brownout reset.

When the XC866 is first powered up, the status of certain pins (see **Table 20**) must be defined to ensure proper start operation of the device. At the end of a reset sequence, the sampled values are latched to select the desired boot option, which cannot be modified until the next power-on reset or hardware reset. This guarantees stable conditions during the normal operation of the device.

In order to power up the system properly, the external reset pin  $\overrightarrow{\text{RESET}}$  must be asserted until  $V_{\text{DDC}}$  reaches  $0.9^* V_{\text{DDC}}$ . The delay of external reset can be realized by an external capacitor at  $\overrightarrow{\text{RESET}}$  pin. This capacitor value must be selected so that  $V_{\text{RESET}}$  reaches 0.4 V, but not before  $V_{\text{DDC}}$  reaches 0.9\*  $V_{\text{DDC}}$ .

A typical application example is shown in **Figure 21**.  $V_{DDP}$  capacitor value is 300 nF.  $V_{DDC}$  capacitor value is 220 nF. The capacitor connected to RESET pin is 100 nF.

Typically, the time taken for  $V_{DDC}$  to reach  $0.9^*V_{DDC}$  is less than 50 µs once  $V_{DDP}$  reaches 2.3V. Hence, based on the condition that 10% to 90%  $V_{DDP}$  (slew rate) is less than 500 µs, the RESET pin should be held low for 500 µs typically. See **Figure 22**.







For power saving purposes, the clocks may be disabled or slowed down according to **Table 23**.

# Table 23System frequency (f<sub>sys</sub> = 80 MHz)

| Power Saving Mode | Action                                                                                                                                    |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Idle              | Clock to the CPU is disabled.                                                                                                             |
| Slow-down         | Clocks to the CPU and all the peripherals, including CCU6, are divided by a common programmable factor defined by bit field CMCON.CLKREL. |
| Power-down        | Oscillator and PLL are switched off.                                                                                                      |



## 3.9 Power Saving Modes

The power saving modes of the XC866 provide flexible power consumption through a combination of techniques, including:

- Stopping the CPU clock
- · Stopping the clocks of individual system components
- Reducing clock speed of some peripheral components
- · Power-down of the entire system with fast restart capability

After a reset, the active mode (normal operating mode) is selected by default (see **Figure 26**) and the system runs in the main system clock frequency. From active mode, different power saving modes can be selected by software. They are:

- · Idle mode
- Slow-down mode
- Power-down mode



Figure 26 Transition between Power Saving Modes



XC866

## 3.11.1 Baud-Rate Generator

The baud-rate generator is based on a programmable 8-bit reload value, and includes divider stages (i.e., prescaler and fractional divider) for generating a wide range of baud rates based on its input clock  $f_{PCLK}$ , see **Figure 29**.



#### Figure 29 Baud-rate Generator Circuitry

The baud rate timer is a count-down timer and is clocked by either the output of the fractional divider ( $f_{MOD}$ ) if the fractional divider is enabled (FDCON.FDEN = 1), or the output of the prescaler ( $f_{DIV}$ ) if the fractional divider is disabled (FDEN = 0). For baud rate generation, the fractional divider must be configured to fractional divider mode (FDCON.FDM = 0). This allows the baud rate control run bit BCON.R to be used to start or stop the baud rate timer. At each timer underflow, the timer is reloaded with the 8-bit reload value in register BG and one clock pulse is generated for the serial channel.

Enabling the fractional divider in normal divider mode (FDEN = 1 and FDM = 1) stops the baud rate timer and nullifies the effect of bit BCON.R. See **Section 3.12**.

The baud rate  $(f_{BR})$  value is dependent on the following parameters:

- Input clock f<sub>PCLK</sub>
- Prescaling factor (2<sup>BRPRE</sup>) defined by bit field BRPRE in register BCON
- Fractional divider (STEP/256) defined by register FDSTEP (to be considered only if fractional divider is enabled and operating in fractional divider mode)



• 8-bit reload value (BR\_VALUE) for the baud rate timer defined by register BG The following formulas calculate the final baud rate without and with the fractional divider respectively:

baud rate = 
$$\frac{f_{PCLK}}{16 \times 2^{BRPRE} \times (BR_VALUE + 1)}$$
 where  $2^{BRPRE} \times (BR_VALUE + 1) > 1$ 

baud rate = 
$$\frac{f_{PCLK}}{16 \times 2^{BRPRE} \times (BR VALUE + 1)} \times \frac{STEP}{256}$$

The maximum baud rate that can be generated is limited to  $f_{PCLK}/32$ . Hence, for a module clock of 26.7 MHz, the maximum achievable baud rate is 0.83 MBaud.

Standard LIN protocal can support a maximum baud rate of 20kHz, the baud rate accuracy is not critical and the fractional divider can be disabled. Only the prescaler is used for auto baud rate calculation. For LIN fast mode, which supports the baud rate of 20kHz to 115.2kHz, the higher baud rates require the use of the fractional divider for greater accuracy.

**Table 26** lists the various commonly used baud rates with their corresponding parameter settings and deviation errors. The fractional divider is disabled and a module clock of 26.7 MHz is used.

| Baud rate  | Prescaling Factor<br>(2 <sup>BRPRE</sup> ) | Reload Value<br>(BR_VALUE + 1) | Deviation Error |  |  |
|------------|--------------------------------------------|--------------------------------|-----------------|--|--|
| 19.2 kBaud | 1 (BRPRE=000 <sub>B</sub> )                | 87 (57 <sub>H</sub> )          | -0.22 %         |  |  |
| 9600 Baud  | 1 (BRPRE=000 <sub>B</sub> )                | 174 (AE <sub>H</sub> )         | -0.22 %         |  |  |
| 4800 Baud  | 2 (BRPRE=001 <sub>B</sub> )                | 174 (AE <sub>H</sub> )         | -0.22 %         |  |  |
| 2400 Baud  | 4 (BRPRE=010 <sub>B</sub> )                | 174 (AE <sub>H</sub> )         | -0.22 %         |  |  |

 Table 26
 Typical Baud rates for UART with Fractional Divider disabled

The fractional divider allows baud rates of higher accuracy (lower deviation error) to be generated. **Table 27** lists the resulting deviation errors from generating a baud rate of



## 3.13 LIN Protocol

The UART can be used to support the Local Interconnect Network (LIN) protocol for both master and slave operations. The LIN baud rate detection feature provides the capability to detect the baud rate within LIN protocol using Timer 2. This allows the UART to be synchronized to the LIN baud rate for data transmission and reception.

LIN is a holistic communication concept for local interconnected networks in vehicles. The communication is based on the SCI (UART) data format, a single-master/multipleslave concept, a clock synchronization for nodes without stabilized time base. An attractive feature of LIN is self-synchronization of the slave nodes without a crystal or ceramic resonator, which significantly reduces the cost of hardware platform. Hence, the baud rate must be calculated and returned with every message frame.

The structure of a LIN frame is shown in Figure 30. The frame consists of the:

- header, which comprises a Break (13-bit time low), Synch Byte (55<sub>H</sub>), and ID field
- response time
- data bytes (according to UART protocol)
- checksum



Figure 30 Structure of LIN Frame

## 3.13.1 LIN Header Transmission

LIN header transmission is only applicable in master mode. In the LIN communication, a master task decides when and which frame is to be transferred on the bus. It also identifies a slave task to provide the data transported by each frame. The information needed for the handshaking between the master and slave tasks is provided by the master task through the header portion of the frame.

The header consists of a break and synch pattern followed by an identifier. Among these three fields, only the break pattern cannot be transmitted as a normal 8-bit UART data.



#### **Electrical Parameters**

#### Table 38Power Down Current (Operating Conditions apply; $V_{DDP}$ = 5V range )

| Parameter                     | Symbol           | Limit Values       |                    | Unit | Test Condition                                                             |  |
|-------------------------------|------------------|--------------------|--------------------|------|----------------------------------------------------------------------------|--|
|                               |                  | typ. <sup>1)</sup> | max. <sup>2)</sup> |      | Remarks                                                                    |  |
| V <sub>DDP</sub> = 5V Range   |                  | -                  |                    |      |                                                                            |  |
| Power-Down Mode <sup>3)</sup> | I <sub>PDP</sub> | 1                  | 10                 | μA   | $T_{\rm A}$ = + 25 °C. <sup>4</sup> )                                      |  |
|                               |                  | -                  | 30                 | μA   | <i>T</i> <sub>A</sub> = + 85 °C, XC866-<br>4FR, XC866-2FR <sup>4)5)</sup>  |  |
|                               |                  | -                  | 35                 | μA   | <i>T</i> <sub>A</sub> = + 85 °C, XC866-<br>1FR, ROM device <sup>4)5)</sup> |  |

<sup>1)</sup> The typical  $I_{PDP}$  values are measured at  $V_{DDP}$  = 5.0 V.

<sup>2)</sup> The maximum  $I_{\text{PDP}}$  values are measured at  $V_{\text{DDP}}$  = 5.5 V.

- <sup>3)</sup> I<sub>PDP</sub> (power-down mode) has a maximum value of 200  $\mu$ A at  $T_A$  = + 125 °C.
- <sup>4)</sup> I<sub>PDP</sub> (power-down mode) is measured with: RESET = V<sub>DDP</sub>, V<sub>AGND</sub>= V<sub>SS</sub>, RXD/INT0 = V<sub>DDP</sub>; rest of the ports are programmed to be input with either internal pull devices enabled or driven externally to ensure no floating inputs.

<sup>5)</sup> Not subject to production test, verified by design/characterization.



#### **Electrical Parameters**

## 4.3.3 Power-on Reset and PLL Timing

| Table 42 | Power-On Reset and PLL | Timing (Opera | ting Conditions apply) |
|----------|------------------------|---------------|------------------------|
|          |                        |               |                        |

| Parameter                           | Symbol                   | Limit Values |      |      | Unit | Test Conditions                                     |
|-------------------------------------|--------------------------|--------------|------|------|------|-----------------------------------------------------|
|                                     |                          | min.         | typ. | max. |      |                                                     |
| Pad operating voltage               | V <sub>PAD</sub> CC      | 2.3          | -    | -    | V    |                                                     |
| On-Chip Oscillator<br>start-up time | t <sub>OSCST</sub><br>CC | _            | -    | 500  | ns   |                                                     |
| Flash initialization time           | t <sub>FINIT</sub> CC    | -            | 160  | -    | μs   |                                                     |
| RESET hold time <sup>1)</sup>       | t <sub>RST</sub> SR      | _            | 500  | -    | μs   | $V_{\text{DDP}}$ rise time (10% – 90%) $\leq$ 500µs |
| PLL lock-in in time                 | t <sub>LOCK</sub> CC     | -            | -    | 200  | μs   |                                                     |
| PLL accumulated jitter              | D <sub>P</sub>           | -            | -    | 0.7  | ns   | 2)                                                  |

<sup>1)</sup> RESET signal has to be active (low) until  $V_{\text{DDC}}$  has reached 90% of its maximum value (typ. 2.5V).

<sup>2)</sup> PLL lock at 80 MHz using a 4 MHz external oscillator. The PLL Divider settings are K = 2, N = 40 and P = 1.



## Figure 42 Power-on Reset Timing



## **Electrical Parameters**

| Table 45 | JTAG Timing | (Operating | Conditions | apply; C | _ = 50 pF) |
|----------|-------------|------------|------------|----------|------------|
|----------|-------------|------------|------------|----------|------------|

| Parameter                                          |                       | nbol | Limits |     | Unit |
|----------------------------------------------------|-----------------------|------|--------|-----|------|
|                                                    |                       |      | min    | max |      |
| TMS setup to TCK 🖌                                 | <i>t</i> <sub>1</sub> | SR   | 8.0    | -   | ns   |
| TMS hold to TCK _                                  | $t_2$                 | SR   | 5.0    | -   | ns   |
| TDI setup to TCK 🦨                                 | <i>t</i> <sub>1</sub> | SR   | 11.0   | -   | ns   |
| TDI hold to TCK 🦨                                  | <i>t</i> <sub>2</sub> | SR   | 6.0    | _   | ns   |
| TDO valid output from TCK 🥆                        | $t_3$                 | СС   | -      | 23  | ns   |
| TDO high impedance to valid output from TCK 🥆      | $t_4$                 | СС   | -      | 26  | ns   |
| TDO valid output to high impedance from TCK $\sim$ | $t_5$                 | СС   | -      | 18  | ns   |



Figure 44 JTAG Timing