

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·XFl

| 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              | 9                                                                                |
| Program Memory Size        | 4KB (4K x 8)                                                                     |
| Program Memory Type        | FLASH                                                                            |
| EEPROM Size                | -                                                                                |
| RAM Size                   | 768 × 8                                                                          |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                                      |
| Data Converters            | A/D 4x10b                                                                        |
| Oscillator Type            | Internal                                                                         |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                                |
| Mounting Type              | Surface Mount                                                                    |
| Package / Case             | 20-TSSOP (0.173", 4.40mm Width)                                                  |
| Supplier Device Package    | PG-TSSOP-20                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/infineon-technologies/saf-xc864l-1fri-5v-aa |

Email: info@E-XFL.COM

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



#### **General Device Information**

# 2 General Device Information

## 2.1 Block Diagram



Figure 2 XC864 Block Diagram



#### **General Device Information**

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

| Symbol        | Pin<br>Number | Туре | Reset<br>State | Function                                                                                                                                                                             |  |  |  |
|---------------|---------------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| P1            |               | I/O  |                | <b>Port 1</b><br>Port 1 is an 8-bit bidirectional general purpose<br>I/O port. It can be used as alternate functions<br>for the JTAG, CCU6, UART, Timer 0, Timer 2<br>and SSC.       |  |  |  |
| P1.0/<br>P1.1 | 15            |      | PU             | RXD_0UART Receive Data InputT2EXTimer 2 External Trigger InputEXINT3External Interrupt Input 3T0Timer 0 InputTDO_1JTAG Serial Data OutputTXD_0UART Transmit Data Output/Clock Output |  |  |  |
|               |               |      |                | Note: Pin 15 is bonded to both P1.0 and P1<br>port pins. See <b>Section 2.3</b> on the type<br>of port pin configuration to be avoided<br>prevent permanent damage.                  |  |  |  |



#### **General Device Information**

| Table 1 | Pin Definitions and Functions | (cont'd) | ) |
|---------|-------------------------------|----------|---|
|         |                               |          | / |

| Symbol                                | Pin<br>Number | Туре | Reset<br>State | Function                                                                                                                              |
|---------------------------------------|---------------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------|
| P3                                    |               | I/O  |                | <b>Port 3</b><br>Port 3 is an 8-bit bidirectional general purpose<br>I/O port. It can be used as alternate functions<br>for CCU6.     |
| P3.0                                  | 16            |      | Hi-Z           | CCPOS1_2 CCU6 Hall Input 1<br>CC60_0 Input/Output of Capture/<br>Compare channel 0                                                    |
| P3.1                                  | 17            |      | Hi-Z           | CCPOS0_2 CCU6 Hall Input 0<br>CC61_2 Input/Output of Capture/<br>Compare channel 1<br>COUT60_0 Output of Capture/Compare<br>channel 0 |
| V <sub>DDP</sub>                      | 11            | _    | _              | <b>I/O Port Supply (3.3 or 5.0 V)</b><br>Also used by EVR and analog modules. All pins must be connected.                             |
| V <sub>DDC</sub>                      | 3             | _    | -              | Core Supply Monitor (2.5 V)                                                                                                           |
| V <sub>SSC</sub>                      | 2             | _    | -              | Core Supply Ground                                                                                                                    |
| V <sub>AREF</sub>                     | 13            | -    | -              | ADC Reference Voltage                                                                                                                 |
| $V_{\text{AGND}}$<br>$V_{\text{SSP}}$ | 12            | _    | -              | ADC Reference Ground/<br>I/O Ground<br>All pins must be connected.                                                                    |
| TMS                                   | 4             | 1    | PD             | Test Mode Select                                                                                                                      |
| RESET                                 | 18            | Ι    | PU             | Reset Input                                                                                                                           |



| Field | Bits | Туре | Description                                  |
|-------|------|------|----------------------------------------------|
| 0     | 3    | r    | Reserved                                     |
|       |      |      | Returns 0 if read; should be written with 0. |



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

| Addr            | Register Name                                                              | Bit               | 7          | 6          | 5          | 4          | 3    | 2          | 1          | 0          |  |
|-----------------|----------------------------------------------------------------------------|-------------------|------------|------------|------------|------------|------|------------|------------|------------|--|
| CB <sub>H</sub> | ADC_RCR1 Reset: 00 <sub>H</sub><br>Result Control Register 1               | Bit Field         | VFCTR      | WFR        | 0          | IEN        |      | 0          | 1          | DRCT<br>R  |  |
|                 |                                                                            | Туре              | rw         | rw         | r          | rw         |      | r          |            | rw         |  |
| CCH             | ADC_RCR2 Reset: 00 <sub>H</sub><br>Result Control Register 2               | Bit Field         | VFCTR      | WFR        | 0          | IEN        | IEN  |            | 0          |            |  |
|                 |                                                                            | Туре              | rw         | rw         | r          | rw         |      | r          |            | rw         |  |
| CD <sub>H</sub> | ADC_RCR3 Reset: 00 <sub>H</sub><br>Result Control Register 3               | 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                                                                  | 1                 |            |            |            |            |      |            |            |            |  |
| CA <sub>H</sub> | ADC_CHINFR Reset: 00 <sub>H</sub><br>Channel Interrupt Flag Register       | Bit Field         | CHINF<br>7 |            | (          | )          |      | CHINF<br>2 | CHINF<br>1 | CHINF<br>0 |  |
|                 |                                                                            | Туре              | rh         |            | r          | h          |      | rh         | rh         | rh         |  |
| СВ <sub>Н</sub> | ADC_CHINCR Reset: 00 <sub>H</sub><br>Channel Interrupt Clear Register      | Bit Field         | CHINC<br>7 |            | (          | )          |      | CHINC<br>2 | CHINC<br>1 | CHINC<br>0 |  |
|                 |                                                                            | Туре              | w          |            | V          | V          |      | w          | w          | w          |  |
| CC <sub>H</sub> | ADC_CHINSR Reset: 00 <sub>H</sub><br>Channel Interrupt Set Register        | Bit Field         | CHINS<br>7 |            | (          | )          |      | CHINS<br>2 | CHINS<br>1 | CHINS<br>0 |  |
|                 |                                                                            | Туре              | w          | w          |            |            |      | w          | w          | w          |  |
| CD <sub>H</sub> | ADC_CHINPR Reset: 00 <sub>H</sub><br>Channel Interrupt Node Pointer        | Bit Field         | CHINP<br>7 |            | (          | )          |      | CHINP<br>2 | CHINP<br>1 | CHINP<br>0 |  |
|                 | Register                                                                   | Туре              | rw         |            | r          | w          | rw   |            | rw         | rw         |  |
| CE <sub>H</sub> | ADC_EVINFR Reset: 00 <sub>H</sub><br>Event Interrupt Flag Register         | Bit Field         | EVINF<br>7 | EVINF<br>6 | EVINF<br>5 | EVINF<br>4 | 0    |            | EVINF<br>1 | EVINF<br>0 |  |
|                 |                                                                            | Туре              | rh         | rh         | rh         | rh         | r    |            | rh         | rh         |  |
| CF <sub>H</sub> | ADC_EVINCR Reset: 00 <sub>H</sub><br>Event Interrupt Clear Flag Register   | Bit Field         | EVINC<br>7 | EVINC<br>6 | EVINC<br>5 | EVINC<br>4 | 0    |            | EVINC<br>1 | EVINC<br>0 |  |
|                 |                                                                            | Туре              | w          | w          | w          | w          |      | r          | w          | w          |  |
| D2 <sub>H</sub> | ADC_EVINSR Reset: 00 <sub>H</sub><br>Event Interrupt Set Flag Register     | Bit Field         | EVINS<br>7 | EVINS<br>6 | EVINS<br>5 | EVINS<br>4 |      | 0          | EVINS<br>1 | EVINS<br>0 |  |
|                 |                                                                            | Туре              | w          | w          | w          | w          |      | r          | w          | w          |  |
| D3 <sub>H</sub> | ADC_EVINPR Reset: 00 <sub>H</sub><br>Event Interrupt Node Pointer Register | Bit Field         | EVINP<br>7 | EVINP<br>6 | EVINP<br>5 | EVINP<br>4 | 0    |            | EVINP<br>1 | EVINP<br>0 |  |
|                 |                                                                            | Туре              | rw         | rw         | rw         | rw         |      | r          | rw         | rw         |  |
| RMAP =          |                                                                            | D'1 5' 11         | 0117       |            |            |            |      |            |            |            |  |
| CA <sub>H</sub> | ADC_CRCR1 Reset: 00 <sub>H</sub>                                           | Bit Field         | CH7        |            | 0          |            |      | 0          |            |            |  |
| 0.0             |                                                                            | Type<br>Dit Field | rwn        | rwh        |            | r          |      |            |            |            |  |
| СВН             | Conversion Request Pending<br>Register 1                                   | Туре              | rwh        |            | rwh        |            |      |            | r          |            |  |
| CC <sub>H</sub> | ADC_CRMR1 Reset: 00 <sub>H</sub><br>Conversion Request Mode Register 1     | Bit Field         | Rsv        | LDEV       | CLR<br>PND | SCAN       | ENSI | ENTR       | 0          | ENGT       |  |
|                 |                                                                            | Туре              | r          | w          | w          | rw         | rw   | rw         | r          | rw         |  |
| CDн             | ADC_QMR0 Reset: 00                                                         | Bit Field         | CEV        | TREV       | FLUSH      | CLRV       | TRMD | ENTR       | 0          | ENGT       |  |
|                 | Queue Mode Register 0                                                      | Туре              | w          | w          | w          | w          | rw   | rw         | r          | rw         |  |
| CE <sub>H</sub> | ADC_QSR0 Reset: 20 <sub>H</sub>                                            | Bit Field         | Rsv        | 0          | EMPTY      | EV         |      | (          | C          |            |  |
|                 | Queue Status Register 0                                                    | Туре              | r          | r          | rh         | rh         |      |            | r          |            |  |
| CF <sub>H</sub> | ADC_Q0R0 Reset: 00 <sub>H</sub>                                            | Bit Field         | EXTR       | ENSI       | RF         | V          | 0    | F          | REQCHN     | R          |  |
|                 | Queue 0 Register 0                                                         | Туре              | rh         | rh         | rh         | rh         | r    |            | rh         |            |  |
| D2 <sub>H</sub> | ADC_QBUR0 Reset: 00 <sub>H</sub>                                           | Bit Field         | EXTR       | ENSI       | RF         | V          | 0    | F          | REQCHN     | R          |  |
|                 | Queue Backup Register 0                                                    | Туре              | rh         | rh         | rh         | rh         | r    |            | rh         |            |  |



## Table 12 OCDS Register Summary (cont'd)

| Addr            | Register Name                                                                            | Bit       | 7            | 6     | 5          | 4          | 3           | 2     | 1          | 0    |
|-----------------|------------------------------------------------------------------------------------------|-----------|--------------|-------|------------|------------|-------------|-------|------------|------|
| F4 <sub>H</sub> | MMICR Reset: 00 <sub>H</sub><br>Monitor Mode Interrupt Control Registe                   | Bit Field | DVECT        | DRETR | COMR<br>ST | MSTSE<br>L | MMUIE<br>_P | MMUIE | RRIE_<br>P | RRIE |
|                 |                                                                                          | Туре      | rwh          | rwh   | rwh        | rh         | w           | rw    | w          | rw   |
| F5 <sub>H</sub> | MMDR Reset: 00 <sub>H</sub><br>Monitor Mode Data Transfer Register                       | Bit Field |              |       |            | MN         | IRR         |       |            |      |
|                 | Receive                                                                                  | Туре      | rh           |       |            |            |             |       |            |      |
| F6 <sub>H</sub> | HWBPSR         Reset: 00 <sub>H</sub> Hardware Breakpoints Select Register               |           | d 0 BPSEL BF |       |            | BP         | SEL         |       |            |      |
|                 |                                                                                          | Туре      |              | r     |            | w          |             | r     | w          |      |
| F7 <sub>H</sub> | 7 <sub>H</sub> <b>HWBPDR Reset: 00<sub>H</sub></b><br>Hardware Breakpoints Data Register |           | HWBPxx       |       |            |            |             |       |            |      |
|                 |                                                                                          | Туре      |              |       |            | r          | w           |       |            |      |



# 3.3.3 In-Application Programming

In some applications, the Flash contents may need to be modified during program execution. In-Application Programming (IAP) is supported so that users can program or erase the Flash memory from their Flash user program by calling some special subroutines. The Flash subroutines will first perform some checks and an initialization sequence before starting the program or erase operation. A manual check on the Flash data is necessary to determine if the programming or erasing was successful via using the 'MOVC' instruction to read out the Flash contents. Other special subroutines include aborting the Flash erase operation and checking the Flash bank ready-to-read status.

## 3.3.3.1 Flash Programming

Each call of the Flash program subroutine allows the programming of 32 bytes of data into the selected wordline (WL) of the Flash bank. Before calling the Flash program subroutine, the user must ensure that required inputs (Table 14 and Table 15) are provided.

#### Flash Program Subroutine Type 1

If valid inputs have been set up, calling the subroutine begins flash programming. The subroutine exits and returns to the user code, while the target Flash bank is still in program mode, and is not accessible by user code.

The user code continues execution until the Flash NMI event is generated; bit FNMIFLASH in register NMISR is set, and if enabled via NMIFLASH, an NMI to the CPU is triggered to enter the Flash NMI service routine. At this point, the Flash bank is in ready-to-read mode.

| Subroutine | DFF6 <sub>H</sub> : FSM_PROG                                                                                                                                                |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input      | DPTR (DPH, DPL <sup>1)</sup> ): Flash WL address                                                                                                                            |
|            | R0 of Register Bank 3 (IRAM address 18 <sub>H</sub> ):<br>IRAM start address for 32-byte Flash data                                                                         |
|            | 32-byte Flash data                                                                                                                                                          |
|            | Flash NMI (NMICON.NMIFLASH) is enabled (1) or disabled (0)                                                                                                                  |
| Output     | PSW.CY:<br>0 = Flash programming is in progress<br>1 = Flash programming is not started<br>Flag FNMIFLASH will be set when Flash programming has<br>successfully completed. |
|            | DPTR is incremented by 20 <sub>H</sub> <sup>2)</sup>                                                                                                                        |

Table 14Flash Program Subroutin Type 1



#### Table 14Flash Program Subroutin Type 1 (cont'd)

| Stack size required | 12                                                                                                         |
|---------------------|------------------------------------------------------------------------------------------------------------|
| Resource used/      | ACC, B, SCU_PAGE                                                                                           |
| destroyed           | R0 – R7 of Register Bank 3 (IRAM address $18_H - 1F_H$ ) (8 bytes)<br>IRAM address $36_H - 3D_H$ (8 bytes) |

<sup>1)</sup> The last 5 LSB of the DPL is 0 for an aligned WL address, for e.g.  $00_{H}$ ,  $20_{H}$ ,  $40_{H}$ ,  $60_{H}$ ,  $80_{H}$ ,  $A_{0}$ ,  $C_{0}$  and  $E_{0}$ .

