

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

| Details                    |                                                                                     |
|----------------------------|-------------------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                            |
| Core Processor             | ARM® Cortex®-M0                                                                     |
| Core Size                  | 32-Bit Single-Core                                                                  |
| Speed                      | 50MHz                                                                               |
| Connectivity               | EBI/EMI, I <sup>2</sup> C, IrDA, LINbus, SPI, UART/USART                            |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                               |
| Number of I/O              | 40                                                                                  |
| 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            | A/D 8x12b                                                                           |
| Oscillator Type            | Internal                                                                            |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                                   |
| Mounting Type              | Surface Mount                                                                       |
| Package / Case             | 48-LQFP                                                                             |
| Supplier Device Package    | -                                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/nuvoton-technology-corporation-america/m058lbn |
|                            |                                                                                     |

Email: info@E-XFL.COM

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

|   | 6.8 Timer<br>6.8.1<br>6.8.2                                                                                                                                  | Controller<br>Overview<br>Features:                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 45                                                                                                                                           |
|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
|   | 6.9.1<br>6.9.2                                                                                                                                               | dog Timer (WDT)<br>Overview<br>Features                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 46<br>47                                                                                                                                     |
|   | 6.10.1<br>6.10.2                                                                                                                                             | T Interface Controller (UART) ······<br>Overview ······<br>Features ·····                                                                                                                                                                                                                                                                                                                                                                                                                   | 48<br>50                                                                                                                                     |
|   | 6.11 Analo<br>6.11.1<br>6.11.2                                                                                                                               | og-to-Digital Converter (ADC) ······<br>Overview ······<br>Features ·····                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                              |
|   | 6.12 Exter<br>6.12.1<br>6.12.2                                                                                                                               | nal Bus Interface (EBI)<br>Overview<br>Features                                                                                                                                                                                                                                                                                                                                                                                                                                             | 52                                                                                                                                           |
|   | 6.13 Flash<br>6.13.1<br>6.13.2                                                                                                                               | Memory Controller (FMC) ······<br>Overview ······<br>Features ·····                                                                                                                                                                                                                                                                                                                                                                                                                         | 53                                                                                                                                           |
| 7 | TYPICA                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                              |
| 8 | ELECT                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 55                                                                                                                                           |
|   | 8.1 Absolu                                                                                                                                                   | Ite Maximum Ratings                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 55                                                                                                                                           |
|   | 8 2 DC El                                                                                                                                                    | ectrical Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 56                                                                                                                                           |
|   | 0.2 DO LI                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                              |
|   |                                                                                                                                                              | ectrical Characteristics<br>External Crystal<br>External Oscillator<br>Typical Crystal Application Circuits<br>Internal 22.1184 MHz RC Oscillator<br>Internal 10kHz RC Oscillator                                                                                                                                                                                                                                                                                                           |                                                                                                                                              |
|   | 8.3 AC Ele<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>8.4 Analog<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>8.4.5<br>8.4.6<br>8.4.7                         | External Crystal<br>External Oscillator<br>Typical Crystal Application Circuits<br>Internal 22.1184 MHz RC Oscillator<br>Internal 10kHz RC Oscillator<br>Characteristics<br>Specification of 12-bit SARADC<br>Specification of LDO & Power management<br>Specification of LOO & Power management<br>Specification of Low Voltage Reset<br>Specification of Brown-Out Detector<br>Specification of Power-On Reset (5V)<br>Specification of Temperature Sensor<br>Specification of Comparator | 60<br>60<br>61<br>62<br>62<br>63<br>63<br>63<br>63<br>64<br>65<br>65<br>65<br>65<br>65<br>66<br>66<br>66                                     |
|   | 8.3 AC Ele<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>8.4 Analog<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>8.4.5<br>8.4.6<br>8.4.7<br>8.5 Flash            | External Crystal<br>External Oscillator<br>Typical Crystal Application Circuits<br>Internal 22.1184 MHz RC Oscillator<br>Internal 10kHz RC Oscillator<br>Characteristics<br>Specification of 12-bit SARADC<br>Specification of LDO & Power management<br>Specification of LOO & Power management<br>Specification of Low Voltage Reset<br>Specification of Brown-Out Detector<br>Specification of Power-On Reset (5V)<br>Specification of Temperature Sensor<br>Specification of Comparator | 60<br>60<br>61<br>62<br>62<br>63<br>63<br>63<br>63<br>64<br>65<br>65<br>65<br>65<br>65<br>65<br>65<br>66<br>66<br>66<br>67                   |
| 9 | 8.3 AC Ele<br>8.3.1<br>8.3.2<br>8.3.3<br>8.3.4<br>8.3.5<br>8.4 Analog<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>8.4.5<br>8.4.6<br>8.4.7<br>8.5 Flash I<br>PACKA | External Crystal<br>External Oscillator<br>Typical Crystal Application Circuits<br>Internal 22.1184 MHz RC Oscillator<br>Internal 10kHz RC Oscillator<br>Characteristics<br>Specification of 12-bit SARADC<br>Specification of LDO & Power management<br>Specification of LOO & Power management<br>Specification of Low Voltage Reset<br>Specification of Brown-Out Detector<br>Specification of Power-On Reset (5V)<br>Specification of Temperature Sensor<br>Specification of Comparator | 60<br>60<br>61<br>62<br>62<br>63<br>63<br>63<br>63<br>64<br>65<br>65<br>65<br>65<br>65<br>65<br>65<br>65<br>65<br>65<br>65<br>65<br>66<br>66 |

