



# HK32F04AxxxxA Datasheet

Version: 1.0

Release Date: 2023-06-09

Shenzhen Hangshun Chip Technology R&D Co., Ltd.

<http://www.hsxp-hk.com>

## Preface

### Purpose

This document introduces the block diagram, memory mapping, peripheral interfaces, electrical characteristics, and pinouts of HK32F04AxxxxA series microcontrollers (MCUs). This document helps you quickly understand the characteristics and functions of HK32F04AxxxxA.

### Audience

This document is intended for:

- HK32F04AxxxxA developers
- HK32F04AxxxxA testers
- HK32F04AxxxxA users

### Release Notes

This document is applicable to HK32F04AxxxxA series MCUs.

### Revision History

| Version | Date       | Description          |
|---------|------------|----------------------|
| 1.0     | 2023/06/09 | The initial release. |

## Contents

|                                   |    |
|-----------------------------------|----|
| 1 Introduction .....              | 1  |
| 2 Product overview .....          | 2  |
| 2.1 Features .....                | 3  |
| 2.2 Device overview .....         | 5  |
| 3 Function description.....       | 7  |
| 3.1 Block diagram .....           | 7  |
| 3.2 Memory mapping.....           | 8  |
| 3.3 Flash .....                   | 8  |
| 3.4 SRAM.....                     | 8  |
| 3.5 Resets .....                  | 8  |
| 3.5.1 System reset .....          | 8  |
| 3.5.2 Power reset .....           | 9  |
| 3.5.3 Backup domain reset.....    | 9  |
| 3.6 Clocks and clock tree.....    | 10 |
| 3.7 Power supply scheme .....     | 10 |
| 3.8 Boot modes.....               | 11 |
| 3.9 PVD .....                     | 11 |
| 3.10 Low-power modes.....         | 11 |
| 3.11 NVIC .....                   | 12 |
| 3.12 EXTI.....                    | 13 |
| 3.13 IWDG.....                    | 14 |
| 3.14 WWDG .....                   | 14 |
| 3.15 SysTick timer.....           | 14 |
| 3.16 Timer .....                  | 15 |
| 3.16.1 Basic timer .....          | 15 |
| 3.16.2 General-purpose timer..... | 15 |
| 3.16.3 Advanced timer .....       | 16 |
| 3.16.4 Low-power timer .....      | 16 |
| 3.17 IRTIM.....                   | 16 |
| 3.18 I2C .....                    | 17 |
| 3.19 USART.....                   | 17 |
| 3.20 LPUART.....                  | 17 |
| 3.21 SPI/I2S.....                 | 18 |
| 3.22 GPIO .....                   | 18 |
| 3.23 DMA .....                    | 19 |
| 3.24 ADC.....                     | 19 |

|                                               |    |
|-----------------------------------------------|----|
| 3.25 CAN .....                                | 19 |
| 3.26 RTC clock.....                           | 19 |
| 3.27 Information security .....               | 20 |
| 3.27.1 AES128.....                            | 20 |
| 3.27.2 Hash.....                              | 20 |
| 3.27.3 TRNG.....                              | 21 |
| 3.28 CRC calculation unit .....               | 21 |
| 3.29 EMACC .....                              | 21 |
| 3.30 DVSQ calculation unit .....              | 21 |
| 3.31 CLU .....                                | 22 |
| 3.32 Voltage comparator .....                 | 22 |
| 3.33 Internal reference voltage .....         | 22 |
| 3.34 Temperature sensor .....                 | 22 |
| 3.35 96-bit UID.....                          | 22 |
| 3.36 Debug port.....                          | 23 |
| 4 Electrical characteristics .....            | 24 |
| 4.1 Absolute maximum values.....              | 24 |
| 4.1.1 Voltage characteristics .....           | 24 |
| 4.1.2 Current characteristics .....           | 24 |
| 4.1.3 Temperature characteristics .....       | 24 |
| 4.2 Operating conditions.....                 | 24 |
| 4.2.1 Recommended operating conditions .....  | 24 |
| 4.2.2 PVD characteristics .....               | 25 |
| 4.2.3 POR/PDR characteristics .....           | 25 |
| 4.2.4 Internal reference voltage.....         | 25 |
| 4.2.5 Operating current characteristics ..... | 25 |
| 4.2.6 HSE clock characteristics .....         | 27 |
| 4.2.7 LSE clock characteristics .....         | 28 |
| 4.2.8 HSI clock characteristics .....         | 28 |
| 4.2.9 LSI clock characteristics .....         | 29 |
| 4.2.10 PLL characteristics .....              | 29 |
| 4.2.11 Flash memory characteristics .....     | 29 |
| 4.2.12 I/O pin input characteristics.....     | 29 |
| 4.2.13 I/O pin output characteristics .....   | 30 |
| 4.2.14 NRST pin characteristics .....         | 30 |
| 4.2.15 TIM timer characteristics .....        | 30 |
| 4.2.16 EMACC characteristics.....             | 30 |
| 4.2.17 ADC characteristics .....              | 31 |

|                                                 |    |
|-------------------------------------------------|----|
| 4.2.18 Temperature sensor characteristics ..... | 33 |
| 5 Typical circuitry .....                       | 34 |
| 6 Pinouts and pin descriptions.....             | 35 |
| 6.1 TSSOP20 .....                               | 35 |
| 6.2 QFN28 .....                                 | 36 |
| 6.3 QFN32 .....                                 | 36 |
| 6.4 LQFP32 .....                                | 37 |
| 6.5 LQFP48 .....                                | 37 |
| 6.6 LQFP64 .....                                | 38 |
| 6.7 Pin descriptions .....                      | 38 |
| 6.8 Alternate function table.....               | 44 |
| 7 Package characteristics.....                  | 47 |
| 7.1 TSSOP20 .....                               | 47 |
| 7.2 QNF28 .....                                 | 48 |
| 7.3 QFN32 .....                                 | 49 |
| 7.4 LQFP32 .....                                | 50 |
| 7.5 LQFP48 .....                                | 51 |
| 7.6 LQFP64 .....                                | 52 |
| 8 Ordering information .....                    | 53 |
| 9 Acronyms.....                                 | 54 |
| 10 Legal and contact information.....           | 55 |

## 1 Introduction

This document is the datasheet for HK32F04AxxxxA series MCUs. HK32F04AxxxxA is a family of MCUs developed by Shenzhen Hangshun Chip Technology R&D Co., Ltd. (hereinafter referred to as Hangshun) for a wide range of purposes. This MCU family includes:

- HK32F04AFxP6A (TSSOP20 package)
  - HK32F04AF4P6A
  - HK32F04AF6P6A
  - HK32F04AF8P6A
  - HK32F04AFBP6A
- HK32F04AGxU6A (QFN28 package)
  - HK32F04AG4U6A
  - HK32F04AG6U6A
  - HK32F04AG8U6A
  - HK32F04AGBU6A
- HK32F04AKxU6A (QFN32 package)
  - HK32F04AK4U6A
  - HK32F04AK6U6A
  - HK32F04AK8U6A
  - HK32F04AKBU6A
- HK32F04AKxT6A (LQFP32 package)
  - HK32F04AK4T6A
  - HK32F04AK6T6A
  - HK32F04AK8T6A
  - HK32F04AKBT6A
- HK32F04ACxT6A (LQFP48 package)
  - HK32F04AC4T6A
  - HK32F04AC6T6A
  - HK32F04AC8T6A
  - HK32F04ACBT6A
- HK32F04ARxT6A (LQFP64 package)
  - HK32F04AR8T6A
  - HK32F04ARB6A

For more details of HK32F04AxxxxA, see *HK32F04AxxxxA User Manual*.

## 2 Product overview

HK32F04AxxxxA adopts the ARM® Cortex®-M0 core operating at a maximum frequency of 96 MHz and has up to 124 Kbytes of flash and 10 Kbytes of SRAM. You can configure the Flash controller register to remap interrupt vectors in the main Flash.

HK32F04AxxxxA supports conventional Flash readout protection (RDP) Level 0, Level 1, and Level 2 and provides the patented Flash code encryption function of Hangshun.

To meet the security requirements of various applications, HK32F04AxxxxA provides the hardware cyclic redundancy check (CRC), Advanced Encryption Standard 128 (AES128), hash, and True Random Number Generator (TRNG) hardware units. These hardware units can be used to verify data accuracy and data integrity during data transmission and storage and to encrypt and decrypt Flash data.

HK32F04AxxxxA incorporates a wide selection of communication interfaces:

- 2 × USARTs and 1 × LPUART (up to 12 Mbit/s)

The USARTs support the synchronous and asynchronous full-duplex or half-duplex communication, multiprocessor communication, LIN protocol, Smart Card protocol, and IrDA SIR ENDEC. The RX and TX pins can be exchanged by using the software. The USARTs and LPUART can wake up the MCU from Stop mode when receiving data.

- Up to 2 × high-speed SPIs/I2Ss (up to 18 Mbit/s)

The SPIs/I2Ss support the 4-bit to 16-bit full-duplex or half-duplex communication, master/slave mode, TI mode, NSS pulse mode, automatic CRC, and I2S protocol.

- Up to 2 × high-speed I2Cs (up to 1 Mbit/s)

The I2Cs support the 1 Mbit/s, 400 Kbit/s, and 100 Kbit/s transmission rates, master/slave mode, multimaster mode, 7-bit/10-bit addressing, and SMBus protocol. The I2Cs can wake up the MCU from Stop mode when receiving data.

HK32F04AxxxxA embeds a 16-bit advanced PWM timer (four PWM output channels in total, three of which have complementary PWM outputs with programmable inserted dead-times), a 32-bit and five 16-bit general-purpose PWM timers (up to four PWM output channels), a basic timer, and a 16-bit low-power timer.

HK32F04AxxxxA also incorporates the analog circuitry: a 12-bit ADC (16 analog signal input channels in total, differential pair input supported; sampling rate of up to 1 MSPS), a power-on reset (POR)/power-down reset (PDR) circuit, an internal reference voltage obtained from internal ADC sampling, and a 1/2  $V_{BAT}$  voltage divider circuit.

HK32F04AxxxxA integrates the division and square root hardware unit which provides higher performance than software and faster responses to external interrupts.

A hardware unit of motor algorithms is embedded in HK32F04AxxxxA, speeding up the processing of motor drive operations.

HK32F04AxxxxA has four configurable logic units (CLUs) for configurable synchronous and asynchronous Boolean logic operations.

Except for the power pin, ground pin, and NRST pin, all the other pins of HK32F04AxxxxA can be used as GPIOs, peripheral I/Os, or external interrupt inputs. This way, more pin functions can be provided.

HK32F04AxxxxA operates in the  $-40^{\circ}\text{C}$  to  $+105^{\circ}\text{C}$  temperature range, from a 1.8 V to 3.6 V power supply. It meets the environmental requirements of most applications.

With its wide range of peripherals, HK32F04AxxxxA is suitable for various applications:

- Programmable controllers, printers, and scanners
- Motor-driven devices and speed control
- Internet of Things (IoT) terminals, such as water meters, electricity meters, and gas meters

- Drone control, gimbal control
- Toys
- Household appliances
- Intelligent robots
- Smartwatches and fitness trackers
- Electronic toll collection (ETC)

## 2.1 Features

- CPU core
  - ARM® Cortex®-M0
  - Maximum frequency: 96 MHz
  - 24-bit SysTick timer
  - Supports the remapping of interrupt vectors (configured by using the Flash controller register)
- Operating voltage range
  - Single power domain (main power supply  $V_{DD}$ ): 1.8 V to 3.6 V
  - Backup power supply  $V_{BAT}$ : 1.8 V to 3.6 V
- Operating temperature range:  $-40^{\circ}\text{C}$  to  $+105^{\circ}\text{C}$
- Typical operating current
  - Run mode: 6.1 mA@96 MHz; 1.6 mA@8 MHz
  - Sleep mode: 4.7 mA@96 MHz
  - Stop mode:
    - LDO full-speed: 0.7 mA@3.3 V
    - LDO low-power: 60  $\mu\text{A}$ @3.3 V
  - Standby mode: 1.6  $\mu\text{A}$ @3.3 V
  - Shutdown mode: 0.4  $\mu\text{A}$ @3.3 V
- Memory
  - Up to 124 Kbytes of Flash
    - No wait state for Flash access when the CPU frequency is 24 MHz or lower
    - Separate read and write protection for Flash data
    - Encryption for instructions and data stored in the Flash, preventing the damage caused by physical attacks
  - 10-Kbyte SRAM
- Data security
  - CRC hardware implementation unit
  - Multiple encryption modules including AES and hash modules
- Clock
  - High-speed external clock (HSE): 4 MHz to 32 MHz, typical value: 8 MHz
  - Low-speed external clock (LSE): 32.768 kHz
  - High-speed internal clock (HSI): configurable to 8 MHz/14 MHz/56 MHz
  - Low-speed internal clock (LSI): 40 kHz

- PLL clock
- Chip pin input clock
- Reset
  - External pin reset
  - POR/PDR
  - Software reset
  - IWDG and WWDG reset
  - Low-power mode reset
- Programmable voltage detector (PVD)
  - Adjustable eight-level thresholds for detecting voltage
  - Rising edge and falling edge detection configurable
- GPIO
  - Up to 55 GPIO pins
  - Each GPIO pin can be used as an external interrupt input
  - Provide the drive current of up to 40 mA
- Data communication interface
  - 2 × USARTs: support synchronous transmission corresponding to SPI master mode and the modem operations. Provide the ISO7816 interface, LIN, IrDA capability, automatic baud rate detection, and the wakeup feature.
  - Up to 2 × high-speed SPIs: support 8-bit to 16-bit programmable data frames, I2S multiplexed.
  - Up to 2 × I2Cs: can operate in fast mode plus (1 Mbit/s) and support SMBus and PMBus. Can wake up the MCU from Stop mode when receiving data.
  - 1 × LPUART: supports asynchronous serial communication, single-wire half-duplex communication, modem operations (CTS/RTS), and multiprocessor communication in the lowest power mode.
  - 1 × CAN: compliant with Specification 2.0A and 2.0B (active).
- Timer and PWM generator
  - 1 × 16-bit advanced timer: with the break function and four PWM outputs in total, three of which have complementary PWM outputs with programmable inserted dead-times
  - 5 × 16-bit and 1 × 32-bit general-purpose timers: TIM2/TIM3/TIM14/TIM15/TIM16/TIM17
  - 1 × 16-bit basic timer: TIM6
  - 1 × low-power timer: LPTIM
- On-chip analog circuitry
  - 1 × 12-bit SAR ADC (up to 16 analog input channels)
  - Maximum frequency: 1 MSPS
  - Supports automatic continuous conversion and scan conversion
  - 3 × voltage comparators
- DMA controller (7-channel)
  - Can be triggered by peripherals such as the timer, ADC, SPI, I2C, USART, AES, and hash
- Temperature sensor
  - The analog output is connected to an independent ADC channel.
- CPU trace and debug
  - SWD debug port

- ARM® CoreSight™ debug component (ROM-Table, DWT, BPU)
- Customized DBGMCU debug controller (for low-power mode simulation control, debugged peripheral clock control, and debug and trace interfaces allocation)
- Division and square root calculation unit
  - Supports 32-bit fixed point division, with the quotient and remainder calculated
  - Supports 32-bit fixed point high-precision root calculation
- Four configurable logic units (CLUs) for handling simple logic operations
- Electric motor acceleration (EMACC) hardware unit for faster motor algorithm processing
- RTC
  - With the alarm function
  - Periodically wakes up the MCU from Stop or Standby mode
- 96-bit unique ID (UID) of each MCU
- Reliability
  - Passed HBM6000V/CDM2000V/MM200V/LU200mA level tests.

## 2.2 Device overview

Table 2-1 HK32F04AxxxxA series features

| Feature               |                       | HK32F04A<br>FxP6A                                                 | HK32F04A<br>GxU6A | HK32F04A<br>KxU6A | HK32F04A<br>KxT6A | HK32F04A<br>CxT6A | HK32F04A<br>RxT6A |
|-----------------------|-----------------------|-------------------------------------------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|
| Operating voltage     | Main power supply     | 1.8 V to 3.6 V                                                    |                   |                   |                   |                   |                   |
|                       | Backup power supply   | 1.8 V to 3.6 V                                                    |                   |                   |                   |                   |                   |
| Operating temperature |                       | −40°C to +105°C                                                   |                   |                   |                   |                   |                   |
| Memory                | Flash (Kbyte)         | 16/32/64/<br>124                                                  | 16/32/64/<br>124  | 16/32/64/<br>124  | 16/32/64/<br>124  | 16/32/64/<br>124  | 64/124            |
|                       | SRAM                  | 10 Kbytes                                                         |                   |                   |                   |                   |                   |
| CPU                   | Core                  | Cortex®-M0                                                        |                   |                   |                   |                   |                   |
|                       | Frequency             | 96 MHz                                                            |                   |                   |                   |                   |                   |
| DMA                   |                       | 7-channel (handles the ADC/SPI/I2C/USART/timer/AES/hash requests) |                   |                   |                   |                   |                   |
| DVSQ                  |                       | 1                                                                 |                   |                   |                   |                   |                   |
| Clock                 | LSI                   | 40 kHz                                                            |                   |                   |                   |                   |                   |
|                       | HSI                   | Configurable to 8 MHz/14 MHz/56 MHz (default: 56 MHz)             |                   |                   |                   |                   |                   |
|                       | PLL clock             | 1                                                                 |                   |                   |                   |                   |                   |
|                       | HSE                   | 8 MHz – 32 MHz                                                    |                   |                   |                   |                   |                   |
|                       | LSE                   | 32.768 kHz                                                        |                   |                   |                   |                   |                   |
| Timer                 | Advanced timer        | TIM1 (16-bit)                                                     |                   |                   |                   |                   |                   |
|                       | General-purpose timer | 32-bit: TIM2<br>16-bit: TIM3/TIM14/TIM15/TIM16/TIM17              |                   |                   |                   |                   |                   |
|                       | Basic timer           | TIM6 (16-bit)                                                     |                   |                   |                   |                   |                   |
|                       | Low-power timer       | LPTIM (16-bit)                                                    |                   |                   |                   |                   |                   |
|                       | SysTick timer         | 1                                                                 |                   |                   |                   |                   |                   |