<sup>2)</sup> DPTR is only incremented by  $20_{\rm H}$  when PSW.CY is 0.

#### Flash Program Subroutine Type 2

This routine will wait until Flash programming is completed before the user code can continue its execution. Therefore, background programming is not supported. This type of routine can be used to program the Flash bank where the user code is in execution. The Flash cannot be in both program mode and read mode at the same time. It can also be used for programming the Flash bank where the interrupt vectors are defined as interrupts cannot be handled when the Flash is in program mode.

Note: For the Flash programming of XC864 device, Flash Program Subroutine Type 2 is allowed. The users can also use Flash Program Subroutine Type 1 if it is called from XRAM.

| Subroutine          | DFDB <sub>H</sub> : FSM_PROG_NO_BG                                                                                                                                                                                                       |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input               | DPTR (DPH, DPL <sup>1)</sup> ): Flash WL address                                                                                                                                                                                         |
|                     | R0 of Register Bank 3 (IRAM address 18 <sub>H</sub> ):<br>IRAM start address for 32-byte Flash data                                                                                                                                      |
|                     | 32-byte Flash data                                                                                                                                                                                                                       |
|                     | All interrupts including NMI must be disabled (0)<br>Set SFR NMISR = 00 <sub>H</sub>                                                                                                                                                     |
| Output              | PSW.CY:<br>0 = Flash programming is successful<br>1 = Flash programming is not successful due to: Flash<br>Protection Mode 1 is enabled, or NMI has occurred<br>Flag FNMIFLASH is cleared by this routine before return to user<br>code. |
|                     | DPTR is incremented by 20 <sub>H</sub> <sup>2)</sup>                                                                                                                                                                                     |
| Stack size required | 15                                                                                                                                                                                                                                       |