# NuMicro<sup>™</sup> M058/M0516BN Datasheet

# nuvoTon

| 9.2 QFN-33 (5X5 mm <sup>2</sup> , Thickness 0.8mm, Pitch 0.5 mm)69 |
|--------------------------------------------------------------------|
| 10 REVISION HISTORY                                                |



# NuMicro<sup>™</sup> M058/M0516BN Datasheet

# nuvoTon

#### LIST OF FIGURES

| Figure 3-1 NuMicro™ M051 Series Block Diagram                          | 13 |
|------------------------------------------------------------------------|----|
| Figure 4-1 NuMicro™ Naming Rule                                        | 14 |
| Figure 5-1 NuMicro™ M051 Series QFN33 Pin Diagram                      | 15 |
| Figure 5-2 NuMicro™ M051 Series LQFP-48 Pin Diagram                    | 16 |
| Figure 6-1 Functional Block Diagram                                    | 21 |
| Figure 6-2 NuMicro M051 <sup>™</sup> Series Power Architecture Diagram | 24 |
| Figure 6-3 Clock generator block diagram                               | 31 |
| Figure 6-4 System Clock Block Diagram                                  | 32 |
| Figure 6-5 SysTick clock Control Block Diagram                         | 32 |
| Figure 6-6 AHB Clock Source for HCLK                                   | 33 |
| Figure 6-7 Peripherals Clock Source Select for PCLK                    | 34 |
| Figure 6-8 Clock Source of Frequency Divider                           | 35 |
| Figure 6-9 Block Diagram of Frequency Divider                          | 36 |
| Figure 6-10 Push-Pull Output                                           | 37 |
| Figure 6-11 Open-Drain Output                                          | 38 |
| Figure 6-12 Quasi-bidirectional I/O Mode                               | 39 |
| Figure 6-13 I <sup>2</sup> C Bus Timing                                | 40 |
| Figure 6-14 Timing of Interrupt and Reset Signal                       | 47 |
| Figure 8-1 Typical Crystal Application Circuit                         | 61 |

#### **1 GENERAL DESCRIPTION**

The NuMicro M051<sup>™</sup> series is a 32-bit microcontroller with embedded ARM<sup>®</sup> Cortex<sup>™</sup>-M0 core for industrial control and applications which need rich communication interfaces. The Cortex<sup>™</sup>-M0 is the newest ARM embedded processor with 32-bit performance and at a cost equivalent to traditional 8-bit microcontroller. The NuMicro M051<sup>™</sup> series includes M052, M054, M058 and M0516 families.

The M058/M0516 can run up to 50 MHz. Thus it can afford to support a variety of industrial control and applications which need high CPU performance. The M058/M0516 has 32K/64K-byte embedded flash, 4K-byte data flash, 4K-byte flash for the ISP, and 4K-byte embedded SRAM.

