

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             | Active                                                                                  |
|----------------------------|-----------------------------------------------------------------------------------------|
| Core Processor             | ARM® Cortex®-M0                                                                         |
| Core Size                  | 32-Bit Single-Core                                                                      |
| Speed                      | 60MHz                                                                                   |
| Connectivity               | I <sup>2</sup> C, IrDA, SPI, UART/USART, USB                                            |
| Peripherals                | Brown-out Detect/Reset, DMA, I <sup>2</sup> S, LVD, POR, PS2, WDT                       |
| Number of I/O              | 18                                                                                      |
| Program Memory Size        | 32KB (32K x 8)                                                                          |
| Program Memory Type        | FLASH                                                                                   |
| EEPROM Size                | -                                                                                       |
| RAM Size                   | 4K x 8                                                                                  |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 5.5V                                                                             |
| Data Converters            | -                                                                                       |
| Oscillator Type            | Internal                                                                                |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                                       |
| Mounting Type              | Surface Mount                                                                           |
| Package / Case             | 32-WFQFN Exposed Pad                                                                    |
| Supplier Device Package    | -                                                                                       |
| Purchase URL               | https://www.e-xfl.com/product-detail/nuvoton-technology-corporation-america/nuc122zc1an |
|                            |                                                                                         |

Email: info@E-XFL.COM

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

### 3.2.3 NuMicro<sup>™</sup> NUC122 QFN 33-pin



Figure 3-3 NuMicro<sup>™</sup> NUC122 QFN 33-pin Pin Diagram

# nuvoTon

| Pin No.    |                           |            |          |                                          |                                                                 |  |
|------------|---------------------------|------------|----------|------------------------------------------|-----------------------------------------------------------------|--|
| LQFP<br>64 | LQFP<br>48                | QFN<br>33  | Pin Name | Pin Type                                 | Description                                                     |  |
|            | 26 27 10 PC.11 <b>I/O</b> |            | I/O      | General purpose input/output digital pin |                                                                 |  |
| 36         | 27                        | 19         | MOSI10   | 0                                        | MOSI10: SPI1 MOSI (Master Out, Slave In) pin                    |  |
| 07         |                           |            | PC.10    | I/O                                      | General purpose input/output digital pin                        |  |
| 37         | 28                        | 20         | MISO10   | I                                        | MISO10: SPI1 MISO (Master In, Slave Out) pin                    |  |
| 38         |                           |            | VDD      | Р                                        | Power supply for I/O ports                                      |  |
|            |                           |            | PC.9     | I/O                                      | General purpose input/output digital pin                        |  |
| 39         | 29                        | 21         | SPICLK1  | I/O                                      | SPICLK1: SPI1 serial clock pin                                  |  |
|            |                           |            | PC.8     | I/O                                      | General purpose input/output digital pin                        |  |
| 40         | 30                        | 22         | SPISS10  | I/O                                      | SPISS10: SPI1 slave select pin                                  |  |
|            |                           |            | PA.15    | I/O                                      | General purpose input/output digital pin                        |  |
| 41         | 31                        |            | PWM3     | 0                                        | PWM3: PWM output pin                                            |  |
| 42         |                           |            | VSS      | Р                                        | Ground                                                          |  |
| 40         |                           |            | PA.14    | I/O                                      | General purpose input/output digital pin                        |  |
| 43         | 32                        |            | PWM2     | 0                                        | PWM2: PWM output pin                                            |  |
|            | 33                        |            | PA.13    | I/O                                      | General purpose input/output digital pin                        |  |
| 44         |                           | J <b>J</b> | PWM1     | 0                                        | PWM1: PWM output pin                                            |  |
|            |                           |            | PA.12    | I/O                                      | General purpose input/output digital pin                        |  |
| 45         | 34                        |            | PWM0     | 0                                        | PWM0: PWM output pin                                            |  |
| 46         | 35                        | 23         | ICE_DAT  | I/O                                      | Serial Wired Debugger Data pin                                  |  |
| 47         | 36                        | 24         | ICE_CK   | I                                        | Serial Wired Debugger Clock pin                                 |  |
| 48         | 37                        | 25         | AVDD     | AP                                       | Power supply for internal analog circuit                        |  |
| 49         | 38                        |            | PD.0     | I/O                                      | General purpose input/output digital pin                        |  |
| KD         | 255                       |            | PD.1     | I/O                                      | General purpose input/output digital pin                        |  |
| 50         | 39                        | 26         | SPISS01  | I/O                                      | SPISS01: SPI0 2 <sup>nd</sup> slave select pin (for QFN33 only) |  |
| 51         | 40                        | 27         | PD.2     | I/O                                      | General purpose input/output digital pin                        |  |
| 52         | 41                        | 28         | PD.3     | I/O                                      | General purpose input/output digital pin                        |  |
| 53         | 42                        | 25         | PD.4     | I/O                                      | General purpose input/output digital pin                        |  |
| 54         | 43                        | 6          | PD.5     | I/O                                      | General purpose input/output digital pin                        |  |
| 55         |                           | 100        | PB.15    | I/O                                      | General purpose input/output digital pin                        |  |

## nuvoTon