| Table 15 | Flash Program     | Subroutine | Type | 2 |
|----------|-------------------|------------|------|---|
|          | i lasti i logiani | Capicatine | JPC  | - |



#### 3.4.2 Interrupt Source and Vector

Each interrupt source has an associated interrupt vector address. This vector is accessed to service the corresponding interrupt source request. The interrupt service of each interrupt source can be individually enabled or disabled via an enable bit. The assignment of the XC864 interrupt sources to the interrupt vector addresses and the corresponding interrupt source enable bits are summarized in **Table 18**.

| Interrupt<br>Source | Vector<br>Address | Assignment for XC864                            | Enable Bit | SFR    |
|---------------------|-------------------|-------------------------------------------------|------------|--------|
| NMI                 | 0073 <sub>H</sub> | Watchdog Timer NMI                              | NMIWDT     | NMICON |
|                     |                   | PLL NMI                                         | NMIPLL     |        |
|                     |                   | Flash NMI                                       | NMIFLASH   |        |
|                     |                   | VDDC Prewarning NMI                             | NMIVDD     |        |
|                     |                   | VDDP Prewarning NMI                             | NMIVDDP    |        |
|                     |                   | Flash ECC NMI                                   | NMIECC     |        |
| XINTR0              | 0003 <sub>H</sub> | External Interrupt 0                            | EX0        | IEN0   |
| XINTR1              | 000B <sub>H</sub> | Timer 0                                         | ET0        |        |
| XINTR2              | 0013 <sub>H</sub> | External Interrupt 1                            | EX1        |        |
| XINTR3              | 001B <sub>H</sub> | Timer 1                                         | ET1        |        |
| XINTR4              | 0023 <sub>H</sub> | UART                                            | ES         |        |
| XINTR5              | 002B <sub>H</sub> | T2                                              | ET2        |        |
|                     |                   | Fractional Divider<br>(Normal Divider Overflow) |            |        |
|                     |                   | LIN                                             |            |        |
| XINTR6              | 0033 <sub>H</sub> | ADC                                             | EADC       | IEN1   |
| XINTR7              | 003B <sub>H</sub> | SSC                                             | ESSC       |        |
| XINTR8              | 0043 <sub>H</sub> | External Interrupt 2                            | EX2        |        |
| XINTR9              | 004B <sub>H</sub> | External Interrupt 3                            | EXM        |        |
| XINTR10             | 0053 <sub>H</sub> | CCU6 INP0                                       | ECCIP0     |        |
| XINTR11             | 005B <sub>H</sub> | CCU6 INP1                                       | ECCIP1     | ]      |
| XINTR12             | 0063 <sub>H</sub> | CCU6 INP2                                       | ECCIP2     |        |
| XINTR13             | 006B <sub>H</sub> | CCU6 INP3                                       | ECCIP3     | ]      |