Many system level peripheral functions, such as I/O Port, EBI (External Bus Interface), Timer, UART, SPI, I2C, PWM, ADC, Watchdog Timer and Brownout Detector, have been incorporated into the M058/M0516 in order to reduce component count, board space and system cost. These useful functions make the M058/M0516 powerful for a wide range of applications.

Additionally, the M058/M0516 is equipped with ISP (In-System Programming) and ICP (In-Circuit Programming) functions, which allow the user to update the program memory without removing the chip from the actual end product.



- Open-Drain output
- Input only with high impendence
- TTL/Schmitt trigger input selectable
- I/O pin can be configured as interrupt source with edge/level setting
- Supports high driver and high sink IO mode
- Timer
  - Provides four channel 32-bit timers, one 8-bit pre-scale counter with 24-bit up-timer for each timer.
  - Independent clock source for each timer.
  - 24-bit timer value is readable through TDR (Timer Data Register)
  - Provides one-shot, periodic and toggle operation modes.
  - Provide event counter function.
  - Provide external capture/reset counter function equivalent to 8051 Timer2.
- Watchdog Timer
  - Multiple clock sources
  - Supports wake up from power down or sleep mode
  - Interrupt or reset selectable on watchdog time-out
- PWM
  - Built-in up to four 16-bit PWM generators; providing eight PWM outputs or four complementary paired PWM outputs
  - Individual clock source, clock divider, 8-bit pre-scalar and dead-zone generator for each PWM generator
  - PWM interrupt synchronized to PWM period
  - 16-bit digital Capture timers (shared with PWM timers) with rising/falling capture inputs
  - Supports capture interrupt
- UART

- Serial clock synchronization can be used as a handshake mechanism to suspend and resume serial transfer.
- Programmable clocks allow versatile rate control.
- Supports multiple address recognition (four slave address with mask option)
- ADC
  - 12-bit SAR ADC with 760k SPS
  - Up to 8-ch single-ended input or 4-ch differential input
  - Supports single mode/burst mode/single-cycle scan mode/continuous scan mode
  - Supports 2' complement/un-signed format in differential mode conversion result
  - Each channel with an individual result register
  - Supports conversion value monitoring (or comparison) for threshold voltage detection
  - Conversion can be started either by software trigger or external pin trigger
- Analog Comparator
  - Up to 2 comparator analog modules
  - External input or internal band gap voltage selectable at negative node
  - Interrupt when compare result change
  - Power down wake up
- EBI (External Bus Interface) for external memory-mapped device access
  - Accessible space: 64KB in 8-bit mode or 128KB in 16-bit mode
  - Supports 8-bit/16-bit data width
  - Supports byte-write in 16-bit data width
- In-System Programming (ISP) and In-Circuit Programming (ICP)
- One built-in temperature sensor with 1°C resolution
- Brown-Out Detector
  - With 4 levels: 4.3V/3.7V/2.7V/2.2V

Publication Release Date: Mar. 19, 2012 Revision V1.01

- 11 -

