logo logologo

Language
Search...

Products

Products

Home > Products > Holtek MCUs > 32-bit(Flash)MCU

Holtek MCU HT32F12364

HT32F12364 device is a high performance, low power consumption 32-bit microcontroller based around an Arm® Cortex®-M3 processor core.

General Description

The Holtek HT32F12364 device is a high performance, low power consumption 32-bit microcontroller  based around an Arm® Cortex®-M3 processor core. The Cortex®-M3 is a next-generation processor  core which is tightly coupled with Nested Vectored Interrupt Controller (NVIC), SysTick timer,  and includes advanced debug support.

The device operates at a frequency of up to 72 MHz with a Flash accelerator to obtain maximum  efficiency. It provides 256 KB of embedded Flash memory for code/data storage and 128 KB  of embedded SRAM memory for system operation and application program usage. A variety  of peripherals, such as ADC, I2 C, USART, UART, SPI, SCI, PDMA, GPTM, PWM, SCTM,  EBI, CRC-16/32, AES-128/256, USB2.0 FS and SW-DP (Serial Wire Debug Port), etc., are also  implemented in the device. Several power saving modes provide the flexibility for maximum  optimization between wakeup latency and power consumption, an especially important  consideration in low power applications.

The above features ensure that the device is suitable for use in a wide range of applications,  especially in areas such as white goods application control, power monitors, alarm systems,  consumer products, handheld equipment, data logging applications, motor control, fingerprint  recognition, smart door lock and so on..