#### Table 18 Interrupt Vector Addresses



## 3.6 Power Supply System with Embedded Voltage Regulator

The XC864 microcontroller requires two different levels of power supply:

- 5.0 V for the Embedded Voltage Regulator (EVR) and Ports
- 2.5 V for the core, memory, on-chip oscillator, and peripherals

**Figure 19** shows the XC864 power supply system. A power supply of 5.0 V must be provided from the external power supply pin. The 2.5 V power supply for the logic is generated by the EVR. The EVR helps to reduce the power consumption of the whole chip and the complexity of the application board design.

The EVR consists of a main voltage regulator and a low power voltage regulator. In active mode, both voltage regulators are enabled. In power-down mode, the main voltage regulator is switched off, while the low power voltage regulator continues to function and provide power supply to the system with low power consumption.



Figure 19 XC864 Power Supply System

#### **EVR Features:**

- Input voltage (V<sub>DDP</sub>): 5.0 V
- Output voltage ( $V_{DDC}$ ): 2.5 V ± 7.5%
- · Low power voltage regulator provided in power-down mode
- V<sub>DDC</sub> and V<sub>DDP</sub> prewarning detection
- V<sub>DDC</sub> brownout detection

If the WDT is not serviced before the timer overflow, a system malfunction is assumed. As a result, the WDT NMI is triggered (assert WDTTO) and the reset prewarning is entered. The prewarning period lasts for  $30_{\rm H}$  count, after which the system is reset (assert WDTRST).