| Pin number |        | Imber Alternate Function |                     | ion   | Type <sup>[1]</sup> | Description |                                                                                                                                                    |
|------------|--------|--------------------------|---------------------|-------|---------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| QFN33      | LQFP48 | Symbol                   | 1                   | 2     | 3                   | Type        | Description                                                                                                                                        |
| 16         | 23     | P2.4                     | PWM4 <sup>[2]</sup> | AD12  |                     | D,<br>I/O   | The CPO1 pin is the output of Comparator1.                                                                                                         |
| 17         | 25     | P2.5                     | PWM5 <sup>[2]</sup> | AD13  |                     | D,<br>I/O   | AP OF                                                                                                                                              |
| 18         | 26     | P2.6                     | PWM6 <sup>[2]</sup> | AD14  | CPO1                | D,<br>I/O   | E. C.                                                                                                                                              |
| NC         | 27     | P2.7                     | PWM7 <sup>[2]</sup> | AD15  |                     | D,<br>I/O   | 20.                                                                                                                                                |
| 3          | 5      | P3.0                     | RXD <sup>[2]</sup>  |       | CPN1                | I/O         | <b>PORT3:</b> Port 3 is an 8-bit four mode output pin and two mode input. Its multifunction pins are                                               |
| 5          | 7      | P3.1                     | TXD <sup>[2]</sup>  |       | CPP1                | I/O         | for RXD, TXD, INTO, INT1, T0, T1, WR,                                                                                                              |
| 6          | 8      | P3.2                     | INT0                | STADC | TOEX                | I/O         | and RD.<br>The RXD/TXD pins are for UART0 function                                                                                                 |
| NC         | 9      | P3.3                     | INT1                | MCLK  | T1EX                | I/O         | used.<br>The SDA/SCK pins are for I <sup>2</sup> C function used.<br>MCLK: EBI clock output pin.                                                   |
| 7          | 10     | P3.4                     | T0                  | SDA   |                     | I/O         | CKO: HCLK clock output                                                                                                                             |
| 8          | 11     | P3.5                     | T1                  | SCL   |                     | I/O         | The STADC pin is for ADC external trigger input.                                                                                                   |
| 9          | 13     | P3.6                     | WR                  | ско   | CPO0                | I/O         | The CPN1/CPP1 pins are for Comparator1 negative/positive inputs.<br>The CPO0 pin is the output of Comparator0.                                     |
| NC         | 14     | P3.7                     | RD                  |       |                     | I/O         | The T0/T1 pins are for Timer0/1 external even<br>counter input.<br>The T0EX/T1EX pins are for external<br>capture/reset trigger input of Timer0/1. |
| NC         | 24     | P4.0                     | PWM0 <sup>[2]</sup> |       | T2EX                | I/O         | <b>PORT4:</b> Port 4 is an 8-bit four mode output pin and two mode input. Its multifunction pins are                                               |
| NC         | 36     | P4.1                     | PWM1 <sup>[2]</sup> |       | T3EX                | I/O         | for /CS, ALE, ICE_CLK and ICE_DAT.                                                                                                                 |
| NC         | 48     | P4.2                     | PWM2 <sup>[2]</sup> |       |                     | I/O         | CS for EBI (External Bus Interface) used.<br>ALE (Address Latch Enable) is used to enable                                                          |
| NC         | 12     | P4.3                     | PWM3 <sup>[2]</sup> |       |                     | I/O         | the address latch that separates the address from the data on Port 0 and Port 2.                                                                   |

| Pin n | umber  | Alternate Fun |                          | ate Func | tion<br>Type <sup>[1]</sup> |                                         | Description                                                                  |
|-------|--------|---------------|--------------------------|----------|-----------------------------|-----------------------------------------|------------------------------------------------------------------------------|
| QFN33 | LQFP48 | e ysei        | 1                        | 2        | 3                           | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 2000 piton                                                                   |
| NC    | 28     | P4.4          | $\overline{\mathrm{CS}}$ |          | ų                           | I/O                                     | The ICE_CLK/ICE_DAT pins are for JTAG-ICE function used.                     |
| NC    | 29     | P4.5          | ALE                      |          |                             | I/O                                     | PWM0-3 can be used from P4.0-P4.3 when EBI is active.                        |
| 19    | 30     | P4.6          | ICE_CLK                  |          |                             | I/O                                     | The T2EX/T3EX pins are for external capture/reset trigger input of Timer2/3. |
| 20    | 31     | P4.7          | ICE_DAT                  |          |                             | I/O                                     |                                                                              |

Table 5-1 NuMicro<sup>™</sup> M051 Series Pin Description

[1] I/O type description. I: input, O: output, I/O: quasi bi-direction, D: open-drain, P: power pins, ST: Schmitt trigger.

[2] The pins features which are set by S/W. Only one-set pin can be used while S/W to set it.



#### 6.2 System Manager

#### 6.2.1 Overview

The following functions are included in system manager section

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

#### 6.2.2 System Reset

The system reset includes one of the list below event occurs. For these reset event flags can be read by RSTSRC register.