|            | Pin No.    |           |          |          |                                                                                                        |
|------------|------------|-----------|----------|----------|--------------------------------------------------------------------------------------------------------|
| LQFP<br>64 | LQFP<br>48 | QFN<br>33 | Pin Name | Pin Type | Description                                                                                            |
|            |            |           | /INT1    | 19       | /INT1: External interrupt 1 input pin                                                                  |
| 56         | 44         | 29        | XT1_OUT  | 0        | Crystal output pin                                                                                     |
| 57         | 45         | 30        | XT1_IN   | I        | Crystal input pin                                                                                      |
| 58         | 46         | 31        | /RESET   | I        | External reset input: Low active, set this pin low reset chip to initial state. With internal pull-up. |
| 59         |            | 33        | VSS      | Р        | Ground                                                                                                 |
| 60         |            |           | VDD      | Р        | Power supply for I/O ports                                                                             |
| 61         | 47         |           | PS2DAT   | I/O      | PS/2 data pin                                                                                          |
| 62         | 48         |           | PS2CLK   | I/O      | PS/2 clock pin                                                                                         |
| 63         | 1          | 32        | PVSS     | Р        | PLL Ground                                                                                             |
| 64         |            |           | PB.8     | I/O      | General purpose input/output digital pin                                                               |
| 64         |            |           | ТМО      | 0        | TM0: Timer0 external counter input                                                                     |

Note: Pin Type I=Digital Input, O=Digital Output; AI=Analog Input; P=Power Pin; AP=Analog Power

Jan. 09, 2015

Page 17 of 66

Revision 1.11

#### 4 **BLOCK DIAGRAM**

#### NuMicro<sup>™</sup> NUC122 Block Diagram 4.1



Figure 4-1 NuMicro<sup>™</sup> NUC122 Block Diagram

### nuvoTon

### 5.2 System Manager

#### 5.2.1 Overview

System management includes these following sections:

- System Resets
- System Memory Map
- System management registers for Part Number ID, chip reset and on-chip controllers reset, multi-functional pin control
- System Timer (SysTick)
- Nested Vectored Interrupt Controller (NVIC)
- System Control registers

#### 5.2.2 System Reset

The system reset can be issued by one of the below listed events. These reset event flags can be read from RSTSRC register.

- The Power-On Reset
- The low level on the /RESET pin
- Watchdog Timer Time-Out Reset
- Low Voltage Reset
- Brownout Detector Reset
- Cortex<sup>®</sup>-M0 Reset
- System Reset

Both System Reset and Power-On Reset can reset the whole chip including all peripherals. The difference between System Reset and Power-On Reset is external Crystal circuit and ISPCON.BS bit. System Reset doesn't reset external Crystal circuit and ISPCON.BS bit, but Power-On Reset does.

#### 5.2.3 System Power Distribution

In this chip, the power distribution is divided into three segments.

- Analog power from AVDD and AVSS provides the power for analog components operation.
- Digital power from VDD and VSS supplies the power to the internal regulator which provides a fixed 1.8 V power for digital operation and I/O pins.
- USB transceiver power from VBUS offers the power for operating the USB transceiver.

The outputs of internal voltage regulators, LDO and VDD33, require an external capacitor which should be located close to the corresponding pin. Analog power (AVDD) should be the same voltage level of the digital power (VDD). The following diagram shows the power distribution of this chip.



Figure 5-2 NuMicro<sup>™</sup> NUC122 Power Distribution Diagram

#### 5.2.5 Nested Vectored Interrupt Controller (NVIC)

Cortex<sup>®</sup>-M0 provides an interrupt controller as an integral part of the exception mode, named as "Nested Vectored Interrupt Controller (NVIC)". It is closely coupled to the processor kernel and provides following features:

- Nested and Vectored interrupt support
- Automatic processor state saving and restoration
- Dynamic priority changing
- Reduced and deterministic interrupt latency

The NVIC prioritizes and handles all supported exceptions. All exceptions are handled in "Handler Mode". This NVIC architecture supports 32 (IRQ[31:0]) discrete interrupts with 4 levels of priority. All of the interrupts and most of the system exceptions can be configured to different priority levels. When an interrupt occurs, the NVIC will compare the priority of the new interrupt to the current running one's priority. If the priority of the new interrupt is higher than the current one, the new interrupt handler will override the current handler.

When any interrupts is accepted, the starting address of the interrupt service routine (ISR) is fetched from a vector table in memory. There is no need to determine which interrupt is accepted and branch to the starting address of the correlated ISR by software. While the starting address is fetched, NVIC will also automatically save processor state including the registers "PC, PSR, LR, R0~R3, R12" to the stack. At the end of the ISR, the NVIC will restore the mentioned registers from stack and resume the normal execution. Thus it will take less and deterministic time to process the interrupt request.

The NVIC supports "Tail Chaining" which handles back-to-back interrupts efficiently without the overhead of states saving and restoration and therefore reduces delay time in switching to pending ISR at the end of current ISR. The NVIC also supports "Late Arrival" which improves the efficiency of concurrent ISRs. When a higher priority interrupt request occurs before the current ISR starts to execute (at the stage of state saving and starting address fetching), the NVIC will give priority to the higher one without delay penalty. Thus it advances the real-time capability.

For more detailed information, please refer to the documents "ARM<sup>®</sup> Cortex<sup>®</sup>-M0 Technical Reference Manual" and "ARM<sup>®</sup> v6-M Architecture Reference Manual".

## nuvoTon