The WDT has a "programmable window boundary" which disallows any refresh during the WDT's count-up. A refresh during this window boundary constitutes an invalid access to the WDT, causing the reset prewarning to be entered but without triggering the WDT NMI. The system will still be reset after the prewarning period is over. The window boundary is from  $0000_{\rm H}$  to the value obtained from the concatenation of WDTWINB and  $00_{\rm H}$ .

After being serviced, the WDT continues counting up from the value ( $\langle WDTREL \rangle * 2^8$ ). The time period for an overflow of the WDT is programmable in two ways:

- the input frequency to the WDT can be selected to be either  $f_{PCLK}/2$  or  $f_{PCLK}/128$
- the reload value WDTREL for the high byte of WDT can be programmed in register WDTREL

The period,  $P_{WDT}$ , between servicing the WDT and the next overflow can be determined by the following formula:

[4]

$$P_{WDT} = \frac{2^{(1 + WDTIN \times 6)} \times (2^{16} - WDTREL \times 2^8)}{f_{PCLK}}$$

If the Window-Boundary Refresh feature of the WDT is enabled, the period  $P_{WDT}$  between servicing the WDT and the next overflow is shortened if WDTWINB is greater than WDTREL, see Figure 26. This period can be calculated using the same formula by replacing WDTREL with WDTWINB. For this feature to be useful, WDTWINB should not be smaller than WDTREL.



XC864

#### 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 27.



#### Figure 27 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)



# 3.18.1 ADC Clocking Scheme

A common module clock  $f_{\mbox{ADC}}$  generates the various clock signals used by the analog and digital parts of the ADC module:

- f<sub>ADCA</sub> is input clock for the analog part.
- $f_{ADCI}$  is internal clock for the analog part (defines the time base for conversion length and the sample time). This clock is generated internally in the analog part, based on the input clock  $f_{ADCA}$  to generate a correct duty cycle for the analog components.
- f<sub>ADCD</sub> is input clock for the digital part.

The internal clock for the analog part  $f_{ADCI}$  is limited to a maximum frequency of 10 MHz. Therefore, the ADC clock prescaler must be programmed to a value that ensures  $f_{ADCI}$  does not exceed 10 MHz. The prescaler ratio is selected by bit field CTC in register GLOBCTR. A prescaling ratio of 32 can be selected when the maximum performance of the ADC is not required.



Figure 31 ADC Clocking Scheme

For module clock  $f_{ADC}$  = 26.7 MHz, the analog clock  $f_{ADCI}$  frequency can be selected as shown in **Table 30**.



### XC864

#### **Functional Description**

| Module Clock f <sub>ADC</sub> | СТС                       | Prescaling Ratio | Analog Clock f <sub>ADCI</sub> |  |  |  |  |  |  |
|-------------------------------|---------------------------|------------------|--------------------------------|--|--|--|--|--|--|
| 26.7 MHz                      | 00 <sub>B</sub>           | ÷2               | 13.3 MHz (N.A)                 |  |  |  |  |  |  |
|                               | 01 <sub>B</sub>           | ÷ 3              | 8.9 MHz                        |  |  |  |  |  |  |
|                               | 10 <sub>B</sub>           | ÷ 4              | 6.7 MHz                        |  |  |  |  |  |  |
|                               | 11 <sub>B</sub> (default) | ÷ 32             | 833.3 kHz                      |  |  |  |  |  |  |

#### Table 30f\_ADCIFrequency Selection

As  $f_{ADCI}$  cannot exceed 10 MHz, bit field CTC should not be set to  $00_B$  when  $f_{ADC}$  is 26.7 MHz. During slow-down mode where  $f_{ADC}$  may be reduced to 13.3 MHz, 6.7 MHz etc., CTC can be set to  $00_B$  as long as the divided analog clock  $f_{ADCI}$  does not exceed 10 MHz. However, it is important to note that the conversion error could increase due to loss of charges on the capacitors, if  $f_{ADC}$  becomes too low during slow-down mode.

## 3.18.2 ADC Conversion Sequence

The analog-to-digital conversion procedure consists of the following phases:

- Synchronization phase (t<sub>SYN</sub>)
- Sample phase (t<sub>S</sub>)
- Conversion phase
- Write result phase (t<sub>WR</sub>)



Figure 32 ADC Conversion Timing



#### 3.20 Chip Identification Number

The XC864 identity (ID) register is located at Page 1 of address  $B3_H$ . The value of ID register is  $1B_H$ . However, for easy identification of product variants, the Chip Identification Number, which is an unique number assigned to each product variant, is available. The differentiation is based on the product, variant type and device step information.

The Chip Identification Numbers associated with XC864 are  $1B810C00_{\rm H}$  for 5V device and  $1B010C00_{\rm H}$  for 3.3V device.

Two methods are provided to read a device's Chip Identification Number:

- In-application subroutine, GET\_CHIP\_INFO
- Bootstrap loader (BSL) mode A



#### 4.2 DC Parameters

# 4.2.1 Input/Output Characteristics

### Table 33 Input/Output Characteristics (Operating Conditions apply)