Product Features

  • Core

    ▆ 32-bit Arm® Cortex®-M3 processor core

    ▆ Up to 72 MHz operating frequency

    ▆ Single-cycle multiplication and hardware division

    ▆ Integrated Nested Vectored Interrupt Controller (NVIC)

    ▆ 24-bit SysTick timer

    The Cortex®-M3 processor is a general-purpose 32-bit processor core especially suitable for  products requiring high performance and low power consumption microcontrollers. It offers many  special features such as a Thumb-2 instruction set, hardware divider, low latency interrupt respond  time, atomic bit-banding access and multiple buses for simultaneous accesses. The Cortex®-M3  processor is based on the ARMv7 architecture and supports both Thumb and Thumb-2 instruction  sets.

  • On-chip Memory

    ▆ 256 KB on-chip Flash memory for instruction/data and option storage

    ▆ 128 KB on-chip SRAM

    ▆ Supports multiple booting modes

    The Arm® Cortex®-M3 processor is structured using Harvard architecture which uses a separate  bus structure to fetch instructions and load/store data. The instruction code and data are both  located in the same memory address space but in different address ranges. The maximum address  range of the Cortex®-M3 is 4 GB due to its 32-bit bus address width. Additionally, a pre-defined  memory map is provided by the Cortex®-M3 processor to reduce the software complexity of  repeated implementation for different device vendors. However, some regions are used by the Arm® Cortex®-M3 system peripherals. Refer to the Arm® Cortex®-M3 Technical Reference Manual for  more information. Figure 2 in the Overview chapter shows the memory map of the HT32F12364  device, including Code, SRAM, peripheral and other pre-defined regions.

  • Flash Memory Controller – FMC

    ▆ Flash accelerator for maximum efficiency

    ▆ 32-bit word programming with In System Programming (ISP) and In Application Programming  (IAP)

    ▆ Flash protection capability to prevent illegal access

    The Flash Memory Controller, FMC, provides all the necessary functions and pre-fetch buffer  for the embedded on-chip Flash Memory. Since the access speed of the Flash Memory is slower  than the CPU, a wide access interface with a pre-fetch buffer and cache are provided for the Flash  Memory in order to reduce the CPU waiting time which will cause CPU instruction execution  delays. Flash Memory word programming/page erase functions are also provided.

  • Reset Control Unit – RSTCU

    ▆ Supply supervisor:

    ● Power On Reset / Power Down Reset – POR/PDR

    ● Brown-out Detector – BOD

    ● Programmable Low Voltage Detector – LVD

    The Reset Control Unit, RSTCU, has three kinds of reset, a power on reset, a system reset and an  APB unit reset. The power on reset, known as a cold reset, resets the full system during power up.  A system reset resets the processor core and peripheral IP components with the exception of the  SW-DP controller. The resets can be triggered by an external signal, internal events and the reset  generators.

  • Clock Control Unit – CKCU

    ▆ External 4 to 16 MHz crystal oscillator

    ▆ External 32.768 kHz crystal oscillator

    ▆ Internal 8 MHz RC oscillator trimmed to ±1.5 % accuracy at 3.3 V operating voltage and 25 °C  operating temperature

    ▆ Internal 32 kHz RC oscillator

    ▆ Integrated system clock PLL and USB PLL

    ▆ Independent clock divider and gating bits for peripheral clock sources

    The Clock Control unit, CKCU, provides a range of oscillator and clock functions. These include  a High Speed Internal RC oscillator (HSI), a High Speed External crystal oscillator (HSE), a Low  Speed Internal RC oscillator (LSI), a Low Speed External crystal oscillator (LSE), a Phase Lock  Loop (PLL), an HSE clock monitor, clock prescalers, clock multiplexers, APB clock divider and  gating circuitry. The clocks of the AHB, APB and Cortex®-M3 are derived from the system clock  (CK_SYS) which can come from the LSI, LSE, HSI, HSE or PLL. The Watchdog Timer and Real  Time Clock (RTC) use either the LSI or LSE as their clock source.

  • Power Management – PWRCU

    ▆ Single VDD power supply: 1.65 V to 3.6 V

    ▆ Integrated 1.5 V LDO regulator for CPU core, peripherals and memories power supply

    ▆ VDD power supply for RTC

    ▆ Two power domains: VDD and 1.5 V

    ▆ Four power saving modes: Sleep, Deep-Sleep1, Deep-Sleep2, Power-Down

    Power consumption can be regarded as one of the most important issues for many embedded  system applications. Accordingly the Power Control Unit, PWRCU, in the device provides many  types of power saving modes such as Sleep, Deep-Sleep1, Deep-Sleep2 and Power-Down mode.  These operating modes reduce the power consumption and allow the application to achieve the best  trade-off between the conflicting demands of CPU operating time, speed and power consumption.

  • External Interrupt/Event Controller – EXTI

    ▆ Up to 16 EXTI lines with configurable trigger source and type

    ▆ All GPIO pins can be selected as EXTI trigger source

    ▆ Source trigger type includes high level, low level, negative edge, positive edge or both edges

    ▆ Individual interrupt enable, wakeup enable and status bits for each EXTI line

    ▆ Software interrupt trigger mode for each EXTI line

    ▆ Integrated deglitch filter for short pulse blocking

    The External Interrupt/Event Controller, EXTI, comprises 16 edge detectors which can generate  a wake-up event or interrupt requests independently. Each EXTI line can also be masked  independently

  • Analog to Digital Converter – ADC

    ▆ 12-bit SAR ADC engine

    ▆ Up to 1 Msps conversion rate

    ▆ Up to 8 external analog input channels

    A 12-bit multi-channel ADC is integrated in the device. There are multiplexed channels, which  include 8 external analog signal channels and 3 internal channels can be measured. If the input  voltage is required to remain within a specific threshold window, an Analog Watchdog function  will monitor and detect these signals. An interrupt will then be generated to inform the device  that the input voltage is not within the preset threshold levels. There are three conversion modes  to convert an analog signal to digital data. The ADC can be operated in one shot, continuous and  discontinuous conversion modes.

    The internal voltage reference (VREF) which can provide a stable reference voltage for the A/D  Converter is internally connected to the ADC_BUILT-IN input channel. The precise voltage of the  VREF is individually measured for each part by Holtek during production test.

  • I/O Ports – GPIO

    ▆ Up to 52 GPIOs

    ▆ Port A, B, C, D, F are mapped as 16 external interrupts – EXTI

    ▆ Almost all I/O pins have configurable output driving current

    There are up to 52 General Purpose I/O pins, GPIO, named from PA0~PA15 to PD0~PD2 and  PF0 for the implementation of logic input/output functions. Each of the GPIO ports has a series of  related control and configuration registers to maximize flexibility and to meet the requirements of a  wide range of applications.

    The GPIO ports are pin-shared with other alternative functions to obtain maximum functional  flexibility on the package pins. The GPIO pins can be used as alternative functional pins by  configuring the corresponding registers regardless of the input or output pins. The external  interrupts on the GPIO pins of the device have related control and configuration registers in the  External Interrupt Control Unit, EXTI.

  • General-Purpose Timer – GPTM

    ▆ 16-bit up/down auto-reload counter

    ▆ 16-bit programmable prescaler allowing dividing the counter clock frequency by any factor  between 1 and 65536

    ▆ Input Capture function

    ▆ Compare Match Output

    ▆ PWM waveform generation with Edge-aligned and Center-aligned Counting Modes

    ▆ Single Pulse Mode Output

    ▆ Encoder interface controller with two inputs using quadrature decoder

    The General-Purpose Timer, GPTM, consists of one 16-bit up/down-counter, four 16-bit Capture/ Compare Registers (CCRs), one 16-bit Counter Reload Register (CRR) and several control/status  registers. They can be used for a variety of purposes including general time measurement, input  signal pulse width measurement, output waveform generation such as single pulse generation or  PWM output generation. The GPTM supports an Encoder Interface using a decoder with two inputs.

  • Pulse-Width-Modulation Timer – PWM

    ▆ 16-bit up/down auto-reload counter

    ▆ Up to 4 independent channels for each timer

    ▆ 16-bit programmable prescaler allowing dividing the counter clock frequency by any factor  between 1 and 65536

    ▆ Compare Match Output

    ▆ PWM waveform generation with Edge-aligned and Center-aligned Counting Modes

    ▆ Single Pulse Mode Output

    The Pulse-Width-Modulation Timer, PWM, consists of one 16-bit up/down-counter, four 16-bit  Compare Registers (CRs), one 16-bit Counter Reload Register (CRR) and several control/status  registers. It can be used for a variety of purposes including general timer and output waveform  generation such as single pulse generation or PWM output.

  • Single Channel Timer – SCTM

    ▆ 16-bit auto-reload up-counter

    ▆ One channel for each timer

    ▆ 16-bit programmable prescaler allowing dividing the counter clock frequency by any factor  between 1 and 65536

    ▆ Input Capture function

    ▆ Compare Match Output

    ▆ PWM waveform generation with Edge-aligned

    ▆ Single Pulse Mode Output

    The Single Channel Timer, SCTM, consists of one 16-bit up-counter, one 16-bit Capture/Compare  Register (CCR), one 16-bit Counter Reload Register (CRR) and several control/status registers. It  can be used for a variety of purposes including general timer, input signal pulse width measurement  or output waveform generation such as single pulse generation or PWM outputs.

  • Basic Function Timer – BFTM

    ▆ 32-bit compare/match count-up counters – no I/O control features

    ▆ One shot mode – counting stops after a match condition

    ▆ Repetitive mode – restart counter after a match condition

    The Basic Function Timer, BFTM, is a simple 32-bit up-counting counter designed to measure  time intervals, generate one shot or generate repetitive interrupts. The BFTM can operate in two  functional modes which are repetitive and one shot modes. In the repetitive mode, the counter will  be restarted at each compare match event. The BFTM also supports a one shot mode which will  force the counter to stop counting when a compare match event occurs.

  • Watchdog Timer – WDT

    ▆ 12-bit down-counter with a 3-bit prescaler

    ▆ Reset event for the system

    ▆ Programmable watchdog timer window function

    ▆ Register write protection function

    The Watchdog Timer is a hardware timing circuit that can be used to detect system failures due  to software malfunctions. It includes a 12-bit count-down counter, a prescaler, a WDT counter  value register, a WDT delta value register, WDT operation control circuitry and a WDT protection  mechanism. The Watchdog Timer can be operated in a reset mode. The Watchdog Timer will  generate a reset when the counter counts down and reaches a zero value. If the software does not  reload the counter value before a Watchdog Timer underflow occurs, a reset will be generated  when the counter underflows. In addition, reset is also generated if the software reloads the counter  when the counter value is greater than or equal to the WDT delta value. This means the counter  must be reloaded within a limited timing window using a specific method. The Watchdog Timer  counter can be stopped while the processor is in the debug mode or the three sleep modes. There is  a register write protection function which can be enabled to prevent it from changing the Watchdog  Timer configuration unexpectedly

  • Real Time Clock – RTC

    ▆ 32-bit up-counter with a programmable prescaler

    ▆ Alarm function

    ▆ Interrupt and Wake-up event

    The Real Time Clock, RTC for short, includes an APB interface, a 32-bit count-up counter, a  control register, a prescaler, a compare register and a status register. Most of the RTC circuits are  located in the VDD Domain except for the APB interface. The APB interface is located in the VDD15 power domain. Therefore, it is necessary to be isolated by the ISO signal that comes from the  power control unit when the VDD15 power domain is powered off, that is when the device enters the  Power-Down mode. The RTC counter is used as a wakeup timer to generate a system resume signal  from the MCU power saving modes.

  • Inter-integrated Circuit – I2 C

    ▆ Supports both master and slave modes with a frequency of up to 1 MHz

    ▆ Provides an arbitration function and clock synchronization

    ▆ Supports 7-bit and 10-bit addressing modes and general call addressing

    ▆ Supports slave multi-addressing mode using address mask function

    The I2 C is an internal circuit allowing communication with an external I2 C interface which is an  industry standard two line serial interface used for connection to external hardware. These two serial  lines are known as a serial data line, SDA, and a serial clock line, SCL. The I2 C module provides  three data transfer rates: 100 kHz in the Standard mode, 400 kHz in the Fast mode and 1 MHz  in the Fast plus mode. The SCL period generation register is used to setup different kinds of duty  cycle implementations for the SCL pulse.

    The SDA line which is connected directly to the I2 C bus is a bidirectional data line between the  master and slave devices and is used for data transmission and reception. The I2 C also has an  arbitration detection and clock synchronization function to prevent the situations where more than  one master attempts to transmit data to the I2 C bus at the same time.

  • Serial Peripheral Interface – SPI

    ▆ Supports both master and slave mode

    ▆ Frequency of up to (fPCLK/2) MHz for master mode and (fPCLK/3) MHz for slave mode

    ▆ FIFO Depth: 8 levels

    ▆ Multi-master and multi-slave operation

    The Serial Peripheral Interface, SPI, provides an SPI protocol data transmit and receive function  in both master and slave mode. The SPI interface uses 4 pins, which are the serial data input and  output lines MISO and MOSI, the clock line, SCK, and the slave select line, SEL. One SPI device  acts as a master device which controls the data flow using the SEL and SCK signals to indicate the  start of data communication and the data sampling rate. To receive a data byte, the streamed data  bits are latched on a specific clock edge and stored in the data register or in the RX FIFO. Data  transmission is carried out in a similar way but in a reverse sequence. The mode fault detection  provides a capability for multi-master applications.

  • Universal Synchronous Asynchronous Receiver Transmitter – USART

    ▆ Supports both asynchronous and clocked synchronous serial communication modes

    ▆ Asynchronous operating baud rate clock frequency of up to (fPCLK/16) MHz and synchronous operating baud rate clock frequency of up to (fPCLK/8) MHz

    ▆ Full duplex communication

    ▆ Fully programmable serial communication characteristics including:

    ● Word length: 7, 8 or 9-bit character

    ● Parity: Even, odd or no-parity bit generation and detection

    ● Stop bit: 1 or 2 stop bit generation

    ● Bit order: LSB-first or MSB-first transfer

    ▆ Error detection: Parity, overrun and frame error

    ▆ Auto hardware flow control mode – RTS, CTS

    ▆ IrDA SIR encoder and decoder

    ▆ RS485 mode with output enable control

    ▆ FIFO Depth: 8-level for both receiver and transmitter

    The Universal Synchronous Asynchronous Receiver Transceiver, USART, provides a flexible  full duplex data exchange using synchronous or asynchronous transfer. The USART is used to  translate data between parallel and serial interfaces, and is commonly used for RS232 standard  communication. The USART peripheral function supports four types of interrupt including Line  Status Interrupt, Transmitter FIFO Empty Interrupt, Receiver Threshold Level Reaching Interrupt  and Time Out Interrupt. The USART module includes an 8-level transmitter FIFO, (TX FIFO) and  an 8-level receiver FIFO (RX FIFO). The software can detect a USART error status by reading the  USART Status & Interrupt Flag Register, USRSIFR. The status includes the type and the condition  of transfer operations as well as several error conditions resulting from Parity, Overrun, Framing  and Break events.

  • Universal Asynchronous Receiver Transmitter – UART

    ▆ Asynchronous serial communication operating baud-rate clock frequency of up to (fPCLK/16) MHz

    ▆ Full duplex communication

    ▆ Fully programmable serial communication characteristics including:

    ● Word length: 7, 8 or 9-bit character

    ● Parity: Even, odd or no-parity bit generation and detection

    ● Stop bit: 1 or 2 stop bit generation

    ● Bit order: LSB-first or MSB-first transfer

    ▆ Error detection: Parity, overrun and frame error

    The Universal Asynchronous Receiver Transceiver, UART, provides a flexible full duplex data  exchange using asynchronous transfer. The UART is used to translate data between parallel and  serial interfaces, and is commonly used for RS232 standard communication. The UART peripheral  function supports Line Status Interrupt. The software can detect a UART error status by reading  the UART Status & Interrupt Flag Register, URSIFR. The status includes the type and the  condition of transfer operations as well as several error conditions resulting from Parity, Overrun,  Framing and Break events.

  • Smart Card Interface – SCI

    ▆ Supports ISO 7816-3 standard

    ▆ Character Transfer mode

    ▆ Single transmit buffer and single receive buffer

    ▆ 11-bit ETU (Elementary Time Unit) counter

    ▆ 9-bit guard time counter

    ▆ 24-bit general purpose waiting time counter

    ▆ Parity generation and check functions

    ▆ Automatic character retry on parity error detection in transmission and reception modes

    The Smart Card Interface, SCI, is compatible with the ISO 7816-3 standard. This interface includes  functions for Card Insertion/Removal detection, SCI data transfer control logic and data buffers,  internal Timer Counters and corresponding control logic circuits to perform the required Smart  Card operations. The Smart Card interface acts as a Smart Card Reader to facilitate communication  with the external Smart Card. The overall functions of the Smart Card interface are controlled  by a series of registers including control and status registers together with several corresponding  interrupts which are generated to get the attention of the microcontroller for SCI transfer status.

  • Cyclic Redundancy Check – CRC

    ▆ Supports CRC16 polynomial: 0x8005, X16 + X15 + X2  + 1

    ▆ Supports CCITT CRC16 polynomial: 0x1021, X16 + X12 + X5  + 1

    ▆ Supports IEEE-802.3 CRC32 polynomial: 0x04C11DB7, X32 + X26 + X23 + X22 + X16 + X12 + X11 + X10 + X8  + X7  + X5  + X4  + X2  + X + 1

    ▆ Supports 1's complement, byte reverse and bit reverse operation on data and checksum

    ▆ Supports byte, half-word and word data size

    ▆ Programmable CRC initial seed value

    ▆ CRC computation executed in 1 AHB clock cycle for 8-bit data and 4 AHB clock cycles for 32- bit data

    ▆ Supports PDMA to complete a CRC computation of a block of memory

    The CRC calculation unit is an error detection technique test algorithm which is used to verify data  transmission or storage data correctness. A CRC calculation takes a data stream or a block of data  as input and generates a 16-bit or 32-bit output remainder. Ordinarily, a data stream is suffixed by  a CRC code and used as a checksum when being sent or stored. Therefore, the received or restored  data stream is calculated by the same generator polynomial as described above. If the new CRC  code result does not match the one calculated earlier, that means data stream contains a data error.

  • Peripheral Direct Memory Access – PDMA

    ▆ 6 channels with trigger source grouping

    ▆ 8-bit, 16-bit and 32-bit width data transfer

    ▆ Supports Linear address, circular address and fixed address modes

    ▆ 4-level programmable channel priority

    ▆ Auto reload mode

    ▆ Supports trigger source: ADC, SPI, USART, UART, I2 C, SCI, GPTM, PWM, AES and software request

    The Peripheral Direct Memory Access controller, PDMA, moves data between the peripherals  and the system memory on the AHB bus. Each PDMA channel has a source address, destination  address, block length and transfer count. The PDMA can exclude the CPU intervention and avoid  interrupt service routine execution. It improves system performance as the software does not need  to connect each data movement operation.

  • External Bus Interface – EBI

    ▆ Programmable interface for various memory types

    ▆ Translate the AHB transactions into the appropriate external device protocol

    ▆ Individual chip select signal for per memory bank

    ▆ Programmable timing to support a wide range of devices

    ▆ Automatic translation when AHB transaction width and external memory interface width is  different

    ▆ Write buffer to decrease the stalling of the AHB write burst transaction

    ▆ Multiplexed and non-multiplexed address and data line configurations

    ● Up to 21 address lines

    ● Up to 16-bit data bus width

    The external bus interface is able to access external parallel interface devices such as SRAM, Flash  and LCD modules. The interface is memory mapped into the CPU internal address map. The data  and address lines are multiplexed in order to reduce the number of pins required to connect to the  external devices. The read/write timing of the bus can be adjusted to meet the timing specification  of the external devices. Note the interface only supports asynchronous 8-bit or 16-bit bus interface.

  • Universal Serial Bus Device Controller – USB

    ▆ Complies with USB 2.0 full-speed (12 Mbps) specification

    ▆ On-chip USB full-speed transceiver

    ▆ 1 control endpoint (EP0) for control transfer

    ▆ 3 single-buffered endpoints for bulk and interrupt transfer

    ▆ 4 double-buffered endpoints for bulk, interrupt and isochronous transfer

    ▆ 1024-byte EP_SRAM used as the endpoint data buffers

    The USB device controller is compliant with the USB 2.0 full-speed specification. There is one  control endpoint known as Endpoint 0 and seven configurable endpoints. A 1024-byte EP_SRAM  is used as the endpoint buffer. Each endpoint buffer size is programmable using corresponding  registers, which provides maximum flexibility for various applications. The integrated USB fullspeed transceiver helps to minimize overall system complexity and cost. The USB also contains  suspend and resume features to meet low-power consumption requirement.

  • Advanced Encryption Standard – AES

    ▆ Supports AES Encrypt / Decrypt Function

    ▆ Supports AES ECB/CBC/CTR mode

    ▆ Supports Key Size 128, 192 and 256 bits

    ▆ Supports 4 words Initial Vector for CBC and CTR mode

    ▆ 8 × 32 bits ( Each IN and OUT FIFO Capacity ) for 2 AES Data blocks

    ▆ Supports PDMA Interface

    ▆ Supports Word Data Swap Function

    The AES core supports both encryption and decryption functions and supports 128-bit input data.  It should be noted that hardware does not pad out any input data bits, therefore users need to do pad  action by software at first.

  • Debug Support

    ▆ Serial Wire Debug Port SW-DP

    ▆ 6 instruction comparators and 2 literal comparators for hardware breakpoint or code / literal  patches

    ▆ 4 comparators for hardware watchpoints

    ▆ 1-bit asynchronous trace for serial wire debug mode – TRACESWO

  • Package and Operation Temperature

    ▆ 40-pin QFN and 48 / 64-pin LQFP packages

    ▆ Operation temperature range: -40 °C to 85 °C

Device Information


Block Diagram


Memory Map

Holtek MCU HT32F52220


How to Order

You can get your Holtek MCU HT32F12364 solution by flling out the form below and we will contact you immediately.

Want to turn your idea into reality? Contact YFM Support
Copyright © 2022 Shenzhen Yufan Microelectronics Co., Ltd. All Rights Reserved. | Sitemap

Contact

Copyright © 2022 Shenzhen Yufan Microelectronics Co., Ltd. All Rights Reserved. | { fanyi('Sitemap') }}
Online

Email

Message
TOP