| 28       | 12  | Reserved       | Reserved          | Reserved                     |  |  |
|----------|-----|----------------|-------------------|------------------------------|--|--|
| 29       | 13  | UART1_INT      | UART1             | UART1 interrupt              |  |  |
| 30       | 13  | SPI0_INT       | SPIO              | SPI0 interrupt               |  |  |
|          |     |                | - 0               |                              |  |  |
| 31       | 15  | SPI1_INT       | SPI1              | SPI1 interrupt               |  |  |
| 32       | 16  | Reserved       | Reserved          | Reserved                     |  |  |
| 33       | 17  | Reserved       | Reserved          | Reserved                     |  |  |
| 34       | 18  | Reserved       | Reserved          | Reserved                     |  |  |
| 35       | 19  | I2C1_INT       | I <sup>2</sup> C1 | I <sup>2</sup> C1 interrupt  |  |  |
| 36       | 20  | Reserved       | Reserved          | Reserved                     |  |  |
| 37       | 21  | Reserved       | Reserved          | Reserved                     |  |  |
| 38       | 22  | Reserved       | Reserved          | Reserved                     |  |  |
| 39       | 23  | USB_INT        | USBD              | USB 2.0 FS Device interrupt  |  |  |
| 40       | 24  | PS2_INT        | PS/2              | PS/2 interrupt               |  |  |
| 41       | 25  | Reserved       | Reserved          | Reserved                     |  |  |
| 42       | 26  | Reserved       | Reserved          | Reserved                     |  |  |
| 43       | 27  | Reserved       | Reserved          | Reserved                     |  |  |
| 44       | 28  | PWRWU_INT CLKC |                   | Power Down Wake-up interrupt |  |  |
| 45       | 29  | Reserved       | Reserved          | Reserved                     |  |  |
| 46       | 30  | Reserved       | Reserved          | Reserved                     |  |  |
| 47       | 31  | RTC_INT        | RTC               | Real time clock interrupt    |  |  |
|          |     |                |                   | Interrupt Map                |  |  |
|          |     |                |                   |                              |  |  |
| lon 00 2 | 045 |                | Dama 20           | of <b>66</b> Povision 1.1    |  |  |

#### 5.2.5.2 Vector Table

When any interrupts is accepted, the processor will automatically fetch the starting address of the interrupt service routine (ISR) from a vector table in memory. For ARM<sup>®</sup> v6-M, the vector table base address is fixed at 0x00000000. The vector table contains the initialization value for the stack pointer on reset, and the entry point addresses for all exception handlers. The vector number on previous page defines the order of entries in the vector table associated with exception handler entry as illustrated in previous section.

| Vector Table Word Offset | Description                                      |
|--------------------------|--------------------------------------------------|
| 0                        | SP_main – The Main stack pointer                 |
| Vector Number            | Exception Entry Pointer using that Vector Number |

Table 5-3 Vector Table Format

#### 5.2.5.3 Operation Description

NVIC interrupts can be enabled and disabled by writing to their corresponding Interrupt Set-Enable or Interrupt Clear-Enable register bit-field. The registers use a write-1-to-enable and write-1-to-clear policy, both registers reading back the current enabled state of the corresponding interrupts. When an interrupt is disabled, interrupt assertion will cause the interrupt to become Pending, however, the interrupt will not activate. If an interrupt is Active when it is disabled, it remains in its Active state until cleared by reset or an exception return. Clearing the enable bit prevents new activations of the associated interrupt.

NVIC interrupts can be pended/un-pended using a complementary pair of registers to those used to enable/disable the interrupts, named the Set-Pending Register and Clear-Pending Register respectively. The registers use a write-1-to-enable and write-1-to-clear policy, both registers reading back the current pended state of the corresponding interrupts. The Clear-Pending Register has no effect on the execution status of an Active interrupt.

NVIC interrupts are prioritized by updating an 8-bit field within a 32-bit register (each register supporting four interrupts).

The general registers associated with the NVIC are all accessible from a block of memory in the System Control Space and will be described in next section.

### 5.3.3 System Clock & SysTick Clock

The system clock has 5 clock sources which were generated from clock generator block. The clock source switch depends on the register HCLK\_S (CLKSEL0[2:0]). The block diagram is listed below.



Figure 5-5 System Clock Block Diagram