| Parameter                                                      | Symbol            |      | Limit Values              |                             | Unit | Test Conditions          |  |
|----------------------------------------------------------------|-------------------|------|---------------------------|-----------------------------|------|--------------------------|--|
|                                                                |                   |      | min.                      | max.                        |      |                          |  |
| V <sub>DDP</sub> = 5V Range                                    |                   |      |                           | •                           | 1    |                          |  |
| Output low voltage                                             | $V_{OL}$          | CC   | _                         | 1.0                         | V    | I <sub>OL</sub> = 15 mA  |  |
|                                                                |                   |      | —                         | 0.4                         | V    | I <sub>OL</sub> = 5 mA   |  |
| Output high voltage                                            | V <sub>OH</sub>   | CC   | V <sub>DDP</sub> -<br>1.0 | -                           | V    | I <sub>OH</sub> = -15 mA |  |
|                                                                |                   |      | V <sub>DDP</sub> -<br>0.4 | -                           | V    | I <sub>OH</sub> = -5 mA  |  |
| Input low voltage on<br>port pins<br>(all except P0.0 & P0.1)  | V <sub>ILP</sub>  | SR   | -                         | $0.3 \times V_{\text{DDP}}$ | V    | CMOS Mode                |  |
| Input low voltage on<br>P0.0 & P0.1                            | V <sub>ILP0</sub> | SR   | -0.2                      | $0.3 \times V_{\text{DDP}}$ | V    | CMOS Mode                |  |
| Input low voltage on<br>RESET pin                              | $V_{ILR}$         | SR   | -                         | $0.3 \times V_{\text{DDP}}$ | V    | CMOS Mode                |  |
| Input low voltage on<br>TMS pin                                | V <sub>ILT</sub>  | SR   | -                         | $0.3 	imes V_{ m DDP}$      | V    | CMOS Mode                |  |
| Input high voltage on<br>port pins<br>(all except P0.0 & P0.1) | V <sub>IHP</sub>  | SR   | $0.7 \times V_{ m DDP}$   | _                           | V    | CMOS Mode                |  |
| Input high voltage on P0.0 & P0.1                              | VIHPO             | ) SR | $0.7 \times V_{ m DDP}$   | V <sub>DDP</sub>            | V    | CMOS Mode                |  |
| Input high voltage on RESET pin                                | V <sub>IHR</sub>  | SR   | $0.7 \times V_{ m DDP}$   | -                           | V    | CMOS Mode                |  |
| Input high voltage on TMS pin                                  | V <sub>IHT</sub>  | SR   | $0.7 	imes V_{ m DDP}$    | -                           | V    | CMOS Mode                |  |
| Input Hysteresis <sup>1)</sup>                                 | HYS               | CC   | $0.08 \times V_{ m DDP}$  | -                           | V    | CMOS Mode                |  |
| Pull-up current <sup>2)</sup>                                  | I <sub>PU</sub>   | SR   | _                         | -10                         | μA   | V <sub>IH,min</sub>      |  |
|                                                                |                   |      | -150                      | _                           | μA   | V <sub>IL,max</sub>      |  |



#### Table 33 Input/Output Characteristics (Operating Conditions apply)

| Parameter                             | Symbol                   | Limit Values |      | Unit | Test Conditions |
|---------------------------------------|--------------------------|--------------|------|------|-----------------|
|                                       |                          | min.         | max. |      |                 |
| Maximum current into $V_{\text{DDP}}$ | I <sub>MVDDP</sub><br>SR | -            | 80   | mA   |                 |
| Maximum current out of $V_{\rm SS}$   | I <sub>MVSS</sub> SR     | _            | 80   | mA   |                 |

<sup>1)</sup> Not subjected to production test, verified by design/characterization. Hysteresis is implemented to avoid meta stable states and switching due to internal ground bounce. It cannot be guaranteed that it suppresses switching due to external system noise.

<sup>2)</sup> Single pull device is enabled for the measurement of P0.0/P1.0.

<sup>3)</sup> <u>An additional error current (*I*<sub>INJ</sub>) will flow if an overload current flows through an adjacent pin. TMS pin and RESET pin have internal pull devices and are not included in the input leakage current characteristic.
 <sup>4)</sup> Not subjected to production test, verified by design/characterization.
</u>

<sup>5)</sup> Not subjected to production test, verified by design/characterization. However, for applications with strict low power-down current requirements, it is mandatory that no active voltage source is supplied at any GPIO pin when  $V_{\text{DDP}}$  is powered off.



#### Table 35ADC Characteristics (Operating Conditions apply; $V_{DDP}$ = 5V Range)

| Parameter                                                  | Symbol                      | Limit Values |       |      | Unit | Test Conditions/ |  |  |
|------------------------------------------------------------|-----------------------------|--------------|-------|------|------|------------------|--|--|
|                                                            |                             | min.         | typ . | max. |      | Remarks          |  |  |
| Switched<br>capacitance at the<br>analog voltage<br>inputs | C <sub>AINSW</sub><br>CC    | _            | 5     | 7    | рF   | 2)4)             |  |  |
| Input resistance of the reference input                    | <i>R</i> <sub>AREF</sub> CC | -            | 1     | 2    | kΩ   | 2)               |  |  |
| Input resistance of the selected analog channel            | R <sub>AIN</sub> CC         | _            | 1     | 1.5  | kΩ   | 2)               |  |  |

<sup>1)</sup> TUE is tested at  $V_{AREF}$  = 5.0 V,  $V_{AGND}$  = 0 V,  $V_{DDP}$  = 5.0 V.

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

<sup>&</sup>lt;sup>3)</sup> This represents an equivalent switched capacitance. This capacitance is not switched to the reference voltage at once. Instead of this, smaller capacitances are successively switched to the reference voltage.