| Feature                  |                     | HK32F04A<br>FxP6A                | HK32F04A<br>GxU6A | HK32F04A<br>KxU6A | HK32F04A<br>KxT6A | HK32F04A<br>CxT6A | HK32F04A<br>RxT6A |
|--------------------------|---------------------|----------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|
| Peripheral communication | RTC                 | 1                                |                   |                   |                   |                   |                   |
|                          | IWDG                | 1                                |                   |                   |                   |                   |                   |
|                          | WWDG                | 1                                |                   |                   |                   |                   |                   |
|                          | USART               | 2                                |                   |                   |                   |                   |                   |
|                          | LPUART              | 1                                |                   |                   |                   |                   |                   |
|                          | I2C                 | 1                                | 1                 | 2                 | 2                 | 2                 | 2                 |
| ADC                      | SPI/I2S             | 1                                | 1                 | 1                 | 1                 | 2                 | 2                 |
|                          | CAN (2.0A/2.0B)     | 1                                |                   |                   |                   |                   |                   |
|                          | Channels            | 9                                | 10                | 10                | 10                | 10                | 16                |
|                          | Reference selection | External reference voltage input |                   |                   |                   |                   |                   |
|                          | ADC sampling rate   | 1 MSPS                           |                   |                   |                   |                   |                   |
|                          | ADC accuracy        | 12-bit                           |                   |                   |                   |                   |                   |
|                          | EMACC               | 1                                |                   |                   |                   |                   |                   |
|                          | Voltage comparator  | 3                                |                   |                   |                   |                   |                   |
| CLU                      |                     | 4                                |                   |                   |                   |                   |                   |
| Info. security           | CRC                 | 1                                |                   |                   |                   |                   |                   |
|                          | 96-bit UID          | 1                                |                   |                   |                   |                   |                   |
|                          | Encryption module   | AES128                           |                   |                   |                   |                   |                   |
|                          | Hash                | SHA256                           |                   |                   |                   |                   |                   |
|                          | TRNG                | 1                                |                   |                   |                   |                   |                   |
| PVD                      |                     | 1                                |                   |                   |                   |                   |                   |
| GPIO                     |                     | 15                               | 23                | 27                | 25                | 39                | 55                |
| Package                  |                     | TSSOP20                          | QFN28             | QFN32             | LQFP32            | LQFP48            | LQFP64            |

## 3 Function description

### 3.1 Block diagram

ARM® Cortex®-M0 is a 32-bit RISC processor which provides an MCU platform featuring low cost and low power consumption. It delivers outstanding computational performance and advanced system responses to interrupts. With an embedded ARM® Cortex®-M0 core, the HK32F04AxxxxA family is compatible with ARM tools and software.

The block diagram of HK32F04ARBT6A is as follows:



Figure 3-1 HK32F04ARBT6A block diagram

## 3.2 Memory mapping



Figure 3-2 HK32F04AxxxxA memory mapping

## 3.3 Flash

HK32F04AxxxxA integrates a Flash memory of up to 124 Kbytes to store programs and data.

## 3.4 SRAM

HK32F04AxxxxA integrates a 10-Kbyte SRAM which can be accessed in words, half words, or bytes. The CPU can access the SRAM with no wait state, meeting the requirements of most applications.

## 3.5 Resets

### 3.5.1 System reset

The system reset resets all registers, except for the reset flags in the control/status register RCC\_CSR and the registers in the backup domain. You can identify the reset source by checking reset status flags in the RCC\_CSR register.



Figure 3-3 Reset signal

A system reset is generated when any of the following events occurs:

- Low level on the NRST pin (external reset)
- Window watchdog counting terminates (WWDG reset)
- Independent watchdog counting terminates (IWDG reset)
- Software reset (SW reset): The SYSRESETREQ bit in Cortex®-M0 Application Interrupt and Reset Control Register must be set to 1 to force a software reset on the device.
- Low-power management reset
- Option byte loading (OBL) reset

The reset sources act on the NRST pin and the NRST pin keeps the low level during resets. The reset routine vector is fixed at address 0x0000 0004.

The internal reset signals are output on the NRST pin. The pulse generator guarantees a reset pulse duration of at least 40 μs for each internal reset source. When the NRST pin is pulled low and an external reset is generated, the reset pulse is generated.

### 3.5.2 Power reset

A power reset is generated when any of the following events occurs:

- POR/PDR
- Exit from Standby mode

The power reset resets all registers, except for the registers in the backup domain.

HK32F04AxxxxA MCUs contain the POR/PDR circuitry. The circuitry keeps operating to ensure that the system runs properly when the power supply exceeds the 1.8 V threshold. When V<sub>DD</sub> is less than the POR/PDR threshold, the MCU will be reset without using any external reset circuit.

### 3.5.3 Backup domain reset

The backup domain has two resets that affect the backup domain exclusively.

A backup domain reset is generated when one of the following events occurs:

- Software reset triggered by the BDRST bit in the RCC\_BDCR register
- V<sub>DD</sub> and/or V<sub>BAT</sub> power-on after being powered down

## 3.6 Clocks and clock tree



Figure 3-4 Clock tree of HK32F04AxxxxA

As Figure 3-4 shows, HSI and HSI14 are generated by the same internal oscillator operating at 56 MHz. Therefore, when HSI or HSI14 is used, disabling the other clock cannot reduce power consumption. HSI/HSE can be used as the input of the phase-locked loop (PLL) prescaler. You can use HSI together with PLL to configure different system clock frequencies.

HK32F04AxxxxA MCUs use SYSCLK as the CPU clock when they start. The 56 MHz clock output by the internal oscillator, or the prescaled HSI or HSI14 can be used as the SYSCLK.

HK32F04AxxxxA provides more clock sources for the system clock and offers convenient, flexible, and diverse operating modes to customers. The following clocks can act as the system clock:

- 56 MHz HSI
- HSE
- PLL clock
- 14 MHz HSI14
- 8 MHz HSI
- 40 kHz LSI, which can drive the IWDG or be used as the RTC to automatically wake up the MCU from Stop/Standy mode
- 32.768 kHz LSE, which can drive the RTCCLK

In addition, PCLK can act as the I2C clock source.

## 3.7 Power supply scheme

- $V_{DD} = 1.8 \text{ V to } 3.6 \text{ V}$ . The  $V_{DD}$  pin supplies power to I/O pins and the internal low dropout regulators (LDOs).
- $V_{DDA} = 1.8 \text{ V to } 3.6 \text{ V}$ . The  $V_{DDA}$  pin supplies power to the analog circuitry, such as the ADC and temperature sensor.
- $V_{BAT} = 1.8 \text{ V to } 3.6 \text{ V}$ . When  $V_{DD}$  is powered off,  $V_{BAT}$  supplies power to the RTC, external 32.768 kHz oscillator, and backup registers.

## 3.8 Boot modes

The Boot0 pin and its configuration bit are used to select the system boot mode:

- Boot from Flash memory
- Boot from system memory
- Boot from internal SRAM

The bootloader program is stored in the system memory. The bootloader program can reprogram the Flash via the USART1 PA9/PA10 pin or USART2 PA14/PA15 pin.

## 3.9 PVD

HK32F04AxxxxA integrates a programmable voltage detector (PWD). The PVD monitors  $V_{DD}$  and compares it with the  $V_{PWD}$  threshold. When  $V_{DD}$  is below or over the  $V_{PWD}$  threshold, an interrupt is generated, and the interrupt program may send a warning message or set the MCU in the safe state. The PVD is enabled by setting the software.

## 3.10 Low-power modes

HK32F04AxxxxA supports multiple power consumption modes.

- Run mode

In Run mode, the CPU runs at full speed.

- Sleep mode

In Sleep mode, only the CPU stops. All peripherals keep operating. The CPU can be woken up when an interrupt or event occurs.

- Stop mode

In Stop mode, MCUs achieve the lowest power consumption while retaining the content in SRAM and registers. In Stop mode, all clocks in the core domain, the HSI RC oscillator, and the HSE crystal oscillator are disabled. MCUs can be woken up from Stop mode by any EXTI line. The EXTI line source can be any of the 16 external I/O pins, a PVD output, or an RTC alarm signal.

- Standby mode

In Standby mode, the MCU achieves the lowest power consumption. The internal LDO is off, so the entire 1.2 V domain is powered off. The PLL, HSI RC oscillator, and HSE crystal oscillator are disabled. The SRAM and register content is lost, except for registers in the backup domain. The Standby circuitry works as normal.

MCUs exit from Standby mode when an external reset on the NRST pin, an IWDG reset, a rising edge on the WKUP pin, or an RTC alarm occurs.

- Shutdown mode

In Shutdown mode, the MCU achieves extremely low power consumption as in Standby mode. All internal LDO power supplies (including the power supply of the backup domain) and all clock sources are off, except for the shutdown wakeup circuitry. MCUs exit from Shutdown mode when an external reset on the NRST pin, an IWDG reset, or a rising edge on the WKUP pin occurs. The backup domain is off, so the MCU cannot be woken up by an RTC alarm.

Table 3-1 Operating modes and power consumption

| Operating Mode | Power Consumption                                 | Wakeup Time                 |
|----------------|---------------------------------------------------|-----------------------------|
| Run mode       | Power consumption 1.6 mA/8 MHz@3.3 V              | -                           |
| Sleep mode     | Power consumption 1.3 mA/8 MHz@3.3 V              | 4.7 $\mu$ s                 |
| Stop mode      | Static power consumption 60 $\mu$ A@3.3 V         | 132 $\mu$ s (fastest speed) |
| Standby mode   | Static power consumption 1.6 $\mu$ A@3.3 V        | 152 $\mu$ s                 |
| Shutdown mode  | Lowest static power consumption 0.4 $\mu$ A@3.3 V | 364 $\mu$ s                 |

The conditions for entering and exiting low-power modes are listed in the following table:

Table 3-2 Conditions of entering and exiting low-power modes

| Operating Mode | Entry                                                                                                                                                                                                   | Exit                                                         |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
| Sleep          | 1. Set PWR_CR:LPDS = 0.<br>2. The software executes WFI/WFE instructions.                                                                                                                               | Any IRQ interrupt/event, including the SysTick timer.        |
| Stop           | 1. Set PWR_CR:LPDS = 0.<br>2. Set the SLEEPDEEP bit in the Cortex-M0 system control register. The software executes WFI/WFE instructions.                                                               | Any EXTI line.                                               |
| Standby        | 1. Set PWR_CR:LPDS = 0.<br>2. Set PWR_CR:PDSS = 1.<br>3. Set the SLEEPDEEP bit in the Cortex-M0 system control register.<br>4. The software executes WFI/WFE instructions.                              | Three polarity-configurable external pins, or the RTC alarm. |
| Shutdown       | 1. Set PWR_CR:LPDS = 0.<br>2. Set PWR_CR:PDSS = 1.<br>3. Set PWR_CSR2:SHDS = 1.<br>4. Set the SLEEPDEEP bit in the Cortex-M0 system control register.<br>5. The software executes WFI/WFE instructions. | Three polarity-configurable external pins.                   |

### 3.11 NVIC

HK32F04AxxxxA incorporates the nested vectored interrupt controller (NVIC). NVIC can flexibly manage up to 32 maskable interrupt channels (including 16 Cortex®-M0 interrupt lines) and four interrupt priorities with the lowest interrupt latency.

- The closely coupled NVIC ensures low latency during interrupt processing.
- The interrupt vector entry address is directly passed to the core.
- Provides the closely coupled NVIC interface.
- Allows the early processing of interrupts.
- Processes higher-priority interrupts even if they arrive late.
- Supports tail-chaining.
- Saves the processor state automatically.
- The previous state is resumed upon interrupt exit with no extra instruction needed.

Table 3-3 NVIC

| Position | Priority | Name         | Description | Address                                                                                        |
|----------|----------|--------------|-------------|------------------------------------------------------------------------------------------------|
| -        | -        | -            | Reserved    | 0x0000_0000                                                                                    |
| -        | -3       | Fixed        | Reset       | 0x0000_0004                                                                                    |
| -        | -2       | Fixed        | NMI         | Non-maskable interrupt.<br>The RCC clock security system (CSS) is connected to the NMI vector. |
| -        | -1       | Fixed        | HardFault   | All classes of faults                                                                          |
| -        | 3        | Configurable | SVCall      | System service call via SWI instruction                                                        |
| -        | 5        | Configurable | PendSV      | Pendable request for system service                                                            |
| -        | 6        | Configurable | SysTick     | SysTick timer                                                                                  |
| 0        | 7        | Configurable | WWDG        | Window watchdog interrupt                                                                      |
| 1        | 8        | Configurable | PVD         | PVD interrupt (through EXTI line 16)                                                           |
| 2        | 9        | Configurable | RTC         | RTC interrupt (through EXTI line 17, 19, and 20)                                               |
| 3        | 10       | Configurable | Flash       | Flash global interrupt                                                                         |
| 4        | 11       | Configurable | RCC         | RCC global interrupt                                                                           |

| Position | Priority |              | Name                | Description                                                     | Address     |
|----------|----------|--------------|---------------------|-----------------------------------------------------------------|-------------|
| 5        | 12       | Configurable | EXTI0_1             | EXTI Line[1:0] interrupts                                       | 0x0000_0054 |
| 6        | 13       | Configurable | EXTI2_3             | EXTI Line[3:2] interrupts                                       | 0x0000_0058 |
| 7        | 14       | Configurable | EXTI4_15            | EXTI Line[15:4] interrupts                                      | 0x0000_005C |
| 8        | 15       | Configurable | LPUART_IRQ          | LPUART interrupt (through EXTI line 28)                         | 0x0000_0060 |
| 9        | 16       | Configurable | DMA_CH1             | DMA channel 1 global interrupt                                  | 0x0000_0064 |
| 10       | 17       | Configurable | DMA_CH2_3           | DMA channel 2/3 interrupt                                       | 0x0000_0068 |
| 11       | 18       | Configurable | DMA_CH4_7           | DMA channel 4/5/6/7 interrupt                                   | 0x0000_006C |
| 12       | 19       | Configurable | ADC                 | ADC interrupt (through EXTI line 21, 22, 30, and 31)            | 0x0000_0070 |
| 13       | 20       | Configurable | TIM1_BRK_UP_TRG_COM | TIM1 break, update, trigger, and commutation interrupt          | 0x0000_0074 |
| 14       | 21       | Configurable | TIM1_CC             | TIM1 capture/compare interrupt                                  | 0x0000_0078 |
| 15       | 22       | Configurable | TIM2                | TIM2 global interrupt                                           | 0x0000_007C |
| 16       | 23       | Configurable | TIM3                | TIM3 global interrupt                                           | 0x0000_0080 |
| 17       | 24       | Configurable | TIM6                | TIM6 global interrupt                                           | 0x0000_0084 |
| 18       | 25       | Configurable | LPTIM               | LPTIM global interrupt (through EXTI line 29)                   | 0x0000_0088 |
| 19       | 26       | Configurable | TIM14               | TIM14 global interrupt (through EXTI line 32 connected to CLU0) | 0x0000_008C |
| 20       | 27       | Configurable | TIM15               | TIM15 global interrupt                                          | 0x0000_0090 |
| 21       | 28       | Configurable | TIM16               | TIM16 global interrupt (through EXTI line 33 connected to CLU1) | 0x0000_0094 |
| 22       | 29       | Configurable | TIM17               | TIM17 global interrupt                                          | 0x0000_0098 |
| 23       | 30       | Configurable | I2C1                | I2C1 global interrupt (through EXTI line 23)                    | 0x0000_009C |
| 24       | 31       | Configurable | I2C2                | I2C2 global interrupt (through EXTI line 24)                    | 0x0000_00A0 |
| 25       | 32       | Configurable | SPI1                | SPI1 global interrupt (through EXTI line 34 connected to CLU2)  | 0x0000_00A4 |
| 26       | 33       | Configurable | SPI2                | SPI2 global interrupt (through EXTI line 35 connected to CLU3)  | 0x0000_00A8 |
| 27       | 34       | Configurable | USART1              | USART1 global interrupt (through EXTI line 25)                  | 0x0000_00AC |
| 28       | 35       | Configurable | USART2              | USART2 global interrupt (through EXTI line 26)                  | 0x0000_00B0 |
| 29       | 36       | Configurable | AES_TRNG_HASH_EMACC | AES, TRNG, HASH, and EMACC global interrupt                     | 0x0000_00B4 |
| 30       | 37       | Configurable | CAN                 | CAN global interrupt                                            | 0x0000_00B8 |
| 31       | 38       | Configurable | DVSQ                | DVSQ global interrupt                                           | 0x0000_00BC |

### 3.12 EXTI

The external interrupt/event controller (EXTI) manages 34 interrupt lines that are used to generate interrupt/event requests and wake up the system through edge detection. The trigger event of each EXTI line can be configured and masked independently. The trigger event can be a rising edge, a falling edge, or both. The pending register stores the status of each interrupt request. EXTI can detect external interrupt line signals whose pulse width is shorter than the internal clock period. Up to 55 GPIOs can be connected to up to 16 external interrupt lines.

The EXTI lines from EXTI 0 to EXTI 15 are connected to I/O pins. The connections of the other EXTI lines are as follows:

- EXTI 16 connected to the PVD output
- EXTI 17 connected to the RTC alarm event

- EXTI 19 connected to the RTC tamper detection and timestamp event
- EXTI 20 connected to the RTC wakeup event
- EXTI 21 connected to the Comp1 output
- EXTI 22 connected to the Comp2 output
- EXTI 23 connected to the I2C1 wakeup event
- EXTI 24 connected to the I2C2 wakeup event
- EXTI 25 connected to the USART1 wakeup event
- EXTI 26 connected to the USART2 wakeup event
- EXTI 28 connected to the LPUART wakeup event
- EXTI 29 connected to the LPTIM wakeup event
- EXTI 30 connected to the Comp3 output
- EXTI 31 connected to the ADC AWD event
- EXTI 32 connected to the CLU0 output
- EXTI 33 connected to the CLU1 output
- EXTI 34 connected to the CLU2 output
- EXTI 35 connected to the CLU3 output