The clock source of SysTick in Cortex<sup>®</sup>-M0 core can use CPU clock or external clock (SYST\_CSR[2]). If using external clock, the SysTick clock (STCLK) has 5 clock sources. The clock source switch depends on the setting of the register STCLK\_S (CLKSEL0[5:3]. The block diagram is listed below.



Figure 5-6 SysTick Clock Control Block Diagram

### 5.8 Watchdog Timer (WDT)

The purpose of Watchdog Timer is to perform a system reset when system runs into an unknown state. This prevents system from hanging for an infinite period of time. Besides, this Watchdog Timer supports another function to wake-up chip from power down mode. The Watchdog Timer includes an 18-bit free running counter with programmable time-out intervals. Table 5-4 show the Watchdog Timer time-out interval selection and Figure 5-10 shows the timing of Watchdog interrupt signal and reset signal.

Setting WTE (WDTCR [7]) enables the watchdog timer and the WDT counter starts counting up. When the counter reaches the selected time-out interval, Watchdog timer interrupt flag WTIF will be set immediately to request a WDT interrupt if the watchdog timer interrupt enable bit WTIE is set, in the meanwhile, a specified delay time (1024 \* T<sub>WDT</sub>) follows the time-out event. User must set WTR (WDTCR [0]) (Watchdog timer reset) high to reset the 18-bit WDT counter to avoid chip from Watchdog timer reset before the delay time expires. WTR bit is cleared automatically by hardware after WDT counter is reset. There are eight time-out intervals with specific delay time which are selected by Watchdog timer interval select bits WTIS (WDTCR [10:8]). If the WDT counter has not been cleared after the specific delay time expires, the watchdog timer will set Watchdog Timer Reset Flag (WTRF) high and reset chip. This reset will last 63 WDT clocks (T<sub>RST</sub>) then chip restarts executing program from reset vector (0x0000\_0000). WTRF will not be cleared by Watchdog reset. User may poll WTRF by software to recognize the reset source. WDT also provides wake-up function. When chip is powered down and the Watchdog Timer Wake-up Function Enable bit (WDTR[4]) is set, if the WDT counter reaches the specific time interval defined by WTIS (WDTCR [10:8]), the chip is wokenup from power down state. First example, if WTIS is set as 000, the specific time interval for chip to be woken-up from power down state is  $2^4 * T_{WDT}$ . When power down command is set by software, then, chip enters power down state. After  $2^4 * T_{WDT}$  time is elapsed, chip is woken-up from power down state. Second example, if WTIS (WDTCR [10:8]) is set as 111, the specific time interval for chip to be woken-up from power down state is  $2^{18} * T_{WDT}$ . If power down command is set by software, then, chip enters power down state. After  $2^{18} * T_{WDT}$  time is elapsed, chip is woken-up from power down state. Notice if WTRE (WDTCR [1]) is set to 1, after chip is woken-up, software should clear the Watchdog Timer counter by setting WTR(WDTCR [0]) to 1 as soon as possible. Otherwise, if the Watchdog Timer counter is not cleared by setting WTR (WDTCR [0]) to 1 before time starting from waking up to software clearing Watchdog Timer counter is over 1024 \* T<sub>WDT</sub> , the chip is reset by Watchdog Timer.

| WTIS | Time-out Interval<br>Selection<br>T <sub>TIS</sub> | Interrupt Period<br>T <sub>INT</sub> | WTR Time-out Interval<br>(WDT_CLK=10 KHz)<br>Min. T <sub>WTR</sub> ~ Max. T <sub>WTR</sub> |
|------|----------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------|
| 000  | 2 <sup>4</sup> * T <sub>WDT</sub>                  | 1024 * T <sub>WDT</sub>              | 1.6 ms ~ 104 ms                                                                            |
| 001  | 2 <sup>6</sup> * T <sub>WDT</sub>                  | 1024 * T <sub>WDT</sub>              | 6.4 ms ~ 108.8 ms                                                                          |
| 010  | 2 <sup>8</sup> * T <sub>WDT</sub>                  | 1024 * T <sub>WDT</sub>              | 25.6 ms ~ 128 ms                                                                           |
| 011  | 2 <sup>10</sup> * T <sub>WDT</sub>                 | 1024 * T <sub>WDT</sub>              | 102.4 ms ~ 204.8 ms                                                                        |
| 100  | 2 <sup>12</sup> * T <sub>WDT</sub>                 | 1024 * T <sub>WDT</sub>              | 409.6 ms ~ 512 ms                                                                          |
| 101  | 2 <sup>14</sup> * T <sub>WDT</sub>                 | 1024 * T <sub>WDT</sub>              | 1.6384 s ~ 1.7408 s                                                                        |
| 110  | 2 <sup>16</sup> * T <sub>WDT</sub>                 | 1024 * T <sub>WDT</sub>              | 6.5536 s ~ 6.656 s                                                                         |
| 111  | 2 <sup>18</sup> * T <sub>WDT</sub>                 | 1024 * T <sub>WDT</sub>              | 26.2144 s ~ 26.3168 s                                                                      |

Table 5-4 Watchdog Timer Time-out Interval Selection

### nuvoton

### 5.10 UART Interface Controller (UART)

NuMicro<sup>™</sup> NUC122 provides two channels of Universal Asynchronous Receiver/Transmitters (UART0/1). Both of UART0 and UART1 perform Normal Speed UART, besides, UART0 and UART1 also support flow control function.

#### 5.10.1 Overview

The Universal Asynchronous Receiver/Transmitter (UART0/1) performs a serial-to-parallel conversion on data received from the peripheral, and a parallel-to-serial conversion on data transmitted from the CPU. The UART controller also supports IrDA SIR Function and RS-485 mode functions. Each UART channel supports seven types of interrupts including transmitter FIFO empty interrupt (INT\_THRE), receiver threshold level reaching interrupt (INT RDA), line status interrupt (parity error or framing error or break interrupt) (INT RLS), receiver buffer time-out interrupt (INT TOUT), MODEM/Wake-Up status interrupt (INT MODEM), Buffer error interrupt (INT BUF ERR). Interrupt number 13 (vector number is 29) supports UART0/1 interrupt. Refer to Nested Vectored Interrupt Controller chapter for System Interrupt Map.

The UART0/1 are equipped 14-byte transmitter FIFO (TX\_FIFO) and 14-byte receiver FIFO (RX FIFO). The CPU can read the status of the UART at any time during the operation. The reported status information includes the type and condition of the transfer operations being performed by the UART, as well as 4 error conditions (parity error, framing error, break interrupt and buffer error) probably occur while receiving data. The UART includes a programmable baud rate generator that is capable of dividing clock input by divisors to produce the serial clock that transmitter and receiver need. The baud rate equation is Baud Rate = UART\_CLK / M \* [BRD + 2], where M and BRD are defined in Baud Rate Divider Register (UA BAUD). Below table lists the equations in the various conditions and the UART baud rate setting table.

| Mode | DIV_X_EN | DIV_X_ONE | Divider X  | BRD | Baud rate equation                       |
|------|----------|-----------|------------|-----|------------------------------------------|
| 0    | 0        | 0         | В          | A   | UART_CLK / [16 * (A+2)]                  |
| 1    | 1        | 0         | В          | A   | UART_CLK / [(B+1) * (A+2)] , B must >= 8 |
| 2    | 1        | 1         | Don't care | A   | UART_CLK / (A+2), A must >=3             |

|       | 2        | 1 | 1         | Don't care    | A                | UART_C     | CLK / (A+2), A |
|-------|----------|---|-----------|---------------|------------------|------------|----------------|
| and a | <u>.</u> |   | Table     | e 5-5 UART I  | Baud Ra          | te Equat   | ion            |
|       |          |   | Syste     | m clock = 22. | 1184 MH:         | z high spe | eed            |
|       |          |   | Baud rate | Mode0         | Mode             | e1         | Mode2          |
|       |          |   | 921600    | х             | A=0,B            | =11        | A=22           |
|       |          |   | 460800    | A=1           | A=1,B<br>A=2,B   |            | A=46           |
|       |          |   | 230400    | A=4           | A=4,B<br>A=6,B   |            | A=94           |
|       |          |   | 115200    | A=10          | A=10,E<br>A=14,E |            | A=190          |
|       |          |   | 57600     | A=22          | A=22,E<br>A=30,E |            | A=382          |

### 5.11 PS/2 Device Controller (PS2D)

#### 5.11.1 Overview

PS/2 device controller provides basic timing control for PS/2 communication. All communication between the device and the host is managed through the CLK and DATA pins. Unlike PS/2 keyboard or mouse device controller, the received/transmit code needs to be translated as meaningful code by firmware. The device controller generates the CLK signal after receiving a request to send, but host has ultimate control over communication. DATA sent from the host to the device is read on the rising edge and DATA sent from device to the host is change after rising edge. A 16 bytes FIFO is used to reduce CPU intervention. S/W can select 1 to 16 bytes for a continuous transmission.

#### 5.11.2 Features

- Host communication inhibit and request to send detection
- Reception frame error detection
- Programmable 1 to 16 bytes transmit buffer to reduce CPU intervention
- Double buffer for data reception
- S/W override bus

### 5.13 Serial Peripheral Interface (SPI)

#### 5.13.1 Overview

The Serial Peripheral Interface (SPI) is a synchronous serial data communication protocol which operates in full duplex mode. Devices communicate in master/slave mode with 4-wire bi-direction interface. The NuMicro<sup>™</sup> NUC122 contains up to two sets of SPI controller performing a serial-to-parallel conversion on data received from a peripheral device, and a parallel-to-serial conversion on data transmitted to a peripheral device. Each set of SPI controller can be set as a master that can drive up to 2 external peripheral slave devices; it also can be configured as a slave device controlled by an off-chip master device.

This controller also supports a variable serial clock for special application.

#### 5.13.2 Features

- Up to two sets of SPI controller for NuMicro<sup>™</sup> NUC122
- Support master or slave mode operation
- Support 1-bit transfer mode
- Configurable bit length up to 32 bits of a transfer word and configurable word numbers up to 2 of a transaction, so the maximum bit length is 64 bits for each data transfer
- Provide burst mode operation, transmit/receive can be transferred up to two times word transaction in one transfer
- Support MSB or LSB first transfer
- 2 device/slave select lines in master mode, but 1 device/slave select line in slave mode
- Support byte reorder in data register
- Support byte or word suspend mode
- Variable output serial clock frequency in master mode
- Support two programmable serial clock frequencies in master mode

### 6 ELECTRICAL CHARACTERISTICS

### 6.1 Absolute Maximum Ratings

| SYMBOL                                    | PARAMETER           | MIN.    | MAX.    | UNIT |
|-------------------------------------------|---------------------|---------|---------|------|
| DC Power Supply                           | VDD-VSS             | -0.3    | +7.0    | V    |
| Input Voltage                             | VIN                 | VSS-0.3 | VDD+0.3 | V    |
| Oscillator Frequency                      | 1/t <sub>CLCL</sub> | 4       | 24      | MHz  |
| Operating Temperature                     | ТА                  | -40     | +85     | °C   |
| Storage Temperature                       | TST                 | -55     | +150    | °C   |
| Maximum Current into VDD                  |                     | -       | 120     | mA   |
| Maximum Current out of VSS                |                     |         | 120     | mA   |
| Maximum Current sunk by a I/O pin         |                     |         | 35      | mA   |
| Maximum Current sourced by a I/O pin      |                     |         | 35      | mA   |
| Maximum Current sunk by total I/O pins    |                     |         | 100     | mA   |
| Maximum Current sourced by total I/O pins |                     |         | 100     | mA   |

Note: Exposure to conditions beyond those listed under absolute maximum ratings may adversely affects the lift and reliability of the device.

### 6.2 DC Electrical Characteristics

### 6.2.1 NuMicro<sup>™</sup> NUC122 DC Electrical Characteristics

(V<sub>DD</sub>-V<sub>SS</sub>=3.3 V, TA = 25 °C, FOSC = 60 MHz unless otherwise specified.)

| DADAMETED                            | 0)/14             | SPECIFICATION |      |                 |      |                                                                                    |
|--------------------------------------|-------------------|---------------|------|-----------------|------|------------------------------------------------------------------------------------|
| PARAMETER                            | SYM.              | MIN.          | TYP. | MAX.            | UNIT | TEST CONDITIONS                                                                    |
| Operation voltage                    | V <sub>DD</sub>   | 2.5           |      | 5.5             | V    | V <sub>DD</sub> =2.5 V ~ 5.5 V up to 60 MHz                                        |
| LDO Output Voltage                   | V <sub>LDO</sub>  | 1.6           | 1.8  | 2.1             | v    | $V_{DD} \ge 2.5 \text{ V}$                                                         |
| Analog Operating Voltage             | AV <sub>DD</sub>  | 0             |      | V <sub>DD</sub> | V    | 8 20 La                                                                            |
|                                      | I <sub>DD1</sub>  |               | 26   |                 | mA   | V <sub>DD</sub> = 5.5 V @ 60 MHz,<br>enable all IP and PLL, XTAL=12 MH             |
| Operating Current                    | I <sub>DD2</sub>  |               | 21   |                 | mA   | $V_{DD} = 5.5 V @ 60 MHz,$<br>disable all IP and enable PLL,<br>XTAL=12 MHz        |
| Normal Run Mode<br>@ 60 MHz          | I <sub>DD3</sub>  |               | 24   |                 | mA   | V <sub>DD</sub> = 3.3 V @ 60 MHz,<br>enable all IP and PLL, XTAL=12 MH             |
|                                      | I <sub>DD4</sub>  |               | 19   |                 | mA   | V <sub>DD</sub> = 3.3 V @ 60 MHz,<br>disable all IP and enable PLL,<br>XTAL=12 MHz |
|                                      | I <sub>DD5</sub>  |               | 6.5  |                 | mA   | $V_{DD} = 5.5 V @ 12MHz,$<br>enable all IP and disable PLL,<br>XTAL=12 MHz         |
| Operating Current<br>Normal Run Mode | I <sub>DD6</sub>  |               | 5    |                 | mA   | V <sub>DD</sub> = 5.5 V @ 12 MHz,<br>disable all IP and PLL, XTAL=12 M⊦            |
| @ 12 MHz                             | I <sub>DD7</sub>  |               | 4.5  |                 | mA   | $V_{DD} = 3.3 V @ 12 MHz,$<br>enable all IP and disable PLL,<br>XTAL=12 MHz        |
|                                      | I <sub>DD8</sub>  |               | 3.5  |                 | mA   | V <sub>DD</sub> = 3.3 V @ 12 MHz,<br>disable all IP and PLL, XTAL=12 MH            |
| Operating Current<br>Normal Run Mode | I <sub>DD9</sub>  | 0             | 3.5  |                 | mA   | $V_{DD} = 5.5 V @ 4 MHz,$<br>enable all IP and disable PLL,<br>XTAL=4 MHz          |
| @ 4 MHz                              | I <sub>DD10</sub> | 3             | 3    |                 | mA   | V <sub>DD</sub> = 5.5 V @ 4 MHz,                                                   |