- The Power-On Reset (POR)
- The low level on the /RESET pin
- Watchdog Time Out Reset (WDT)
- Low Voltage Reset (LVR)
- Brown-Out Detected Reset (BOD)
- CPU Reset
- Software one shot Reset

|          | 052/54/58/516                              |             | -        |                               |             |           |
|----------|--------------------------------------------|-------------|----------|-------------------------------|-------------|-----------|
| 4 GB     |                                            | OxFFFF_FFF  |          |                               |             |           |
| Reserve  | ed                                         | I           |          | System Control                |             | -         |
|          |                                            | 0xE000_F000 |          | - System Timer Control        | 0xE000_E000 | SCS_BA    |
| System   | Control                                    | 0xE000_EFFF |          |                               |             |           |
| System   | control                                    | 0xE000_E000 | <b>▲</b> |                               |             |           |
|          |                                            | 0xE000_E00F |          |                               |             |           |
| Reserve  | ed                                         | I           |          |                               |             |           |
|          |                                            | 0x6002_0000 |          |                               |             |           |
| EBI      |                                            | 0x6001_FFFF |          |                               |             |           |
| EDI      |                                            | 0x6000_0000 |          |                               |             |           |
|          |                                            | 0x5FFF_FFF  |          |                               |             |           |
| Reserve  | ed                                         | I           |          |                               |             |           |
|          |                                            | 0x5020_0000 |          | AHB peripherals               |             |           |
| АНВ      |                                            | 0x501F_FFFF |          | EBI Control                   | 0x5001_0000 | EBI_CTL_E |
| And      |                                            | 0x5000_0000 |          | FMC                           | 0x5000_C000 | FLASH_BA  |
|          |                                            | Ox4FFF_FFF  |          | GPIO Control                  | 0x5000_4000 | GPIO_BA   |
| Reserve  | od.                                        |             |          | Interrupt Multiplexer Control | 0x5000_0300 | INT_BA    |
| Kesel ve | ru                                         | I           |          | Clock Control                 | 0x5000_0200 | CLK_BA    |
|          |                                            | 0x4020_0000 |          | System Global Control         | 0x5000_0000 | GCR_BA    |
|          |                                            | 0x401F_FFFF |          |                               |             |           |
| APB      |                                            | I           | •        |                               |             |           |
| 1 GB     |                                            | 0x4000_0000 |          |                               |             |           |
|          |                                            | 0x3FFF_FFF  |          |                               |             |           |
| Reserve  | ed                                         | 1           |          | APB peripherals               |             |           |
|          |                                            |             |          | UART1 Control                 | 0x4015_0000 | UART1_BA  |
|          |                                            | 0x2000_1000 | 4        | PWM4/5/6/7 Control            | 0x4014_0000 | PWMB_BA   |
|          |                                            | 0x2000_0FFF |          | Timer2/Timer3 Control         | 0x4011_0000 | TMR23_B   |
| 4 KB SI  | ΣΔΜ                                        |             |          | ADC Control                   | 0x400E_0000 | ADC_BA    |
|          | M054/M058/M0516)                           | I           |          | COMP control                  | 0x400D_0000 | ACMP_BA   |
|          |                                            |             | Ľ        | UART0 Control                 | 0x4005_0000 | UARTO_B   |
| 0.5 GB   |                                            | 0x2000_0000 |          | PWM0/1/2/3 Control            | 0x4004_0000 | PWMA_BA   |
|          |                                            | 0x1FFF_FFF  |          | SPI1 Control                  | 0x4003_4000 | SPI1_BA   |
| Reserve  | ed                                         |             |          | SPI0 Control                  | 0x4003_0000 | SPI0_BA   |
|          |                                            | · ·         |          | I2C Control                   | 0x4002_0000 | I2C_BA    |
|          |                                            | 0x0001_0000 | 1        | Timer0/Timer1 Control         | 0x4001_0000 | TMR01_B   |
|          | n-chip Flash (M0516)                       | 0x0000_FFFF | 1 '      | WDT Control                   | 0x4000_4000 | WDT_BA    |
| 64 KB 0  |                                            | 0x0000_7FFF | 1        |                               |             |           |
|          | n-chip Flash (M058)                        | 0x0000_/111 | _        |                               |             |           |
| 32 KB 0  | n-chip Flash (M058)<br>n-chip Flash (M054) | 0x0000_3FFF | 1        |                               |             |           |