EXTI lines from EXTI 23 to EXTI 26, from EXTI 28 to EXTI 29, and EXTI 31 are connected to internal events and do not have the rising trigger selection register (RTSR), falling trigger selection register (FTSR), software interrupt event register (SWIER), and pending register (PR). These EXTI lines detect the rising edge of events in only Stop mode and generate the event request (ERQ) and interrupt request (IRQ) to wake up the system. The corresponding interrupt control bit and status bit are stored in the peripheral from which events are generated.

### 3.13 IWDG

The independent watchdog (IWDG) is based on a 12-bit downcounter and an 8-bit prescaler. The IWDG is clocked by an internal independent 40 kHz RC oscillator. The RC oscillator is independent of the main clock, so it can operate in Stop mode and Standby mode. The IWDG can work as a watchdog to reset the system when a problem occurs or as a free-running timer that provides timeout management for applications. The IWDG can be started by hardware or software through the configuration of the option bytes. In debug mode, the counter can be frozen.

You can set the IWDG\_WINR register to use IWDG in window mode.

### 3.14 WWDG

The window watchdog (WWDG) is based on an internal 7-bit downcounter. The counter can be set to the free running mode or used as a watchdog to reset the system when the system crashes. The WWDG is clocked by the main clock and has the early warning interrupt function. In debug mode, the counter can be frozen.

### 3.15 SysTick timer

The SysTick timer is a dedicated standard downcounter for the operating system. Its features include:

- 24-bit downcounter
- Auto-reload capability
- Generates a maskable interrupt when the counter reaches 0
- Programmable clock source

## 3.16 Timers

Each HK32F04AxxxxA MCU has an advanced timer, six general-purpose timers, a basic timer, and a low-power timer. The features of the timers are listed in the following table.

Table 3-4 Features of the timers

| Type                  | Timer | Counter Resolution | Counter Type      | Prescaler Factor | DMA Request | Break Input | Capture/Compare Channels | Complementary Outputs |
|-----------------------|-------|--------------------|-------------------|------------------|-------------|-------------|--------------------------|-----------------------|
| Advanced timer        | TIM1  | 16-bit             | Up, down, up/down | 0 – 0xFFFF       | Yes         | Yes         | 4                        | 3                     |
| General-purpose timer | TIM2  | 32-bit             | Up, down, up/down | 0 – 0xFFFF       | Yes         | No          | 4                        | No                    |
|                       | TIM3  | 16-bit             | Up, down, up/down | 0 – 0xFFFF       | Yes         | No          | 4                        | No                    |
|                       | TIM14 | 16-bit             | Up                | 0 – 0xFFFF       | No          | No          | 1                        | No                    |
|                       | TIM15 | 16-bit             | Up                | 0 – 0xFFFF       | Yes         | Yes         | 2                        | 1                     |
|                       | TIM16 | 16-bit             | Up                | 0 – 0xFFFF       | Yes         | Yes         | 1                        | 1                     |
|                       | TIM17 | 16-bit             | Up                | 0 – 0xFFFF       | Yes         | Yes         | 1                        | 1                     |
| Basic timer           | TIM6  | 16-bit             | Up                | 0 – 0xFFFF       | Yes         | No          | No                       | No                    |
| Low-power timer       | LPTIM | 16-bit             | Up                | 1/2/4...../128   | No          | No          | 1                        | No                    |

### 3.16.1 Basic timer

HK32F04AxxxxA integrates a basic timer TIM6.

TIM6 embeds a 16-bit upcounter and a 16-bit prescaler.

### 3.16.2 General-purpose timer

HK32F04AxxxxA integrates six general-purpose timers.

- TIM2 and TIM3

TIM2 is based on a 32-bit auto-reload up/down counter and a 16-bit prescaler. TIM3 is based on a 16-bit auto-reload up/down counter and a 16-bit prescaler. TIM2 and TIM3 have four independent channels respectively. The channels can be used for input capture, output compare, PWM output, and one-pulse mode output. In the LQFP64 package, up to 12 channels are available for input capture, output compare, and PWM output.

TIM2 and TIM3 can work with advanced timer TIM1 through the Timer Link feature for synchronization and event chaining. TIM2 and TIM3 can generate independent DMA requests. TIM2 and TIM3 can process quadrature (incremental) encoder signals and the digital outputs from one to three hall-effect sensors. In debug mode, the counter can be frozen.

- TIM14 and TIM15

TIM14 and TIM15 are based on a 16-bit auto-reload upcounter and a 16-bit prescaler respectively. TIM14 has a channel for input capture, output compare, PWM output, and one-pulse mode output. TIM15 has two channels, one of which is for complementary output. In debug mode, the counter can be frozen. TIM15 can generate DMA requests but TIM14 cannot.

- TIM16 and TIM17

TIM16 and TIM17 are based on a 16-bit auto-reload upcounter and a 16-bit prescaler respectively. TIM16 and TIM17 have a channel respectively for input capture, output compare, PWM output, and one-pulse mode output. TIM16 and TIM17 all have complementary outputs with programmable inserted dead-times and can generate independent DMA requests. In debug mode, the counter can be frozen.

### 3.16.3 Advanced timer

HK32F04AxxxxA integrates an advanced timer TIM1.

TIM1 can be deemed as a three-phase PWM generator with six channels or used as a complete general-purpose timer. The four independent channels of TIM1 can be used for:

- Input capture
- Output compare
- PWM generation (edge- or center-aligned mode)
- One-pulse mode output
- Three of the four channels have complementary PWM outputs with programmable inserted dead-times.

If TIM1 is configured as a 16-bit basic timer, it has the same functions as a basic timer. If the advanced timer is configured as a 16-bit PWM generator, it has full modulation capability (0–100%). Many functions of TIM1 are the same as those of general-purpose timers. Therefore, the advanced timer can work together with general-purpose timers through the Timer Link feature for synchronization or event chaining.

In debug mode, the counter can be frozen.

### 3.16.4 Low-power timer

HK32F04AxxxxA has a 16-bit low-power timer LPTIM.

LPTIM can work in Sleep mode and Stop mode. If no internal clock source is available, LPTIM can provide the pulse counter function. LPTIM can wake up the system from low-power modes.

The flexible clock schemes provided by LPTIM can minimize the power consumption of the system.

LPTIM has the following functions:

- 16-bit upcounter
- Prescaler (1/2/4/8/16/32/64/128)
- Clock sources for selection
- 16-bit auto-reload register
- 16-bit compare register
- Continuous/One-shot mode
- Software/Hardware input trigger configurable
- Programmable digital filter
- Configurable output

## 3.17 IRTIM

An infrared interface (IRTIM) is embedded in each HK32F04AxxxxA MCU. The IRTIM works with infrared LEDs to provide the remote control function. To generate infrared remote control signals, you must enable the IRTIM (PB9) and configure TIM16 channel 1 (TIM16\_OC1) and TIM17 channel 1 (TIM17\_OC1).

The infrared receiver function can be implemented by setting TIM16 channel 1 and TIM17 channel 1 to the basic input capture mode.

### 3.18 I2C

Up to two I2C bus interfaces are embedded in HK32F04AxxxxA MCUs. Each I2C bus interface has an output drive of 30 mA and can operate in master or slave mode at one of the following speeds:

- Standard mode (up to 100 Kbit/s)
- Fast mode (up to 400 Kbit/s)
- Fast mode plus (up to 1 Mbit/s)

The I2C bus interfaces support the 7-bit or 10-bit addressing mode and 7-bit dual addressing mode (as slave). The I2C interfaces embed hardware CRC generation/verification.

The I2C interfaces are compatible with SMBus 2.0 and PMBus 1.1. The address resolution protocol (ARP) capability, host notify protocol, hardware CRC (packet error checking, PEC) generation/verification, timeout verification, and alert protocol management are supported.

The I2C interfaces also have a clock independent of the CPU clock domain, so they can wake up the MCU from Stop mode when the address is matched.

The I2C interfaces have an analog filter and a digital filter. The following table lists the features of the filters:

Table 3-5 Programmable analog noise filter and digital noise filter

|                        | Analog Filter                                                        | Digital Filter                                                                                                                              |
|------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Suppressed pulse width | ≥ 50 ns                                                              | Programmable length from 1 to 15 I2C peripheral clock periods                                                                               |
| Advantage              | Available in Stop mode                                               | <ul style="list-style-type: none"> <li>• Extra filtering capability, standard requirements</li> <li>• Stable programmable length</li> </ul> |
| Disadvantage           | Performance changes along with the temperature, voltage, and process | When the digital filter is enabled, I2C cannot wake up the MCU from Stop mode even if the address is matched.                               |

### 3.19 USART

Two universal synchronous/asynchronous receivers/transmitters (USART1 and USART2) are embedded in each HK32F04AxxxxA MCU. They can communicate at up to 12 Mbit/s.

The USARTs provide hardware management for the CTS, RTS, and RS485 DE signals. The USARTs support the multiprocessor communication mode, host synchronous communication mode, and single-wire half-duplex communication mode. The USARTs also support Smart Card communication (ISO 7816), IrDA SIR ENDEC, LIN master/slave capability, and automatic baud rate detection. The USARTs can be served by the DMA controller.

The USARTs have a clock independent of the CPU clock domain, so they can wake up the MCU from Stop mode.

Table 3-6 USART1/USART2 features

| Feature                                      | USART1/USART2 |
|----------------------------------------------|---------------|
| Modem hardware flow control                  | Supported     |
| DMA continuous transmission                  | Supported     |
| Multiprocessor communication                 | Supported     |
| Synchronous mode                             | Supported     |
| Smart Card mode                              | Supported     |
| Single-wire half-duplex communication        | Supported     |
| IrDA SIR ENDEC                               | Supported     |
| LIN mode                                     | Supported     |
| Dual clock domains and wakeup from Stop mode | Supported     |
| Receiver timeout interrupt                   | Supported     |
| Modbus communication                         | Supported     |
| Automatic baud rate detection                | Supported     |
| Driver enable                                | Supported     |

### 3.20 LPUART

HK32F04AxxxxA incorporates a low-power universal asynchronous receiver/transmitter (LPUART) which can

communicate at up to 10 Mbit/s. The LPUART supports asynchronous serial communication, single-wire half-duplex communication, and modem operations (CTS/RTS) in low-power mode. It also supports multiprocessor communication.

The LPUART has a clock independent of the CPU clock domain. It can wake up the MCU from Stop mode at a baud rate of up to 4.8 Kbit/s. The LPUART can wake up the MCU from Stop mode when any of the following events occurs:

- Start bit detection event
- Interrupt of receiving any data frame
- Receiving specific programming data frame

When using the 32.768 kHz LSE, the LPUART can communicate at up to 9600 baud. In Stop mode, the LPUART waits for incoming frames at extremely low power consumption. If the LPUART uses a faster clock, it can communicate at a higher baud rate.

The LPUART can be served by the DMA controller.

## 3.21 SPI/I2S

Up to two SPI interfaces operating at up to 18 Mbit/s are embedded in HK32F04AxxxxA MCUs. The SPI interfaces support master and slave modes and full-duplex or half-duplex communication. The 3-bit prescaler generates eight frequencies of master mode. Each frame can be configured to 4- to 16-bit.

Table 3-7 SPI1/SPI2 features

| SPI Feature              | SPI1/SPI2 |
|--------------------------|-----------|
| Hardware CRC calculation | Supported |
| RX/TX FIFO               | Supported |
| NSS pulse mode           | Supported |
| I2S mode                 | Supported |
| TI mode                  | Supported |

The standard I2S interfaces (with SPI multiplexed) provide four types of audio standards and can operate in master/slave half-duplex communication mode. The I2S interfaces have dedicated signals for data synchronization. The data format can be 16-bit, 24-bit, or 32-bit and the I2S interfaces can operate with 16- or 32-bit resolution. The I2S interfaces can be set to an audio sampling frequency from 8 kHz to 192 kHz by the 8-bit programmable linear prescaler. When working in master mode, the I2S interface can output a clock of 256 times the sampling frequency to external audio components.

Table 3-8 I2S features

| I2S Feature                         | I2S       |
|-------------------------------------|-----------|
| Half-duplex mode                    | Supported |
| Master/Slave mode configurable      | Supported |
| 8-bit programmable linear prescaler | Supported |
| Data format programmable            | Supported |
| Clock polarity programmable         | Supported |
| I2S protocol                        | Supported |
| DMA transmission                    | Supported |
| Driving external audio components   | Supported |

## 3.22 GPIO

Each GPIO pin can be configured by software as an output pin (push-pull or open-drain), an input pin (floating, pull-up, or pull-down), or a peripheral alternate function pin. Most of the GPIO pins are shared by digital and analog peripherals. All GPIOs are high current capable. I/O alternate functions can be locked as needed to avoid unexpected writes to the I/O registers.

### 3.23 DMA

The 7-channel general-purpose DMA controller manages the data transfer from memories to memories, from devices to memories, and from memories to devices. The DMA controller supports circular buffer management, preventing the interrupt that occurs when the DMA controller reaches the end of the buffer.

Each channel is connected to a dedicated hardware DMA request and can be triggered by using software. The length, source, and destination of data to be transferred can be independently set by using the software. DMA can be used with the main peripherals, such as SPI, I2C, USART, TIMx, SDIO, and ADC.

### 3.24 ADC

The 12-bit analog-to-digital converter (ADC) has the following functions:

- Up to 16 external channels and three internal channels (temperature sensor, reference voltage, and  $V_{BAT}$ )
- Performs A/D conversion in single-channel or in multi-channel scan mode. In scan mode, the conversion is automatically performed on a selected group of analog inputs.
- Can be served by the DMA controller
- Supports the sampling of  $1/2 V_{BAT}$
- Can be triggered by external trigger sources

The analog watchdog function can realize precise monitoring of one, some, or all selected channels. If the converted voltage exceeds the threshold set by the program, an interrupt is generated.

### 3.25 CAN

The CAN interface is compliant with Specification 2.0A and 2.0B (active). The highest bit rate is 1 Mbit/s. The CAN interface can receive and transmit standard frames with 11-bit identifiers as well as extended frames with 29-bit identifiers. The CAN interface has three transmit mailboxes and two 3-stage receive FIFOs. Each FIFO has 14 scalable filters.

### 3.26 RTC clock

In all operating modes of HK32F04AxxxxA (including the Standby mode), a real-time clock (RTC) and five backup registers are provided. The backup registers are 32-bit registers. They are used to store 20 bytes of user application data. The system reset and wakeup from the Standby mode do not reset backup registers.

The RTC has programmable periodic wakeup flags with the interrupt function.

The digital calibration feature compensates for deviation in the crystal oscillator accuracy.

After the RTC domain is reset, unexpected writes to all RTC registers are prevented.

As long as the power supply voltage of the MCU is within the operating range, the RTC keeps working in all modes of the MCU.

The RTC is an independent binary-coded decimal (BCD) timer/counter. It has the following features:

- Calendar with sub-seconds, seconds, minutes, hours (12- or 24-hour format), day of week, day of month, month, and year in BCD
- Automatic adjustment to the days of different months: 28 days, 29 days (leap year), 30 days, and 31 days. Adjustment of daylight saving time supported.
- Two programmable alarms that can wake up the MCU from Stop or Standby mode
- Programmable resolution and periodic wakeup from Stop or Standby mode
- Correction of 1 to 32,767 RTC clock pulses during runtime for synchronization between RTC and the main clock

- Reference clock detection: a more accurate secondary clock source (50 Hz or 60 Hz) that can improve calendar accuracy
- Digital calibration circuit with 1 ppm resolution for compensation of deviation in the crystal oscillator accuracy
- Two tamper detection pins with programmable filters. Wakeup from Stop or Standby mode when any tamper event is detected
- Timestamp feature used for storage of calendar content. The timestamp feature can be triggered by the event on the timestamp pin or by the tamper event. MCUs can be woken up from Stop or Standby mode when any timestamp event is detected.

The RTC clock source can be:

- 32.768 kHz external crystal oscillator
- Low-power internal RC oscillator (typical frequency: 40 kHz)
- HSE divided by 32

## 3.27 Information security

### 3.27.1 AES128

HK32F04AxxxxA integrates an Advanced Encryption Standard 128 (AES128) unit compliant with Federal Information Processing Standards 197 (FIPS 197).

- Supports the Electronic Code Book (ECB) mode
  - Supports the 128-bit, 192-bit, and 256-bit keys for encryption
  - Encryption computation time:
    - 128-bit key: 57 clock periods
    - 192-bit key: 67 clock periods
    - 256-bit key: 77 clock periods
  - Decryption computation time:
    - 128-bit key: 57 clock periods
    - 192-bit key: 67 clock periods
    - 256-bit key: 77 clock periods
  - After calling a single decryption operation, enter the decryption key in the AES\_KEYRx register again. Even if the decryption key adopted in this decryption is the same as that of the previous decryption, you still need to enter the decryption key again.
- Supports the randomization of the AES clock by using TRNG.
- More convenient protection of the register content and easier resumption of the context when interrupts occur.
- Supports data transmission by using DMA (two DMA channels required)

### 3.27.2 Hash

The hash module is applicable to data authentication applications. It is compliant with the following protocols:

- Federal Information Processing Standards Publications 180-2 (FIPS PUB 180-2)
- Secure Hash Algorithm 256 (SHA-256)

The SHA-256 fast computation processing module is a slave peripheral attached to the AHB. It receives 32-bit data in words, half-words, bytes, and bits. The SHA-256 module only supports data stored in little-endian mode.

The input data in little-endian mode is automatically converted to the big-endian mode adopted by SHA-256. The last input data in little-endian mode is automatically padded to fit the digest minimum block size of 512 bits ( $16 \times 32$  bits). The digest of the whole message is obtained by adding the 32-bit words of the digests of consecutive message blocks. The data flow can be automatically controlled by using DMA.

### 3.27.3 TRNG

The true random number generator (TRNG) provides a 32-bit random number based on continuous analog noise when the CPU reads data. TRNG has the following features:

- Provides 32-bit random numbers generated by the analog generator.
- The interval at which two random numbers are generated is 40 RNG\_CLK (48 MHz) periods.
- The entropy of RNG is monitored for the identification of exceptional behaviors (generation of stable values or stable value sequences).
- TRNG can be disabled to reduce system power consumption.