# nuvoTon

|  |                                           | 0)/14               | SPECIFICATION |      |      |      | TEAT CONDITIONS                                                                    |
|--|-------------------------------------------|---------------------|---------------|------|------|------|------------------------------------------------------------------------------------|
|  | PARAMETER                                 | SYM.                | MIN.          | TYP. | MAX. | UNIT | TEST CONDITIONS                                                                    |
|  |                                           |                     |               |      | 27   | 200  | disable all IP and PLL, XTAL=4 MHz                                                 |
|  |                                           | I <sub>DD11</sub>   |               | 3    | No.  | mA   | V <sub>DD</sub> = 3.3 V @ 4 MHz,<br>enable all IP and disable PLL,<br>XTAL=4 MHz   |
|  |                                           | I <sub>DD12</sub>   |               | 2    |      | mA   | $V_{DD} = 3.3 V @ 4 MHz,$<br>disable all IP and PLL, XTAL=4 MHz                    |
|  |                                           | I <sub>IDLE1</sub>  |               | 17   |      | mA   | $V_{DD} = 5.5 V @ 60 MHz,$<br>enable all IP and PLL, XTAL=12 MHz                   |
|  | Operating Current                         | I <sub>IDLE2</sub>  |               | 12   |      | mA   | $V_{DD} = 5.5 V @ 60 MHz,$<br>disable all IP and enable PLL,<br>XTAL=12 MHz        |
|  | @ 60 MHz                                  | I <sub>IDLE3</sub>  |               | 15   |      | mA   | $V_{DD} = 3.3 V @ 60 MHz,$<br>enable all IP and PLL, XTAL=12 MHz                   |
|  |                                           | I <sub>IDLE4</sub>  |               | 11   |      | mA   | $V_{DD}$ = 3.3 V @ 60 MHz,<br>disable all IP and enable PLL,<br>XTAL=12 MHz        |
|  |                                           | I <sub>IDLE5</sub>  |               | 4.5  |      | mA   | V <sub>DD</sub> = 5.5 V @ 12 MHz,<br>enable all IP and disable PLL,<br>XTAL=12 MHz |
|  | Operating Current                         | I <sub>IDLE6</sub>  |               | 3.5  |      | mA   | V <sub>DD</sub> = 5.5 V @ 12 MHz,<br>disable all IP and PLL, XTAL=12 MH            |
|  | Idle Mode<br>@ 12 MHz                     | I <sub>IDLE7</sub>  |               | 3    |      | mA   | $V_{DD} = 3.3 V @ 12 MHz,$<br>enable all IP and disable PLL,<br>XTAL=12 MHz        |
|  | *                                         | I <sub>IDLE8</sub>  |               | 2    |      | mA   | V <sub>DD</sub> = 3.3 V @ 12 MHz,<br>disable all IP and PLL, XTAL=12 MH            |
|  | W. A                                      | I <sub>IDLE9</sub>  |               | 3    |      | mA   | V <sub>DD</sub> = 5.5 V @ 4 MHz,<br>enable all IP and disable PLL,<br>XTAL=4 MHz   |
|  | Operating Current<br>Idle Mode<br>@ 4 MHz | I <sub>IDLE10</sub> |               | 2.5  |      | mA   | V <sub>DD</sub> = 5.5 V @ 4 MHz,<br>disable all IP and PLL, XTAL=4 MHz             |
|  |                                           | IDLE11              |               | 2    |      | mA   | V <sub>DD</sub> = 3.3 V @ 4 MHz,<br>enable all IP and disable PLL,<br>XTAL=4 MHz   |
|  |                                           | I <sub>IDLE12</sub> | 0             | 1    |      | mA   | V <sub>DD</sub> = 3.3 V @ 4 MHz,<br>disable all IP and PLL, XTAL=4 MHz             |