#### 6.2.5 Whole System Memory Mapping Table

#### 6.2.6 System Timer (SysTick)

The Cortex-M0 includes an integrated system timer, SysTick. SysTick provides a simple, 24-bit

Publication Release Date: Mar. 19, 2012 Revision V1.01

- 27 -

clear-on-write, decrementing, wrap-on-zero counter with a flexible control mechanism. The counter can be used as a Real Time Operating System (RTOS) tick timer or as a simple counter.

When system timer is enabled, it will count down from the value in the SysTick Current Value Register (SYST\_CVR) to zero, and reload (wrap) to the value in the SysTick Reload Value Register (SYST\_RVR) on the next clock edge, then decrement on subsequent clocks. When the counter transitions to zero, the COUNTFLAG status bit is set. The COUNTFLAG bit clears on reads.

The SYST\_CVR value is UNKNOWN on reset. Software should write to the register to clear it to zero before enabling the feature. This ensures the timer will count from the SYST\_RVR value rather than an arbitrary value when it is enabled.

If the SYST\_RVR is zero, the timer will be maintained with a current value of zero after it is reloaded with this value. This mechanism can be used to disable the feature independently from the timer enable bit.

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



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

Cortex-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".

#### 6.3 Clock Controller

#### 6.3.1 Overview

The clock controller generates the clocks for the whole chip, including system clocks and all peripheral clocks. The clock controller also implements the power control function with the individually clock ON/OFF control, clock source selection and clock divider. The chip will not enter power-down mode until CPU sets the power down enable bit (PWR\_DOWN\_EN) and Cortex-M0 core executes the WFI instruction. After that, chip enter power-down mode and wait for wake-up interrupt source triggered to leave power-down mode. In the power down mode, the clock controller turns off the external crystal and internal 22.1184 MHz oscillator to reduce the overall system power consumption.

#### 6.3.2 Clock Generator Block Diagram

The clock generator consists of 4 sources which list below:

- One external 4~24 MHz crystal
- One internal 22.1184 MHz RC oscillator
- One programmable PLL FOUT(PLL source consists of external 4~24 MHz crystal and internal 22.1184M)
- One internal 10 kHz oscillator





Figure 6-3 Clock generator block diagram

### ηυνοτοη

#### 6.3.5 Peripherals Clock Source Select

The peripherals clock had different clock source switch setting which depends on the different peripheral.



Figure 6-7 Peripherals Clock Source Select for PCLK

#### 6.8 Timer Controller

#### 6.8.1 Overview

NuMicro M051<sup>™</sup> series timer controller includes four 32-bit timers, which allows user to easily implement a timer control for applications. The timer can perform functions like frequency measurement, event counting, interval measurement, clock generation, delay timing, and so on. The timer can generates an interrupt signal upon timeout, or provide the current counting value during operation.

#### 6.8.2 Features:

- 4 sets of 32-bit timers with 24-bit up-timer and one 8-bit pre-scale counter
- Independent clock source for each timer
- Provides one-shot, periodic, toggle and continuous counting operation modes
- Time out period = (Period of timer clock input) \* (8-bit pre-scale counter + 1) \* (24-bit TCMP)
- Maximum counting cycle time =  $(1 / T MHz) * (2^8) * (2^{24})$ , T is the period of timer clock
- 24-bit timer value is readable through TDR (Timer Data Register)
- Support event counting function to count the event from external pin
- Support input capture function to capture or reset counter value



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





Figure 6-14 Timing of Interrupt and Reset Signal

#### 6.9.2 Features

- 18-bit free running counter to avoid chip from Watchdog timer reset before the delay time expires.
- Selectable time-out interval  $(2^4 \sim 2^{18})$  and the time out interval is 104 ms ~ 26.3168 s (if WDT\_CLK = 10 kHz).
- Reset period = (1 / 10 kHz) \* 63, if WDT\_CLK = 10 kHz.

Publication Release Date: Mar. 19, 2012 Revision V1.01

- 47 -

### nuvoton