### 3.28 CRC calculation unit

The cyclic redundancy check (CRC) is used to verify the integrity of data during transmission and storage. HK32F04AxxxxA integrates a CRC hardware calculation unit. It is used to get a CRC code from an 8-, 16- or 32-bit data word by using a generator polynomial.

The CRC calculation unit computes a signature of the software during runtime. This signature is to be compared with a reference signature generated at link time and stored at a specified memory location.

### 3.29 EMACC

The Electric Motor Acceleration (EMACC) unit can be used on brushless direct current (BLDC) motors controlled by the field-oriented control (FOC) algorithm. EMACC accelerates the mathematical operations of motor drives. Mathematical operations can be completed at a speed higher than that of software-based mathematical operations while occupying less CPU resources. The EMACC-embedded MCUs support higher motor rotation speeds under the same CPU frequency.

The Coordinate Rotation Digital Computer (CORDIC) algorithm, Clarke, Park, and Inverse Park transformations, and proportional-integral-derivative (PID) control of the FOC algorithm are implemented by hardware, which reduces CPU usage and speeds up computing. Users input three-phase currents  $I_a$ ,  $I_b$ , and  $I_c$ . After the processing by EMACC, the input  $U_\alpha$  and  $U_\beta$  of space vector pulse width modulation (SVPWM) can be obtained. EMACC decreases the time consumed by the FOC algorithm.

EMACC can significantly increase algorithm efficiency.

### 3.30 DVSQ calculation unit

The division and square root (DVSQ) calculation unit has the following features:

- Supports the 32-bit signed integer division (SDIV), unsigned integer division (UDIV), and root calculation.
  - The DVSQ calculation unit supports either the division or root calculation at one time.
  - The quotient and remainder of 32-bit SDIV and UDIV are updated to the corresponding register.
  - The MOD operation is supported in the division.
- High-precision root calculation can be selected for unsigned integer root calculation by using the software.
- In the streamlined design, a 2-bit calculation is completed in each clock period.
- The calculation time varies based on the calculation data.
- Supports divide-by-zero interrupt and overflow interrupt.

### 3.31 CLU

HK32F04AxxxxA embeds a configurable logic module (CLM). The CLM offers several programmable digital logic blocks which can operate without using the CPU resource. The CLM consists of four dedicated configurable logic units (CLUs) for configurable synchronous and asynchronous Boolean logic operations. The input of each CLU can be an internal or external signal, and the output of each CLU can be connected to an I/O pin or to the input of a specified peripheral.

The CLU has the following features:

- Each CLU supports 65,536 combinations of logical functions, such as AND, OR, XOR, or multiplexing, and has a clock trigger used for synchronization.
- Synchronous and asynchronous operations are supported.
- CLUs can be cascaded to realize more complex logical functions.
- CLUs can be used in conjunction with timers or serial peripherals such as UART and SPI.
- CLUs can be used to synchronize and trigger multiple on-chip resources (such as ADC and timers).
- The output of asynchronous operations can be used to wake up the MCU from low-power modes.

### 3.32 Voltage comparator

HK32F04AxxxxA has three built-in voltage comparators: COMP1, COMP2, and COMP3. The three comparators can be used as independent window comparators or used together.

### 3.33 Internal reference voltage

The internal reference voltage  $V_{REFINT}$  provides a stable voltage output for the ADC and comparators.  $V_{REFINT}$  is internally connected to the ADC\_IN17 input channel. The  $V_{REFINT}$  memory address can only be read.

Table 3-9 Internal voltage benchmark value

| Value Name        | Description                                                                            | Memory Address          |
|-------------------|----------------------------------------------------------------------------------------|-------------------------|
| $V_{REFINT\_CAL}$ | The original data obtained under 25°C temperature. $V_{DDA} = 3.3$ V<br>( $\pm 10$ mV) | 0xFFFF F7BA-0x1FFF F7BB |

### 3.34 Temperature sensor

The temperature sensor generates a voltage that varies linearly based on the temperature. The temperature sensor is internally connected to the ADC1\_IN16 input channel which is used to convert the sensor output voltage into a digital value.

The temperature sensor is accurate, but it still needs to be calibrated to ensure the accuracy of overall temperature measurement. The temperature sensor offset of different MCUs varies based on the manufacturing processes of the MCUs. Therefore, uncalibrated temperature sensors are suited only for applications that measure temperature changes. All HK32F04AxxxxA MCUs are factory-calibrated to ensure the measurement accuracy of the temperature sensors. The factory calibration data of temperature sensors is stored in the system memory and can only be read.

### 3.35 96-bit UID

The 96-bit unique identifier (UID) provides a reference number for each HK32F04AxxxxA MCU. The UID is unique in any circumstances. You are not allowed to modify the UID. The 96-bit UID can be read in bytes (8 bits), half words (16 bits), or words (32 bits) for different applications. The 96-bit UID can be used:

- As a serial number. For example, as a USB string serial number or used for other terminal applications.
- As a security key. When programming the Flash, use the UID together with software encryption and decryption algorithms to enhance the security of code in the Flash.

- To activate the boot processes that have the security mechanism.

### 3.36 Debug port

Based on the ARM SWJ-DP embedded in HK32F04AxxxxA, SWDIO/SWCLK functions are available.

## 4 Electrical characteristics

### 4.1 Absolute maximum values

The absolute maximum values are stress test values within a short period.

Note:

- Do not use the device in conditions equal to or exceeding the absolute maximum values.
- Stresses beyond the absolute maximum values listed in [Table 4-1](#) to [Table 4-26](#) may cause permanent damage to the device.
- If the device works under the maximum values for extended periods, its reliability may deteriorate.

#### 4.1.1 Voltage characteristics

Table 4-1 Voltage characteristics

| Symbol               | Description                                                            | Min            | Max      | Unit |
|----------------------|------------------------------------------------------------------------|----------------|----------|------|
| $V_{DD} - V_{SS}$    | External main power supply voltage (including $V_{DDA}$ and $V_{DD}$ ) | -0.3           | 3.75     | V    |
| $V_{IN}$             | Input voltage on pins                                                  | $V_{SS} - 0.3$ | $V_{DD}$ |      |
| $ \Delta V_{DDX} $   | Variation between different power pins                                 | -              | 50       | mV   |
| $ V_{SSX} - V_{SS} $ | Variation between different ground pins                                | -              | 50       |      |

#### 4.1.2 Current characteristics

Table 4-2 Current characteristics

| Symbol               | Description                                                       | Max      | Unit |
|----------------------|-------------------------------------------------------------------|----------|------|
| $I_{VDD}$            | Total current into $V_{DD}/V_{DDA}$ (source) <sup>(1)</sup>       | 100      |      |
| $I_{VSS}$            | Total current from $V_{SS}$ (sink) <sup>(1)</sup>                 | -100     |      |
| $I_{IO}$             | Output current sunk by any I/O and control pin                    | 20       |      |
|                      | Output current sourced by any I/O and control pin                 | -40      |      |
| $I_{INJ(PIN)}^{(2)}$ | Injected current on pins <sup>(3)</sup>                           | $\pm 5$  |      |
| $\sum I_{INJ(PIN)}$  | Total injected current (all I/Os and control pins) <sup>(4)</sup> | $\pm 25$ |      |

(1). All main power ( $V_{DD}$ ,  $V_{DDA}$ ) and ground ( $V_{SS}$ ,  $V_{SSA}$ ) pins must be connected to the external power supply within the permitted range all the time.

(2). Negative injected current causes the analog performance of the device to fluctuate.

(3). When  $V_{IN}$  is larger than  $V_{DD}$ , a positive injected current is induced; when  $V_{IN}$  is smaller than  $V_{SS}$ , a negative injected current is induced. The injected current must be within the permitted range.

(4). If multiple I/Os have current injection simultaneously, the maximum  $\sum I_{INJ(PIN)}$  is the sum of the absolute instantaneous values of positive and negative injected currents.

#### 4.1.3 Temperature characteristics

Table 4-3 Temperature characteristics

| Symbol    | Description                  | Value       | Unit |
|-----------|------------------------------|-------------|------|
| $T_{STG}$ | Storage temperature range    | -45 to +125 | °C   |
| $T_J$     | Maximum junction temperature | 125         |      |

## 4.2 Operating conditions

### 4.2.1 Recommended operating conditions

Table 4-4 Recommended operating conditions

| Symbol      | Description                   | Min | Max | Unit |
|-------------|-------------------------------|-----|-----|------|
| $f_{HCLK}$  | Internal AHB clock frequency  | 0   | 96  |      |
| $f_{PCLK1}$ | Internal APB1 clock frequency | 0   | 96  | MHz  |
| $f_{PCLK2}$ | Internal APB2 clock frequency | 0   | 96  |      |

| Symbol                          | Description                | Min | Max | Unit |
|---------------------------------|----------------------------|-----|-----|------|
| V <sub>DD</sub>                 | Standard operating voltage | 1.8 | 3.6 | V    |
| V <sub>DDA</sub> <sup>(1)</sup> | Analog operating voltage   | 1.8 | 3.6 | V    |
| T                               | Operating temperature      | -40 | 105 | °C   |

(1). V<sub>DDA</sub> can be lower than V<sub>DD</sub>. For example, V<sub>DD</sub> = 3.6 V, V<sub>DDA</sub> = 3.3 V; V<sub>DD</sub> = 3.3 V, V<sub>DDA</sub> = 2.5 V.

## 4.2.2 PVD characteristics

Table 4-5 PVD characteristics

| Symbol           | Parameter                                                                    | Condition      | Min  | Typ  | Max  | Unit |
|------------------|------------------------------------------------------------------------------|----------------|------|------|------|------|
| V <sub>PVD</sub> | Programmable voltage detector level selection (V <sub>DD</sub> rising edge)  | PLS[2:0] = 000 | 2.10 | 2.23 | 2.36 | V    |
|                  |                                                                              | PLS[2:0] = 001 | 2.19 | 2.33 | 2.47 |      |
|                  |                                                                              | PLS[2:0] = 010 | 2.31 | 2.43 | 2.55 |      |
|                  |                                                                              | PLS[2:0] = 011 | 2.40 | 2.53 | 2.66 |      |
|                  |                                                                              | PLS[2:0] = 100 | 2.49 | 2.63 | 2.77 |      |
|                  |                                                                              | PLS[2:0] = 101 | 2.60 | 2.74 | 2.88 |      |
|                  |                                                                              | PLS[2:0] = 110 | 2.68 | 2.84 | 3.00 |      |
|                  | Programmable voltage detector level selection (V <sub>DD</sub> falling edge) | PLS[2:0] = 111 | 2.80 | 2.94 | 3.08 |      |
|                  |                                                                              | PLS[2:0] = 000 | 2.11 | 2.21 | 2.31 |      |
|                  |                                                                              | PLS[2:0] = 001 | 2.21 | 2.31 | 2.41 |      |
|                  |                                                                              | PLS[2:0] = 010 | 2.31 | 2.41 | 2.51 |      |
|                  |                                                                              | PLS[2:0] = 011 | 2.40 | 2.51 | 2.62 |      |
|                  |                                                                              | PLS[2:0] = 100 | 2.50 | 2.61 | 2.72 |      |
|                  |                                                                              | PLS[2:0] = 101 | 2.59 | 2.71 | 2.83 |      |
|                  |                                                                              | PLS[2:0] = 110 | 2.69 | 2.81 | 2.93 |      |
|                  |                                                                              | PLS[2:0] = 111 | 2.78 | 2.91 | 3.04 |      |

## 4.2.3 POR/PDR characteristics

Table 4-6 POR/PDR characteristics

| Symbol                               | Parameter         | Condition                   | Min | Typ  | Max  | Unit |
|--------------------------------------|-------------------|-----------------------------|-----|------|------|------|
| V <sub>POR/PDR</sub> <sup>(1)</sup>  | POR/PDR threshold | Falling edge <sup>(2)</sup> | -   | 1.70 | -    | V    |
|                                      |                   | Rising edge                 | -   | 1.64 | -    | V    |
| V <sub>PDRHyst</sub>                 | PDR hysteresis    | -                           | -   | 60   | -    | mV   |
| t <sub>RSTTEMPO</sub> <sup>(3)</sup> | Reset duration    | -                           | 3.0 | 3.50 | 4.50 | ms   |

(1) PDR is based on the monitoring of V<sub>DD</sub> and V<sub>DDA</sub>. POR is based on the monitoring of only V<sub>DD</sub>.

(2) The actual performance value is guaranteed to be smaller than the minimum V<sub>POR/PDR</sub> value.

(3) The value is guaranteed in design.

## 4.2.4 Internal reference voltage

Table 4-7 Internal reference voltage characteristics

| Symbol              | Parameter                  | Condition      | Min  | Typ | Max  | Unit |
|---------------------|----------------------------|----------------|------|-----|------|------|
| V <sub>REFINT</sub> | Internal reference voltage | -40°C to 105°C | 1.15 | 1.2 | 1.23 | V    |

## 4.2.5 Operating current characteristics

Table 4-8 Operating current characteristics

| Mode | Condition                                                                   | Parameter         | -40°C, V <sub>DD</sub> = 3.3 V | 25°C, V <sub>DD</sub> = 3.3 V | 85°C, V <sub>DD</sub> = 3.3 V | 105°C, V <sub>DD</sub> = 3.3 V | Unit |
|------|-----------------------------------------------------------------------------|-------------------|--------------------------------|-------------------------------|-------------------------------|--------------------------------|------|
| Run  | HCLK = 96 MHz,<br>seven wait states for FLASH_LATENCY,<br>APB clock enabled | Operating current | 10.636                         | 9.777                         | 10.301                        | 10.743                         | mA   |

| Mode | Condition                                                                             | Parameter         | -40°C, V <sub>DD</sub> = 3.3 V | 25°C, V <sub>DD</sub> = 3.3 V | 85°C, V <sub>DD</sub> = 3.3 V | 105°C, V <sub>DD</sub> = 3.3 V | Unit |
|------|---------------------------------------------------------------------------------------|-------------------|--------------------------------|-------------------------------|-------------------------------|--------------------------------|------|
|      | HCLK = 96 MHz,<br>seven wait states for FLASH_LATENCY,<br>APB clock disabled          |                   | 6.933                          | 6.062                         | 6.578                         | 7.008                          | mA   |
|      | HCLK = HSE (8 MHz),<br>zero wait states for FLASH_LATENCY,<br>APB clock enabled       |                   | 2.857                          | 1.950                         | 2.433                         | 2.844                          | mA   |
|      | HCLK = HSE (8 MHz),<br>zero wait states for FLASH_LATENCY,<br>APB clock disabled      |                   | 2.543                          | 1.641                         | 2.122                         | 2.533                          | mA   |
|      | HCLK = LSE (32.768 kHz),<br>zero wait states for FLASH_LATENCY,<br>APB clock enabled  |                   | 0.995                          | 1.080                         | 1.567                         | 1.912                          | mA   |
|      | HCLK = LSE (32.768 kHz),<br>zero wait states for FLASH_LATENCY,<br>APB clock disabled |                   | 0.994                          | 1.078                         | 1.565                         | 1.908                          | mA   |
|      | HCLK = LSI (40 kHz),<br>zero wait states for FLASH_LATENCY,<br>APB clock enabled      |                   | 0.996                          | 1.080                         | 1.517                         | 1.914                          | mA   |
|      | HCLK = LSI (40 kHz),<br>zero wait states for FLASH_LATENCY,<br>APB clock disabled     |                   | 0.994                          | 1.079                         | 1.514                         | 1.909                          | mA   |
|      | Sleep                                                                                 |                   | 5.676                          | 4.786                         | 5.286                         | 5.710                          | mA   |
|      | HCLK = HSE (96 MHz),<br>APB clock disabled                                            | Operating current | 1.275                          | 1.363                         | 1.796                         | 2.191                          | mA   |
|      | HCLK = HSI (8 MHz),<br>APB clock disabled                                             | Wakeup time       | -                              | 4.7                           | -                             | -                              | μs   |
|      |                                                                                       | Operating current | 0.993                          | 1.077                         | 1.561                         | 1.905                          | mA   |
|      | HCLK = LSE (32.768 kHz),<br>APB clock disabled                                        | Operating current | 0.993                          | 1.077                         | 1.510                         | 1.905                          | mA   |
|      | HCLK = LSI (40 kHz),<br>APB clock disabled                                            | Operating current | 0.628                          | 0.688                         | 1.099                         | 1.487                          | mA   |
|      | Stop                                                                                  | Wakeup time       | -                              | 20                            | -                             | -                              | μs   |
|      |                                                                                       | Operating current | 18.227                         | 60.026                        | 393.768                       | 708.269                        | μA   |
|      | LDO in the low-power state<br>HSE/HSI/LSE disabled<br>IWDG disabled                   | Wakeup time       | -                              | 132                           | -                             | -                              | μs   |
|      |                                                                                       | Operating current | 1.834                          | 2.254                         | 6.004                         | 10.898                         | μA   |
|      | Standby                                                                               | Wakeup time       | -                              | 152                           | -                             | -                              | μs   |
|      |                                                                                       | Operating current | 1.829                          | 2.253                         | 5.993                         | 10.883                         | μA   |
|      | All oscillators disabled.                                                             | Wakeup time       | -                              | 152                           | -                             | -                              | μs   |
|      |                                                                                       | Operating current | 1.154                          | 1.642                         | 5.393                         | 10.285                         | μA   |
|      |                                                                                       | Wakeup time       | -                              | 152                           | -                             | -                              | μs   |
|      | Shutdown                                                                              | Operating current | 1.465                          | 2.002                         | 165.692                       | 10.606                         | μA   |
|      |                                                                                       | Wakeup time       | -                              | 96                            | -                             | -                              | μs   |
|      | LSE disabled and RTC stopped<br>(BKPPDS = 0)                                          | Operating current | 1.152                          | 1.633                         | 5.306                         | 10.112                         | μA   |
|      |                                                                                       | Wakeup time       | -                              | 96                            | -                             | -                              | μs   |

| Mode | Condition                         | Parameter         | -40°C, V <sub>DD</sub> = 3.3 V | 25°C, V <sub>DD</sub> = 3.3 V | 85°C, V <sub>DD</sub> = 3.3 V | 105°C, V <sub>DD</sub> = 3.3 V | Unit |
|------|-----------------------------------|-------------------|--------------------------------|-------------------------------|-------------------------------|--------------------------------|------|
|      | LSE and RTC disabled (BKPPDS = 1) | Operating current | 0.319                          | 0.406                         | 1.027                         | 2.446                          | μA   |
|      |                                   | Wakeup time       | -                              | 364                           | -                             | -                              | μs   |

#### 4.2.6 HSE clock characteristics

Table 4-9 HSE clock characteristics

| Symbol                | Parameter                                                                                                   | Condition                                                     | Min | Typ  | Max | Unit |
|-----------------------|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-----|------|-----|------|
| fosc_IN               | Oscillator frequency                                                                                        | -                                                             | 4   | 8    | 32  | MHz  |
| R <sub>F</sub>        | Feedback resistor                                                                                           | -                                                             | -   | 2    | -   | MΩ   |
| T <sub>SU</sub> (HSE) | Oscillator startup time                                                                                     | V <sub>SS</sub> ≤ V <sub>IN</sub> ≤ V <sub>DD</sub>           | 3   | -    | 4   | μs   |
| C                     | Recommended load capacitance minus equivalent serial resistance of the crystal oscillator (R <sub>s</sub> ) | -                                                             | -   | 12.5 | -   | PF   |
| I <sub>DD</sub> (HSE) | HSE oscillator power consumption                                                                            | Normal operation: V <sub>DD</sub> = 3.3 V, CL = 12.5 pF@8 MHz | 60  | 100  | 300 | μA   |

HK32F04AxxxxA integrates an HSE negative feedback circuit supplied with a resonator. The following oscillator circuit outside the chip is recommended:



Figure 4-1 HSE crystal oscillator circuit with negative feedback

Alternatively, HK32F04AxxxxA can be clocked from the OSC\_IN pin. The following table lists the requirements for this clock signal:

Table 4-10 Characteristics of the input HSE clock

| Symbol                                 | Parameter                                  | Condition | Min                | Typ | Max                | Unit |
|----------------------------------------|--------------------------------------------|-----------|--------------------|-----|--------------------|------|
| f <sub>HSE_ext</sub>                   | External clock source frequency            | -         | 1                  | 8   | 25                 | MHz  |
| V <sub>HSEH</sub>                      | High level voltage on the OSC_IN input pin | -         | 0.7V <sub>DD</sub> | -   | V <sub>DD</sub>    | V    |
| V <sub>HSEL</sub>                      | Low level voltage on the OSC_IN input pin  | -         | V <sub>SS</sub>    | -   | 0.3V <sub>DD</sub> | V    |
| t <sub>H(HSE)/t<sub>L(HSE)</sub></sub> | High or low time of OSC_IN                 | -         | 5                  | -   | -                  | ns   |
| t <sub>r(HSE)/t<sub>f(HSE)</sub></sub> | Rise or fall time of OSC_IN                | -         | -                  | -   | 20                 | ns   |
| C <sub>in(HSE)</sub>                   | OSC_IN input capacitance                   | -         | -                  | 5   | -                  | pF   |
| DuCy(HSE)                              | Duty cycle                                 | -         | 45                 | -   | 55                 | %    |

## 4.2.7 LSE clock characteristics

Table 4-11 LSE clock characteristics ( $f_{LSE} = 32.768 \text{ kHz}$ )

| Symbol        | Parameter                                                                                 | Condition                                                                         | Min | Typ  | Max  | Unit             |
|---------------|-------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----|------|------|------------------|
| $R_F$         | Feedback resistor                                                                         | -                                                                                 | -   | 2    | -    | $\text{M}\Omega$ |
| $T_{su(LSE)}$ | Oscillator startup time                                                                   | $V_{SS} \leq V_{IN} \leq V_{DD}$                                                  | -   | -    | 2000 | ms               |
| C             | Recommended load capacitance minus equivalent serial resistance of the crystal oscillator | -                                                                                 | -   | 12.5 | -    | pF               |
| $I_2$         | LSE driving current                                                                       | -                                                                                 | -   | 400  | -    | nA               |
| $I_{DD(LSE)}$ | LSE oscillator power consumption                                                          | Normal operation: $V_{DD} = 3.3 \text{ V}$ , $CL = 12.5 \text{ pF}@8 \text{ MHz}$ | -   | 80   | 100  | $\mu\text{A}$    |

HK32F04AxxxxA integrates an LSE negative feedback circuit supplied with a resonator. The following oscillator circuit outside the chip is recommended:



Figure 4-2 LSE crystal oscillator circuit with negative feedback

Alternatively, HK32F04AxxxxA can be clocked from the OSC32\_IN pin. The following table lists the requirements for this clock signal.

Table 4-12 Characteristics of the input LSE clock

| Symbol              | Parameter                                  | Condition | Min          | Typ    | Max          | Unit |
|---------------------|--------------------------------------------|-----------|--------------|--------|--------------|------|
| $f_{LSE\_ext}$      | External clock source frequency            | -         | -            | 32.768 | 1000         | kHz  |
| $V_{LSEH}$          | High level voltage on the OSC_IN input pin | -         | 0.7 $V_{DD}$ | -      | $V_{DD}$     | V    |
| $V_{LSEL}$          | Low level voltage on the OSC_IN input pin  | -         | $V_{SS}$     | -      | 0.3 $V_{DD}$ | V    |
| $t_H(LSE)/t_L(LSE)$ | High or low time of OSC_IN                 | -         | 450          | -      | -            | ns   |
| $t_r(LSE)/t_f(LSE)$ | Rise or fall time of OSC_IN                | -         | -            | -      | 50           | ns   |
| $C_{in(LSE)}$       | OSC_IN input capacitance                   | -         | -            | 5      | -            | pF   |
| $DuC_y(LSE)$        | Duty cycle                                 | -         | 30           | -      | 70           | %    |

## 4.2.8 HSI clock characteristics

Table 4-13 HSI clock characteristics

| Symbol       | Parameter               | Condition                                         | Min                                                      | Typ  | Max | Unit          |
|--------------|-------------------------|---------------------------------------------------|----------------------------------------------------------|------|-----|---------------|
| $f_{HSI}$    | Frequency               | -                                                 | -                                                        | 8    | -   | MHz           |
| $DuC_y(HSI)$ | Duty cycle              | -                                                 | 45                                                       | -    | 55  | %             |
| ACC(HSI)     | HSI oscillator accuracy | RCC_CR register calibration completed by the user | -                                                        | -    | 1   | %             |
|              |                         | Factory calibrated                                | $T_A = -40^\circ\text{C} \text{ to } +105^\circ\text{C}$ | -1.5 | -   | 1.5           |
|              |                         |                                                   | $T_A = -40^\circ\text{C} \text{ to } +85^\circ\text{C}$  | -1.0 | -   | 1.0           |
| $T_{su(HS)}$ | Oscillator startup time | $V_{SS} \leq V_{IN} \leq V_{DD}$                  | 3                                                        | -    | 4   | $\mu\text{s}$ |
|              |                         |                                                   |                                                          |      |     |               |

| Symbol               | Parameter                    | Condition | Min | Typ | Max | Unit |
|----------------------|------------------------------|-----------|-----|-----|-----|------|
| I <sub>DD(HSI)</sub> | Oscillator power consumption | -         | -   | 80  | 100 | μA   |

#### 4.2.9 LSI clock characteristics

Table 4-14 LSI clock characteristics

| Symbol               | Parameter                    | Condition                                           | Min | Typ | Max | Unit |
|----------------------|------------------------------|-----------------------------------------------------|-----|-----|-----|------|
| f <sub>LSI</sub>     | Frequency                    | -                                                   | 34  | 40  | 46  | kHz  |
| T <sub>SU(LSI)</sub> | Oscillator startup time      | V <sub>SS</sub> ≤ V <sub>IN</sub> ≤ V <sub>DD</sub> | -   | 150 | -   | μs   |
| I <sub>DD(LSI)</sub> | Oscillator power consumption | -                                                   | -   | 0.5 | -   | μA   |

#### 4.2.10 PLL characteristics

Table 4-15 PLL characteristics

| Symbol               | Parameter              | Min | Typ | Max | Unit |
|----------------------|------------------------|-----|-----|-----|------|
| f <sub>PLL_IN</sub>  | Input clock frequency  | 2   | 8.0 | 80  | MHz  |
|                      | Input clock duty cycle | 40  | -   | 60  | %    |
| f <sub>PLL_OUT</sub> | Output clock frequency | 16  | -   | 120 | MHz  |
| t <sub>LOCK</sub>    | PLL lock time          | -   | 80  | 120 | μs   |
| Jitter               | Cycle-to-cycle jitter  | -   | 5   | 13  | ps   |

#### 4.2.11 Flash memory characteristics

Table 4-16 Flash memory characteristics

| Symbol               | Parameter                         | Min     | Typ <sup>(1)</sup> | Max | Unit   |
|----------------------|-----------------------------------|---------|--------------------|-----|--------|
| T <sub>PROG</sub>    | Half word programming time        | -       | 42                 | -   | μs     |
|                      | One-word programming time         | -       | 42                 | -   | μs     |
| T <sub>ERASE</sub>   | Half page erase time              | -       | 3.7                | -   | ms     |
|                      | Page erase time                   | -       | 7.45               | -   | ms     |
|                      | Mass erase time                   | -       | 190                | -   | ms     |
| IDD <sub>PROG</sub>  | Programming current               | -       | 1.5                | 5   | mA     |
| IDD <sub>ERASE</sub> | Page/Mass erase current           | -       | 0.9                | 2   | mA     |
| IDD <sub>READ</sub>  | Supply current@24 MHz (read mode) | -       | 2.5                | -   | mA     |
| N <sub>END</sub>     | Endurance                         | 100,000 | -                  | -   | Cycles |
| t <sub>RET</sub>     | Data retention                    | 10      | -                  | -   | Years  |

(1). The typical values are obtained in the following conditions: 1.5 V, TT process corner, 25°C.

#### 4.2.12 I/O pin input characteristics

Table 4-17 I/O pin input direct current characteristics

| Symbol             | Parameter                          | Condition                                            | Min  | Typ | Max  | Unit |
|--------------------|------------------------------------|------------------------------------------------------|------|-----|------|------|
| V <sub>IH</sub>    | Input high level voltage           | V <sub>DD</sub> = 3.3 V                              | 1.82 | -   | -    | V    |
| V <sub>IL</sub>    | Input low level voltage            | V <sub>DD</sub> = 3.3 V                              | -    | -   | 1.3  | V    |
| V <sub>IHHys</sub> | Input high level voltage           | V <sub>DD</sub> = 3.3 V                              | 1.64 | -   | -    | V    |
| V <sub>ILHys</sub> | Input low level voltage            | V <sub>DD</sub> = 3.3 V                              | -    | -   | 1.44 | V    |
| V <sub>Hys</sub>   | Schmitt trigger voltage hysteresis | V <sub>DD</sub> = 3.3 V                              | -    | 160 | -    | mV   |
| I <sub>lk</sub>    | Input leakage current              | V <sub>DD</sub> = 3.3 V; 0 < V <sub>IN</sub> < 3.3 V | -    | -   | 0.01 | μA   |
|                    |                                    | V <sub>DD</sub> = 3.3 V; V <sub>IN</sub> = 5 V       | -    | -   | 1.65 | μA   |
| R <sub>PU</sub>    | Pull-up resistor                   | V <sub>IN</sub> = V <sub>SS</sub>                    | -    | 33  | -    | kΩ   |
| R <sub>PD</sub>    | Pull-down resistor                 | V <sub>IN</sub> = V <sub>DD</sub>                    | -    | 34  | -    | kΩ   |
| C <sub>io</sub>    | I/O pin capacitance                | -                                                    | -    | 5   | -    | pF   |

## 4.2.13 I/O pin output characteristics

Table 4-18 I/O pin output alternating current characteristics

| Mode<br>OSPEEDy[1:0]           | Symbol          | Parameter                          | Condition                           | Min | Typ  | Max | Unit |
|--------------------------------|-----------------|------------------------------------|-------------------------------------|-----|------|-----|------|
| x0                             | $t_{f(I/O)out}$ | Output high to low level fall time | CL = 50 pF, V <sub>DD</sub> = 3.3 V | -   | 9.50 | -   | ns   |
|                                | $t_{r(I/O)out}$ | Output low to high level rise time |                                     | -   | 22.7 | -   | ns   |
| 01                             | $t_{f(I/O)out}$ | Output high to low level fall time | CL = 50 pF, V <sub>DD</sub> = 3.3 V | -   | 5.0  | -   | ns   |
|                                | $t_{r(I/O)out}$ | Output low to high level rise time |                                     | -   | 6.70 | -   | ns   |
| 11                             | $t_{f(I/O)out}$ | Output high to low level fall time | CL = 50 pF, V <sub>DD</sub> = 3.3 V | -   | 4.25 | -   | ns   |
|                                | $t_{r(I/O)out}$ | Output low to high level rise time |                                     | -   | 5.00 | -   | ns   |
| OSPEEDy[1:0] = 11 and UHDy = 1 | $t_{f(I/O)out}$ | Output high to low level fall time | CL = 50 pF, V <sub>DD</sub> = 3.3 V | -   | 3.35 | -   | ns   |
|                                | $t_{r(I/O)out}$ | Output low to high level rise time |                                     | -   | 3.85 | -   | ns   |

## 4.2.14 NRST pin characteristics

The NRST pin is connected to a pull-up resistor. Its peripheral application circuit can connect to an external RC circuit or no circuit.

Table 4-19 NRST pin input characteristics

| Symbol             | Parameter                  | Min | Max | Unit |
|--------------------|----------------------------|-----|-----|------|
| T <sub>Noise</sub> | Low level ignored duration | -   | 50  | ns   |

## 4.2.15 TIM timer characteristics

Table 4-20 TIM pin input characteristics

| Symbol           | Condition                                    | Min | Max                                    | Unit |
|------------------|----------------------------------------------|-----|----------------------------------------|------|
| F <sub>EXT</sub> | Timer external clock frequency on CH1 to CH4 | 0   | F <sub>TIMxCLK</sub> /2 <sup>(1)</sup> | MHz  |

(1).  $f_{TIMxCLK} = 96$  MHz

## 4.2.16 EMACC characteristics

Table 4-21 Motor drive frequency characteristics

| System Clock | ADC Clock                                        | Min | Typ | Max    | Unit |
|--------------|--------------------------------------------------|-----|-----|--------|------|
| 48 MHz       | $f_{PCLK} = f_{apb}$<br>$f_{ADC} = f_{PCLK}/4$   | -   | 20  | 21±0.3 | kHz  |
| 72 MHz       | $f_{PCLK} = f_{apb}$<br>$f_{ADC} = f_{PCLK}/4$   | -   | 24  | 25±0.3 | kHz  |
| 96 MHz       | $f_{PCLK} = f_{apb}/2$<br>$f_{ADC} = f_{PCLK}/4$ | -   | 28  | 29±0.3 | kHz  |

Table 4-22 Comparison between the software and the FOC algorithm with EMACC

| Test Condition                                      | Electrical Angle | Coordinate System Conversion | Software-based SVPWM | Total Time Consumption | Unit |
|-----------------------------------------------------|------------------|------------------------------|----------------------|------------------------|------|
| System clock: 48 MHz (software-based motor library) | 12               | 13                           | 7                    | 32                     | μs   |
| System clock: 48 MHz (EMACC-powered motor library)  | 12               | 2.8                          | 7                    | 21.8                   | μs   |

## 4.2.17 ADC characteristics

Table 4-23 ADC characteristics

| Item                             | Description                                                                                                        | Condition                                                                                                            | Min                                                                                 | Typ | Max              | Unit                 |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----|------------------|----------------------|
| V <sub>DDA</sub>                 | Analog power supply voltage when ADC is enabled                                                                    | -                                                                                                                    | 2.4                                                                                 | -   | 3.6              | V                    |
| INL                              | Integral non linearity (maximum difference between the actual conversion point and the end point correlation line) | f <sub>ADC</sub> = 14 MHz<br>R <sub>Ain</sub> < 10 kΩ<br>Test after calibration<br>V <sub>DDA</sub> = 2.4 V to 3.6 V | -                                                                                   | ±1  | -2 to 3          | LSB                  |
| DNL                              | Differential non linearity (maximum difference between the actual step and the ideal step)                         | f <sub>ADC</sub> = 14 MHz<br>R <sub>Ain</sub> < 10 kΩ<br>Test after calibration<br>V <sub>DDA</sub> = 2.4 V to 3.6 V | -                                                                                   | ±1  | -2 to 3          | LSB                  |
| f <sub>ADC</sub>                 | ADC clock frequency                                                                                                | -                                                                                                                    | 0.6                                                                                 | -   | 14               | MHz                  |
| f <sub>S</sub> <sup>(1)</sup>    | Sampling frequency                                                                                                 | -                                                                                                                    | 0.05                                                                                | -   | 1                | MHz                  |
| f <sub>TRIG</sub> <sup>(1)</sup> | External trigger frequency                                                                                         | f <sub>ADC</sub> = 14 MHz                                                                                            | -                                                                                   | -   | 823              | kHz                  |
|                                  |                                                                                                                    | -                                                                                                                    | -                                                                                   | -   | 17               | 1/f <sub>ADC</sub>   |
| V <sub>Ain</sub>                 | Conversion voltage range                                                                                           | -                                                                                                                    | 0                                                                                   | -   | V <sub>DDA</sub> | V                    |
| R <sub>Ain</sub> <sup>(1)</sup>  | External input impedance                                                                                           | For details, see Table 4-24.                                                                                         | -                                                                                   | -   | 60               | kΩ                   |
| R <sub>ADC</sub> <sup>(1)</sup>  | Sampling switch resistance                                                                                         | -                                                                                                                    | -                                                                                   | -   | 1                | kΩ                   |
| C <sub>ADC</sub> <sup>(1)</sup>  | Sampling and hold capacitor                                                                                        | -                                                                                                                    | -                                                                                   | -   | 5                | pF                   |
| t <sub>CAL</sub> <sup>(2)</sup>  | ADC calibration time                                                                                               | f <sub>ADC</sub> = 14 MHz                                                                                            | 5.9                                                                                 |     |                  | μs                   |
|                                  |                                                                                                                    | -                                                                                                                    | 8.3                                                                                 |     |                  | 1/f <sub>ADC</sub>   |
| t <sub>latr</sub>                | Trigger conversion latency                                                                                         | f <sub>ADC</sub> = f <sub>PCLK</sub> /2 = 14 MHz                                                                     | 0.196                                                                               |     |                  | μs                   |
|                                  |                                                                                                                    | f <sub>ADC</sub> = f <sub>PCLK</sub> /2                                                                              | 5.5                                                                                 |     |                  | 1/f <sub>PCLK</sub>  |
|                                  |                                                                                                                    | f <sub>ADC</sub> = f <sub>PCLK</sub> /4 = 12 MHz                                                                     | 0.219                                                                               |     |                  | μs                   |
|                                  |                                                                                                                    | f <sub>ADC</sub> = f <sub>PCLK</sub> /4                                                                              | 10.5                                                                                |     |                  | 1/f <sub>PCLK</sub>  |
|                                  |                                                                                                                    | f <sub>ADC</sub> = f <sub>HSI14</sub> = 14 MHz                                                                       | 0.188                                                                               | -   | 0.259            | μs                   |
| Jitter <sub>ADC</sub>            | Jitters triggered by ADC conversions                                                                               | f <sub>ADC</sub> = f <sub>HSI14</sub>                                                                                | -                                                                                   | 1   | -                | 1/f <sub>HSI14</sub> |
| t <sub>s</sub> <sup>(1)</sup>    | Sampling time                                                                                                      | f <sub>ADC</sub> = 14 MHz                                                                                            | 0.107                                                                               |     | 17.1             | μs                   |
|                                  |                                                                                                                    | -                                                                                                                    | 1.5                                                                                 |     | 239.5            | 1/f <sub>ADC</sub>   |
| t <sub>STAB</sub> <sup>(1)</sup> | Sampling stable time                                                                                               | -                                                                                                                    | 14                                                                                  |     |                  | μs                   |
| t <sub>CONV</sub> <sup>(1)</sup> | Total conversion time (including sampling time)                                                                    | f <sub>ADC</sub> = 14 MHz<br>12-bit resolution                                                                       | 1                                                                                   | -   | 18               | μs                   |
|                                  |                                                                                                                    | 12-bit resolution                                                                                                    | 14 to 252 (t <sub>CONV</sub> = sampling time t <sub>s</sub> + conversion time 12.5) |     |                  | 1/f <sub>ADC</sub>   |

(1). The value is guaranteed in design but not tested in production.

(2). The values are measured based on the ADC clock. The register access latency is not taken into account.

The calculation formula of the maximum input impedance R<sub>Ain</sub>:

$$R_{Ain} < \frac{Ts}{f_{ADC} \times C_{ADC} \times \ln(2^{N+2})} - R_{ADC}$$

The value of N (resolution) is 12.

The allowable error can be lower than 1/4 least significant bit (LSB).

Table 4-24 Maximum input impedance values (f<sub>ADC</sub> = 14 MHz)

| Sampling Cycles (Cycles) | Sampling Time t <sub>S</sub> (μs) | Maximum Input Impedance (kΩ) |
|--------------------------|-----------------------------------|------------------------------|
| 1.5                      | 0.11                              | 1.21                         |
| 7.5                      | 0.54                              | 10.05                        |
| 13.5                     | 0.96                              | 18.88                        |
| 28.5                     | 2.04                              | 40.97                        |
| 41.5                     | 2.96                              | 60.12                        |
| 55.5                     | 3.96                              | 80.74                        |
| 71.5                     | 5.11                              | N/A                          |
| 239.5                    | 17.1                              | N/A                          |

Table 4-25 ADC accuracy

| Symbol | Parameter                                   | Test Condition                                                                                                                 | Typ     | Max     | Unit |
|--------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|---------|---------|------|
| ET     | Total unadjusted error <sup>(1)</sup>       | SystemCLK = 56 MHz<br>ADCCLK = 14 MHz<br>Input impedance < 10 kΩ<br>$V_{DD} = V_{DDA} = 3.305$ V<br>Test after ADC calibration | -1 to 1 | -2 to 3 | LSB  |
| EO     | Offset error <sup>(2)</sup>                 |                                                                                                                                | 1       | 0 to 2  |      |
| EG     | Gain error <sup>(3)</sup>                   |                                                                                                                                | 3       | 1 to 3  |      |
| ED     | Differential linearity error <sup>(4)</sup> |                                                                                                                                | -1 to 1 | -2 to 3 |      |
| EL     | Integral linearity error <sup>(5)</sup>     |                                                                                                                                | -1 to 1 | -2 to 3 |      |

(1). Total unadjusted error: The maximum deviation between the actual transfer curve and the ideal transfer curve.

(2). Offset error: The deviation between the first actual conversion and the first ideal conversion.

(3). Gain error: The deviation between the last ideal conversion and the last actual conversion.

(4). Differential linearity error: The maximum deviation between the actual step and the ideal step.

(5). Integral linearity error: The maximum deviation between any actual transition and the endpoint correlation line.

#### Note:

- The ADC direct current accuracy values are measured after internal calibration.
- ADC accuracy and negative current injection: Avoid injecting negative currents on any standard (non-robust) analog input pin. Otherwise, the accuracy of the conversion being performed on another analog input pin is greatly reduced. It is recommended that you add a Schottky diode (pin to ground) to the standard analog pins on which negative currents may be injected.
- With restricted  $V_{DDA}$ , frequency, and temperature ranges, better ADC performance can be achieved.
- The data is based on characterization but not tested in production.



Figure 4-3 ADC accuracy characteristics

Note: For the explanations of EO, ET, EG, EL, and ED, see [Table 4-25](#).



Figure 4-4 Typical connection diagram of ADC

- (1). For the ADC characteristics of  $R_{ADC}$  and  $C_{ADC}$ , see [Table 4-23](#).
- (2).  $C_{parasitic}$  equals the PCB capacitance (decided by soldering and the PCB layout quality) plus the pad capacitance (about 7 pF). A high  $C_{parasitic}$  value would reduce conversion accuracy, so  $f_{ADC}$  should be reduced.

PCB design recommendation for ADC sampling: The power supply decoupling should be performed by following section "[5 Typical circuitry](#)". To ensure the ADC conversion accuracy, the 10 nF capacitors should be ceramic and placed close to the chip.

#### 4.2.18 Temperature sensor characteristics

Table 4-26 Temperature sensor characteristics

| Symbol    | Parameter                          | Condition | Min  | Typ  | Max  | Unit  |
|-----------|------------------------------------|-----------|------|------|------|-------|
| $T_L$     | Temperature sensor linearity error | -         | -    | ±1   | ±3   | °C    |
| $V_{25}$  | Output voltage                     | 25°C      | 0.85 | 0.89 | 0.93 | V     |
| Avg_Slope | Temperature sensor slope           | -         | -    | 3    | -    | mV/°C |

## 5 Typical circuitry



Figure 5-1 Power supply reference circuitry

## 6 Pinouts and pin descriptions

HK32F04Axxxx MCUs are delivered in TSSOP20, QFN28, QFN32, LQFP32, LQFP48, and LQFP64 packages. The pinouts of the packages are as follows:

### 6.1 TSSOP20



Figure 6-1 TSSOP20 (HK32F04AFxP6A) pinout

## 6.2 QFN28



Figure 6-2 QFN28 (HK32F04AGxU6A) pinout

## 6.3 QFN32



Figure 6-3 QFN32 (HK32F04AKxU6A) pinout

## 6.4 LQFP32



Figure 6-4 LQFP32 (HK32F04AKxT6A) pinout

## 6.5 LQFP48



Figure 6-5 LQFP48 (HK32F04ACxT6A) pinout

## 6.6 LQFP64



Figure 6-6 LQFP64 (HK32F04ARxT6A) pinout

## 6.7 Pin descriptions

Table 6-1 Pin description of each package

| TSSOP20 | QFN28 | QFN32 | QFN32 | LQFP32 | LQFP48 | LQFP64 | Pin Name | Pin Type <sup>(1)</sup> | 5 V-tolerant                                  | Alternate Function                                | Additional Function |
|---------|-------|-------|-------|--------|--------|--------|----------|-------------------------|-----------------------------------------------|---------------------------------------------------|---------------------|
| -       | -     | -     | -     | 1      | 1      | VBAT   | S        |                         |                                               | Battery power supply input                        |                     |
| -       | -     | -     | -     | 2      | 2      | PC13   | I/O      | FT                      | -                                             | RTC_TAMP1<br>RTC_TS<br>RTC_OUT<br>WKUP2<br>EXTI13 |                     |
| -       | -     | -     | -     | 3      | 3      | PC14   | I/O      | FT                      | -                                             | OSC32_IN<br>EXTI14                                |                     |
| -       | -     | -     | -     | 4      | 4      | PC15   | I/O      | FT                      | -                                             | OSC32_OUT<br>EXTI15                               |                     |
| 2       | 2     | 2     | 2     | 5      | 5      | PF0    | I/O      | FT                      | I2C1_SDA                                      | OSC_IN                                            |                     |
| 3       | 3     | 3     | 3     | 6      | 6      | PF1    | I/O      | FT                      | I2C1_SCL                                      | OSC_OUT                                           |                     |
| 4       | 4     | 4     | 4     | 7      | 7      | NRST   | I/O      | -                       | Reset input/internal reset output, active low |                                                   |                     |
| -       | -     | -     | -     | -      | 8      | PC0    | I/O      | -                       | LPTIM_IN1                                     | ADC_IN10<br>EXTI0                                 |                     |
| -       | -     | -     | -     | -      | 9      | PC1    | I/O      | -                       | LPTIM_OUT                                     | ADC_IN11<br>EXTI1                                 |                     |
| -       | -     | -     | -     | -      | 10     | PC2    | I/O      | -                       | SPI2_MISO<br>I2S2_MCK<br>LPTIM_IN2            | ADC_IN12<br>EXTI2                                 |                     |
| -       | -     | -     | -     | -      | 11     | PC3    | I/O      | -                       | SPI2_MOSI<br>I2S2_SD                          | ADC_IN13<br>EXTI3                                 |                     |

| TSSOP20 | QFN28 | QFN32 | LQFP32 | LQFP48 | LQFP64 | Pin Name | Pin Type <sup>(1)</sup> | 5 V-tolerant | Alternate Function                                                                                                                       | Additional Function                               |
|---------|-------|-------|--------|--------|--------|----------|-------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
|         |       |       |        |        |        |          |                         |              | LPTIM_ETR                                                                                                                                |                                                   |
| -       | -     | -     | -      | 8      | 12     | VSSA     | S                       | -            | Analog ground                                                                                                                            |                                                   |
| 5       | 5     | 5     | 5      | 9      | 13     | VDDA     | S                       | -            | Analog power supply                                                                                                                      |                                                   |
| 6       | 6     | 6     | 6      | 10     | 14     | PA0      | I/O                     | -            | USART1_CTS<br>USART2_CTS<br>TIM2_CH1<br>TIM2_ETR<br>CMP1_INN1/CMP1_OUT<br>LPUART_RX<br>LPTIM_IN1<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O | ADC_IN0<br>WKUP1<br>RTC_TAMP2<br>EXTCLK4<br>EXTIO |
| 7       | 7     | 7     | 7      | 11     | 15     | PA1      | I/O                     | -            | USART1_RTS/USART1_DE<br>USART2_RTS/USART2_DE<br>TIM15_CH1N<br>TIM2_CH2<br>CMP1_INP1<br>LPTIM_IN2<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O | ADC_IN1<br>EXTI1                                  |
| 8       | 8     | 8     | 8      | 12     | 16     | PA2      | I/O                     | -            | USART1_TX<br>USART2_TX<br>TIM15_CH1<br>TIM2_CH3<br>CMP2_INN1<br>CMP2_OUT<br>LPTIM_ETR<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O            | ADC_IN2<br>EXTI2                                  |
| 9       | 9     | 9     | 9      | 13     | 17     | PA3      | I/O                     | -            | USART1_RX<br>USART2_RX<br>TIM15_CH2<br>TIM2_CH4<br>CMP2_INP1<br>LPTIM_OUT<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O                        | ADC_IN3<br>EXTI3                                  |
| -       | -     | -     | -      | -      | 18     | PF4      | I/O                     | -            | -                                                                                                                                        | ADC_AIN17<br>EXTI4                                |
| -       | -     | -     | -      | -      | 19     | PF5      | I/O                     | FT           | -                                                                                                                                        | EXTI5                                             |
| 10      | 10    | 10    | 10     | 14     | 20     | PA4      | I/O                     | -            | SPI1_NSS<br>I2S1_WS<br>USART1_CK<br>USART2_CK<br>TIM14_CH1<br>CMP1_INN2<br>CMP2_INN2<br>CMP3_INN2<br>CLU0_O<br>CLU1_O<br>CLU2_O          | ADC_IN4<br>EXTCLK1<br>EXTI4                       |

| TSSOP20 | QFN28 | QFN32 | LQFP32 | LQFP48 | LQFP64 | Pin Name | Pin Type <sup>(1)</sup> | 5 V-tolerant | Alternate Function                                                                                                                               | Additional Function |
|---------|-------|-------|--------|--------|--------|----------|-------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
|         |       |       |        |        |        |          |                         |              | CLU3_O<br>DAC1_AOUT0                                                                                                                             |                     |
| 11      | 11    | 11    | 11     | 15     | 21     | PA5      | I/O                     | -            | SPI1_SCK<br>I2S1_CK<br>TIM2_CH1<br>TIM2_ETR<br>CMP1_INN3<br>CMP2_INN3<br>CMP3_INN1<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O                       | ADC_IN5<br>EXTI5    |
| 12      | 12    | 12    | 12     | 16     | 22     | PA6      | I/O                     | -            | SPI1_MISO<br>I2S1_MCK<br>TIM3_CH1<br>TIM1_BKIN<br>TIM16_CH1<br>CMP1_OUT<br>LPUART_CTS<br>CAN_RX<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O          | ADC_IN6<br>EXTI6    |
| 13      | 13    | 13    | 13     | 17     | 23     | PA7      | I/O                     | -            | SPI1_MOSI<br>I2S1_SD<br>TIM3_CH2<br>TIM14_CH1<br>TIM1_CH1N<br>TIM17_CH1<br>RCC_MCO<br>CMP2_OUT<br>CAN_TX<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O | ADC_IN7<br>EXTI7    |
| -       | -     | -     | -      | -      | 24     | PC4      | I/O                     | -            | LPUART_TX                                                                                                                                        | ADC_IN14<br>EXTI4   |
| -       | -     | -     | -      | -      | 25     | PC5      | I/O                     | -            | LPUART_RX                                                                                                                                        | ADC_IN15<br>EXTI5   |
| -       | 14    | 14    | 14     | 18     | 26     | PB0      | I/O                     | -            | TIM3_CH3<br>TIM1_CH2N<br>CMP3_INN3                                                                                                               | ADC_IN8<br>EXTI0    |
| 14      | 15    | 15    | 15     | 19     | 27     | PB1      | I/O                     |              | TIM3_CH4<br>TIM14_CH1<br>TIM1_CH3N<br>CMP3_INN1/CMP3_O<br>UT<br>LPUART_RTS/LPUART<br>_DE<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O                 | ADC_IN9<br>EXTI1    |
| -       | -     | 16    | -      | 20     | 28     | PB2      | I/O                     | FT           | I2C1_SMBA<br>I2C2_SMBA<br>LPTIM_OUT                                                                                                              | EXTI2               |
| -       | -     | -     | -      | 21     | 29     | PB10     | I/O                     | FT           | I2C1_SCL<br>I2C2_SCL<br>SPI2_SCK                                                                                                                 | EXTI10              |

| TSSOP20 | QFN28 | QFN32 | LQFP32 | LQFP48 | LQFP64 | Pin Name | Pin Type <sup>(1)</sup> | 5 V-tolerant | Alternate Function                                                                                           | Additional Function |
|---------|-------|-------|--------|--------|--------|----------|-------------------------|--------------|--------------------------------------------------------------------------------------------------------------|---------------------|
|         |       |       |        |        |        |          |                         |              | I2S2_CK<br>TIM2_CH3<br>LPUART_TX                                                                             |                     |
| -       | -     | -     | -      | 22     | 30     | PB11     | I/O                     | FT           | I2C1_SDA<br>I2C2_SDA<br>TIM2_CH4<br>LPUART_RX                                                                | EXTI11              |
| 15      | 16    | -     | 16     | 23     | 31     | VSS      | I/O                     | -            | Ground                                                                                                       |                     |
| 16      | 17    | 17    | 17     | 24     | 32     | VDD      | I/O                     | -            | Digital power supply                                                                                         |                     |
| -       | -     | -     | -      | 25     | 33     | PB12     | I/O                     | FT           | SPI1_NSS<br>I2S1_WS<br>SPI2_NSS<br>I2S2_WS<br>TIM1_BKIN<br>TIM15_BKIN<br>I2C2_SMBA<br>LPUART_RTS/LPUART_DE   | EXTI12              |
| -       | -     | -     | -      | 26     | 34     | PB13     | I/O                     | FT           | SPI1_SCK<br>I2S1_CK<br>SPI2_SCK<br>I2S2_CK<br>TIM1_CH1N<br>I2C2_SCL<br>LPUART_CTS                            | EXTI13              |
| -       | -     | -     | -      | 27     | 35     | PB14     | I/O                     | FT           | SPI1_MISO<br>I2S1_MCK<br>SPI2_MISO<br>I2S2_MCK<br>TIM1_CH2N<br>TIM15_CH1<br>I2C2_SDA<br>LPUART_RTS/LPUART_DE | EXTI14              |
| -       | -     | -     | -      | 28     | 36     | PB15     | I/O                     | FT           | SPI1_MOSI<br>I2S1_SD<br>SPI2_MOSI<br>I2S2_SD<br>TIM1_CH3N<br>TIM15_CH1N<br>TIM15_CH2                         | EXTI15<br>RTC_REFIN |
| -       | -     | -     | -      | -      | 37     | PC6      | I/O                     | FT           | TIM3_CH1<br>LPTIM_IN1                                                                                        | EXTI6               |
| -       | -     | -     | -      | -      | 38     | PC7      | I/O                     | FT           | TIM3_CH2<br>LPTIM_OUT                                                                                        | EXTI7               |
| -       | -     | -     | -      | -      | 39     | PC8      | I/O                     | FT           | TIM3_CH3<br>LPTIM_IN2                                                                                        | EXTI8               |
| -       | -     | -     | -      | -      | 40     | PC9      | I/O                     | FT           | TIM3_CH4<br>LPTIM_ETR                                                                                        | EXTI9               |
| -       | 18    | 18    | 18     | 29     | 41     | PA8      | I/O                     | FT           | USART1_CK<br>TIM1_CH1<br>RCC_MCO<br>LPUART_RX                                                                | WKUP3<br>EXTI8      |
| 17      | 19    | 19    | 19     | 30     | 42     | PA9      | I/O                     | FT           | USART1_TX<br>TIM1_CH2<br>TIM15_BKIN<br>I2C1_SCL<br>RCC_MCO<br>LPUART_TX<br>CAN_RX                            | EXTI9               |
| 18      | 20    | 20    | 20     | 31     | 43     | PA10     | I/O                     | FT           | USART1_RX<br>TIM1_CH3                                                                                        | EXTI10              |

| TSSOP20 | QFN28 | QFN32 | LQFP32 | LQFP48 | LQFP64 | Pin Name | Pin Type <sup>(1)</sup> | 5 V-tolerant | Alternate Function                                                                                         | Additional Function |
|---------|-------|-------|--------|--------|--------|----------|-------------------------|--------------|------------------------------------------------------------------------------------------------------------|---------------------|
|         |       |       |        |        |        |          |                         |              | TIM17_BKIN<br>I2C1_SDA<br>LPUART_RX<br>CAN_TX                                                              |                     |
| -       | -     | 21    | 21     | 32     | 44     | PA11     | I/O                     | -            | USART1_CTS<br>TIM1_CH4<br>I2C2_SCL<br>CAN_RX<br>CMP1_OUT<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O           | EXTI11              |
| -       | -     | 22    | 22     | 33     | 45     | PA12     | I/O                     | -            | USART1 RTS/USART1 DE<br>TIM1_ETR<br>I2C2_SDA<br>CAN_TX<br>CMP2_OUT<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O | EXTI12              |
| 19      | 21    | 23    | 23     | 34     | 46     | PA13     | I/O                     | FT           | IRTIM_IROUT<br>SWDIO<br>CAN_RX<br>LPUART_RX<br>CMP3_OUT<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O            | EXTCLK2<br>EXTI13   |
| -       | -     | -     | -      | 35     | 47     | PF6      | I/O                     | FT           | I2C1_SCL<br>I2C2_SCL                                                                                       | EXTI6               |
| -       | -     | -     | -      | 36     | 48     | PF7      | I/O                     | FT           | I2C1_SDA<br>I2C2_SDA                                                                                       | EXTI7               |
| 20      | 22    | 24    | 24     | 37     | 49     | PA14     | I/O                     | FT           | USART1_TX<br>USART2_TX<br>SWCLK<br>CAN_TX<br>LPUART_TX<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O             | EXTCLK3<br>EXTI14   |
| -       | 23    | 25    | 25     | 38     | 50     | PA15     | I/O                     | FT           | SPI1_NSS<br>I2S1_WS<br>USART1_RX<br>USART2_RX<br>TIM2_CH1<br>TIM2_ETR                                      | EXTI15              |
| -       | -     | -     | -      | -      | 51     | PC10     | I/O                     | FT           | LPUART_RX<br>LPTIM_IN1<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O                                             | EXTI10              |
| -       | -     | -     | -      | -      | 52     | PC11     | I/O                     | FT           | CAN_RX<br>LPUART_RX<br>LPTIM_OUT<br>CLU0_O<br>CLU1_O                                                       | EXTI11              |

| TSSOP20 | QFN28            | QFN32            | LQFP32 | LQFP48 | LQFP64 | Pin Name             | Pin Type <sup>(1)</sup> | 5 V-tolerant | Alternate Function                                                       | Additional Function |
|---------|------------------|------------------|--------|--------|--------|----------------------|-------------------------|--------------|--------------------------------------------------------------------------|---------------------|
|         |                  |                  |        |        |        |                      |                         |              | CLU2_O<br>CLU3_O                                                         |                     |
| -       | -                | -                | -      | -      | 53     | PC12                 | I/O                     | FT           | CAN_TX<br>LPTIM_IN2<br>CLU0_O<br>CLU1_O<br>CLU2_O<br>CLU3_O              | EXTI12              |
| -       | -                | -                | -      | -      | 54     | PD2                  | I/O                     | FT           | TIM3_ETR<br>LPUART_DE/LPUART_RTS<br>LPTIM_ETR                            | EXTI2               |
| -       | 24               | 26               | 26     | 39     | 55     | PB3                  | I/O                     | FT           | SPI1_SCK<br>I2S1_CK<br>TIM2_CH2<br>CMP3_OUT                              | EXTI3               |
| -       | 25               | 27               | 27     | 40     | 56     | PB4                  | I/O                     | FT           | SPI1_MISO<br>I2S1_MCK<br>TIM3_CH1<br>TIM17_BKIN                          | EXTI4               |
| -       | 26               | 28               | 28     | 41     | 57     | PB5                  | I/O                     | FT           | SPI1_MOSI<br>I2S1_SD<br>I2C1_SMBA<br>TIM16_BKIN<br>TIM3_CH2<br>LPTIM_IN1 | EXTI5               |
| -       | 27               | 29               | 29     | 42     | 58     | PB6                  | I/O                     | FT           | I2C1_SCL<br>USART1_TX<br>TIM16_CH1N<br>LPUART_TX<br>LPTIM_ETR            | EXTI6               |
| -       | 28               | 30               | 30     | 43     | 59     | PB7                  | I/O                     | FT           | I2C1_SDA<br>USART1_RX<br>TIM17_CH1N<br>LPUART_RX<br>LPTIM_IN2            | EXTI7               |
| 1       | 1                | 31               | 31     | 44     | 60     | Boot0 <sup>(2)</sup> | I                       |              | Boot mode configuration                                                  |                     |
| -       | -                | 32               | -      | 45     | 61     | PB8                  | I/O                     | FT           | I2C1_SCL<br>TIM16_CH1<br>CAN_RX                                          | EXTI8               |
| -       | -                | -                | -      | 46     | 62     | PB9                  | I/O                     | FT           | I2C1_SDA<br>IRTIM_IROUT<br>TIM17_CH1<br>SPI2_NSS<br>I2S2_WS<br>CAN_TX    | EXTI9               |
| -       | 0 <sup>(3)</sup> | 0 <sup>(3)</sup> | 32     | 47     | 63     | VSS                  | S                       |              | Ground                                                                   |                     |
| -       | -                | 1                | 1      | 48     | 64     | VDD                  | S                       |              | Digital power supply                                                     |                     |

(1). I = input, O = output, I/O = input/output, S = power supply.

(2). By default, the Boot0 pin has a 50 kΩ pull-down resistor.

(3). In the QFN package, the pin 0 is the thermal pad on the package bottom.

#### Note:

- Unless otherwise specified, all I/Os are configured in input floating mode during and after resets.
- For details about alternate functions, see section "[6.8 Alternate function table](#)".

## 6.8 Alternate function table

Table 6-2 Alternate function table

| Pin      | AF0                | AF1                  | AF2                 | AF3                  | AF4                  | AF5                  | AF6       | AF7       | AF8 | AF9    | AF10   | AF11   | AF12   | AF13 | AF14   | AF15    |
|----------|--------------------|----------------------|---------------------|----------------------|----------------------|----------------------|-----------|-----------|-----|--------|--------|--------|--------|------|--------|---------|
| PA0/AINO | -                  | USART1_CTS           | TIM2_CH1/TIM2_ETRIN | USART2_CTS           | -                    | LPUART_RX/LPUA_RT_TX | LPTIM_IN1 | COMP1_OUT | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | -      | -       |
| PA1/AIN1 | -                  | USART1_RTS/USART1_DE | TIM2_CH2            | USART2_RTS/USART2_DE | -                    | TIM15_C_H1N          | LPTIM_IN2 | -         | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | -      | -       |
| PA2/AIN2 | TIM15_C_H1         | USART1_TX/USART1_RX  | TIM2_CH3            | USART2_TX/USART2_RX  | -                    | -                    | LPTIM_ETR | COMP2_OUT | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | -      | -       |
| PA3/AIN3 | TIM15_C_H2         | USART1_RX/USART1_TX  | TIM2_CH4            | USART2_RX/USART2_TX  | -                    | -                    | LPTIM_OUT | -         | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | -      | -       |
| PA4/AIN4 | SPI1_NSS/I2S1_WS   | USART1_CK            | -                   | USART2_CK            | TIM14_C_H1           | -                    | -         | -         | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | -      | -       |
| PA5/AIN5 | SPI1_SCK/I2S1_CK   | -                    | TIM2_CH1/TIM2_ETRIN | -                    | -                    | -                    | -         | -         | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | -      | -       |
| PA6/AIN6 | SPI1_MISO/I2S1_MCK | TIM3_CH1             | TIM1_BKIN           | LPUART_CTS           | -                    | TIM16_C_H1           | -         | COMP1_OUT | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | CAN_RX | -       |
| PA7/AIN7 | SPI1_MOSI/I2S1_SD  | TIM3_CH2             | TIM1_CH1N           | -                    | TIM14_C_H1           | TIM17_C_H1           | -         | COMP2_OUT | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | CAN_TX | RCC_MCO |
| PA8      | RCC_MCO            | USART1_CK            | TIM1_CH1            | -                    | LPUART_RX/LPUA_RT_TX | -                    | -         | -         | -   | -      | -      | -      | -      | -    | -      | -       |
| PA9      | TIM15_B_KIN        | USART1_TX/USART1_RX  | TIM1_CH2            | LPUART_TX/LPUA_RT_RX | I2C1_SCL             | RCC_MCO              | -         | -         | -   | -      | -      | -      | -      | -    | CAN_RX | -       |
| PA10     | TIM17_B_KIN        | USART1_RX/USART1_TX  | TIM1_CH3            | LPUART_RX/LPUA_RT_TX | I2C1_SDA             | -                    | -         | -         | -   | -      | -      | -      | -      | -    | CAN_TX | -       |
| PA11     | -                  | USART1_CTS           | TIM1_CH4            | -                    | -                    | I2C2_SCL             | -         | COMP1_OUT | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | CAN_RX | -       |
| PA12     | -                  | USART1_RTS/USART1_DE | TIM1_ETR            | -                    | -                    | I2C2_SDA             | -         | COMP2_OUT | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | CAN_TX | -       |
| PA13     | CM0_SW_D           | IRTIM_IR_OUT         | -                   | LPUART_RX/LPUA_RT_TX | -                    | -                    | -         | COMP3_OUT | -   | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | CAN_RX | -       |

| Pin      | AF0                  | AF1                  | AF2                   | AF3                   | AF4        | AF5                  | AF6        | AF7       | AF8                | AF9    | AF10   | AF11   | AF12   | AF13 | AF14   | AF15       |
|----------|----------------------|----------------------|-----------------------|-----------------------|------------|----------------------|------------|-----------|--------------------|--------|--------|--------|--------|------|--------|------------|
| PA14     | CM0_SW_CLK           | USART1_TX/USAR T1_RX | -                     | LPUART_TX//LPUA RT_RX | -          | USART2_TX/USAR T2_RX | -          | -         | -                  | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | CAN_TX | -          |
| PA15     | SPI1_NSS /I2S1_WS    | USART1_RX/USAR T1_TX | TIM2_CH 1/TIM2_E TRIN | -                     | -          | USART2_RX/USAR T2_TX | -          | -         | -                  | -      | -      | -      | -      | -    | -      | -          |
| PB0/AIN8 |                      | TIM3_CH 3            | TIM1_CH 2N            | -                     | -          | -                    | -          | -         | -                  | -      | -      | -      | -      | -    | -      | -          |
| PB1/AIN9 | TIM14_C H1           | TIM3_CH 4            | TIM1_CH 3N            | LPUART_RTS/LPUA RT_DE | -          | -                    | -          | COMP3_OUT | -                  | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | -      | -          |
| PB2      | -                    | -                    | -                     | -                     | I2C2_SM_BA | -                    | LPTIM_O_UT | -         | -                  | -      | -      | -      | -      | -    | -      | I2C1_SM_BA |
| PB3      | SPI1_SCK /I2S1_CK    | -                    | TIM2_CH 2             | -                     | -          | -                    | -          | COMP3_OUT | -                  | -      | -      | -      | -      | -    | -      | -          |
| PB4      | SPI1_MISO/I2S1_MCK   | TIM3_CH 1            | -                     | -                     | -          | TIM17_B_KIN          | -          | -         | -                  | -      | -      | -      | -      | -    | -      | -          |
| PB5      | SPI1_MOSI/I2S1_SD    | TIM3_CH 2            | TIM16_B_KIN           | I2C1_SM_BA            | -          | -                    | LPTIM_IN_1 | -         | -                  | -      | -      | -      | -      | -    | -      | -          |
| PB6      | USART1_TX/USAR T1_RX | I2C1_SCL             | TIM16_C_H1N           | LPUART_TX/LPUA RT_RX  | -          | -                    | LPTIM_ETR  | -         | -                  | -      | -      | -      | -      | -    | -      | -          |
| PB7      | USART1_RX/USAR T1_TX | I2C1_SDA             | TIM17_C_H1N           | LPUART_RX/LPUA RT_TX  | -          | -                    | LPTIM_IN_2 | -         | -                  | -      | -      | -      | -      | -    | -      | -          |
| PB8      | -                    | I2C1_SCL             | TIM16_C_H1            | -                     | -          | -                    | -          | -         | -                  | -      | -      | -      | -      | -    | CAN_RX | -          |
| PB9      | IRTIM_IR_OUT         | I2C1_SDA             | TIM17_C_H1            | -                     | -          | SPI2_NSS /I2S2_WS    | -          | -         | -                  | -      | -      | -      | -      | -    | CAN_TX | -          |
| PB10     | -                    | I2C1_SCL             | TIM2_CH 3             | LPUART_TX/LPUA RT_RX  | -          | SPI2_SCK /I2S2_CK    | I2C2_SCL   | -         | -                  | -      | -      | -      | -      | -    | -      | -          |
| PB11     | -                    | I2C1_SDA             | TIM2_CH 4             | LPUART_RX/LPUA RT_TX  | -          | -                    | I2C2_SDA   | -         | -                  | -      | -      | -      | -      | -    | -      | -          |
| PB12     | SPI1_NSS /I2S1_WS    |                      | TIM1_BKIN             | LPUART_RTS/LPUA RT_DE | -          | TIM15_B_KIN          | -          | -         | SPI2_NSS /I2S2_WS  | -      | -      | -      | -      | -    | -      | I2C2_SM_BA |
| PB13     | SPI1_SCK /I2S1_CK    | -                    | TIM1_CH 1N            | LPUART_CTS            | -          | I2C2_SCL             | -          | -         | SPI2_SCK /I2S2_CK  | -      | -      | -      | -      | -    | -      | -          |
| PB14     | SPI1_MISO/I2C1_MCK   | TIM15_C_H1           | TIM1_CH 2N            | LPUART_RTS/LPUA RT_DE | -          | I2C2_SDA             | -          | -         | SPI2_MISO/I2S2_MCK | -      | -      | -      | -      | -    | -      | -          |

| Pin       | AF0                   | AF1                       | AF2           | AF3                          | AF4 | AF5 | AF6           | AF7 | AF8                   | AF9    | AF10   | AF11   | AF12   | AF13 | AF14   | AF15 |
|-----------|-----------------------|---------------------------|---------------|------------------------------|-----|-----|---------------|-----|-----------------------|--------|--------|--------|--------|------|--------|------|
| PB15      | SPI1_MO<br>SI/I2S1_SD | TIM15_C<br>H2             | TIM1_CH<br>3N | TIM1_C<br>H1N                | -   | -   | -             | -   | SPI2_MO<br>SI/I2S2_SD | -      | -      | -      | -      | -    | -      | -    |
| PC0/AIN10 | -                     | -                         | -             | -                            | -   | -   | LPTIM_IN<br>1 | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PC1/AIN11 | -                     | -                         | -             | -                            | -   | -   | LPTIM_O<br>UT | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PC2/AIN12 | -                     | SPI2_MIS<br>O/I2S_M<br>CK | -             | -                            | -   | -   | LPTIM_IN<br>2 | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PC3/AIN13 | -                     | SPI2_MO<br>SI/I2S2_SD     | -             | -                            | -   | -   | LPTIM_ET<br>R | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PC4/AIN14 | -                     | -                         | -             | LPUART_<br>T/LPUART_RX       | -   | -   | -             | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PC5/AIN15 | -                     | -                         | -             | LPUART_RX/LPUA<br>RT_TX      | -   | -   | -             | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PC6       | TIM3_CH<br>1          | -                         | -             | -                            | -   | -   | LPTIM_IN<br>1 | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PC7       | TIM3_CH<br>2          | -                         | -             | -                            | -   | -   | LPTIM_O<br>UT | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PC8       | TIM3_CH<br>3          | -                         | -             | -                            | -   | -   | LPTIM_IN<br>2 | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PC9       | TIM3_CH<br>4          | -                         | -             | -                            | -   | -   | LPTIM_ET<br>R | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PC10      | -                     | -                         | -             | LPUART_<br>TX/LPUA<br>RT_RX  | -   | -   | LPTIM_IN<br>1 | -   | -                     | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | -      | -    |
| PC11      | -                     | -                         | -             | LPUART_RX/LPUA<br>RT_TX      | -   | -   | LPTIM_O<br>UT | -   | -                     | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | CAN_RX | -    |
| PC12      | -                     | -                         | -             | -                            | -   | -   | LPTIM_IN<br>2 | -   | -                     | CLU0_O | CLU1_O | CLU2_O | CLU3_O | -    | CAN_TX | -    |
| PD2       | TIM3_ET<br>R          | -                         | -             | LPUART_<br>RTS/LPUA<br>RT_DE | -   | -   | LPTIM_ET<br>R | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PF0       | -                     | I2C1_SDA                  | -             | -                            | -   | -   | -             | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PF1       | -                     | I2C1_SCL                  | -             | -                            | -   | -   | -             | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PF4       | -                     | -                         | -             | -                            | -   | -   | -             | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PF5       | -                     | -                         | -             | -                            | -   | -   | -             | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PF6       | -                     | I2C1_SCL                  | -             | -                            | -   | -   | I2C2_SCL      | -   | -                     | -      | -      | -      | -      | -    | -      | -    |
| PF7       | -                     | I2C1_SDA                  | -             | -                            | -   | -   | I2C2_SDA      | -   | -                     | -      | -      | -      | -      | -    | -      | -    |

## 7 Package characteristics

### 7.1 TSSOP20

TSSOP20 is a 6.5 mm × 6.5 mm, 0.65 mm pitch package.



Figure 7-1 TSSOP20 package outline

Table 7-1 TSSOP20 package parameters

| Symbol | Min (mm) | Typ (mm) | Max (mm) | Min (inches) <sup>(1)</sup> | Typ (inches) <sup>(1)</sup> | Max (inches) <sup>(1)</sup> |
|--------|----------|----------|----------|-----------------------------|-----------------------------|-----------------------------|
| A      | -        | -        | 1.200    | -                           | -                           | 0.0472                      |
| A1     | 0.050    | -        | 0.150    | 0.0020                      | -                           | 0.0059                      |
| A2     | 0.800    | 1.000    | 1.050    | 0.0315                      | 0.0394                      | 0.0413                      |
| b      | 0.190    | -        | 0.300    | 0.0075                      | -                           | 0.0118                      |
| c      | 0.090    | -        | 0.200    | 0.0035                      | -                           | 0.0079                      |
| D      | 6.400    | 6.500    | 6.600    | 0.2520                      | 0.2559                      | 0.2598                      |
| E      | 6.200    | 6.400    | 6.600    | 0.2441                      | 0.2520                      | 0.2598                      |
| E1     | 4.300    | 4.400    | 4.500    | 0.1693                      | 0.1732                      | 0.1772                      |
| e      | -        | 0.650    | -        | -                           | 0.0256                      | -                           |
| L      | 0.450    | 0.600    | 0.750    | 0.0177                      | 0.0236                      | 0.0295                      |
| L1     | -        | 1.000    | -        | -                           | 0.0394                      | -                           |
| k      | 0°       | -        | 8.0°     | 0°                          | -                           | 8.0°                        |
| aaa    | -        | -        | 0.1000   | -                           | -                           | 0.0039                      |

(1). The values in inches are converted from the values in millimeters and rounded to four decimal places.

## 7.2 QFN28

QFN28 is a 4 mm × 4 mm, 0.4 mm pitch package.



Figure 7-2 QFN28 package outline

Table 7-2 QFN28 package parameters

| Symbol | Min (mm)                 | Typ (mm) | Max (mm) |
|--------|--------------------------|----------|----------|
| A      | 0.7                      | 0.75     | 0.8      |
| A1     | 0                        | 0.02     | 0.05     |
| A2     | -                        | 0.55     | -        |
| A3     | 0.203 REF <sup>(1)</sup> |          |          |
| b      | 0.15                     | 0.20     | 0.25     |
| D      | 4 BSC <sup>(2)</sup>     |          |          |
| E      | 4 BSC                    |          |          |
| e      | 0.4 BSC                  |          |          |
| D2     | 2.7                      | 2.9      | 2.9      |
| E2     | 2.7                      | 2.9      | 2.9      |
| L      | 0.3                      | 0.35     | 0.4      |
| K      | 0.25 REF                 |          |          |
| aaa    | 0.1                      |          |          |
| ccc    | 0.1                      |          |          |
| eee    | 0.08                     |          |          |
| bbb    | 0.1                      |          |          |
| fff    | 0.1                      |          |          |

(1). REF indicates a reference value.

(2). BSC: basic spacing between centers.

## 7.3 QFN32

QFN32 is a 5 mm × 5 mm, 0.5 mm pitch package.



Figure 7-3 QFN32 package outline

Table 7-3 QFN32 package parameters

| Symbol | Min (mm) | Typ (mm) | Max (mm) | Min (inches) <sup>(1)</sup> | Typ (inches) <sup>(1)</sup> | Max (inches) <sup>(1)</sup> |
|--------|----------|----------|----------|-----------------------------|-----------------------------|-----------------------------|
| A      | 0.500    | 0.550    | 0.600    | 0.0197                      | 0.0217                      | 0.0236                      |
| A1     | 0.500    | 0.550    | 0.600    | 0.0197                      | 0.0217                      | 0.0236                      |
| A2     | 0.000    | 0.020    | 0.050    | 0.0000                      | 0.0008                      | 0.0020                      |
| A3     | -        | 0.152    | -        | -                           | 0.0060                      | -                           |
| b      | 0.180    | 0.230    | 0.280    | 0.0071                      | 0.0091                      | 0.0110                      |
| D      | 4.900    | 5.000    | 5.100    | 0.1929                      | 0.1969                      | 0.2008                      |
| D1     | 3.400    | 3.500    | 3.600    | 0.1339                      | 0.1378                      | 0.1417                      |
| D2     | 3.400    | 3.500    | 3.600    | 0.1339                      | 0.1378                      | 0.1417                      |
| E      | 4.900    | 5.000    | 5.100    | 0.1929                      | 0.1969                      | 0.2008                      |
| E1     | 3.400    | 3.500    | 3.600    | 0.1339                      | 0.1378                      | 0.1417                      |
| E2     | 3.400    | 3.500    | 3.600    | 0.1339                      | 0.1378                      | 0.1417                      |
| e      | -        | 0.500    | -        | -                           | 0.0197                      | -                           |
| L      | 0.300    | 0.400    | 0.500    | 0.0118                      | 0.0157                      | 0.0197                      |
| ddd    | -        | -        | 0.080    | -                           | -                           | 0.0031                      |

(1). The values in inches are converted from the values in millimeters and rounded to four decimal places.

## 7.4 LQFP32

LQFP32 is a 7 mm × 7 mm, 0.8 mm pitch package.



Figure 7-4 LQFP32 package outline

Table 7-4 LQFP32 package parameters

| Symbol | Min (mm) | Typ (mm) | Max (mm) | Min (inches) <sup>(1)</sup> | Typ (inches) <sup>(1)</sup> | Max (inches) <sup>(1)</sup> |
|--------|----------|----------|----------|-----------------------------|-----------------------------|-----------------------------|
| A      | -        | -        | 1.600    | -                           | -                           | 0.0630                      |
| A1     | 0.050    | -        | 0.150    | 0.0020                      | -                           | 0.0059                      |
| A2     | 1.350    | 1.400    | 1.450    | 0.0531                      | 0.0551                      | 0.0571                      |
| b      | 0.300    | 0.370    | 0.450    | 0.0118                      | 0.0146                      | 0.0177                      |
| c      | 0.090    | -        | 0.200    | 0.0035                      | -                           | 0.0079                      |
| D      | 8.800    | 9.000    | 9.200    | 0.3465                      | 0.3543                      | 0.3622                      |
| D1     | 6.800    | 7.000    | 7.200    | 0.2677                      | 0.2756                      | 0.2835                      |
| D3     | -        | 5.600    | -        | -                           | 0.2205                      | -                           |
| E      | 8.800    | 9.000    | 9.200    | 0.3465                      | 0.3543                      | 0.3622                      |
| E1     | 6.800    | 7.000    | 7.200    | 0.2677                      | 0.2756                      | 0.2835                      |
| E3     | -        | 5.600    | -        | -                           | 0.2205                      | -                           |
| e      | -        | 0.800    | -        | -                           | 0.0315                      | -                           |
| K      | 0°       | 3.5°     | 7°       | 0°                          | 3.5°                        | 7°                          |
| L      | 0.450    | 0.600    | 0.750    | 0.0177                      | 0.0236                      | 0.0295                      |
| L1     | -        | 1.000    | -        | -                           | 0.0394                      | -                           |
| ccc    | -        | -        | 0.100    | -                           | -                           | 0.0039                      |

(1). The values in inches are converted from the values in millimeters and rounded to four decimal places.

## 7.5 LQFP48

LQFP48 is a 7 mm × 7 mm, 0.5 mm pitch package.



Figure 7-5 LQFP48 package outline

Table 7-5 LQFP48 package parameters

| Symbol | Min (mm) | Typ (mm) | Max (mm) | Min (inches) <sup>(1)</sup> | Typ (inches) <sup>(1)</sup> | Max (inches) <sup>(1)</sup> |
|--------|----------|----------|----------|-----------------------------|-----------------------------|-----------------------------|
| A      | -        | -        | 1.600    | -                           | -                           | 0.0630                      |
| A1     | 0.050    | -        | 0.150    | 0.0020                      | -                           | 0.0059                      |
| A2     | 1.350    | 1.400    | 1.450    | 0.0531                      | 0.0551                      | 0.0571                      |
| b      | 0.170    | 0.220    | 0.270    | 0.0067                      | 0.0087                      | 0.0106                      |
| c      | 0.090    | -        | 0.200    | 0.0035                      | -                           | 0.0079                      |
| D      | 8.800    | 9.000    | 9.200    | 0.3465                      | 0.3543                      | 0.3622                      |
| D1     | 6.800    | 7.000    | 7.200    | 0.2677                      | 0.2756                      | 0.2835                      |
| D3     | -        | 5.500    | -        | -                           | 0.2165                      | -                           |
| E      | 8.800    | 9.000    | 9.200    | 0.3465                      | 0.3543                      | 0.3622                      |
| E1     | 6.800    | 7.000    | 7.200    | 0.2677                      | 0.2756                      | 0.2835                      |
| E3     | -        | 5.500    | -        | -                           | 0.2165                      | -                           |
| e      | -        | 0.500    | -        | -                           | 0.0197                      | -                           |
| L      | 0.450    | 0.600    | 0.750    | 0.0177                      | 0.0236                      | 0.0295                      |
| L1     | -        | 1.000    | -        | -                           | 0.0394                      | -                           |
| k      | 0°       | 3.5°     | 7°       | 0°                          | 3.5°                        | 7°                          |
| ccc    | 0.080    |          |          | 0.0031                      |                             |                             |

(1). The values in inches are converted from the values in millimeters and rounded to four decimal places.

## 7.6 LQFP64

LQFP64 is a 10 mm × 10 mm, 0.5 mm pitch package.



Figure 7-6 LQFP64 package outline

Table 7-6 LQFP64 package parameters

| Symbol | Min (mm) | Typ (mm) | Max (mm) | Min (inches) <sup>(1)</sup> | Typ (inches) <sup>(1)</sup> | Max (inches) <sup>(1)</sup> |
|--------|----------|----------|----------|-----------------------------|-----------------------------|-----------------------------|
| A      | -        | -        | 1.600    | -                           | -                           | 0.0630                      |
| A1     | 0.050    | -        | 0.150    | 0.0020                      | -                           | 0.0059                      |
| A2     | 1.350    | 1.400    | 1.450    | 0.0531                      | 0.0551                      | 0.0571                      |
| b      | 0.170    | 0.220    | 0.270    | 0.0067                      | 0.0087                      | 0.0106                      |
| c      | 0.090    | -        | 0.200    | 0.0035                      | -                           | 0.0079                      |
| D      | -        | 12.000   | -        | -                           | 0.4724                      | -                           |
| D1     | -        | 10.000   | -        | -                           | 0.3937                      | -                           |
| D3     | -        | 7.500    | -        | -                           | 0.2953                      | -                           |
| E      | -        | 12.000   | -        | -                           | 0.4724                      | -                           |
| E1     | -        | 10.000   | -        | -                           | 0.3937                      | -                           |
| E3     | -        | 7.500    | -        | -                           | 0.2953                      | -                           |
| e      | -        | 0.500    | -        | -                           | 0.0197                      | -                           |
| K      | 0°       | 3.5°     | 7°       | 0°                          | 3.5°                        | 7°                          |
| L      | 0.450    | 0.600    | 0.750    | 0.0177                      | 0.0236                      | 0.0295                      |
| L1     | -        | 1.000    | -        | -                           | 0.0394                      | -                           |
| ccc    | -        | -        | 0.080    | -                           | -                           | 0.0031                      |

(1). The values in inches are converted from the values in millimeters and rounded to four decimal places.

## 8 Ordering information

Table 8-1 HK32F04AxxxxA ordering information

| Package Type | Part Number   | Shipping Option    | Remarks |
|--------------|---------------|--------------------|---------|
| TSSOP20      | HK32F04AF4P6A | Tape and reel/Tube | -       |
|              | HK32F04AF6P6A | Tape and reel/Tube | -       |
|              | HK32F04AF8P6A | Tape and reel/Tube | -       |
|              | HK32F04AFBP6A | Tape and reel/Tube | -       |
| QFN28        | HK32F04AG4U6A | Tape and reel/Tray | -       |
|              | HK32F04AG6U6A | Tape and reel/Tray | -       |
|              | HK32F04AG8U6A | Tape and reel/Tray | -       |
|              | HK32F04AGBU6A | Tape and reel/Tray | -       |
| QFN32        | HK32F04AK4U6A | Tape and reel/Tray | -       |
|              | HK32F04AK6U6A | Tape and reel/Tray | -       |
|              | HK32F04AK8U6A | Tape and reel/Tray | -       |
|              | HK32F04AKBU6A | Tape and reel/Tray | -       |
| LQFP32       | HK32F04AK4T6A | Tape and reel/Tray | -       |
|              | HK32F04AK6T6A | Tape and reel/Tray | -       |
|              | HK32F04AK8T6A | Tape and reel/Tray | -       |
|              | HK32F04AKBT6A | Tape and reel/Tray | -       |
| LQFP48       | HK32F04AC4T6A | Tape and reel/Tray | -       |
|              | HK32F04AC6T6A | Tape and reel/Tray | -       |
|              | HK32F04AC8T6A | Tape and reel/Tray | -       |
|              | HK32F04ACBT6A | Tape and reel/Tray | -       |
| LQFP64       | HK32F04AR8T6A | Tape and reel/Tray | -       |
|              | HK32F04ARB6A  | Tape and reel/Tray | -       |

## 9 Acronyms

| Term  | Full Name                                               |
|-------|---------------------------------------------------------|
| ADC   | Analog-to-Digital Converter                             |
| AHB   | Advanced High-performance Bus                           |
| APB   | Advanced Peripheral Bus                                 |
| AWU   | Auto-wakeup Unit                                        |
| CLU   | Configurable Logic Unit                                 |
| CRC   | Cyclic Redundancy Check                                 |
| CSS   | Clock Security System                                   |
| CTS   | Clear to Send                                           |
| DMA   | Direct Memory Access                                    |
| EMACC | Electric Motor Acceleration                             |
| EXTI  | Extended Interrupt/Event Controller                     |
| GPIO  | General-purpose Input/Output                            |
| HSE   | High Speed External (Clock Signal)                      |
| I2C   | Inter-Integrated Circuit                                |
| I2S   | Inter-IC Sound                                          |
| IWDG  | Independent Watchdog                                    |
| LSI   | Low Speed Internal (clock signal)                       |
| MCU   | Microcontroller Unit                                    |
| MSPS  | Million Samples Per Second                              |
| NVIC  | Nested Vectored Interrupt Controller                    |
| PDR   | Power-down Reset                                        |
| PLL   | Phase-locked Loop                                       |
| POR   | Power-on Reset                                          |
| PPM   | Parts per Million                                       |
| PWM   | Pulse Width Modulation                                  |
| RCC   | Reset and Clock Control                                 |
| RISC  | Reduced Instruction Set Computer                        |
| RTS   | Request to Send                                         |
| SPI   | Serial Peripheral Interface                             |
| SRAM  | Static Random Access Memory                             |
| SWD   | Serial Wire Debug                                       |
| USART | Universal Synchronous/Asynchronous Receiver/Transmitter |
| WWDG  | Window Watchdog                                         |

## 10 Legal and contact information



航顺芯片 and other Hangshun trademarks are trademarks of Shenzhen Hangshun Chip Technology R&D Co., Ltd. (hereinafter referred to as Hangshun). All other trademarks or trade names mentioned in this document are the property of their respective holders.

No part or sub-part of Hangshun product specifications and datasheets may be modified in any form or by any means without consent. Hangshun reserves the right to modify the datasheets and/or products, discontinue any product, or terminate any service without notice. It is recommended that customers obtain relevant information of the latest version and verify that the information is up-to-date and complete before placing an order. All products are sold in accordance with the terms of the sales contract provided at the time of order confirmation. The terms include the scope of warranty, intellectual property rights, and responsibility.

Hangshun guarantees the performance of Hangshun products in accordance with Hangshun's standards during the sales period. Hangshun believes it is necessary to support this warranty by using testing and other quality control techniques. Unless mandatory government regulations are brought in, special tests or measurements by using other instruments are unnecessary.

The customer acknowledges that Hangshun products are not designed or manufactured for purposes related to life support, or for systems or products in dangerous activities or environments. Malfunctioning products may cause personal injuries, deaths, or damage to property or environments (collectively referred to as high-risk activities). The Hangshun products that are used in high-risk activities are not under warranty. Hangshun assumes no liability for customers or third parties involved therein.

Hangshun will provide the same technical support, help, advice, and information as it does now (including the design, development, or debugging of the purchased circuit boards or other applications). Hangshun makes no guarantee and assumes no legal liability for all support technologies, merchantability, or fitness for a particular purpose if the support technologies are error-free and circuit boards and other applications can operate normally.

**Copyright © Shenzhen Hangshun Chip Technology R&D Co., Ltd. 2015-2023**

**Shenzhen Hangshun Chip Technology R&D Co., Ltd.**

TEL: +86-755-83247667

Website: [www.hsxp-hk.com](http://www.hsxp-hk.com)