| PARAMETER                                                              | CVM                            | SPECIFICATION       |                     |                          |      |                                                                      |  |  |
|------------------------------------------------------------------------|--------------------------------|---------------------|---------------------|--------------------------|------|----------------------------------------------------------------------|--|--|
| PARAMETER                                                              | SYM.                           | MIN.                | TYP.                | MAX.                     | UNIT | TEST CONDITIONS                                                      |  |  |
|                                                                        | I <sub>PWD1</sub>              |                     | 13                  | 22                       | μA   | V <sub>DD</sub> = 5.5 V, RTC OFF, No load<br>@ Disable BOV function  |  |  |
| Standby Current<br>Power Down Mode                                     | I <sub>PWD2</sub>              |                     | 12                  | N.                       | μA   | V <sub>DD</sub> = 3.3 V, RTC OFF, No load<br>@ Disable BOV function  |  |  |
| r ower bown mode                                                       | I <sub>PWD3</sub>              |                     | 15                  | ~                        | μA   | V <sub>DD</sub> = 5.5 V, RTC run , No load<br>@ Disable BOV function |  |  |
|                                                                        | I <sub>PWD4</sub>              |                     | 13                  |                          | μA   | V <sub>DD</sub> = 3.3 V, RTC run , No load<br>@ Disable BOV function |  |  |
| Input Current PA, PB, PC,<br>PD (Quasi-bidirectional mode)             | I <sub>IN1</sub>               | -60                 | -                   | +15                      | μA   | $V_{DD} = 5.5 \text{ V}, V_{IN} = 0 \text{ V or } V_{IN} = V_{DI}$   |  |  |
| Input Current at /RESET <sup>[1]</sup>                                 | I <sub>IN2</sub>               | -55                 | -45                 | -30                      | μA   | $V_{DD} = 3.3 \text{ V}, V_{IN} = 0.45 \text{ V}$                    |  |  |
| Input Leakage Current PA, PB,<br>PC, PD                                | I <sub>LK</sub>                | -2                  | -                   | +2                       | μA   | $V_{DD} = 5.5 \text{ V}, 0 < V_{IN} < V_{DD}$                        |  |  |
| Logic 1 to 0 Transition Current<br>PA~PD (Quasi-bidirectional<br>mode) | I <sub>TL</sub> <sup>[3]</sup> | -650                | -                   | -200                     | μΑ   | $V_{DD} = 5.5 \text{ V}, \text{ V}_{IN} < 2.0 \text{ V}$             |  |  |
| Input Low Voltage PA, PB, PC,                                          |                                | -0.3                | -                   | 0.8                      |      | V <sub>DD</sub> = 4.5 V                                              |  |  |
| PD (TTL input)                                                         | V <sub>IL1</sub>               | -0.3                | -                   | 0.6                      | V    | V <sub>DD</sub> = 2.5 V                                              |  |  |
| Input High Voltage PA, PB, PC,<br>PD(TTL input)                        | V <sub>IH1</sub>               | 2.0                 | -                   | V <sub>DD</sub><br>+0.2  | V    | V <sub>DD</sub> = 5.5 V                                              |  |  |
|                                                                        | 101                            | 1.5                 | -                   | V <sub>DD</sub><br>+0.2  | •    | V <sub>DD</sub> = 3.0 V                                              |  |  |
| Input Low Voltage PA, PB, PC,<br>PD (Schmitt input)                    | $V_{\text{IL2}}$               | -0.5                |                     | $0.4 V_{DD}$             | V    |                                                                      |  |  |
| Input High Voltage PA, PB, PC, PD(Schmitt input)                       | $V_{\text{IH2}}$               | 0.6 V <sub>DD</sub> |                     | V <sub>DD</sub> +0.<br>5 | V    |                                                                      |  |  |
| Hysteresis voltage of PA~PD<br>(Schmitt input)                         | $V_{\text{HY}}$                |                     | 0.2 V <sub>DD</sub> |                          | V    |                                                                      |  |  |
| Negative going threshold<br>(Schmitt input), /RESET                    | V <sub>ILS</sub>               | -0.5                | -                   | 0.3 V <sub>DD</sub>      | V    |                                                                      |  |  |
| Positive going threshold<br>(Schmitt input), /RESET                    | V <sub>IHS</sub>               | $0.7 V_{DD}$        | -                   | V <sub>DD</sub> +0.<br>5 | V    |                                                                      |  |  |
| The De                                                                 | I <sub>SR11</sub>              | -300                | -370                | -450                     | μA   | $V_{DD} = 4.5 V, V_{S} = 2.4 V$                                      |  |  |
| Source Current PA, PB, PC,<br>PD (Quasi-bidirectional Mode)            | I <sub>SR12</sub>              | -50                 | -70                 | -90                      | μA   | $V_{DD} = 2.7 \text{ V}, \text{ V}_{S} = 2.2 \text{ V}$              |  |  |
| SAL.                                                                   | I <sub>SR12</sub>              | -40                 | -60                 | -80                      | μA   | $V_{DD} = 2.5 \text{ V}, \text{ V}_{S} = 2.0 \text{ V}$              |  |  |
|                                                                        | I <sub>SR21</sub>              | -22                 | -28                 | -32                      | mA   | $V_{DD}$ = 4.5 V, $V_{S}$ = 2.4 V                                    |  |  |
| Source Current PA, PB, PC,<br>PD (Push-pull Mode)                      | I <sub>SR22</sub>              | -4                  | -6                  | -8                       | mA   | $V_{DD} = 2.7 \text{ V}, \text{ V}_{S} = 2.2 \text{ V}$              |  |  |
| 2                                                                      | I <sub>SR22</sub>              | -3                  | -5                  | -7                       | mA   | $V_{DD} = 2.5 \text{ V}, \text{ V}_{S} = 2.0 \text{ V}$              |  |  |