#### 6.10 UART Interface Controller (UART)

NuMicro M051<sup>™</sup> series provides two channels of Universal Asynchronous Receiver/Transmitters (UART). UART0~1 performs Normal Speed UART, and support flow control function.

#### 6.10.1 **Overview**

The Universal Asynchronous Receiver/Transmitter (UART) 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, LIN master/slave mode 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/Wakeup status interrupt (INT MODEM), Buffer error interrupt (INT BUF ERR) and LIN receiver break field detected interrupt (INT LIN RX BREAK).

The UART0 and UART1 are built-in with a 16-byte transmitter FIFO (TX\_FIFO) and a 16-byte receiver FIFO (RX FIFO) that reduces the number of interrupts presented to the CPU. 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 3 error conditions (parity error, framing error, break interrupt) 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). Table 6-3 lists the equations in the various conditions and Table 6-4 list the UART baud rate setting table.

|      | Mode | DIV_X_EN | DIV_X_ONE | Divider X  | BRD | М                       | Baud rate equation                                                           |
|------|------|----------|-----------|------------|-----|-------------------------|------------------------------------------------------------------------------|
|      | 0    | 0        | 0         | В          | А   | 16                      | UART_CLK / [16 * (A+2)]                                                      |
|      | 1    | 1        | 0         | В          | А   | B+1                     | UART_CLK / [(B+1) * (A+2)] , B must >= 8                                     |
| -18- | 2    | 1        | 1         | Don't care | А   | 1                       | UART_CLK / (A+2), A must >=3                                                 |
|      |      |          |           | Table 6-3  |     | Г Вацо<br>- <i>48</i> - | d Rate Equation<br>Publication Release Date: Mar. 19, 2012<br>Revision V1.01 |
|      |      |          |           |            |     |                         |                                                                              |

The alternate function of UART controllers is LIN (Local Interconnect Network) function. The LIN mode is selected by setting UA\_FUN\_SEL [1:0] = '01'. In LIN mode, one start bit and 8-bit data format with 1-bit stop bit are required in accordance with the LIN standard.

Another alternate function of UART controllers is RS-485 9 bit mode function, and direction control provided by RTS pin or can program GPIO (P0.3 for RTS0 and P0.1 for RTS1) to implement the function by software. The RS-485 mode is selected by setting the UA\_FUN\_SEL register to select RS-485 function. The RS-485 driver control is implemented by using the RTS control signal from an asynchronous serial port to enable the RS-485 driver. In RS-485 mode, many characteristics of the RX and TX are same as UART.

#### 6.10.2 Features

- Full duplex, asynchronous communications
- Separate receive / transmit 16/16 bytes entry FIFO for data payloads
- Support hardware auto flow control/flow control function (CTS, RTS) and programmable RTS flow control trigger level
- Programmable receiver buffer trigger level
- Support programmable baud-rate generator for each channel individually
- Support CTS wake up function
- Support 8 bit receiver buffer time out detection function
- Programmable transmitting data delay time between the last stop and the next start bit by setting UA\_TOR [DLY] register
- Support break error, frame error, parity error and receive / transmit buffer overflow detect function
- Fully programmable serial-interface characteristics
  - Programmable number of data bit, 5, 6, 7, 8 bit character
  - Programmable parity bit, even, odd, no parity or stick parity bit generation and detection
  - Programmable stop bit, 1, 1.5, or 2 stop bit generation
- Support IrDA SIR function mode
  - Support for 3/16 bit duration for normal mode
- Support LIN function mode
  - Support LIN master/slave mode
  - Support programmable break generation function for transmitter
  - Support break detect function for receiver
- Support RS-485 function mode.
  - Support RS-485 9bit mode
  - Support hardware or software enable to program RTS pin to control RS-485 transmission direction directly

### **10 REVISION HISTORY**

| VERSION | DATE          | PAGE  | DESCRIPTION                                   |
|---------|---------------|-------|-----------------------------------------------|
| V1.0    | Oct 20, 2011  | -     | Initial issued                                |
| V1.01   | Mar. 19, 2012 | 8.3.4 | Updated the Center Frequency of 22Mhz RC spec |