<sup>&</sup>lt;sup>4)</sup> The sampling capacity of the conversion C-Network is pre-charged to  $V_{AREF}/2$  before connecting the input to the C-Network. Because of the parasitic elements, the voltage measured at ANx is lower than  $V_{AREF}/2$ .



# Table 38Power Supply Current Parameters (Operating Conditions apply; $V_{\text{DDP}}$ = 3.3V range)

| Parameter                          | Symbol           | Limit Values       |                    | Unit | <b>Test Condition</b> |
|------------------------------------|------------------|--------------------|--------------------|------|-----------------------|
|                                    |                  | typ. <sup>1)</sup> | max. <sup>2)</sup> |      |                       |
| V <sub>DDP</sub> = 3.3V Range      | ·                |                    |                    |      |                       |
| Active Mode                        | I <sub>DDP</sub> | 21.6               | 23.3               | mA   | 3)                    |
| Idle Mode                          | I <sub>DDP</sub> | 12                 | 13.5               | mA   | 4)                    |
| Active Mode with slow-down enabled | I <sub>DDP</sub> | 5.7                | 7.3                | mA   | 5)                    |
| Idle Mode with slow-down enabled   | I <sub>DDP</sub> | 5.4                | 6.9                | mA   | 6)                    |

<sup>1)</sup> The typical  $I_{\text{DDP}}$  values are periodically measured at  $T_{\text{A}}$  = + 25 °C and  $V_{\text{DDP}}$  = 3.3 V.

<sup>2)</sup> The maximum  $I_{\text{DDP}}$  values are measured under worst case conditions ( $T_{\text{A}}$  = + 125 °C and  $V_{\text{DDP}}$  = 3.6 V).

<sup>3)</sup> I<sub>DDP</sub> (active mode) is measured with: CPU clock and input clock to all peripherals running at 26.7 MHz (set by on-chip oscillator of 10 MHz and NDIV in PLL\_CON to 0010<sub>B</sub>), RESET =  $V_{DDP}$ , no load on ports.

<sup>4)</sup> I<sub>DDP</sub> (idle mode) is measured with: <u>CPU clock disabled</u>, watchdog timer disabled, input clock to all peripherals enabled and running at 26.7 MHz, RESET = V<sub>DDP</sub>, no load on ports.

<sup>5)</sup> I<sub>DDP</sub> (active mode with slow-down mode) is measured with: CPU clock and input clock to all peripherals running at 833 KHz by setting CLKREL in CMCON to 0101<sub>B</sub>, RESET = V<sub>DDP</sub>, no load on ports.

<sup>6)</sup> I<sub>DDP</sub> (idle mode with slow-down mode) is measured with: CPU clock disabled, watchdog timer disabled, input <u>clock to all peripherals enable and running at 833 KHz by setting CLKREL in CMCON to 0101<sub>B</sub>, RESET = V<sub>DDP</sub>, no load on ports.</u>

# Table 39Power Down Current (Operating Conditions apply; $V_{DDP} = 3.3V$ <br/>range )

| Parameter | Symbol | Limit Values       |                    | Unit | <b>Test Condition</b> |
|-----------|--------|--------------------|--------------------|------|-----------------------|
|           |        | typ. <sup>1)</sup> | max. <sup>2)</sup> |      |                       |
|           |        |                    |                    |      |                       |

 $V_{\text{DDP}}$  = 3.3V Range

| Power-Down Mode <sup>3)</sup> | I <sub>PDP</sub> | 1 | 10 | μA | $T_{A} = + 25  {}^{\circ}\text{C.}^{4)}$ |
|-------------------------------|------------------|---|----|----|------------------------------------------|
|                               |                  | - | 35 | μA | $T_{A} = + 85 \circ C.^{(4)5)}$          |

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

<sup>2)</sup> The maximum  $I_{PDP}$  values are measured at  $V_{DDP}$  = 3.6 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.



## 4.3.5 JTAG Timing

# Table 43TCK Clock Timing (Operating Conditions apply; $C_L = 50 \text{ pF}$ )

| Parameter           | Symbol              | Lir | Unit |    |
|---------------------|---------------------|-----|------|----|
|                     |                     | min | max  |    |
| TCK clock period    | t <sub>TCK</sub> SR | 50  | _    | ns |
| TCK high time       | t <sub>1</sub> SR   | 20  | —    | ns |
| TCK low time        | t <sub>2</sub> SR   | 20  | _    | ns |
| TCK clock rise time | t <sub>3</sub> SR   | -   | 4    | ns |
| TCK clock fall time | t <sub>4</sub> SR   | -   | 4    | ns |



Figure 41 TCK Clock Timing