#### 6.4.5 Specification of USB PHY

6.4.5.1 USB DC Electrical Characteristics

| SYMBOL           | PARAMETER                                           | CONDITIONS                                                                                                     | MIN.       | TYP. | MAX.  | UNIT |
|------------------|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------|------------|------|-------|------|
| V <sub>IH</sub>  | Input high (driven)                                 | The second s | 2.0        |      |       | V    |
| V <sub>IL</sub>  | Input low                                           | S.                                                                                                             | The second |      | 0.8   | V    |
| V <sub>DI</sub>  | Differential input sensitivity                      | PADP-PADM                                                                                                      | 0.2        |      |       | V    |
| V <sub>CM</sub>  | Differential<br>common-mode range                   | Includes V <sub>DI</sub> range                                                                                 | 0.8        | 0    | 2.5   | V    |
| V <sub>SE</sub>  | Single-ended receiver threshold                     |                                                                                                                | 0.8        | 20   | 2.0   | V    |
|                  | Receiver hysteresis                                 |                                                                                                                | 1          | 200  | 1h    | mV   |
| V <sub>OL</sub>  | Output low (driven)                                 |                                                                                                                | 0          | - Zi | 0.3   | V    |
| V <sub>OH</sub>  | Output high (driven)                                |                                                                                                                | 2.8        |      | 3.6   | V    |
| V <sub>CRS</sub> | Output signal cross voltage                         |                                                                                                                | 1.3        |      | 2.0   | V    |
| R <sub>PU</sub>  | Pull-up resistor                                    |                                                                                                                | 1.425      |      | 1.575 | kΩ   |
| R <sub>PD</sub>  | Pull-down resistor                                  |                                                                                                                | 14.25      |      | 15.75 | kΩ   |
| V <sub>TRM</sub> | Termination Voltage for upstream port pull up (RPU) |                                                                                                                | 3.0        |      | 3.6   | V    |
| Z <sub>DRV</sub> | Driver output resistance                            | Steady state drive*                                                                                            |            | 10   |       | Ω    |
| C <sub>IN</sub>  | Transceiver capacitance                             | Pin to GND                                                                                                     |            |      | 20    | pF   |

\*Driver output resistance doesn't include series resistor resistance.

| 6.4.5.2 USB Full-Speed Driver Electrical Characteristics | s |
|----------------------------------------------------------|---|
|----------------------------------------------------------|---|

| SYMBOL            | PARAMETER                   | CONDITIONS                                          | MIN. | TYP. | MAX.   | UNIT |
|-------------------|-----------------------------|-----------------------------------------------------|------|------|--------|------|
| T <sub>FR</sub>   | Rise Time                   | C <sub>L</sub> =50p                                 | 4    |      | 20     | ns   |
| TFF               | Fall Time                   | CL=50p                                              | 4    |      | 20     | ns   |
| T <sub>FRFF</sub> | Rise and fall time matching | T <sub>FRFF</sub> =T <sub>FR</sub> /T <sub>FF</sub> | 90   |      | 111.11 | %    |

#### 6.4.5.3 USB Power Dissipation

| SYMBOL                                   | PARAMETER                                                             | CONDITIONS  | MIN. | TYP. | MAX. | UNIT |
|------------------------------------------|-----------------------------------------------------------------------|-------------|------|------|------|------|
| VDDREG<br>(Full (Steady State)<br>Speed) | Standby                                                               |             | 50   |      | μA   |      |
|                                          | V <sub>DDD</sub> and V <sub>DDREG</sub> Supply Current (Steady State) | Input mode  |      |      |      | μA   |
|                                          | 200                                                                   | Output mode |      |      |      | μΑ   |

### nuvoton

#### **Important Notice**

Nuvoton Products are neither intended nor warranted for usage in systems or equipment, any malfunction or failure of which may cause loss of human life, bodily injury or severe property damage. Such applications are deemed, "Insecure Usage".

Insecure usage includes, but is not limited to: equipment for surgical implementation, atomic energy control instruments, airplane or spaceship instruments, the control or operation of dynamic, brake or safety systems designed for vehicular use, traffic signal instruments, all types of safety devices, and other applications intended to support or sustain life.

All Insecure Usage shall be made at customer's risk, and in the event that third parties lay claims to Nuvoton as a result of customer's Insecure Usage, customer shall indemnify the damages and liabilities thus incurred by Nuvoton.

Please note that all data and specifications are subject to change without notice. All the trademarks of products and companies mentioned in this datasheet belong to their respective owners