## STM8AF61xx, STM8H61xx STM8AF51xx, STM8AH51xx Automotive 8-bit MCU, with up to 128 Kbytes Flash, EEPROM, 10-bit ADC, timers, LIN, CAN, USART, SPI, I<sup>2</sup>C, 3 V to 5.5 V #### **Features** #### Core - Max f<sub>CPU</sub>: 24 MHz - Advanced STM8A core with Harvard architecture and 3-stage pipeline - Average 1.6 cycles/instruction resulting in 10 MIPS at 16 MHz f<sub>CPU</sub> for industry standard benchmark #### **Memories** - Program memory: 48 to 128 Kbytes Flash; data retention 20 years at 55 °C after 1 kcycle - Data memory: 1.5 to 2 Kbytes true data EEPROM; endurance 300 kcycles - RAM: 3 to 6 Kbytes #### **Clock management** - Low power crystal resonator oscillator with external clock input - Internal, user-trimmable 16 MHz RC and low power 128 kHz RC oscillators - Clock security system with clock monitor #### Reset and supply management - Multiple low power modes (wait, slow, auto wake-up, halt) with user definable clock gating - Low consumption power-on and power-down reset ### Interrupt management - Nested interrupt controller with 32 interrupt vectors - Up to 37 external interrupts on 5 vectors #### **Timers** - Up to 2 auto-reload 16-bit PWM timers with up to 3 CAPCOM channels each (IC, OC or PWM) - Multipurpose timer: 16-bit, 4 CAPCOM channels, 3 complementary outputs, dead-time insertion and flexible synchronization - 8-bit AR system timer with 8-bit prescaler - Auto wake-up timer - 2 watchdog timers: Window and standard #### **Communication interfaces** - High speed 1 Mbit/s active CAN 2.0B interface - USART with clock output for synchronous operation LIN master mode - LINUART LIN 2.1 compliant, master/slave modes with automatic resynchronization - SPI interface up to 10 Mbit/s or (f<sub>CPLI</sub>/2) - I<sup>2</sup>C interface up to 400 Kbit/s #### Analog to digital converter (ADC) ■ 10-bit, 3 LSB ADC with up to 16 multiplexed channels #### I/Os - Up to 70 user pins including 10 high sink I/Os - Highly robust I/O design, immune against current injection #### Table 1. Device summary<sup>(1)</sup> #### STM8AF61xx/STM8AH61xx (without CAN) STM8AF/H61AA, STM8AF/H619A, STM8AF/H61A9, STM8AF/H6199, STM8AF/H6189, STM8AF/H6179, STM8AF/H6169, STM8AF/H61A8, STM8AF/H6198, STM8AF/H6188, STM8AF/H6178, STM8AF/H6186, STM8AF/H6176 #### STM8AF51xx/STM8AH51xx (with CAN) STM8AF/H51AA, STM8AF/H519A, STM8AF/H51A9, STM8AF/H5199, STM8AF/H5189, STM8AF/H5179, STM8AF/H5169, STM8AF/H51A8, STM8AF/H5198, STM8AF/H5188, STM8AF/H5178 This datasheet applies to product versions with and without data EEPROM. The order code identifier is 'F' or 'H' respectively, only one of which appears in an order code. ## **Contents** | 1 | Intro | Introduction 8 | | | | | | | | | | | | |---|-----------------|----------------|-----------------------------------------------|----|--|--|--|--|--|--|--|--|--| | 2 | Desc | cription | | 9 | | | | | | | | | | | 3 | Prod | luct line | e-up | 10 | | | | | | | | | | | 4 | Block diagram 1 | | | | | | | | | | | | | | 5 | Prod | duct ove | rview | 12 | | | | | | | | | | | | 5.1 | Centra | Central processing unit STM8A | | | | | | | | | | | | | | 5.1.1 | Architecture and registers | 12 | | | | | | | | | | | | | 5.1.2 | Addressing | 12 | | | | | | | | | | | | | 5.1.3 | Instruction set | 12 | | | | | | | | | | | | 5.2 | Single | wire interface module (SWIM) and debug module | 13 | | | | | | | | | | | | | 5.2.1 | SWIM | 13 | | | | | | | | | | | | | 5.2.2 | Debug module | 13 | | | | | | | | | | | | 5.3 | Interru | pt controller | 13 | | | | | | | | | | | | 5.4 | 13 | | | | | | | | | | | | | | | 5.4.1 | Architecture | 13 | | | | | | | | | | | | | 5.4.2 | Write protection (WP) | 14 | | | | | | | | | | | | | 5.4.3 | Read-out protection (ROP) | 15 | | | | | | | | | | | | | 5.4.4 | Speed | 15 | | | | | | | | | | | | 5.5 | Low-po | ower operating modes | 16 | | | | | | | | | | | | 5.6 | Clock a | and clock controller | 16 | | | | | | | | | | | | | 5.6.1 | Features | 16 | | | | | | | | | | | | | 5.6.2 | Internal 16 MHz RC oscillator | 17 | | | | | | | | | | | | | 5.6.3 | Internal 128 kHz RC oscillator | 17 | | | | | | | | | | | | | 5.6.4 | Internal high-speed crystal oscillator | 17 | | | | | | | | | | | | | 5.6.5 | External clock input | 17 | | | | | | | | | | | | | 5.6.6 | Clock security system (CSS) | 17 | | | | | | | | | | | | 5.7 | Timers | 3 | 18 | | | | | | | | | | | | | 5.7.1 | Watchdog timers | 18 | | | | | | | | | | | | | 5.7.2 | Auto wake-up counter | 18 | | | | | | | | | | | | | 5.7.3 | Multipurpose and PWM timers | 19 | | | | | | | | | | | | | 5.7.4 | Timer 4: System timer | 19 | |----|-------|-----------|---------------------------------------------------|------| | | 5.8 | ADC . | | . 20 | | | 5.9 | Commu | ınication interfaces | . 20 | | | | 5.9.1 | USART | 20 | | | | 5.9.2 | LINUART | 22 | | | | 5.9.3 | SPI | 22 | | | | 5.9.4 | I <sup>2</sup> C | 23 | | | | 5.9.5 | CAN | 23 | | | 5.10 | Input/ou | utput specifications | . 24 | | 6 | Pino | uts and | pin description | . 25 | | | 6.1 | Packag | e pinouts | . 25 | | | 6.2 | Pin des | cription | . 28 | | | | 6.2.1 | Alternate function remapping | 32 | | 7 | Mem | ory map | ) | . 33 | | 8 | Inter | rupt tab | le | . 34 | | 9 | Regi | ster map | oping | . 36 | | 10 | Optio | on bytes | | . 49 | | 11 | Elect | rical cha | aracteristics | . 54 | | | 11.1 | Parame | eter conditions | . 54 | | | | 11.1.1 | Minimum and maximum values | 54 | | | | 11.1.2 | Typical values | 54 | | | | 11.1.3 | Typical curves | 54 | | | | 11.1.4 | Loading capacitor | 54 | | | | 11.1.5 | Pin input voltage | 55 | | | 11.2 | Absolut | e maximum ratings | . 55 | | | 11.3 | Operati | ng conditions | . 57 | | | | 11.3.1 | Supply current characteristics | 58 | | | | 11.3.2 | External clock sources and timing characteristics | 67 | | | | 11.3.3 | Internal clock sources and timing characteristics | 69 | | | | 11.3.4 | Memory characteristics | 71 | | | | 11.3.5 | I/O port pin characteristics | 72 | | | | | | | | | | 11.3.6 | Reset pin characteristics | 76 | | | | | | | | | | | |----|-------|---------------------------|--------------------------------------------|------|--|--|--|--|--|--|--|--|--|--| | | | | · | | | | | | | | | | | | | | | 11.3.7 | TIM 1, 2, 3, and 4 timer characteristics | | | | | | | | | | | | | | | 11.3.8 | SPI serial peripheral interface | | | | | | | | | | | | | | | 11.3.9 | I <sup>2</sup> C interface characteristics | | | | | | | | | | | | | | | 11.3.10 | 10-bit ADC characteristics | 83 | | | | | | | | | | | | | | 11.3.11 | EMC characteristics | 85 | | | | | | | | | | | | | 11.4 | Therma | al characteristics | 88 | | | | | | | | | | | | | | 11.4.1 | Reference document | 88 | | | | | | | | | | | | | | 11.4.2 | Selecting the product temperature range | 89 | | | | | | | | | | | | 12 | Pack | Package characteristics90 | | | | | | | | | | | | | | | 12.1 | Packag | e mechanical data | 91 | | | | | | | | | | | | 13 | Orde | ring info | ormation | . 95 | | | | | | | | | | | | 14 | STM | 3 develo | ppment tools | . 96 | | | | | | | | | | | | | 14.1 | Emulati | ion and in-circuit debugging tools | 96 | | | | | | | | | | | | | 14.2 | 14.2 Software tools | | | | | | | | | | | | | | | | 14.2.1 | STM8 toolset | 97 | | | | | | | | | | | | | | 14.2.2 | C and assembly toolchains | 97 | | | | | | | | | | | | | 14.3 | Prograr | mming tools | | | | | | | | | | | | | 15 | Revis | sion his | tory | . 98 | | | | | | | | | | | | | | | - | | | | | | | | | | | | ## List of tables | Table 1. | Device summary | 1 | |-----------|-----------------------------------------------------------------------------------|----| | Table 2. | STM8AF/H51xx product line-up - with CAN | | | Table 3. | STM8AF/H61xx product line-up - without CAN | | | Table 4. | STM8A timer configuration | 19 | | Table 5. | Legend/abbreviation for <i>Table 6</i> | | | Table 6. | STM8A microcontroller family pin description | | | Table 7. | Stack and RAM partitioning | | | Table 8. | STM8A interrupt table | 34 | | Table 9. | STM8A I/O port hardware register map | 36 | | Table 10. | STM8A general hardware register map | | | Table 11. | CPU/SWIM/debug module/interrupt controller registers | | | Table 12. | Option bytes | | | Table 13. | Option byte description | | | Table 14. | Voltage characteristics | 55 | | Table 15. | Current characteristics | 56 | | Table 16. | Thermal characteristics | 56 | | Table 17. | General operating conditions | 57 | | Table 18. | Operating conditions at power-up/power-down | 58 | | Table 19. | Total current consumption in run, wait and slow mode at V <sub>DD</sub> = 5.0 V | 59 | | Table 20. | Total current consumption and timing in halt, fast active halt and slow | | | | active halt modes at $V_{DD}$ = 5.0 V | 61 | | Table 21. | Total current consumption in run, wait and slow mode at V <sub>DD</sub> = 3.3 V | 61 | | Table 22. | Total current consumption and timing in halt, fast active halt and slow | | | | active halt modes at V <sub>DD</sub> = 3.3 V | 64 | | Table 23. | Typical peripheral current consumption V <sub>DD</sub> = 5.0 V | 65 | | Table 24. | HSE user external clock characteristics | 67 | | Table 25. | HSE oscillator characteristics | 68 | | Table 26. | HSI oscillator characteristics | 69 | | Table 27. | LSI oscillator characteristics | 70 | | Table 28. | RAM and hardware registers | | | Table 29. | Flash program memory/data EEPROM memory | | | Table 30. | I/O static characteristics | 72 | | Table 31. | NRST pin characteristics | | | Table 32. | TIM 1, 2, 3 characteristics | | | Table 33. | SPI characteristics | | | Table 34. | I <sup>2</sup> C characteristics | | | Table 35. | ADC characteristics | | | Table 36. | ADC accuracy with $R_{AIN}$ < 10 k $\Omega$ $R_{AIN}$ , $V_{DDA}$ = 3.3 $V_{BDA}$ | 84 | | Table 37. | ADC accuracy with $R_{AIN}$ < 10 k $\Omega$ , $V_{DDA}$ = 5 V | | | Table 38. | EMS data | | | Table 39. | EMI data | | | Table 40. | ESD absolute maximum ratings | | | Table 41. | Electrical sensitivities | | | Table 42. | Thermal characteristics | | | Table 43. | 80-pin low profile quad flat package mechanical data | | | Table 44. | 64-pin low profile quad flat package mechanical data | | | Table 45. | 48-pin low profile quad flat package mechanical data | | | Table 46. | 32-pin low profile quad flat package mechanical data | 94 | | List of tabl | es | STM8AF61xx, STM8AF51xx | |--------------|---------------------------|------------------------| | Table 47. | Document revision history | 98 | # **List of figures** | Figure 1. | STM8A block diagram | 11 | |------------|--------------------------------------------------------------------------------------------|----| | Figure 2. | STM8A products: Flash memory organization | 14 | | Figure 3. | LQFP 80-pin pinout | | | Figure 4. | LQFP 64-pin pinout | 26 | | Figure 5. | LQFP 48-pin pinout | 27 | | Figure 6. | LQFP 32-pin pinout | 28 | | Figure 7. | Register and memory map | 33 | | Figure 8. | Pin loading conditions | 54 | | Figure 9. | Pin input voltage | | | Figure 10. | f <sub>CPUmax</sub> versus V <sub>DD</sub> | 57 | | Figure 11. | Typ. I <sub>DD(RUN)HSE</sub> vs. V <sub>DD</sub> @f <sub>CPU</sub> = 16 MHz, periph = on | 66 | | Figure 12. | Typ. $I_{DD(RUN)HSE}$ vs. $f_{CPU}$ @ $V_{DD}$ = 5.0 V, periph = on | 66 | | Figure 13. | Typ. I <sub>DD(RUN)HSI</sub> vs. V <sub>DD</sub> @ f <sub>CPU</sub> = 16 MHz, periph = off | 66 | | Figure 14. | Typ. I <sub>DD(WFI)</sub> HSE vs. V <sub>DD</sub> @ f <sub>CPU</sub> = 16 MHz, periph = on | 66 | | Figure 15. | Typ. I <sub>DD(WFI)</sub> HSE vs. f <sub>CPU</sub> @ V <sub>DD</sub> = 5.0 V, periph = on | | | Figure 16. | Typ. $I_{DD(WFI)HSI}$ vs. $V_{DD}$ @ $f_{CPU} = 16$ MHz, periph = off | | | Figure 17. | HSE external clock source | | | Figure 18. | HSE oscillator circuit diagram | | | Figure 19. | Typical HSI frequency vs $V_{DD}$ @ four temperatures | | | Figure 20. | Typical LSI frequency vs V <sub>DD</sub> @ room temperature | | | Figure 21. | Typical $V_{IL}$ and $V_{IH}$ vs $V_{DD}$ @ four temperatures | | | Figure 22. | Typical pull-up resistance R <sub>PU</sub> vs V <sub>DD</sub> @ four temperatures | | | Figure 23. | Typical pull-up current I <sub>pu</sub> vs V <sub>DD</sub> @ four temperatures | | | Figure 24. | Typ. $V_{OL}$ @ $V_{DD}$ = 3.3 V (standard ports) | | | Figure 25. | Typ. $V_{OL}$ @ $V_{DD}$ = 5.0 V (standard ports) | | | Figure 26. | Typ. $V_{OL}$ @ $V_{DD}$ = 3.3 V (true open drain ports) | | | Figure 27. | Typ. $V_{OL}$ @ $V_{DD}$ = 5.0 V (true open drain ports) | | | Figure 28. | Typ. $V_{OL}$ @ $V_{DD}$ = 3.3 V (high sink ports) | | | Figure 29. | Typ. $V_{OL}$ @ $V_{DD}$ = 5.0 V (high sink ports) | | | Figure 30. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 3.3 V (standard ports) | | | Figure 31. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 5.0 V (standard ports) | | | Figure 32. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 3.3 V (high sink ports) | | | Figure 33. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 5.0 V (high sink ports) | | | Figure 34. | Typical NRST V <sub>IL</sub> and V <sub>IH</sub> vs V <sub>DD</sub> @ four temperatures | | | Figure 35. | Typical NRST pull-up resistance R <sub>PU</sub> vs V <sub>DD</sub> @ four temperatures | | | Figure 36. | Typical NRST pull-up current I <sub>pu</sub> vs V <sub>DD</sub> @ four temperatures | | | Figure 37. | Recommended reset pin protection | // | | Figure 38. | SPI timing diagram - slave mode and CPHA = 0 | 80 | | Figure 39. | SPI timing diagram - slave mode and CPHA = 1 <sup>(1)</sup> | 80 | | Figure 40. | SPI timing diagram - master mode <sup>(1)</sup> | | | Figure 41. | ADC accuracy characteristics | | | Figure 42. | Typical application with ADC | | | Figure 43. | 80-pin low profile quad flat package (14 x 14) | | | Figure 44. | 64-pin low profile quad flat package (10 x 10) | | | Figure 45. | 48-pin low profile quad flat package (7 x 7) | | | Figure 46. | 32-pin low profile quad flat package (7 x 7) | | | Figure 47. | STM8A order codes | 95 | ## 1 Introduction This datasheet refers to the STM8AF61xx, STM8AH61xx, STM8AF51xx, STM8AH51xx products with 48 to 128 Kbytes of program memory. The STM8AF51xx and STM8AH51xx are hereafter referred to as the STM8AF/H51xx and the STM8AF61xx and STM8AH61xx are hereafter referred to as the STM8AF/H61xx. 'F' refers to product versions with data EEPROM and 'H' refers to product versions without EEPROM. The identifiers 'F' and 'H' do not both appear in an order code. The datasheet contains the description of family features, pinout, electrical characteristics, mechanical data and ordering information. - For complete information on the STM8A microcontroller memory, registers and peripherals, please refer to STM8A microcontroller family reference manual (RM0009). - For information on programming, erasing and protection of the internal Flash memory please refer to the STM8 Flash programming manual (PM0047). - For information on the debug and SWIM (single wire interface module) refer to the STM8 SWIM communication protocol and debug module user manual (UM0470). - For information on the STM8 core, please refer to the STM8 CPU programming manual (PM0044). ## 2 Description The STM8A automotive 8-bit microcontrollers offer from 48 to 128 Kbytes of program memory and integrated true data EEPROM. The STM8AF/H51xx series feature a CAN interface. All devices of the STM8A product line provide the following benefits: - Reduced system cost - Integrated true data EEPROM for up to 300 k write/erase cycles - High system integration level with internal clock oscillators, watchdog and brownout reset - Performance and robustness - Peak performance 20 MIPS at 24 MHz and average performance 10 MIPS at 16 MHz CPU clock frequency - Robust I/O, independent watchdogs with separate clock source - Clock security system - Short development cycles - Applications scalability across a common family product architecture with compatible pinout, memory map and and modular peripherals. - Full documentation and a wide choice of development tools - Product longevity - Advanced core and peripherals made in a state-of-the art technology - Native automotive product family operating both at 3.3 V and 5 V supply All STM8A and ST7 microcontrollers are supported by the same tools including STVD/STVP development environment, the STice emulator and a low-cost, third party incircuit debugging tool (for more details, see *Section 14: STM8 development tools on page 96*). # 3 Product line-up Table 2. STM8AF/H51xx product line-up - with CAN | Order code | Package | Prog.<br>(bytes) | RAM<br>(bytes) | Data EE<br>(bytes) | 10-bit<br>A/D ch. | Timers<br>(IC/OC/PWM) | Serial<br>interfaces | I/0 wakeup<br>pins | | |---------------|-------------------|------------------|----------------|--------------------|-------------------|-----------------------------------------------------------|-------------------------------------------------------|--------------------|--| | STM8AF/H51AAT | LQFP80 | 128 K | | | | 1x8-bit: TIM4<br>3x16-bit: TIM1,<br>TIM2, TIM3<br>(9/9/9) | CAN,<br>LIN(UART),<br>SPI, USART,<br>I <sup>2</sup> C | 72/37 | | | STM8AF/H519AT | (14x14) | 96 K | 6 K | 2 K | | | | 12/31 | | | STM8AF/H51A9T | | 128 K | OK | 2 K | | | | | | | STM8AF/H5199T | | 96 K | | | 16 | | | | | | STM8AF/H5189T | LQFP64<br>(10x10) | 64 K | 4 K | 1 E V | | | | 56/36 | | | STM8AF/H5179T | (10/110) | 48 K | 3 K | 1.5 K | | | | | | | STM8AF/H5169T | | 32 K | 2 K | 1 K | | | | | | | STM8AF/H51A8T | | 128 K | 6 K | 2 K | | | | | | | STM8AF/H5198T | LQFP48 | 96 K | ΟN | 2 K | 10 | | | 40/05 | | | STM8AF/H5188T | $(7x7)^{(1)}$ | 64 K | 4 K | 4.5.14 | 10 | | | 40/35 | | | STM8AF/H5178T | | 48 K | 3 K | 1.5 K | | | | | | <sup>1.</sup> QFN package planned Table 3. STM8AF/H61xx product line-up - without CAN | Order code | Package | Prog.<br>(bytes) | RAM<br>(bytes) | Data EE<br>(bytes) | 10-bit<br>A/D ch. | Timers<br>(IC/OC/PWM) | Serial<br>interfaces | I/0<br>wakeup<br>pins | |---------------|--------------------------------|------------------|----------------|--------------------|-------------------|-----------------------------------------------------------|-------------------------------------|-----------------------| | STM8AF/H61AAT | LQFP80 | 128 K | | | | 1x8-bit: TIM4<br>3x16-bit: TIM1,<br>TIM2, TIM3<br>(9/9/9) | | 72/37 | | STM8AF/H619AT | (14x14) | 96 K | 6 K | 2 K | 16 | | | 12/31 | | STM8AF/H61A9T | | 128 K | OK | 2 K | | | | | | STM8AF/H6199T | LQFP64<br>(10x10) | 96 K | | | | | LIN(UART), | 56/36 | | STM8AF/H6189T | | 64 K | 4 K | 1.5 K | | | | | | STM8AF/H6179T | (10/110) | 48 K | 3 K | 1.5 K | | | SPI, USART, | | | STM8AF/H6169T | | 32 K | 2 K | 1 K | | | I <sup>2</sup> C | | | STM8AF/H61A8T | | 128 K | C 1/ | 0.14 | | | | | | STM8AF/H6198T | LQFP48 | 96 K | 6 K | 2 K | 10 | | | 40/35 | | STM8AF/H6188T | $(7x7)^{(1)}$ | 64 K | 4 K | | 10 | | | 40/35 | | STM8AF/H6178T | | 48 K | 3 K | | | | | | | STM8AF/H6186T | | 64 K | 4 K | 1.5 K | | 1x8-bit: TIM4 | | | | STM8AF/H6176T | LQFP32<br>(7x7) <sup>(1)</sup> | 48 K | 3 K | | 7 | 3x16-bit: TIM1,<br>TIM2, TIM3<br>(8/8/8) | LIN(UART),<br>SPI, I <sup>2</sup> C | 25/23 | <sup>1.</sup> QFN package planned 10/100 ## 4 Block diagram ## 5 Product overview The following section intends to give an overview of the basic features of the STM8A functional modules and peripherals. For more detailed information please refer to the STM8A microcontroller family reference manual (RM0009). ## 5.1 Central processing unit STM8A The 8-bit STM8A core is designed for code efficiency and performance. It contains 21 internal registers (six directly addressable in each execution context), 20 addressing modes including indexed indirect and relative addressing and 80 instructions. ## 5.1.1 Architecture and registers - Harvard architecture - 3-stage pipeline - 32-bit wide program memory bus with single cycle fetching for most instructions - X and Y 16-bit index registers, enabling indexed addressing modes with or without offset and read-modify-write type data manipulations - 8-bit accumulator - 24-bit program counter with 16-Mbyte linear memory space - 16-bit stack pointer with access to a 64 Kbyte stack - 8-bit condition code register with seven condition flags for the result of the last instruction #### 5.1.2 Addressing - 20 addressing modes - Indexed indirect addressing mode for look-up tables located anywhere in the address space - Stack pointer relative addressing mode for local variables and parameter passing #### 5.1.3 Instruction set - 80 instructions with 2-byte average instruction size - Standard data movement and logic/arithmetic functions - 8-bit by 8-bit multiplication - 16-bit by 8-bit and 16-bit by 16-bit division - Bit manipulation - Data transfer between stack and accumulator (push/pop) with direct stack access - Data transfer using the X and Y registers or direct memory-to-memory transfers ## 5.2 Single wire interface module (SWIM) and debug module The single wire interface module, SWIM, together with an integrated debug module, permits non-intrusive, real-time in-circuit debugging and fast memory programming. #### 5.2.1 SWIM Single wire interface for direct access to the debugging module and memory programming. The interface can be activated in all device operation modes and supports hot-plugging. The maximum data transmission speed is 145 bytes/ms. ## 5.2.2 Debug module The non-intrusive debugging module features a performance close to a full-featured emulator. Besides memory and peripheral operation, CPU operation can also be monitored in real-time by means of shadow registers. - R/W of RAM and peripheral registers in real-time - R/W for all resources when the application is stopped - Breakpoints on all program-memory instructions (software breakpoints) except the vector table - Two advanced breakpoints and 23 predefined configurations ## 5.3 Interrupt controller - Nested interrupts with three software priority levels - 32 interrupt vectors with hardware priority - Up to 37 external interrupts on five vectors - Trap and reset interrupts ## 5.4 Non-volatile memory - Up to 128 Kbytes of program single voltage Flash memory - Up to 2 Kbytes true (not emulated) data EEPROM - Read while write: Writing in the data memory is possible while executing code in the program memory - 128 user option bytes permit permanent device set up #### 5.4.1 Architecture - Array: Up to 128 Kbytes of Flash program memory organized in blocks of 128 bytes each - Read granularity: 1 word = 4 bytes - Write/erase granularity: 1 word (4 bytes) or 1 block (128 bytes) in parallel Writing, erasing, word and block register management is handled automatically by the memory interface. ### 5.4.2 Write protection (WP) Write protection in application mode is intended to avoid unintentional overwriting of the memory in case of user software malfunction. Code update in user mode is still possible after execution of a specific MASS key sequence. The program memory is divided into two areas: - Main program memory: Up to 128 Kbytes minus user-specific boot code (UBC) - UBC: Configurable up to 128 Kbytes The UBC area also remains write-protected during in-application programming. It permits storage of the boot program or specific code libraries. The boot area is a part of the program memory that contains the reset and interrupt vectors, the reset routine and usually the IAP and communication routines. The UBC area has a second level of protection to prevent unintentional erasing or modification during IAP programming. This means that the MASS keys do not unlock the UBC area. The size of the UBC is programmable through the UBC option byte, in increments of 512 bytes, by programming the UBC option byte in ICP mode. ### 5.4.3 Read-out protection (ROP) STM8A devices provide a read-out protection of the code and data memory by programming the lock byte at address 4800h with the value AAh. Read-out protection prevents reading and writing the program and data memory via the debug module and SWIM interface. This protection is active in all device operation modes. Any attempt to remove the protection by overwriting the lock byte triggers a global erase of the program and data memory. The ROP circuit may provide a temporary access for debugging or failure analysis. This is a specific product option and must be specified while ordering STM8A products. Temporary read access is protected by a user defined, 8-byte keyword that is different from 00h or FFh. The keys are stored in the option byte area. Temporary read-out can be permanently disabled by means of the option byte TMU\_DIS. For enabling temporary read access the eight access keys have to be written in the TMU registers. A wrong code does not change the protection status. More than eight unsuccessful access trials trigger an erase of the program and data memory. Entering the right key sequence enables a temporary read access to the code and data memory after a delay of several milliseconds. The procedure for temporary read access is as follows: - Activate SWIM mode under device reset the CPU is stalled, code and data memory are not visible by the debug module. - Enable the internal 128 KHz LSI oscillator - Write the 8eight key bytes into the TMU registers - Set the bit(0) of the TMU status register to 1. A dedicated state machine on an isolated bus, compares the TMU register content with the key stored in the TMU option bytes. During this periode read and write operations have no effect. A reset re-activates the initial protection status. The comparison can be monitored by means of the TU\_CTL\_ST register. - In case of a successful key comparison, the SWIM interface enables read access to the code and data memory and program execution. A comparison error does not change the protection status but increments the counter MAXATT. If the counter content exceedes eight unsuccessful trials, a global erase of the data and code memory is triggered. The read access is temporary. A device reset restores the initial protection. #### 5.4.4 Speed - Operation at up to 16 MHz CPU clock frequency without wait states. At a higher clock frequency, a single wait state has to be inserted. - Programming time modes (same for word or block) - Fast programming: Without erase - Standard programming: Erase and program ## 5.5 Low-power operating modes The product features various low-power modes: - Slow mode: Prescaled CPU clock, selected peripherals at full clock speed - Active halt mode: CPU and peripheral clocks are stopped - Halt mode: CPU and peripheral clocks are stopped, the device remains powered on. Wake-up is triggered by an external interrupt. In all modes the CPU and peripherals remain permanently powered on, the system clock is applied only to selected modules. The RAM content is preserved and the brown-out reset circuit remains activated. #### 5.6 Clock and clock controller The clock controller distributes the system clock coming from different oscillators to the core and the peripherals. It also manages clock gating for low power modes and ensures clock robustness. #### 5.6.1 Features - Clock sources: - Internal 16 MHz and 128 kHz RC oscillators - Crystal oscillator - External clock input - Reset: After reset the microcontroller restarts by default with an internal 2-MHz clock (16 MHz/8). The prescaler ratio and clock source can be changed by the application program as soon as the code execution starts. - Safe clock switching: Clock sources can be changed safely on the fly in run mode through a configuration register. The clock signal is not switched until the new clock source is ready. The design guarantees glitch-free switching. - **Clock management:** To reduce power consumption, the clock controller can stop the clock to the core, individual peripherals or memory. - Wake-up: Recovery from halt and AWU (auto wake-up) low power modes uses the internal RC oscillator (16 MHz/8) for quick start-up and then switches to the last selected clock source before halt mode is entered. - Clock security system (CSS): The CSS permits monitoring of external clock sources and automatic switching to the internal RC (16 MHz/8) in case of a clock failure. - Configurable main clock output (CCO): This outputs an external clock for use by the application. #### 5.6.2 Internal 16 MHz RC oscillator - Default clock after reset 2 MHz (16 MHz/8) - Wake-up time: < 2 μs #### **User trimming** The register CLK\_HSITRIMR with two trimming bits plus one additional bit for the sign permits frequency tuning to a precision of 1% by the application program. The trimming step granularity is 1.5 %. The adjustment range covers all possible frequency variations versus supply voltage and temperature. This trimming does not change the initial production setting. #### 5.6.3 Internal 128 kHz RC oscillator The frequency of this clock is 128 kHz and it is independent from the main clock. It drives the watchdog or the AWU wake-up timer. In systems which do not need independent clock sources for the watchdog counters, the 128 kHz signal can be used as the system clock. This configuration has to be enabled by setting an option byte (OPT3, LSI EN). ## 5.6.4 Internal high-speed crystal oscillator The internal high-speed crystal oscillator delivers the main clock in normal run mode. It operates with quartz crystals and ceramic resonators. - Frequency range: 1 to 24 MHz - Crystal oscillation mode: Preferred fundamental - I/Os: Standard I/O pins multiplexed with OSCIN, OSCOUT Optionally, an external clock signal can be injected into the OSCIN input pin. #### 5.6.5 External clock input The external clock signal is applied to the OSCIN input pin of the crystal oscillator. The frequency range is 0 to 24 MHz. #### 5.6.6 Clock security system (CSS) The clock security system protects against a system stall in case of an external crystal clock failure. In case of a clock failure an interrupt is generated and the high speed internal clock (HSI) is automatically selected with a frequency of 2 MHz (16 MHz/8). This function can be enabled using the CSS register (CLK\_CSSR). The CSS operates by detecting when the external clock signal (crystal or external clock) falls below 500 kHz. With active CSS this is the minimum operating frequency. #### 5.7 Timers ## 5.7.1 Watchdog timers The watchdog system is based on two independent timers providing maximum security to the applications. The WDG timer activity is controlled by the application program or option bytes. Once the watchdog is activated, it cannot be disabled by the user program without a reset. #### Window watchdog timer The window watchdog is used to detect the occurrence of a software fault, usually generated by external interferences or by unexpected logical conditions, which cause the application program to abandon its normal sequence. The window function can be used to trim the watchdog behavior to match the application perfectly. The application software must refresh the counter before time-out and during a limited time window. A reset is generated in two situations: - 1. Timeout - 2. Refresh out of window: The downcounter is refreshed before its value is lower then the one stored in the window register. #### Independent watchdog timer The independent watchdog peripheral can be used to resolve processor malfunctions due to hardware or software failures. It is clocked by the 128 kHz LSI internal RC clock source, and thus stays active even in case of a CPU clock failure. If the hardware watchdog feature is enabled through the device option bits, the watchdog is automatically enabled at power-on, and generates a reset unless the key register is written by software before the counter reaches the end of count. The IWDG time base spans from $60 \mu s$ to 1 s. It can be adjusted by setting the registers of the 7-bit prescaler and 8-bit down-counter. #### 5.7.2 Auto wake-up counter - Used for auto wake-up from active halt mode. - Clock source: Internal 128 kHz internal low frequency RC oscillator or external clock. ### 5.7.3 Multipurpose and PWM timers STM8A devices described in this datasheet, contain up to three 16-bit multipurpose and PWM timers providing nine CAPCOM channels in total. Table 4. STM8A timer configuration | Timer | Counter | Prescaler | Туре | CAPCOM | Complementary outputs | Synchronization module | | | |--------|---------|-------------------------------|---------|--------|-----------------------|------------------------|--|--| | Timer1 | | 16 | Up/down | 4 | 3 | Yes | | | | Timer2 | 16 | 15-bit fixed power | | 3 | | | | | | Timer3 | | of 2 ratios | Up | 2 | 0 | No | | | | Timer4 | 8 | 7-bit fixed power of 2 ratios | - 7 | 0 | - | | | | #### **Timer 1: Multipurpose PWM timer** This is a high-end timer designed for a wide range of control applications. With its complementary outputs, dead-time control and center-aligned PWM capability, the field of applications is extended to motor control, lighting and half-bridge driver. - 16-bit up, down and up/down AR (auto-reload) counter with 16-bit prescaler - Four independent CAPCOM channels configurable as input capture, output compare, PWM generation (edge and center aligned mode) and single pulse mode output - Trigger module which allows the interaction of timer 1 with other timers or the ADC to be controlled - Break input to force the timer outputs into a defined state - Three complementary outputs with adjustable dead time - Interrupt sources: 4 x input capture/output compare, 1 x overflow/update, 1 x break #### Timer 2 and 3: 16-bit PWM timers - 16-bit auto-reload up-counter - 15-bit prescaler adjustable to fixed power of two ratios 1...32768 - Timers with three or two individually configurable CAPCOM channels - Interrupt sources: 2 or 3 x input capture/output compare, 1 x overflow/update #### 5.7.4 Timer 4: System timer - 8-bit auto-reload, adjustable prescaler ratio to any power of two from 1 to 128 - Clock source: master clock - Interrupt source: 1 x overflow/update ## 5.8 ADC The STM8A products described in this datasheet, contain a 10-bit successive approximation ADC with 16 multiplexed input channels. #### **General features:** - 10-bit ADC with up to 16 channels - Input voltage range: 0 to V<sub>DDA</sub> - Acqusition modes - Single conversion - Continous acquisition up to 100 ksamples/s effective sampling rate - Trigger register and external trigger input - Interrupts - End of conversion (EOC) can be masked ### 5.9 Communication interfaces The following communication interfaces are implemented on STM8A products: - USART: Full feature UART, SPI emulation, LIN master capability - LINUART: LIN2.1 master/slave capability, full feature UART - SPI full and half-duplex, 10 Mbit/s - I<sup>2</sup>C up to 400 Kbit/s - CAN (rev. 2.0A,B) 3 Tx mailboxes up to 1 Mbit/s - SWIM for debugging and device programming #### 5.9.1 **USART** #### **Main features** - 1 Mbit/s full duplex SCI - LIN master capable - SPI emulation - 16-bit baud-rate prescaler #### Full duplex, asynchronous communication - NRZ standard format (mark/space) - High-precision baud rate generator system - Common programmable transmit and receive baud rates up to 2.5 M baud - Programmable data word length (8 or 9 bits) - Configurable stop bits providing support for 1 or 2 stop bits - LIN master mode - LIN break and delimiter generation - LIN break and delimiter detection with separate flag and interrupt source for readback checking - Transmitter clock output for synchronous communication - Single wire half duplex communication - Separate enable bits for transmitter and receiver - Transfer detection flags - Receive buffer full - Transmit buffer empty - End of transmission flags - Parity control: - Transmit parity bit - Check parity of received data byte - Four error detection flags - Overrun error - Noise error - Frame error - Parity error - Six interrupt sources with flags - Transmit data register empty - Transmission complete - Receive data register full - Idle line received - Parity error - LIN break and delimiter detection - Two interrupt vectors - Transmitter interrupt - Receiver interrupt - Reduced power consumption mode - Multi-processor communication, allowing entry into mute mode if address match does not occur - Wakeup from mute mode (by idle line detection or address mark detection) - Two receiver wakeup modes: - Address bit (MSB) - Idle line #### 5.9.2 LINUART #### **Main features** - LIN master/slave rev. 2.1 compliant - Auto-synchronization in LIN slave mode - 16-bit baud rate prescaler - 1 Mbit full duplex SCI #### LIN master - Autonomous header handling - 13-bit LIN synch break generation #### LIN slave - Autonomous header handling one single interrupt per valid message header - Automatic baud rate synchronization maximum tolerated initial clock deviation ±15 % - Synch delimiter checking - 11-bit LIN synch break detection break detection always active - Parity check on the LIN identifier field - LIN error management - Hot plugging support #### Asynchronous communication (UART) - Full duplex, asynchronous communications NRZ standard format (mark/space) - Independently programmable transmit and receive baud rates up to 500 Kbit/s - Programmable data word length (8 or 9 bits) - Low-power standby mode two receiver wake-up modes: - Address bit (MSB) - Idle line - Muting function for multiprocessor configurations - Overrun, noise and frame error detection - Six interrupt sources - Tx, Rx parity control #### 5.9.3 SPI - Maximum speed: 10 Mbit/s or f<sub>CPU</sub>/2 both for master and slave - Full duplex synchronous transfers - Simplex synchronous transfers on two lines with a possible bidirectional data line - Master or slave operation selectable by hardware or software - CRC calculation - 1 byte Tx and Rx buffer - Slave/master selection input pin ## 5.9.4 I<sup>2</sup>C - I<sup>2</sup>C master features: - Clock generation - Start and stop generation - I<sup>2</sup>C slave features: - Programmable I<sup>2</sup>C address detection - Stop bit detection - Generation and detection of 7-bit/10-bit addressing and general call - Supports different communication speeds: - Standard speed (up to 100 kHz), - Fast speed (up to 400 kHz) - Interrupt: - Successful address/data communication - Error condition - Wake-up from halt - Wake-up from halt on address detection in slave mode #### 5.9.5 CAN The beCAN3 controller (basic enhanced CAN), interfaces the CAN network and supports the CAN protocol version 2.0A and B. It has been designed to manage a high number of incoming messages efficiently with a minimum CPU load. For safety-critical applications, the CAN controller provides all hardware functions to support the CAN time triggered communication option (TTCAN). The maximum transmission speed is 1 Mbit. #### **Transmission** - Three transmit mailboxes - Configurable transmit priority by identifier or order request - Time stamp on SOF transmission #### Reception - 11- and 29-bit ID - 1 receive FIFO (3 messages deep) - Software-efficient mailbox mapping at a unique address space - FMI (filter match index) stored with message - Configurable FIFO overrun - Time stamp on SOF reception - 6 filter banks, 2 x 32 bytes (scalable to 4 x 16-bit) each, enabling various masking configurations, such as 12 filters for 29-bit ID or 48 filters for 11-bit ID - Filtering modes: - Mask mode permitting ID range filtering - ID list mode - Time triggered communication option - Disable automatic retransmission mode - 16-bit free running timer - Configurable timer resolution - Time stamp sent in last two data bytes ### Interrupt management - Maskable interrupt - Software-efficient mailbox mapping at a unique address space ## 5.10 Input/output specifications The product features four different I/O types: - Standard I/O 2 MHz - Fast I/O 10 MHz - High sink 8 mA, 2 MHz - True open drain (I<sup>2</sup>C interface) To decrease EMI (electromagnetic interference), high sink I/Os have a limited maximum slew rate. The rise and fall times are similar to those of standard I/Os. Selected I/Os include a low leakage analog switch. STM8A I/Os are designed to withstand current injection. For a negative injection current of 4 mA, the resulting leakage current in the adjacent input does not exceed 1 $\mu$ A. External protection diodes are no longer required. ## 6 Pinouts and pin description ## 6.1 Package pinouts Figure 3. LQFP 80-pin pinout ``` 0 | PD77TLI 9 | PD67TLI 9 | PD67LINUART_RX 7 | PD4 (HS)/TIM2_CC1/BEEP 6 | PD2 (HS)/TIM2_CC2 6 | PD2 (HS)/TIM3_CC1 1 | PD0 (HS)/TIM3_CC1 2 | PD1 (HS)/SWIM 3 | PD0 (HS)/TIM3_CC2 2 | PD7 1 | PD6 0 | PE6/CLK_CCO PE6/CLK_CC PI3 PPI2 PPI1 NRST□ OSCIN/PA1 OSCOUT/PA2 PIO PG4 57 VCĂP ₽РG3 PFG2 PPG1/CAN_RX<sup>(1)</sup> PPG0/CAN_TX<sup>(1)</sup> V<sub>DDIO_1</sub> TIM2_CC3/PA3 D USART_TX/PA5Q PC7/SPI_MISO PC6/SPI_MOSI ¬ V<sub>DDIO_2</sub> ¬ V<sub>SSIO_2</sub> ¬ PC5/SPI_SCK ¬ PC4 (H2)/TIM1_CC4 USART_CK/PA6 (HS) PH0 13 (HS) PH1 14 PH2↓ 15 PH3 D AIN15/PF7 D 45 PC3 (HS)/TIM1_CC3 PC2 (HS)/TIM1_CC2 16 17 AIN14/PF6□ 18 AIN13/PF5 □ 19 VDDA VSSA VSSA VSSA ANN7/PB7 ANN7/PB7 ANN7/PB1 A (HS) high sink capability ``` 1. The CAN interface is only available on the STM8AF/H51xx product line Figure 4. LQFP 64-pin pinout 1. The CAN interface is only available on the STM8AF/H51xx product line Figure 5. LQFP 48-pin pinout ``` ● # PD7/TLI L2D PD6/LINUART_RX B) D PD5/LINUART_TX G) PD5/LINUART_ PLI PEO/CIK_CCO 6D PE1/I<sup>2</sup>C_SCL 8CD PE1/I<sup>2</sup>C_SDA 2U PE3/TIM1_BKIN , 36□PG1 NRST □1 OSCIN/PA1 2 35 PG0 OSCOUT/PA2 3 34 PC7/SPI_MISO 34 PC//SPI_MISO 33 PC6/SPI_MOSI 32 V<sub>DDIO_2</sub> 31 V<sub>SSIO_2</sub> 30 PC5/SPI_SCK 29 PC4 (HS)/TIM1_CC4 V<sub>SSIO_1</sub> □4 V<sub>SS</sub> □5 VCAP □6 V<sub>DD</sub> □7 V<sub>DDIO_1</sub> □8 TIM2_CC3/PA3 □9 28 PC3 (HS)/TIM1_CC3 PA4 🗖 10 27 PC2 (HS)/TIM1_CC2 PA5 🗆 11 26 PC1 (HS)/TIM1_CC1 PA6 □12 V V DDA CLIP AINS/PB7 CLIP AINS/PB7 CLIP AINS/PB7 CLIP AINS/PB7 CLIP AINS/PB8 CLIP AINS/PB8 CLIP AINS/PB8 CLIP AINS/PB8 CLIP AINS/PB8 CLIP AINS/PB7 AIN 25 PE5/SPI_NSS (HS) high sink capability ``` 1. The CAN interface is only available on the STM8AF/H51xx product line Figure 6. LQFP 32-pin pinout ## 6.2 Pin description Table 5. Legend/abbreviation for Table 6 | Туре | I= input, O = | I= input, O = output, S = power supply | | | | | | | | | | | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--|--|--|--|--|--|--|--|--|--| | Level | Input | CM = CMOS (standard for all I/Os) | | | | | | | | | | | | | Output | HS = High sink (8 mA) | | | | | | | | | | | | Output speed | ard (up to 2 MHz)<br>up to 10 MHz)<br>low programmability with slow as default state after reset<br>low programmability with fast as default state after reset | | | | | | | | | | | | | Port and control | Input | float = floating, wpu = weak pull-up | | | | | | | | | | | | configuration | Output | T = true open drain, OD = open drain, PP = push pull | | | | | | | | | | | Reset state is shown in **bold**. Table 6. STM8A microcontroller family pin description | | ie o.<br>in nu | ımb | | | | Input Ou | | Output | | | | | | | | |--------|----------------|--------|--------|---------------------|------|----------|------|----------------|-----------|-------|-----|----|--------------------------------|-------------------------------|--------------------------------------------| | | ın nı | ımbe | er | | | | inpu | 1 | | Out | put | | Main | | Alternate | | LQFP80 | LQFP64 | LQFP48 | LQFP32 | Pin name | Туре | floating | ndw | Ext. interrupt | High sink | Speed | QO | dd | function<br>(after<br>reset) | Default alternate function | function<br>after<br>remap<br>[option bit] | | 1 | 1 | 1 | 1 | NRST | I/O | | X | | | | | | Reset | | | | 2 | 2 | 2 | 2 | PA1/OSCIN | I/O | X | Х | | | 01 | Х | X | Port A1 | Resonator/crystal in | | | 3 | 3 | 3 | 3 | PA2/OSCOUT | I/O | X | Х | Х | | 01 | Х | X | Port A2 | Resonator/crystal out | | | 4 | 4 | 4 | ı | V <sub>SSIO_1</sub> | S | | | | | | | | I/O groun | d | | | 5 | 5 | 5 | 4 | V <sub>SS</sub> | S | | | | | | | | Digital gro | ound | | | 6 | 6 | 6 | 5 | VCAP | S | | | | | | | | 1.8 V regu | ulator capacitor | | | 7 | 7 | 7 | 6 | V <sub>DD</sub> | S | | | | | | | | Digital po | wer supply | | | 8 | 8 | 8 | 7 | V <sub>DDIO_1</sub> | S | | | | | | | | I/O power | supply | | | 9 | 9 | 9 | - | PA3/TIM2_CC3 | I/O | Х | Х | Х | | 01 | Х | Х | Port A3 | Timer 2 -<br>channel3 | TIM3_CC1<br>[AFR1] | | 10 | 10 | 10 | - | PA4/USART_RX | I/O | Х | Χ | Х | | О3 | Х | Χ | Port A4 | USART receive | | | 11 | 11 | 11 | - | PA5/USART_TX | I/O | Х | Х | Х | | О3 | Х | Χ | Port A5 | USART transmit | | | 12 | 12 | 12 | - | PA6/USART_CK | I/O | x | х | Х | | О3 | х | Х | Port A6 | USART<br>synchronous<br>clock | | | 13 | - | - | - | PH0 | I/O | X | Χ | | HS | О3 | Χ | Χ | Port H0 | | | | 14 | - | - | - | PH1 | I/O | Х | Χ | | HS | О3 | Х | Χ | Port H1 | | | | 15 | - | 1 | - | PH2 | I/O | X | Χ | | | 01 | Χ | Χ | Port H2 | | | | 16 | - | - | - | РН3 | I/O | Х | Х | | | 01 | Х | Χ | Port H3 | | | | 17 | 13 | - | ı | PF7/AIN15 | I/O | X | Х | | | 01 | Х | Χ | Port F7 | Analog input 15 | | | 18 | 14 | - | ı | PF6/AIN14 | I/O | X | Χ | | | 01 | X | Χ | Port F6 | Analog input 14 | | | 19 | 15 | - | ı | PF5/AIN13 | I/O | X | Х | | | 01 | Х | Χ | Port F5 | Analog input 13 | | | 20 | 16 | - | 8 | PF4/AIN12 | I/O | X | X | | | 01 | X | Χ | Port F4 | Analog input 12 | | | 21 | 17 | - | - | PF3/AIN11 | I/O | X | Χ | | | O1 | Χ | Χ | Port F3 | Analog input 11 | | | 22 | 18 | - | 1 | V <sub>REF+</sub> | S | | | | | | | | ADC positive reference voltage | | | | 23 | 19 | 13 | 9 | $V_{DDA}$ | S | | | | | | | | Analog po | ower supply | | | 24 | 20 | 14 | 10 | V <sub>SSA</sub> | S | | | | | | | | Analog gr | ound | | | 25 | 21 | - | - | V <sub>REF-</sub> | S | | | | | | | | ADC negative reference voltage | | | | 26 | 22 | - | • | PF0/AIN10 | I/O | Х | Х | | | 01 | Х | X | Port F0 | Analog input 10 | | Table 6. STM8A microcontroller family pin description (continued) | Р | in nı | ımbe | | WOA INICIOCOTTIC | | | Inpu | | | Out | | • | | | Alternate | |--------|--------|--------|--------|------------------|------|----------|------|----------------|-----------|-------|----|----|--------------------------------------|------------------------------|--------------------------------------------| | LQFP80 | LQFP64 | LQFP48 | LQFP32 | Pin name | Туре | floating | ndw | Ext. interrupt | High sink | Speed | ΦO | dd | Main<br>function<br>(after<br>reset) | Default alternate function | function<br>after<br>remap<br>[option bit] | | 27 | 23 | 15 | - | PB7/AIN7 | I/O | X | Χ | Χ | | 01 | Χ | Χ | Port B7 | Analog input 7 | | | 28 | 24 | 16 | - | PB6/AIN6 | I/O | X | Χ | Χ | | 01 | Х | Χ | Port B6 | Analog input 6 | | | 29 | 25 | 17 | 11 | PB5/AIN5 | I/O | X | Χ | Х | | O1 | X | Х | Port B5 | Analog input 5 | I <sup>2</sup> C_SDA<br>[AFR6] | | 30 | 26 | 18 | 12 | PB4/AIN4 | I/O | X | Х | Х | | 01 | Х | Х | Port B4 | Analog input 4 | I <sup>2</sup> C_SCL<br>[AFR6] | | 31 | 27 | 19 | 13 | PB3/AIN3 | I/O | Х | Х | Х | | 01 | Х | Х | Port B3 | Analog input 3 | TIM1_ETR<br>[AFR5] | | 32 | 28 | 20 | 14 | PB2/AIN2 | I/O | х | х | Х | | O1 | x | Х | Port B2 | Analog input | TIM1_<br>NCC3<br>[AFR5] | | 33 | 29 | 21 | 15 | PB1/AIN1 | I/O | х | х | Х | | O1 | x | Х | Port B1 | Analog input 1 | TIM1_<br>NCC2<br>[AFR5] | | 34 | 30 | 22 | 16 | PB0/AIN0 | I/O | х | х | Х | | O1 | x | Х | Port B0 | Analog input 0 | TIM1_<br>NCC1<br>[AFR5] | | 35 | - | | - | PH4/TIM1_ETR | I/O | X | Х | | | 01 | Х | Х | Port H4 | Timer 1 - trigger input | | | 36 | 1 | • | - | PH5/ TIM1_NCC3 | I/O | X | Х | | | 01 | Х | Х | Port H5 | Timer 1 - inverted channel 3 | | | 37 | 1 | 1 | - | PH6/TIM1_NCC2 | I/O | X | Х | | | 01 | Х | Х | Port H6 | Timer 1 - inverted channel 2 | | | 38 | 1 | • | - | PH7/TIM1_NCC1 | I/O | X | Х | | | 01 | Х | Х | Port H7 | Timer 1 - inverted channel 2 | | | 39 | 31 | 23 | - | PE7/AIN8 | I/O | Х | Χ | | | 01 | Х | Χ | Port E7 | Analog input 8 | | | 40 | 32 | 24 | | PE6/AIN9 | I/O | X | Χ | Х | | 01 | Χ | Х | Port E7 | Analog input 9 | | | 41 | 33 | 25 | 17 | PE5/SPI_NSS | I/O | х | Х | Х | | 01 | Х | Х | Port E5 | SPI master/slave select | | | 42 | - | - | - | PC0/ADC_ETR | I/O | X | Χ | Х | | 01 | Χ | X | Port C0 | ADC trigger input | | | 43 | 34 | 26 | 18 | PC1/TIM1_CC1 | I/O | X | Х | Х | HS | О3 | Х | Х | Port C1 | Timer 1 - channel<br>1 | | | 44 | 35 | 27 | 19 | PC2/TIM1_CC2 | I/O | X | X | Х | HS | О3 | Х | Х | Port C2 | Timer 1- channel<br>2 | | | 45 | 36 | 28 | 20 | PC3/TIM1_CC3 | I/O | х | Х | Х | HS | О3 | Х | Х | Port C3 | Timer 1 - channel<br>3 | | 30/100 Table 6. STM8A microcontroller family pin description (continued) | Pin number | | | | | | Input | | Output | | | ` | - | | Alternata | | |------------|--------|--------|--------|--------------------------|------|----------|-----|----------------|-----------|-------|------------------|----|--------------------------------------|-----------------------------|---------------------------------------------------------| | LQFP80 | LQFP64 | LQFP48 | LQFP32 | Pin name | Type | floating | ndw | Ext. interrupt | High sink | Speed | ОО | dd | Main<br>function<br>(after<br>reset) | Default alternate function | Alternate<br>function<br>after<br>remap<br>[option bit] | | 46 | 37 | 29 | 21 | PC4/TIM1_CC4 | I/O | X | Х | Х | HS | О3 | Х | Х | Port C4 | Timer 1 - channel<br>4 | | | 47 | 38 | 30 | 22 | PC5/SPI_SCK | I/O | Х | Х | Х | | О3 | Х | Χ | Port C5 | SPI clock | | | 48 | 39 | 31 | - | V <sub>SSIO_2</sub> | S | | | | | | | | I/O groun | d | | | 49 | 40 | 32 | - | V <sub>DDIO_2</sub> | S | | | | | | | | I/O power | supply | | | 50 | 41 | 33 | 23 | PC6/SPI_MOSI | I/O | X | X | X | | О3 | X | X | Port C6 | SPI master out/<br>slave in | | | 51 | 42 | 34 | 24 | PC7/SPI_MISO | I/O | X | X | Χ | | О3 | Х | X | Port C7 | SPI master in/<br>slave out | | | 52 | 43 | 35 | - | PG0/CAN_TX | I/O | X | X | | | 01 | Х | Χ | Port G0 | CAN transmit | | | 53 | 44 | 36 | - | PG1/CAN_RX | I/O | X | X | | | 01 | Х | Χ | Port G1 | CAN receive | | | 54 | 45 | 1 | - | PG2 | I/O | X | Χ | | | 01 | Х | Χ | Port G2 | | | | 55 | 46 | ı | - | PG3 | I/O | X | X | | | 01 | Х | Χ | Port G3 | | | | 56 | 47 | ı | - | PG4 | I/O | X | X | | | 01 | Х | Χ | Port G4 | | | | 57 | 48 | 1 | - | PI0 | I/O | X | Χ | | | 01 | Х | Χ | Port I0 | | | | 58 | 1 | ı | - | PI1 | I/O | X | X | | | 01 | Х | Χ | Port I1 | | | | 59 | • | ı | - | PI2 | I/O | X | X | | | 01 | Х | Χ | Port I2 | | | | 60 | - | 1 | - | PI3 | I/O | X | Χ | | | 01 | Х | Χ | Port I3 | | | | 61 | 1 | ı | - | PI4 | I/O | X | X | | | 01 | Х | Χ | Port I4 | | | | 62 | • | ı | - | PI5 | I/O | X | X | | | 01 | Х | Χ | Port I5 | | | | 63 | 49 | 1 | - | PG5 | I/O | X | Χ | | | 01 | Х | Χ | Port G5 | | | | 64 | 50 | ı | - | PG6 | I/O | X | X | | | 01 | Х | Χ | Port G6 | | | | 65 | 51 | ı | - | PG7 | I/O | X | X | | | 01 | Х | Χ | Port G7 | | | | 66 | 52 | 1 | - | PE4 | I/O | X | Χ | Χ | | 01 | Х | Χ | Port E4 | | | | 67 | 53 | 37 | - | PE3/TIM1_BKIN | I/O | X | X | X | | 01 | Х | X | Port E3 | Timer 1 - break input | | | 68 | 54 | 38 | - | PE2/I <sup>2</sup> C_SDA | I/O | Х | X | Х | | 01 | T <sup>(1)</sup> | Χ | Port E2 | I <sup>2</sup> C data | | | 69 | 55 | 39 | - | PE1/I <sup>2</sup> C_SCL | I/O | X | Χ | Х | | 01 | T <sup>(1)</sup> | Χ | Port E1 | I <sup>2</sup> C clock | | | 70 | 56 | 40 | - | PE0/CLK_CCO | I/O | X | X | X | | О3 | Х | Х | Port E0 | Configurable clock output | | | 71 | - | - | - | PI6 | I/O | X | Χ | | | O1 | Х | Χ | Port I6 | | | | 72 | - | - | - | PI7 | I/O | X | Χ | | | 01 | Х | Χ | Port I7 | | | Pin number Input Output **Alternate** Main Ext. interrupt function Type High sink function **Default alternate** floating LQFP48 LQFP32 QFP64 after Pin name Speed mdw (after function 9 remap reset) [option bit] TIM1 BKIN Timer 3 - channel [AFR3]/ I/O X HS Port D0 73 57 41 25 PD0/TIM3\_CC2 Х Χ О3 Χ Χ CLK CCO [AFR2] SWIM data 58 42 26 PD1/SWIM I/O Χ X Χ HS 04 Χ Port D1 interface Timer 3 - channel TIM2 CC3 75 59 43 27 PD2/TIM3\_CC1 I/O X Χ Χ HS О3 Χ Port D2 [AFR1] Timer 2 - channel ADC\_ETR 76 60 44 28 PD3/TIM2\_CC2 I/O X Χ Χ HS О3 Х Χ Port D3 [AFR0] **BEEP** PD4/TIM2\_CC1/B Timer 2 - channel 61 45 29 I/O X Χ Х HS О3 Х Χ Port D4 output 77 **EEP** [AFR7] PD5/ LINUART data 78 62 46 30 I/O X Х Χ 01 Х Χ Port D5 LINUART\_TX transmit LINUART data Port D6 receive PD6/ I/O Χ 79 63 47 31 X Х Χ 01 Х LINUART\_RX Caution: This pin must be held low during power on TIM1\_CC4 32 PD7/TLI Port D7 80 64 48 I/O X Х Χ 01 Χ Χ Top level interrupt Table 6. STM8A microcontroller family pin description (continued) ### 6.2.1 Alternate function remapping As shown in the rightmost column of *Table 6*, some alternate functions can be remapped at different I/O ports by programming one of eight AFR (alternate function remap) option bits. Refer to *Section 10:*Option bytes on page 49. When the remapping option is active, the default alternate function is no longer available. To use an alternate function, the corresponding peripheral must be enabled in the peripheral registers. Alternate function remapping does not effect GPIO capabilities of the I/O ports (see the GPIO section of the STM8A microcontroller family reference manual, RM0009). 577 [AFR4] In the open-drain output column, 'T' defines a true open-drain I/O (P-buffer and protection diode to V<sub>DD</sub> are not implemented) ## 7 Memory map Figure 7. Register and memory map Table 7. Stack and RAM partitioning | Pr | oduct | RAM size | RAM end | Stack | Stack start | | |----|--------|----------|---------|-------|-------------|-------------| | K | Kbytes | Kbytes | naw end | Dec | Hex | Stack Start | | | 128 | 6 | 17FF | 1024 | 0400 | 1400 | # 8 Interrupt table Table 8. STM8A interrupt table | Priority | Source<br>block | Description | Interrupt vector address | Wake-up from halt | Comments | |----------|---------------------|-----------------------------------------|--------------------------|-------------------|-------------------------------------------| | - | Reset | Reset | 6000h | Yes | Reset vector in ROM | | - | TRAP | SW interrupt | 8004h | | | | 0 | TLI | External top level interrupt | 8008h | | | | 1 | AWU | Auto wake up from halt | 800Ch | Yes | | | 2 | Clock<br>controller | Main clock controller | 8010h | | | | 3 | MISC | Ext interrupt E0 | 8014h | Yes | Port A interrupts | | 4 | MISC | Ext interrupt E1 | 8018h | Yes | Port B interrupts | | 5 | MISC | Ext interrupt E2 | 801Ch | Yes | Port C interrupts | | 6 | MISC | Ext interrupt E3 | 8020h | Yes | Port D interrupts | | 7 | MISC | Ext interrupt E4 | 8024h | Yes | Port E interrupts | | 8 | CAN | CAN interrupt Rx | 8028h | Yes | | | 9 | CAN | CAN interrupt<br>TX/ER/SC | 802Ch | | | | 10 | SPI | End of transfer | 8030h | Yes | | | 11 | Timer 1 | Update/overflow/<br>trigger/break | 8034h | | | | 12 | Timer 1 | Capture/compare | 8038h | | | | 13 | Timer 2 | Update/overflow/<br>break | 803Ch | | Trigger not available on medium end timer | | 14 | Timer 2 | Capture/compare | 8040h | | | | 15 | Timer 3 | Update/overflow/<br>break | 8044h | | Trigger not available on medium end timer | | 16 | Timer 3 | Capture/compare | 8048h | | | | 17 | USART<br>(SCI1) | Tx complete/<br>ER/SPI EOT/SPI<br>error | 804Ch | | | | 18 | USART<br>(SCI1) | Receive data full reg. | 8050h | | | | 19 | I <sup>2</sup> C | I <sup>2</sup> C interrupts | 8054h | Yes | | | 20 | LINUART<br>(SCI2) | Tx complete/error/<br>SPI EOT/SPI error | 8058h | | | | 21 | LINUART<br>(SCI2) | Receive data full reg. | 805Ch | | | Table 8. STM8A interrupt table (continued) | Priority | Source<br>block | Description | | Wake-up from halt | Comments | |----------|-------------------------|-------------------|-------|-------------------|----------| | 22 | ADC | End of conversion | 8060h | | | | 23 | Timer 4 | Update/overflow | 8064h | | | | 24 | Reserved <sup>(1)</sup> | Reserved | 8068h | | | <sup>1.</sup> Also unused interrupts should be initialised with "IRET" for robust programming. # 9 Register mapping Table 9. STM8A I/O port hardware register map | Address | Block | Register label | Register name | Reset<br>status | |----------|--------|----------------|-----------------------------------|-----------------| | 00 5000h | Port A | PA_ODR | Port A data output latch register | 00h | | 00 5001h | | PA_IDR | Port A input pin value register | 00h | | 00 5002h | | PA_DDR | Port A data direction register | 00h | | 00 5003h | | PA_CR1 | Port A control register 1 | 00h | | 00 5004h | | PA_CR2 | Port A control register 2 | 00h | | 00 5005h | | PB_ODR | Port B data output latch register | 00h | | 00 5006h | | PB_IDR | Port B input pin value register | 00h | | 00 5007h | Port B | PB_DDR | Port B data direction register | 00h | | 00 5008h | | PB_CR1 | Port B control register 1 | 00h | | 00 5009h | • | PB_CR2 | Port B control register 2 | 00h | | 00 500Ah | | PC_ODR | Port C data output latch register | 00h | | 00 500Bh | | PC_IDR | Port C input pin value register | 00h | | 00 500Ch | Port C | PC_DDR | Port C data direction register | 00h | | 00 500Dh | | PC_CR1 | Port C control register 1 | 00h | | 00 500Eh | | PC_CR2 | Port C control register 2 | 00h | | 00 500Fh | Port D | PD_ODR | Port D data output latch register | 00h | | 00 5010h | | PD_IDR | Port D input pin value register | 00h | | 00 5011h | | PD_DDR | Port D data direction register | 00h | | 00 5012h | | PD_CR1 | Port D control register 1 | 00h | | 00 5013h | | PD_CR2 | Port D control register 2 | 00h | | 00 5014h | | PE_ODR | Port E data output latch register | 00h | | 00 5015h | | PE_IDR | Port E input pin value register | 00h | | 00 5016h | Port E | PE_DDR | Port E data direction register | 00h | | 00 5017h | | PE_CR1 | Port E control register 1 | 00h | | 00 5018h | | PE_CR2 | Port E control register 2 | 00h | | 00 5019h | Port F | PF_ODR | Port F data output latch register | 00h | | 00 501Ah | | PF_IDR | Port F input pin value register | 00h | | 00 501Bh | | PF_DDR | Port F data direction register | 00h | | 00 501Ch | | PF_CR1 | Port F control register 1 | 00h | | 00 501Dh | | PF_CR2 | Port F control register 2 | 00h | **47/** Table 9. STM8A I/O port hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | |----------|--------|----------------|-----------------------------------|-----------------| | 00 501Eh | | PG_ODR | Port G data output latch register | 00h | | 00 501Fh | | PG_IDR | Port G input pin value register | 00h | | 00 5020h | Port G | PG_DDR | Port G data direction register | 00h | | 00 5021h | | PG_CR1 | Port G control register 1 | 00h | | 00 5022h | | PG_CR2 | Port G control register 2 | 00h | | 00 5023h | | PH_ODR | Port H data output latch register | 00h | | 00 5024h | Port H | PH_IDR | Port H input pin value register | 00h | | 00 5025h | | PH_DDR | Port H data direction register | 00h | | 00 5026h | | PH_CR1 | Port H control register 1 | 00h | | 00 5027h | | PH_CR2 | Port H control register 2 | 00h | | 00 5028h | | PI_ODR | Port I data output latch register | 00h | | 00 5029h | | PI_IDR | Port I input pin value register | 00h | | 00 502Ah | Port I | PI_DDR | Port I data direction register | 00h | | 00 502Bh | | PI_CR1 | Port I control register 1 | 00h | | 00 502Ch | | PI_CR2 | Port I control register 2 | 00h | Table 10. STM8A general hardware register map | Address | Block | Register label | Register name | Reset<br>status | | | |----------------------------|--------------------------|--------------------------|--------------------------------------------------|-----------------|--|--| | 00 5050h<br>to<br>00 5059h | | Reserved area (10 bytes) | | | | | | 00 505Ah | | FLASH_CR1 | Flash control register 1 | 00h | | | | 00 505Bh | Flash | FLASH_CR2 | Flash control register 2 | 00h | | | | 00 505Ch | | FLASH_NCR2 | Flash complementary control register 2 | FFh | | | | 00 505Dh | | FLASH_FPR | Flash protection register | 00h | | | | 00 505Eh | | FLASH _NFPR | Flash complementary protection register | FFh | | | | 00 505Fh | | FLASH_IAPSR | Flash in-application programming status register | 00h | | | | 00 5060h<br>to<br>00 5061h | Reserved area (2 bytes) | | | | | | | 00 5062h | Flash | FLASH _PUKR | Flash program memory unprotection register | 00h | | | | 00 5063h | | R | eserved area (1 byte) | | | | | 00 5064h | Flash | FLASH _DUKR | Data EEPROM unprotection register | 00h | | | | 00 5065h<br>to<br>00 509Fh | | Re | eserved area (59 bytes) | | | | | 00 50A0h | ITC | EXTI_CR1 | External interrupt control register 1 | 00h | | | | 00 50A1h | 110 | EXTI_CR2 | External interrupt control register 2 | 00h | | | | 00 50A2h<br>to<br>00 50B2h | Reserved area (17 bytes) | | | | | | | 00 50B3h | RST | RST_SR | Reset status register | xxh | | | | 00 50B4h<br>to<br>00 50BFh | Reserved area (12 bytes) | | | | | | | 00 50C0h | CLIC | CLK_ICKR | Internal clock control register | 01h | | | | 00 50C1h | CLK | CLK_ECKR | External clock control register | 00h | | | | 00 50C2h | | R | eserved area (1 byte) | | | | Table 10. STM8A general hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | |----------------------------|-------------------------|----------------|--------------------------------------------|-----------------| | 00 50C3h | | CLK_CMSR | Clock master status register | E1h | | 00 50C4h | | CLK_SWR | Clock master switch register | E1h | | 00 50C5h | CLK | CLK_SWCR | Clock switch control register | xxxx<br>0000b | | 00 50C6h | | CLK_CKDIVR | Clock divider register | 18h | | 00 50C7h | | CLK_PCKENR1 | Peripheral clock gating register 1 | FFh | | 00 50C8h | | CLK_CSSR | Clock security system register | 00h | | 00 50C9h | | CLK_CCOR | Configurable clock control register | 00h | | 00 50CAh | | CLK_PCKENR2 | Peripheral clock gating register 2 | FFh | | 00 50CBh | | CLK_CANCCR | CAN clock control register | 00h | | 00 50CCh | | CLK_HSITRIMR | HSI clock calibration trimming register | xxh | | 00 50CDh | | CLK_SWIMCCR | SWIM clock control register | x0h | | 00 50CEh<br>to<br>00 50D0h | Reserved area (3 bytes) | | | | | 00 50D1h | WWDG | WWDG_CR | WWDG control register | 7Fh | | 00 50D2h | WWBG | WWDG_WR | WWDR window register | 7Fh | | 00 50D3h<br>to<br>00 50DFh | | Re | served area (13 bytes) | | | 00 50E0h | | IWDG_KR | IWDG key register | - | | 00 50E1h | IWDG | IWDG_PR | IWDG prescaler register | 00h | | 00 50E2h | | IWDG_RLR | IWDG reload register | FFh | | 00 50E3h<br>to<br>00 50EFh | | Re | served area (13 bytes) | | | 00 50F0h | | AWU_CSR1 | AWU control/status register 1 | 00h | | 00 50F1h | AWU | AWU_APR | AWU asynchronous prescaler buffer register | 3Fh | | 00 50F2h | | AWU_TBR | AWU timebase selection register | 00h | | 00 50F3h | BEEP | BEEP_CSR | BEEP control/status register | 1Fh | | 00 50F4h<br>to<br>00 50FFh | | Re | served area (12 bytes) | | Table 10. STM8A general hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | | |----------------------------|-------------------------|--------------------------|-------------------------------------------------|-----------------|--| | 00 5200h | | SPI_CR1 | SPI control register 1 | 00h | | | 00 5201h | | SPI_CR2 | SPI control register 2 | 00h | | | 00 5202h | SPI - | SPI_ICR | SPI interrupt control register | 00h | | | 00 5203h | | SPI_SR | SPI status register | 02h | | | 00 5204h | | SPI_DR | SPI data register | 00h | | | 00 5205h | | SPI_CRCPR | SPI CRC polynomial register | 07h | | | 00 5206h | | SPI_RXCRCR | SPI Rx CRC register | FFh | | | 00 5207h | | SPI_TXCRCR | SPI Tx CRC register | FFh | | | 00 5208h<br>to<br>00 520Fh | Reserved area (8 bytes) | | | | | | 00 5210h | | I2C_CR1 | I <sup>2</sup> C control register 1 | 00h | | | 00 5211h | | I2C_CR2 | I <sup>2</sup> C control register 2 | 00h | | | 00 5212h | | I2C_FREQR | I <sup>2</sup> C frequency register | 00h | | | 00 5213h | | I2C_OARL | I <sup>2</sup> C own address register low | 00h | | | 00 5214h | | I2C_OARH | I <sup>2</sup> C own address register high | 00h | | | 00 5215h | | | Reserved | | | | 00 5216h | | I2C_DR | I <sup>2</sup> C data register | 00h | | | 00 5217h | I <sup>2</sup> C | I2C_SR1 | I <sup>2</sup> C status register 1 | 00h | | | 00 5218h | | I2C_SR2 | I <sup>2</sup> C status register 2 | 00h | | | 00 5219h | | I2C_SR3 | I <sup>2</sup> C status register 3 | 00h | | | 00 521Ah | | I2C_ITR | I <sup>2</sup> C interrupt control register | 00h | | | 00 521Bh | | I2C_CCRL | I <sup>2</sup> C clock control register low | 00h | | | 00 521Ch | 1 | I2C_CCRH | I <sup>2</sup> C clock control register high | 00h | | | 00 521Dh | | I2C_TRISER | I <sup>2</sup> C TRISE register | 02h | | | 00 521Eh | | I2C_PECR | I <sup>2</sup> C packet error checking register | 00h | | | 00 521Fh<br>to<br>00 522Fh | | Reserved area (17 bytes) | | | | Table 10. STM8A general hardware register map (continued) | Address | Block | Register label | Register name | Reset status | | | |----------------------------|---------|-------------------------|------------------------------|--------------|--|--| | 00 5230h | | USART_SR | USART status register | C0h | | | | 00 5231h | | USART_DR | USART data register | xxh | | | | 00 5232h | | USART_BRR1 | USART baud rate register 1 | 00h | | | | 00 5233h | | USART_BRR2 | USART baud rate register 2 | 00h | | | | 00 5234h | | USART_CR1 | USART control register 1 | 00h | | | | 00 5235h | USART | USART_CR2 | USART control register 2 | 00h | | | | 00 5236h | | USART_CR3 | USART control register 3 | 00h | | | | 00 5237h | | USART_CR4 | USART control register 4 | 00h | | | | 00 5238h | | USART_CR5 | USART control register 5 | 00h | | | | 00 5239h | | USART_GTR | USART guard time register | 00h | | | | 00 523Ah | | USART_PSCR | USART prescaler register | 00h | | | | 00 523Bh<br>to<br>00 523Fh | | Reserved area (5 bytes) | | | | | | 00 5240h | | LINUART_SR | LINUART status register | C0h | | | | 00 5241h | | LINUART_DR | LINUART data register | xxh | | | | 00 5242h | | LINUART_BRR1 | LINUART baud rate register 1 | 00h | | | | 00 5243h | | LINUART_BRR2 | LINUART baud rate register 2 | 00h | | | | 00 5244h | | LINUART_CR1 | LINUART control register 1 | 00h | | | | 00 5245h | LINUART | LINUART_CR2 | LINUART control register 2 | 00h | | | | 00 5246h | LINUANI | LINUART_CR3 | LINUART control register 3 | 00h | | | | 005247h | | LINUART_CR4 | LINUART control register 4 | 00h | | | | 00 5248h | | | Reserved | • | | | | 00 5249h | | LINUART_CR6 | LINUART control register 6 | 00h | | | | 00 524Ah<br>to<br>00 524Fh | | Reserved area (6 bytes) | | | | | Table 10. STM8A general hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | |----------------------------|-------|----------------|----------------------------------------|-----------------| | 00 5250h | | TIM1_CR1 | TIM1 control register 1 | 00h | | 00 5251h | 1 | TIM1_CR2 | TIM1 control register 2 | 00h | | 00 5252h | 1 | TIM1_SMCR | TIM1 slave mode control register | 00h | | 00 5253h | 1 | TIM1_ETR | TIM1 external trigger register | 00h | | 00 5254h | 1 | TIM1_IER | TIM1 interrupt enable register | 00h | | 00 5255h | 1 | TIM1_SR1 | TIM1 status register 1 | 00h | | 00 5256h | 1 | TIM1_SR2 | TIM1 status register 2 | 00h | | 00 5257h | 1 | TIM1_EGR | TIM1 event generation register | 00h | | 00 5258h | 1 | TIM1_CCMR1 | TIM1 capture/compare mode register 1 | 00h | | 00 5259h | 1 | TIM1_CCMR2 | TIM1 capture/compare mode register 2 | 00h | | 00 525Ah | 1 | TIM1_CCMR3 | TIM1 capture/compare mode register 3 | 00h | | 00 525Bh | 1 | TIM1_CCMR4 | TIM1 capture/compare mode register 4 | 00h | | 00 525Ch | 1 | TIM1_CCER1 | TIM1 capture/compare enable register 1 | 00h | | 00 525Dh | 1 | TIM1_CCER2 | TIM1 capture/compare enable register 2 | 00h | | 00 525Eh | 1 | TIM1_CNTRH | TIM1 counter high | 00h | | 00 525Fh | TIN44 | TIM1_CNTRL | TIM1 counter low | 00h | | 00 5260h | TIM1 | TIM1_PSCRH | TIM1 prescaler register high | 00h | | 00 5261h | 1 | TIM1_PSCRL | TIM1 prescaler register low | 00h | | 00 5262h | 1 | TIM1_ARRH | TIM1 auto-reload register high | FFh | | 00 5263h | 1 | TIM1_ARRL | TIM1 auto-reload register low | FFh | | 00 5264h | 1 | TIM1_RCR | TIM1 repetition counter register | 00h | | 00 5265h | 1 | TIM1_CCR1H | TIM1 capture/compare register 1 high | 00h | | 00 5266h | 1 | TIM1_CCR1L | TIM1 capture/compare register 1 low | 00h | | 00 5267h | 1 | TIM1_CCR2H | TIM1 capture/compare register 2 high | 00h | | 00 5268h | 1 | TIM1_CCR2L | TIM1 capture/compare register 2 low | 00h | | 00 5269h | 1 | TIM1_CCR3H | TIM1 capture/compare register 3 high | 00h | | 00 526Ah | | TIM1_CCR3L | TIM1 capture/compare register 3 low | 00h | | 00 526Bh | | TIM1_CCR4H | TIM1 capture/compare register 4 high | 00h | | 00 526Ch | | TIM1_CCR4L | TIM1 capture/compare register 4 low | 00h | | 00 526Dh | | TIM1_BKR | TIM1 break register | 00h | | 00 526Eh | | TIM1_DTR | TIM1 dead-time register | 00h | | 00 526Fh | | TIM1_OISR | TIM1 output idle state register | 00h | | 00 5270h<br>to<br>00 52FFh | | Res | served area (147 bytes) | | Table 10. STM8A general hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | | |----------------------------|-------|--------------------------|----------------------------------------|-----------------|--| | 00 5300h | | TIM2_CR1 | TIM2 control register 1 | 00h | | | 00 5301h | 1 | TIM2_IER | TIM2 interrupt enable register | 00h | | | 00 5302h | 1 | TIM2_SR1 | TIM2 status register 1 | 00h | | | 00 5303h | 1 | TIM2_SR2 | TIM2 status register 2 | 00h | | | 00 5304h | 1 | TIM2_EGR | TIM2 event generation register | 00h | | | 00 5305h | 1 | TIM2_CCMR1 | TIM2 capture/compare mode register 1 | 00h | | | 00 5306h | 1 | TIM2_CCMR2 | TIM2 capture/compare mode register 2 | 00h | | | 00 5307h | 1 | TIM2_CCMR3 | TIM2 capture/compare mode register 3 | 00h | | | 00 5308h | 1 | TIM2_CCER1 | TIM2 capture/compare enable register 1 | 00h | | | 00 5309h | • | TIM2_CCER2 | TIM2 capture/compare enable register 2 | 00h | | | 00 530Ah | TIM2 | TIM2_CNTRH | TIM2 counter high | 00h | | | 00 530Bh | 1 | TIM2_CNTRL | TIM2 counter low | 00h | | | 00 530Ch | 1 | TIM2_PSCR | TIM2 prescaler register | 00h | | | 00 530Dh | 1 | TIM2_ARRH | TIM2 auto-reload register high | FFh | | | 00 530Eh | 1 | TIM2_ARRL | TIM2 auto-reload register low | FFh | | | 00 530Fh | 1 | TIM2_CCR1H | TIM2 capture/compare register 1 high | 00h | | | 00 5310h | 1 | TIM2_CCR1L | TIM2 capture/compare register 1 low | 00h | | | 00 5311h | 1 | TIM2_CCR2H | TIM2 capture/compare register 2 high | 00h | | | 00 5312h | | TIM2_CCR2L | TIM2 capture/compare register 2 low | 00h | | | 00 5313h | | TIM2_CCR3H | TIM2 capture/compare register 3 high | 00h | | | 00 5314h | ] | TIM2_CCR3L | TIM2 capture/compare register 3 low | 00h | | | 00 5315h<br>to<br>00 531Fh | | Reserved area (11 bytes) | | | | Table 10. STM8A general hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | |----------------------------|-------|----------------|----------------------------------------|-----------------| | 00 5320h | | TIM3_CR1 | TIM3 control register 1 | 00h | | 00 5321h | | TIM3_IER | TIM3 interrupt enable register | 00h | | 00 5322h | | TIM3_SR1 | TIM3 status register 1 | 00h | | 00 5323h | | TIM3_SR2 | TIM3 status register 2 | 00h | | 00 5324h | | TIM3_EGR | TIM3 event generation register | 00h | | 00 5325h | | TIM3_CCMR1 | TIM3 capture/compare mode register 1 | 00h | | 00 5326h | | TIM3_CCMR2 | TIM3 capture/compare mode register 2 | 00h | | 00 5327h | | TIM3_CCER1 | TIM3 capture/compare enable register 1 | 00h | | 00 5328h | TIM3 | TIM3_CNTRH | TIM3 counter high | 00h | | 00 5329h | | TIM3_CNTRL | TIM3 counter low | 00h | | 00 532Ah | | TIM3_PSCR | TIM3 prescaler register | 00h | | 00 532Bh | | TIM3_ARRH | TIM3 auto-reload register high | FFh | | 00 532Ch | | TIM3_ARRL | TIM3 auto-reload register low | FFh | | 00 532Dh | | TIM3_CCR1H | TIM3 capture/compare register 1 high | 00h | | 00 532Eh | | TIM3_CCR1L | TIM3 capture/compare register 1 low | 00h | | 00 532Fh | | TIM3_CCR2H | TIM3 capture/compare register 2 high | 00h | | 00 5330h | | TIM3_CCR2L | TIM3 capture/compare register 2 low | 00h | | 00 5331h<br>to<br>00 533Fh | | Re | served area (15 bytes) | | | 00 5340h | | TIM4_CR1 | TIM4 control register 1 | 00h | | 00 5341h | | TIM4_IER | TIM4 interrupt enable register | 00h | | 00 5342h | | TIM4_SR | TIM4 status register | 00h | | 00 5343h | TIM4 | TIM4_EGR | TIM4 event generation register | 00h | | 00 5344h | | TIM4_CNTR | TIM4 counter | 00h | | 00 5345h | | TIM4_PSCR | TIM4 prescaler register | 00h | | 00 5346h | | TIM4_ARR | TIM4 auto-reload register | FFh | | 00 5347h<br>to<br>00 53FFh | | Res | served area (184 bytes) | | Table 10. STM8A general hardware register map (continued) | Address | Block | Register label | Register name | Reset status | |----------------------------|------------------|----------------|-------------------------------------------|--------------| | 00 5400h | | ADC _CSR | ADC control/status register | 00h | | 00 5401h | | ADC_CR1 | ADC configuration register 1 | 00h | | 00 5402h | | ADC_CR2 | ADC configuration register 2 | 00h | | 00 5403h | 400 | ADC_CR3 | ADC configuration register 3 | 00h | | 00 5404h | ADC | ADC_DRH | ADC data register high | 00h | | 00 5405h | - | ADC_DRL | ADC data register low | 00h | | 00 5406h | 1 | ADC_TDRH | ADC Schmitt trigger disable register high | 00h | | 00 5407h | 1 | ADC_TDRL | ADC Schmitt trigger disable register low | 00h | | 00 5408h<br>to<br>00 541Fh | | Re | eserved area (24 bytes) | | | 00 5420h | | CAN_MCR | CAN master control register | 02h | | 00 5421h | † | CAN_MSR | CAN master status register | 02h | | 00 5422h | † | CAN_TSR | CAN transmit status register | 00h | | 00 5423h | <u> </u> | CAN_TPR | CAN transmit priority register | 0Ch | | 00 5424h | <del> </del><br> | CAN_RFR | CAN receive FIFO register | 00h | | 00 5425h | † | CAN_IER | CAN interrupt enable register | 00h | | 00 5426h | <u> </u> | CAN_DGR | CAN diagnosis register | 0Ch | | 00 5427h | † | CAN_FPSR | CAN page selection register | 00h | | 00 5428h | † | CAN_P0 | CAN paged register 0 | 00h | | 00 5429h | † | CAN_P1 | CAN paged register 1 | 00h | | 00 542Ah | † | CAN_P2 | CAN paged register 2 | 00h | | 00 542Bh | | CAN_P3 | CAN paged register 3 | 00h | | 00 542Ch | CAN | CAN_P4 | CAN paged register 4 | 00h | | 00 542Dh | † | CAN_P5 | CAN paged register 5 | 00h | | 00 542Eh | † | CAN_P6 | CAN paged register 6 | 00h | | 00 542Fh | 1 | CAN_P7 | CAN paged register 7 | 00h | | 00 5430h | † | CAN_P8 | CAN paged register 8 | 00h | | 00 5431h | 1 | CAN_P9 | CAN paged register 9 | 00h | | 00 5432h | 1 | CAN_PA | CAN paged register A | 00h | | 00 5433h | | CAN_PB | CAN paged register B | 00h | | 00 5434h | 1 | CAN_PC | CAN paged register C | 00h | | 00 5435h | 1 | CAN_PD | CAN paged register D | 00h | | 00 5436h | 1 | CAN_PE | CAN paged register E | 00h | | 00 5437h | 1 | CAN_PF | CAN paged register F | 00h | Table 10. STM8A general hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | |-------------------------|-------|----------------|---------------------------------|-----------------| | 00 5438h to<br>00 57FFh | | Res | served area (968 bytes) | | | 5800h | | TU_KEYS_REG0 | TMU key register 0 [7:0] | 00h | | 5801h | | TU_KEYS_REG1 | TMU key register 1 [7:0] | 00h | | 5802h | | TU_KEYS_REG2 | TMU key register 2 [7:0] | 00h | | 5803h | | TU_KEYS_REG3 | TMU key register 3 [7:0] | 00h | | 5804h | TMU | TU_KEYS_REG4 | TMU key register 4 [7:0] | 00h | | 5805h | | TU_KEYS_REG5 | TMU key register 5 [7:0]] | 00h | | 5806h | | TU_KEYS_REG6 | TMU key register 6 [7:0] | 00h | | 5807h | | TU_KEYS_REG7 | TMU key register 7 [7:0] | 00h | | 5808h | | TU_CTL_ST | TMU control and status register | 00h | Table 11. CPU/SWIM/debug module/interrupt controller registers | Address | Block | Register label | Register name | Reset status | |----------------------------|-------------------------|----------------|----------------------------------------|--------------| | 00 7F00h | | Α | Accumulator | 00h | | 00 7F01h | | PCE | Program counter extended | 00h | | 00 7F02h | | PCH | Program counter high | 60h | | 00 7F03h | CPU - | PCL | Program counter low | 00h | | 00 7F04h | | XH | X index register high | 00h | | 00 7F05h | | XL | X index register low | 00h | | 00 7F06h | | YH | Y index register high | 00h | | 00 7F07h | | YL | Y index register low | 00h | | 00 7F08h | | SPH | Stack pointer high | 17h | | 00 7F09h | | SPL | Stack pointer low | FFh | | 00 7F0Ah | | CCR | Condition code register | 28h | | 00 7F0Bh to<br>00 7F5Fh | | F | deserved area (85 bytes) | | | 00 7F60h | CFG | CFG_GCR | Global configuration register | 00h | | 00 7F70h | | ITC_SPR1 | Interrupt software priority register 1 | FFh | | 00 7F71h | | ITC_SPR2 | Interrupt software priority register 2 | FFh | | 00 7F72h | | ITC_SPR3 | Interrupt software priority register 3 | FFh | | 00 7F73h | ITC | ITC_SPR4 | Interrupt software priority register 4 | FFh | | 00 7F74h | | ITC_SPR5 | Interrupt software priority register 5 | FFh | | 00 7F75h | | ITC_SPR6 | Interrupt software priority register 6 | FFh | | 00 7F76h | | ITC_SPR7 | Interrupt software priority register 7 | FFh | | 00 7F77h<br>to<br>00 7F79h | Reserved area (3 bytes) | | | | | 00 7F80h | SWIM | SWIM_CSR | SWIM control status register | 00h | | 00 7F81h<br>to<br>00 7F8Fh | | F | deserved area (15 bytes) | 1 | Table 11. CPU/SWIM/debug module/interrupt controller registers (continued) | Address | Block | Register label | Register name | Reset<br>status | | |----------------------------|-------------------------|----------------|----------------------------------------|-----------------|--| | 00 7F90h | | DM_BK1RE | DM breakpoint 1 register extended byte | FFh | | | 00 7F91h | | DM_BK1RH | DM breakpoint 1 register high byte | FFh | | | 00 7F92h | | DM_BK1RL | DM breakpoint 1 register low byte | FFh | | | 00 7F93h | | DM_BK2RE | DM breakpoint 2 register extended byte | FFh | | | 00 7F94h | | DM_BK2RH | DM breakpoint 2 register high byte | FFh | | | 00 7F95h | DM | DM_BK2RL | DM breakpoint 2 register low byte | FFh | | | 00 7F96h | | DM_CR1 | Debug module control register 1 | 00h | | | 00 7F97h | | DM_CR2 | Debug module control register 2 | 00h | | | 00 7F98h | | DM_CSR1 | Debug module control/status register 1 | 10h | | | 00 7F99h | | DM_CSR2 | Debug module control/status register 2 | 00h | | | 00 7F9Ah | | DM_ENFCTR | DM enable function register | FFh | | | 00 7F9Bh<br>to<br>00 7F9Fh | Reserved area (5 bytes) | | | | | # 10 Option bytes Option bytes contain configurations for device hardware features as well as the memory protection of the device. They are stored in a dedicated block of the memory. Except for the ROP (read-out protection) byte, each option byte has to be stored twice, in a regular form (OPTx) and a complemented one (NOPTx) for redundancy. Option bytes can be modified in ICP mode (via SWIM) by accessing the EEPROM address shown in *Table 12: Option bytes* below. Option bytes can also be modified 'on the fly' by the application in IAP mode, except the ROP and UBC options that can only be toggled in ICP mode (via SWIM). Refer to the STM8 Flash programming manual (PM0047) and STM8 SWIM communication protocol and debug modulel user manual (UM0470) for information on SWIM programming procedures. Table 12. Option bytes | Addr. | Option Option Option | | | | | | Factory | | | | | |-------|---------------------------------|----------|-----------|----------------------|--------|----------|-------------|---------------|--------------|---------------|-----------------| | Addr. | name | byte no. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | default setting | | 4800h | Read-out<br>protection<br>(ROP) | ОРТ0 | | ROP[7:0] | | | | | | 00h | | | 4801h | User | OPT1 | | | | UBO | C[7:0] | | | | 00h | | 4802h | boot code<br>(UBC) | NOPT1 | | | | NUB | C[7:0] | | | | FFh | | 4803h | Alternate | OPT2 | AFR7 | AFR6 | AFR5 | AFR4 | AFR3 | AFR2 | AFR1 | AFR0 | 00h | | 4804h | function<br>remappin<br>g (AFR) | NOPT2 | NAFR<br>7 | NAFR<br>6 | NAFR5 | NAFR4 | NAFR3 | NAFR2 | NAFR1 | NAFR0 | FFh | | 4805h | Watchdog | ОРТ3 | | Res | served | | LSI<br>_EN | IWDG<br>_HW | WWDG<br>_HW | WWDG<br>_HALT | 00h | | 4806h | option | NOPT3 | | Reserved | | | NLSI<br>_EN | NIWDG<br>_HW | NWWD<br>G_HW | NWWG<br>_HALT | FFh | | 4807h | Clock | OPT4 | | Res | served | | EXT<br>CLK | CKAWU<br>SEL | PRS<br>C1 | PRS<br>C0 | 00h | | 4808h | option | NOPT4 | | Res | served | | NEXT<br>CLK | NCKAW<br>USEL | NPR<br>SC1 | NPR<br>SC0 | FFh | | 4809h | HSE<br>clock | OPT5 | | | | HSEC | NT[7:0] | | | | 00h | | 480Ah | startup | NOPT5 | | | | NHSE | CNT[7:0] | | | | FFh | | 480Bh | TMU | OPT6 | | | | TMU | J[0:3] | | | | 00h | | 480Ch | TIVIU | NOPT6 | | | | NTM | IU[0:3] | | | | FFh | | 480Dh | Flash wait | ОРТ7 | | Reserved WAIT STATE | | | | | | 00h | | | 480Eh | states | NOPT7 | | Reserved NWAIT STATE | | | | | FFh | | | | 480Fh | | | | | | Reserved | | | | | | Table 12. Option bytes (continued) | Addr. | Option | ion Option Option bits | | | | | | | Factory | | | |---------------------|----------|------------------------|---|-------------------|---|--------|------------|---|---------|-----------------|-----| | name | byte no. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | default setting | | | 4810h | | OPT8 | | | | TMU_K | EY 0 [7:0] | | | | 00h | | 4811h | | OPT9 | | | | TMU_K | EY 1 [7:0] | | | | 00h | | 4812h | | OPT10 | | | | TMU_K | EY 2 [7:0] | | | | 00h | | 4813h | | OPT11 | | TMU_KEY 3 [7:0] | | | | | | | 00h | | 4814h | TMU | OPT12 | | TMU_KEY 4 [7:0] | | | | | | | | | 4815h | | OPT13 | | TMU_KEY 5 [7:0] | | | | | | | 00h | | 4816h | | OPT14 | | TMU_KEY 6 [7:0] | | | | | | | 00h | | 4817h | | OPT15 | | | | TMU_KI | EY 7 [7:0] | | | | 00h | | 4818h | | OPT16 | | TMU MAX_ATT [7:0] | | | | | | | 00h | | 4819h<br>to<br>487D | Reserved | | | | | | | | | | | | 487E | Boot- | OPT17 | | BL_EN [7:0] | | | | | | | | | 487F | loader | NOPT17 | | | | NBL_E | EN [7:0] | | | | 00h | Table 13. Option byte description | Option byte no. | Description | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OPT0 | ROP[7:0]: Memory readout protection (ROP) AAh: Enable readout protection (write access via SWIM protocol) Note: Refer to the STM8A microcontroller family reference manual (RM0009) section on Flash/EEPROM memory readout protection for details. | | OPT1 | UBC[7:0]: User boot code area 00h: No UBC, no write-protection 01h: Page 0 to 1 defined as UBC, memory write-protected 02h: Page 0 to 3 defined as UBC, memory write-protected 03h to FFh: Pages 4 to 255 defined as UBC, memory write-protected Note: Refer to the STM8A microcontroller family reference manual (RM0009) section on Flash/EEPROM write protection for more details. | | OPT2 | AFR7: Alternate function remapping option 7 0: Port D4 alternate function = TIM2_CC1 1: Port D4 alternate function = BEEP AFR6: Alternate function remapping option 6 0: Port B5 alternate function = AIN5, port B4 alternate function = AIN4 1: Port B5 alternate function = I <sup>2</sup> C_SDA, port B4 alternate function = I <sup>2</sup> C_SCL. AFR5: Alternate function remapping option 5 0: Port B3 alternate function = AIN3, port B2 alternate function = AIN2, port B1 alternate function = AIN1, port B2 alternate function = AIN0. 1: Port B3 alternate function = TIM1_ETR, port B2 alternate function = TIM1_NC3, port B1 alternate function = TIM1_NC2, port B0 alternate function = TIM1_NCC3, port B1 alternate function = TIM1_NCC2, port B0 alternate function = TIM1_NCC1. AFR4: Alternate function remapping option 4 0: Port D7 alternate function = TIM1_CC4 AFR3: Alternate function = TIM1_CC4 AFR3: Alternate function = TIM3_CC2 1: Port D0 alternate function = TIM3_CC2 1: Port D0 alternate function = TIM3_CC2 1: Port D0 alternate function = CLK_CC0 Note: AFR2 option has priority over AFR3 if both are activated AFR1: Alternate function remapping option 1 0: Port D3 alternate function = TIM3_CC1, port D2 alternate function TIM3_CC1. 1: Port A3 alternate function = TIM3_CC1, port D2 alternate function TIM2_CC3. AFR0: Alternate function remapping option 0 0: Port D3 alternate function = TIM2_CC2 1: Port D3 alternate function = TIM2_CC2 1: Port D3 alternate function = ADC_ETR | Table 13. Option byte description (continued) | Option byte no. | Description | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | LSI_EN: Low speed internal clock enable 0: LSI clock is not available as CPU clock source 1: LSI clock is available as CPU clock source | | OPTO | IWDG_HW: Independent watchdog 0: IWDG Independent watchdog activated by software 1: IWDG Independent watchdog activated by hardware | | OPT3 | WWDG_HW: Window watchdog activation 0: WWDG window watchdog activated by software 1: WWDG window watchdog activated by hardware | | | WWDG_HALT: Window watchdog reset on halt 0: No reset generated on halt if WWDG active 1: Reset generated on halt if WWDG active | | | EXTCLK: External clock selection 0: External crystal connected to OSCIN/OSCOUT 1: External clock signal on OSCIN | | OPT4 | CKAWUSEL: Auto wake-up unit/clock 0: LSI clock source selected for AWU 1: HSE clock with prescaler selected as clock source for for AWU | | | PRSC[1:0]: AWU clock prescaler 00: 24 MHz to 128 kHz prescaler 01: 16 MHz to 128 kHz prescaler 10: 8 MHz to 128 kHz prescaler 11: 4 MHz to 128 kHz prescaler | | OPT5 | HSECNT[7:0]: HSE crystal oscillator stabilization time This configures the stabilisation time to 0, 16, 256, 4096 HSE cycles. | | OPT6 | TMU[3:0]: Enable temporary memory unprotection 0101: Read-out protection can be temporary disabled using a key sequence. Any other value: Permanent ROP | | ОРТ7 | WAIT STATE: Wait state configuration This option configures the number of wait states inserted when reading from the Flash/data EEPROM memory. 0: No wait state 1: One wait state | | OPT8 | TMU_KEY 0 [7:0]: Temporary unprotection key 0 Temporary unprotection key: Must be different from 00h or FFh | | OPT9 | TMU_KEY 1 [7:0]: Temporary unprotection key 1 Temporary unprotection key: Must be different from 00h or FFh | | OPT10 | TMU_KEY 2 [7:0]: Temporary unprotection key 2 Temporary unprotection key: Must be different from 00h or FFh | | OPT11 | TMU_KEY 3 [7:0]: Temporary unprotection key 3 Temporary unprotection key: Must be different from 00h or FFh | Table 13. Option byte description (continued) | Option byte no. | Description | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OPT12 | TMU_KEY 4 [7:0]: Temporary unprotection key 4 Temporary unprotection key: Must be different from 00h or FFh | | OPT13 | TMU_KEY 5 [7:0]: Temporary unprotection key 5 Temporary unprotection key: Must be different from 00h or FFh | | OPT14 | TMU_KEY 6 [7:0]: Temporary unprotection key 6 Temporary unprotection key: Must be different from 00h or FFh | | OPT15 | TMU_KEY 7 [7:0]: Temporary unprotection key 7 Temporary unprotection key: Must be different from 00h or FFh | | OPT16 | TMU_MAXATT [7:0]: TMU access failure counter Every unsuccessful trial to enter the temporary unprotection procedure increments the counter. More than eight unsuccessful trials trigger the global erase of the code and data memory. | | OPT17 | BL_EN [7:0]: Bootloader enable If this optionbyte is set to 55h (complementary value AAh) the bootloader program is activated also in case of a programmed code memory (for more details, see the bootloader user manual, UM0500). | ### 11 Electrical characteristics #### 11.1 Parameter conditions Unless otherwise specified, all voltages are referred to $V_{SS}$ . #### 11.1.1 Minimum and maximum values Unless otherwise specified the minimum and maximum values are guaranteed in the worst conditions of ambient temperature, supply voltage and frequencies by tests in production on 100 % of the devices with an ambient temperature at $T_A = 25$ °C and $T_A = T_{Amax}$ (given by the selected temperature range). Data based on characterization results, design simulation and/or technology characteristics are indicated in the table footnotes and are not tested in production. ### 11.1.2 Typical values Unless otherwise specified, typical data are based on $T_A = 25$ °C, $V_{DD} = 5.0$ V. They are given only as design guidelines and are not tested. Typical ADC accuracy values are determined by characterization of a batch of samples from a standard diffusion lot over the full temperature range. ### 11.1.3 Typical curves Unless otherwise specified, all typical curves are given only as design guidelines and are not tested. #### 11.1.4 Loading capacitor The loading conditions used for pin parameter measurement are shown in Figure 8. Figure 8. Pin loading conditions #### 11.1.5 Pin input voltage The input voltage measurement on a pin of the device is described in Figure 9. Figure 9. Pin input voltage # 11.2 Absolute maximum ratings Stresses above those listed as 'absolute maximum ratings' may cause permanent damage to the device. This is a stress rating only and functional operation of the device under these conditions is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability. Table 14. Voltage characteristics | Symbol | Ratings | Min | Max | Unit | | |---------------------------------------|---------------------------------------------------------------------|-----------------------|----------------------------------------|--------|--| | V <sub>DDx</sub> - V <sub>SS</sub> | Supply voltage (including $V_{DDA}$ and $V_{DDIO}$ ) <sup>(1)</sup> | -0.3 | 6.5 | | | | V <sub>IN</sub> | Input voltage on true open drain pins (PE1, PE2) <sup>(2)</sup> | V <sub>SS</sub> - 0.3 | 6.5 | V | | | | Input voltage on any other pin <sup>(2)</sup> | V <sub>SS</sub> - 0.3 | V <sub>DD</sub> + 0.3 | | | | IV <sub>DDx</sub> - V <sub>SS</sub> I | Variations between different power pins | | 50 | mV | | | IV <sub>SSx</sub> - V <sub>SS</sub> I | Variations between all the different ground pins | | 50 | mv<br> | | | V <sub>ESD</sub> | Electrostatic discharge voltage | ratings ( | te maximum<br>electrical<br>on page 86 | | | <sup>1.</sup> All power ( $V_{DD}$ , $V_{DDIO}$ , $V_{DDA}$ ) and ground ( $V_{SS}$ , $V_{SSIO}$ , $V_{SSA}$ ) pins must always be connected to the external power supply I<sub>INJ(PIN)</sub> must never be exceeded. This is implicitly insured if V<sub>IN</sub> maximum is respected. If V<sub>IN</sub> maximum cannot be respected, the injection current must be limited externally to the I<sub>INJ(PIN)</sub> value. A positive injection is induced by V<sub>IN</sub> < V<sub>DD</sub> while a negative injection is induced by V<sub>IN</sub> < V<sub>SS</sub>. For true open-drain pads, there is no positive injection current, and the corresponding V<sub>IN</sub> maximum must always be respected Table 15. Current characteristics | Symbol | Ratings | Max. | Unit | |---------------------------------------|----------------------------------------------------------------------------|------|--------| | I <sub>VDD</sub> | Total current into V <sub>DD</sub> power lines (source) <sup>(1)(2)</sup> | 60 | | | I <sub>VSS</sub> | Total current out of V <sub>SS</sub> ground lines (sink) <sup>(1)(2)</sup> | 60 | | | 1. | Output current sunk by any I/O and control pin | 20 | | | lio | Output current source by any I/Os and control pin | - 20 | mA | | | Injected current on NRST pin | ± 10 | 1117 ( | | I <sub>INJ(PIN)</sub> (3) | Injected current on OSCIN pin | ± 10 | | | | Injected current on any other pin | ± 10 | | | ΣI <sub>INJ(PIN)</sub> <sup>(4)</sup> | Total injected current (sum of all I/O and control pins) | ± 20 | | - 1. All power ( $V_{DD}$ , $V_{DDIO}$ , $V_{DDA}$ ) and ground ( $V_{SS}$ , $V_{SSIO}$ , $V_{SSA}$ ) pins must always be connected to the external supply. - 2. The total limit applies to the sum of operation and injected currents. - 3. $I_{INJ(PIN)}$ must never be exceeded. This is implicitly insured if $V_{IN}$ maximum is respected. If $V_{IN}$ maximum cannot be respected, the injection current must be limited externally to the $I_{INJ(PIN)}$ value. A positive injection is induced by $V_{IN} > V_{DD}$ while a negative injection is induced by $V_{IN} < V_{SS}$ . For true open-drain pads, there is no positive injection current allowed and the corresponding $V_{IN}$ maximum must always be respected. - 4. When several inputs are submitted to a current injection, the maximum $\mathfrak{L}_{\mathsf{INJ}(\mathsf{PIN})}$ is the sum of the absolute positive and negative injected currents (instantaneous values). These results are based on characterization with $\mathfrak{L}_{\mathsf{INJ}(\mathsf{PIN})}$ maximum current injection on four I/O port pins of the device. Table 16. Thermal characteristics | Symbol | Ratings | Value | Unit | |------------------|------------------------------|-------------|------| | T <sub>STG</sub> | Storage temperature range | -65 to +150 | °C | | T <sub>J</sub> | Maximum junction temperature | 150 | C | # 11.3 Operating conditions Table 17. General operating conditions | Symbol | Parameter | Conditions | Min | Max | Unit | |---------------------|-------------------------------|-------------------------|-----|-----|--------| | 4 | Internal CRI Lalack fraguancy | T <sub>A</sub> ≤105 °C | 0 | 24 | MHz | | f <sub>CPU</sub> | Internal CPU clock frequency | T <sub>A</sub> > 105 °C | 0 | 16 | IVITIZ | | $V_{DD}/V_{DD\_IO}$ | Standard operating voltage | | 3.0 | 5.5 | V | | | | Suffix A | -40 | 85 | °C | | _ | Ambient temperature | Suffix B | -40 | 105 | °C | | T <sub>A</sub> | | Suffix C | -40 | 125 | °C | | | | Suffix D | -40 | 145 | °C | | | | A suffix version | -40 | 90 | °C | | ТЈ | | B suffix version | -40 | 110 | °C | | | Junction temperature range | C suffix version | -40 | 130 | °C | | | | D suffix version | -40 | 150 | °C | Figure 10. $f_{CPUmax}$ versus $V_{DD}$ | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |-----------------------|-----------------------------------------------|-------------------------|--------------------|-------------------|------|------| | | V <sub>DD</sub> rise time rate | | 20 <sup>(1)</sup> | | ∞ | | | t <sub>VDD</sub> | V <sub>DD</sub> fall time rate <sup>(3)</sup> | | 20 <sup>(2)</sup> | | 8 | μs/V | | t <sub>TEMP</sub> | Reset release delay | V <sub>DD</sub> rising | TBD <sup>(2)</sup> | 3 | | ms | | | Reset generation delay <sup>(3)</sup> | V <sub>DD</sub> falling | TBD <sup>(2)</sup> | 3 | | μs | | V <sub>IT+</sub> | Power-on reset threshold | | 2.65 | 2.8 | 2.95 | V | | V <sub>IT-</sub> | Brown-out reset threshold | | 2.58 | 2.73 | 2.88 | V | | V <sub>HYS(BOR)</sub> | Brown-out reset hysteresis | | | 70 <sup>(1)</sup> | | mV | Table 18. Operating conditions at power-up/power-down #### 11.3.1 Supply current characteristics The current consumption is measured as described in *Figure 8 on page 54* and *Figure 9 on page 55*. #### **Total current consumption** The MCU is placed under the following conditions: - All I/O pins in input mode with a static value at V<sub>DD</sub> or V<sub>SS</sub> (no load) - All peripherals are disabled except if explicitly mentioned. Subject to general operating conditions for V<sub>DD</sub> and T<sub>A</sub>. #### Note on the run-current typical and worst-case values - Typical device currents values are representative of an application set-up without any I/O activity at 25 °C. The worst case values correspond to the actual test-limits and include both internal and external device I/O current. - During the execution of an actual application program, the number of read access cycles to the code memory depends on its structure. A code doing arithmetical calculations reads the memory less frequently than programs with jump, loop or data manipulation instructions. The fast-reading access in a Flash memory needs much more power compared to a RAM. Consequently, the run-current for EEPROM execution depends strongly on the actual application code structure. The measurements in the tables below were made using a short, representative code with move, jump and arithmetic operations. The worst case, an infinite loop of 'while' instructions takes approximately 25 % more power. For RAM execution, such power to program structure relations has not been observed. <sup>1.</sup> Guaranteed by design, not tested in production <sup>2.</sup> TBD = To be determined Reset is always generated after a t<sub>TEMP</sub> delay. The application must ensure that V<sub>DD</sub> is still above the minimum operating voltage (V<sub>DD</sub> min) when the t<sub>TEMP</sub> delay has elapsed. Table 19. Total current consumption in run, wait and slow mode at $V_{DD} = 5.0 \text{ V}$ | Symbol | Parameter | | Conditions | Тур | Max | Unit | |----------------------|----------------------------------|-----------------------------------|----------------------------------------------------------------------------|------|---------------------|------| | | | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 4.4 | | | | | | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 3.8 | | | | l | Supply current in | All peripherals off, | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 3.3 | | | | I <sub>DD(RUN)</sub> | run mode | code executed from RAM | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 2.7 | 6.0 <sup>(1)</sup> | mA | | | | | HSI internal RC<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 2.55 | | | | | | | HSI internal RC 16 MHz/8<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | 1.2 | | | | | Supply<br>current in<br>run mode | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 11.4 | | | | | | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 10.8 | | mA | | l | | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 9.0 | | | | I <sub>DD(RUN)</sub> | | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 8.35 | 15.0 <sup>(1)</sup> | | | | | | HSI internal RC<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 8.2 | | | | | | | HSI internal RC 16 MHz/8<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | 1.9 | | | | | | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 6.9 | | | | | | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 6.3 | | | | l== :=: u :: | Supply | All peripherals on, | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 4.3 | | mA | | I <sub>DD(RUN)</sub> | run mode | current in code executed from RAM | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 3.7 | 8.0 <sup>(1)</sup> | | | | | | HSI internal RC<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 3.5 | | | | | | | HSI internal RC 16 MHz/8<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | 1.2 | | | Table 19. Total current consumption in run, wait and slow mode at $V_{DD} = 5.0 \text{ V}$ | Symbol | Parameter | | Conditions | Тур | Max | Unit | | | | | |----------------------|-----------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------|------|--------------------|-------------------------------|-------------------------------------------------------------------------------------|------|--------------------|--| | | | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 13.9 | | | | | | | | | | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 13.3 | | | | | | | | lee (e. n.) | Supply current in | All peripherals on, code executed | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 10.0 | | | | | | | | I <sub>DD(RUN)</sub> | run mode | from EEPROM | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 9.35 | | mA | | | | | | | | | HSI internal RC<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 9.2 | | | | | | | | | | | HSI internal RC 16 MHz/8<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | 2.1 | | | | | | | | | Supply<br>current in<br>wait mode | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 2.4 | | | | | | | | | | rent in all peripherals off | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 1.8 | | - mA | | | | | | l===:: | | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 2.0 | | | | | | | | I <sub>DD(WFI)</sub> | | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 1.38 | 4.0 <sup>(1)</sup> | | | | | | | | | | HSI internal RC<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 1.21 | | | | | | | | | | | HSI internal RC 16 MHz/8<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | 1.05 | | | | | | | | | | | | | | f <sub>CPU</sub> scaled down, | HSE external clock 16 MHz/128<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.125 MHz | 1.15 | 4.0 <sup>(1)</sup> | | | | | all peripherals off, code executed | HSI internal RC 16 MHz/128<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.125 MHz | 1.04 | | | | | | | | | Supply | from RAM | LSI internal RC 128 kHz<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.128 MHz | 0.5 | | - mA | | | | | | IDD(SLOW) | current in<br>slow mode | f <sub>CPU</sub> scaled down, | HSE external clock 16 MHz/128<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.125 MHz | 1.21 | | | | | | | | | | all peripherals off,<br>code executed<br>from EEPROM | HSI internal RC 16 MHz/128<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.125 MHz | 1.09 | | | | | | | | | | | LSI internal RC 128 kHz<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.128 MHz | 0.56 | | _ | | | | | <sup>1.</sup> Prodution test limits Table 20. Total current consumption and timing in halt, fast active halt and slow active halt modes at $V_{DD} = 5.0 \text{ V}$ | Symbol | Parameter | Conditions | Тур | Max | Unit | |----------------------|-----------------------------------------------------|------------------------|------|--------------------|------| | 1 | Supply current in halt mode | Flash powered down | 6.5 | 10 <sup>(1)</sup> | | | I <sub>DD(H)</sub> | | Flash in stand-by mode | 64 | | | | | Supply current in fast active halt mode | Crystal osc 16 MHz/128 | 1050 | | | | I <sub>DD(FAH)</sub> | | HSE osc 16 MHz/128 | 490 | | μΑ | | | | LSI RC 128 kHz | 150 | 200 <sup>(1)</sup> | | | I <sub>DD(SAH)</sub> | Supply current in slow active halt mode | LSI RC 128 kHz | 11 | 30 <sup>(1)</sup> | | | t <sub>WU(FAH)</sub> | Wake-up time from fast active halt mode to run mode | | | 2 <sup>(2)</sup> | | | t <sub>WU(SAH)</sub> | Wake-up time from slow active halt mode to run mode | | | 100 <sup>(2)</sup> | μs | <sup>1.</sup> Maximum values at 55 $^{\circ}$ C, tested in production according to the actual product temperature ranges. Table 21. Total current consumption in run, wait and slow mode at V<sub>DD</sub> = 3.3 V | Symbol | Parameter | | Conditions | Тур | Max | Unit | |-----------------------|-------------------|------------------------------------|----------------------------------------------------------------------------|------|-----|------| | | | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 4 | | | | | | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 3.8 | | | | 1 | Supply current in | All peripherals off, code executed | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 2.9 | | mA | | I <sub>DD</sub> (RUN) | run mode | from RAM | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 2.7 | | IIIA | | | | | HSI internal RC<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 2.55 | | | | | | | HSI internal RC 16 MHz/8<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | 1.2 | | | <sup>2.</sup> Data based on characterization results, not tested in production. Table 21. Total current consumption in run, wait and slow mode at $V_{DD} = 3.3 \text{ V}$ | Symbol | Parameter | | Conditions | Тур | Max | Unit | |----------------------|----------------------------|----------------------------------------------------------------------------|----------------------------------------------------------------------------|------|-----------|------| | | | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 11.0 | | | | | | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 10.8 | | | | l <i></i> | Supply current in | All peripherals off, | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 8.6 | | mA | | I <sub>DD(RUN)</sub> | run mode | code executed from EEPROM | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 8.35 | | IIIA | | | | | HSI internal RC<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 8.2 | | | | | | HSI internal RC 16 MHz/8<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | 1.6 | | | | | | | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 6.5 | | | | | Supply All peripherals on, | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 6.3 | | | | | 1 | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 3.9 | | <b></b> Λ | | | I <sub>DD(RUN)</sub> | current in<br>run mode | code executed<br>from RAM | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 3.7 | | mA | | | | | HSI internal RC<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 3.55 | | | | | | | HSI internal RC 16 MHz/8<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | 1.4 | | | | | | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 13.5 | | | | | | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 13.3 | | | | I | Supply | All peripherals on, | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 9.6 | | mΛ | | 22() | run mode | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 9.35 | | mA | | | | | HSI internal RC<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 9.2 | | | | | | HSI internal RC 16 MHz/8<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | 1.8 | | | | Table 21. Total current consumption in run, wait and slow mode at $V_{DD} = 3.3 \text{ V}$ | Symbol | Parameter | | Conditions | | | Unit | |------------------------|------------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|------|--|------| | | | | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 2.0 | | | | | | | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | 1.8 | | | | 1 | Supply current in | CPU not clocked, | HSE Crystal oscillator<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 1.6 | | mA | | I <sub>DD(WFI)</sub> | wait mode | all peripherals off | HSE external clock<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 1.38 | | IIIA | | | | HSI internal RC<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | 1.21 | | | | | | | | HSI internal RC 16 MHz/8<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | 1.05 | | | | | | f <sub>CPU</sub> scaled down, | HSE external clock 16 MHz/128<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.125 MHz | 1.15 | | | | | | all peripherals off, code executed | HSI internal RC 16 MHz/128<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.125 MHz | 1.04 | | | | lance our | Supply current in | from RAM | LSI internal RC 128 kHz<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.128MHz | 0.5 | | mA | | I <sub>DD</sub> (SLOW) | slow mode | f <sub>CPU</sub> scaled down, | HSE external clock 16 MHz/128<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.125 MHz | 1.21 | | IIIA | | | all peripherals off, code executed | HSI internal RC 16 MHz/128<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.125 MHz | 1.09 | | | | | | | from EEPROM | LSI internal RC 128 kHz<br>f <sub>CPU</sub> = f <sub>MASTER</sub> = 0.128 MHz | 0.56 | | | Table 22. Total current consumption and timing in halt, fast active halt and slow active halt modes at $V_{DD} = 3.3 \text{ V}$ | Symbol | Parameter | Conditions | Тур | Max | Unit | |----------------------|-----------------------------------------------------|------------------------|-----|--------------------|------| | | Supply current in halt mode | Flash powered down | 4.7 | | | | I <sub>DD</sub> (H) | | Flash in stand-by mode | 62 | | | | | Supply current in fast active halt mode | Crystal osc 16 MHz/128 | 600 | | | | I <sub>DD(FAH)</sub> | | HSE osc 16 MHz/128 | 490 | | μΑ | | | | LSI RC 128 kHz | 140 | | | | I <sub>DD(SAH)</sub> | Supply current in slow active halt mode | LSI RC 128 kHz | 9 | | | | t <sub>WU(FAH)</sub> | Wake-up time from fast active halt mode to run mode | | | 2 <sup>(1)</sup> | 116 | | t <sub>WU(SAH)</sub> | Wake-up time from slow active halt mode to run mode | | | 100 <sup>(1)</sup> | μs | <sup>1.</sup> Data based on characterization results, not tested in production ### **On-chip peripherals** Table 23. Typical peripheral current consumption $V_{DD} = 5.0 V^{(1)}$ | Symbol | Parameter | Typ.<br>f <sub>master</sub> =<br>2 MHz | Typ.<br>f <sub>master</sub> =<br>16 MHz | Typ.<br>f <sub>master</sub> =<br>24 MHz | Unit | |---------------------------------|---------------------------------------------------|----------------------------------------|-----------------------------------------|-----------------------------------------|------| | I <sub>DD(TIM1)</sub> | TIM1 supply current <sup>(2)</sup> | 0.03 | 0.23 | 0.34 | | | I <sub>DD(TIM2)</sub> | TIM2 supply current (2) | 0.02 | 0.12 | 0.19 | | | I <sub>DD(TIM3)</sub> | TIM3 supply current <sup>(2)</sup> | 0.01 | 0.1 | 0.16 | | | I <sub>DD(TIM4)</sub> | TIM4 supply current <sup>(2)</sup> | 0.004 | 0.03 | 0.05 | | | I <sub>DD(USART)</sub> | USART supply current <sup>(2)</sup> | 0.03 | 0.09 | 0.15 | | | I <sub>DD(LINUART)</sub> | LINUART supply current <sup>(2)</sup> | 0.03 | 0.11 | 0.18 | | | I <sub>DD(SPI)</sub> | SPI supply current <sup>(2)</sup> | 0.01 | 0.04 | 0.07 | mA | | I <sub>DD(I<sup>2</sup>C)</sub> | I <sup>2</sup> C supply current <sup>(2)</sup> | 0.02 | 0.06 | 0.91 | IIIA | | I <sub>DD(CAN)</sub> | CAN supply current <sup>(3)</sup> | 0.06 | 0.22 | 0.34 | | | I <sub>DD(AWU)</sub> | AWU supply current <sup>(2)</sup> | 0.003 | 0.02 | 0.05 | | | I <sub>DD(TOT_DIG)</sub> | All digital peripherals on | 0.22 | 1 | 2.4 | | | I <sub>DD(ADC)</sub> | ADC supply current when converting <sup>(4)</sup> | 0.93 | 0.95 | 0.96 | | | I <sub>DD(EE_PROG)</sub> | Data EEPROM programming current | 2.5 | 2.9 | 3.1 | | Typical values - not tested in production. Since the peripherals are powered by an internally regulated, constant digital supply voltage, the values are similar in the full supply voltage range. **L**7/ Data based on a differential I<sub>DD</sub> measurement between no peripheral clocked and a single active peripheral. This measurement does not include the pad toggling consumption. Data based on a differential IDD measurement between reset configuration (CAN disabled) and a permanent CAN data transmit sequence in loopback mode at 1 MHz. This measurement does not include the pad toggling consumption. Data based on a differential I<sub>DD</sub> measurement between reset configuration and continuous A/D conversions. #### **Current consumption curves** Figure 11 to Figure 16 show typical current consumption measured with code executing in RAM. Figure 11. Typ. $I_{DD(RUN)HSE}$ vs. $V_{DD}$ @ $f_{CPU}$ = 16 MHz, periph = on Figure 12. Typ. $I_{DD(RUN)HSE}$ vs. $f_{CPU}$ @ $V_{DD}$ = 5.0 V, periph = on Figure 13. Typ. $I_{DD(RUN)HSI}$ vs. $V_{DD}$ @ $f_{CPU}$ = 16 MHz, periph = off Figure 14. Typ. $I_{DD(WFI)HSE}$ vs. $V_{DD}$ @ $f_{CPU}$ = 16 MHz, periph = on Figure 15. Typ. $I_{DD(WFI)HSE}$ vs. $f_{CPU}$ @ $V_{DD}$ = 5.0 V, periph = on Figure 16. Typ. $I_{DD(WFI)HSI}$ vs. $V_{DD}$ @ $f_{CPU}$ = 16 MHz, periph = off #### 11.3.2 External clock sources and timing characteristics #### **HSE** user external clock Subject to general operating conditions for $V_{DD}$ and $T_A$ . Table 24. HSE user external clock characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |-----------------------|--------------------------------------|----------------------------|-----------------------|-----|-----------------------|--------| | f <sub>HSE_ext</sub> | User external clock source frequency | T <sub>A</sub> < 105 °C | 0 <sup>(1)</sup> | | 24 | MHz | | | | T <sub>A</sub> > 105 °C | 0 <sup>(1)</sup> | | 16 | IVITIZ | | V <sub>HSEdHL</sub> | Comparator hysteresis | | 0.1 x V <sub>DD</sub> | | | V | | V <sub>HSEH</sub> | OSCIN input pin high level voltage | | 0.7 x V <sub>DD</sub> | | V <sub>DD</sub> | V | | V <sub>HSEL</sub> | OSCIN input pin low level voltage | | V <sub>SS</sub> | | 0.3 x V <sub>DD</sub> | V | | I <sub>LEAK_HSE</sub> | OSCIN input leakage current | $V_{SS} < V_{IN} < V_{DD}$ | -1 | | +1 | μΑ | <sup>1.</sup> In case of CSS, the external clock must have a frequency above 500 kHz. Figure 17. HSE external clock source #### HSE crystal/ceramic resonator oscillator The HSE clock can be supplied using a crystal/ceramic resonator oscillator of up to 24 MHz. All the information given in this paragraph is based on characterization results with specified typical external components. In the application, the resonator and the load capacitors have to be placed as close as possible to the oscillator pins in order to minimize output distortion and start-up stabilization time. Refer to the crystal resonator manufacturer for more details (frequency, package, accuracy...). Table 25. HSE oscillator characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |--------------------------|---------------------------------------------|----------------------------------|-----|-----|---------------------------------|------| | $R_{F}$ | Feedback resistor | | | 220 | | kΩ | | C <sup>(1)</sup> | Recommended load capacitance <sup>(2)</sup> | | | | 20 | pF | | | HSE oscillator power consumption | C = 20 pF | | | 6 (startup)<br>2 (stabilized) | mA | | IDD(HSE) | | C = 10 pF | | | 6 (startup)<br>1.5 (stabilized) | IIIA | | 9 <sub>m</sub> | Oscillator transconductance | | 5 | | | mA/V | | t <sub>SU(HSE)</sub> (3) | Startup time | V <sub>DD</sub> is<br>stabilized | | 1 | | ms | - 1. C is approximately equivalent to 2 x crystal Cload. - 2. The oscillator selection can be optimized in terms of supply current using a high quality resonator with small R<sub>m</sub> value. Refer to crystal manufacturer for more details - 3. t<sub>SU(HSE)</sub> is the start-up time measured from the moment it is enabled (by software) to a stabilized 24 MHz oscillation is reached. This value is measured for a standard crystal resonator and it can vary significantly with the crystal manufacturer. Figure 18. HSE oscillator circuit diagram ### HSE oscillator critical $g_{\rm m}$ formula $$g_{mcrit} = (2 \times \Pi \times {}^{f}HSE)^{2} \times R_{m}(2Co + C)^{2}$$ R<sub>m</sub>: Notional resistance (see crystal specification) L<sub>m</sub>: Notional inductance (see crystal specification) C<sub>m</sub>: Notional capacitance (see crystal specification) Co: Shunt capacitance (see crystal specification) $C_{L1} = C_{L2} = C$ : Grounded external capacitance g<sub>m</sub> >> g<sub>mcrit</sub> ### 11.3.3 Internal clock sources and timing characteristics Subject to general operating conditions for $V_{DD}$ and $T_{A}. \\$ ## High speed internal RC oscillator (HSI) Table 26. HSI oscillator characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |----------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------|-----|------------------|------| | f <sub>HSI</sub> | Frequency | | | 16 | | MHz | | | HSI oscillator user trimming accuracy | Trimmed by the application for any V <sub>DD</sub> and T <sub>A</sub> conditions | -1 <sup>(1)</sup> | | 1 <sup>(1)</sup> | | | | HSI oscillator accuracy (factory calibrated) | V <sub>DD</sub> = 5.0 V, T <sub>A</sub> = 25°C | -1 <sup>(1)</sup> | | 1 <sup>(1)</sup> | | | ACC <sub>HS</sub> | | V <sub>DD</sub> = 5.0 V,<br>25 °C ≤T <sub>A</sub> ≤85 °C | | ±2 | | % | | | | V <sub>DD</sub> = 5.0 V,<br>25 °C ≤T <sub>A</sub> ≤125 °C | -3 <sup>(1)</sup> | | 3 <sup>(1)</sup> | | | | | $V_{DD} = 3.0 \text{ V} \le V_{DD} \le 5.5 \text{ V},$<br>-40 °C $\le T_A \le 125 \text{ °C}$ | -5 <sup>(1)</sup> | | 5 <sup>(1)</sup> | | | t <sub>su(HSI)</sub> | HSI oscillator wake-up time including calibration | | | | 2 <sup>(2)</sup> | μs | - 1. Tested in production - 2. Guaranteed by design, not tested in production Figure 19. Typical HSI frequency vs $V_{\rm DD}$ @ four temperatures ## Low speed internal RC oscillator (LSI) Subject to general operating conditions for $V_{\mbox{\scriptsize DD}}$ and $T_{\mbox{\scriptsize A}}.$ Table 27. LSI oscillator characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |----------------------|-----------------------------|------------|-----|-----|------------------|------| | f <sub>LSI</sub> | Frequency | | 112 | 128 | 144 | kHz | | t <sub>su(LSI)</sub> | LSI oscillator wake-up time | | | | 7 <sup>(1)</sup> | μs | <sup>1.</sup> Data based on characterization results, not tested in production. ### 11.3.4 Memory characteristics #### **RAM** and hardware registers Table 28. RAM and hardware registers | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |----------|------------------------------------|----------------------|-----|-----|-----|------| | $V_{RM}$ | Data retention mode <sup>(1)</sup> | Halt mode (or reset) | 1.8 | | | V | Minimum supply voltage without losing data stored in RAM (in halt mode or under reset) or in hardware registers (only in halt mode). Guaranteed by design, not tested in production. refer to *Table 18 on page 58* for the value of V<sub>IT-max</sub> #### Flash program memory/data EEPROM memory General conditions: $T_A = -40$ to 125 °C. Table 29. Flash program memory/data EEPROM memory | Symbol | Parameter | Conditions | Min <sup>(1)</sup> | Тур | Max | Unit | |--------------------|--------------------------------------------------------------------------------------------------|--------------------------|--------------------|-----|-----|--------| | $V_{DD}$ | Operating voltage<br>(all modes, execution/write/erase) | f <sub>CPU</sub> ≤24 MHz | 3.0 | | 5.5 | V | | t <sub>prog</sub> | Standard programming time<br>(including erase) for byte/word/block<br>(1 byte/4 bytes/128 bytes) | | | 6 | 6.6 | ms | | Freg | Fast programming time for 1 block (128 bytes) | | | 3 | 3.3 | ms | | t <sub>erase</sub> | Erase time for 1 block (128 bytes) | | | 3 | 3.3 | ms | | | Program memory endurance | T <sub>A</sub> = 25 °C | 1 k | | | cycles | | | erase/write cycles <sup>(2)</sup> | T <sub>A</sub> = 125 °C | 100 | | | | | $N_{RW}$ | Data memory endurance erase/write cycles <sup>(2)</sup> | T <sub>A</sub> = 25 °C | 300 k | | | | | | | T <sub>A</sub> = 125 °C | 100 k | | | | | | | T <sub>A</sub> = 145 °C | 80 k | | | | | | | T <sub>A</sub> = 25 °C | 40 | | | | | | Program memory after cycling | T <sub>A</sub> = 55 °C | 20 | | | years | | $t_{RET}$ | | T <sub>A</sub> = 85 °C | 10 | | | | | | Data memory retention after cycling at the endurance limits (T, n) | Full temperature range | 1000 | | | hours | | | | T <sub>A</sub> = 25 °C | 40 | | | | | t <sub>RETI</sub> | Intrinsic data retention | T <sub>A</sub> = 55 °C | 20 | | | years | | | | T <sub>A</sub> = 85 °C | 10 | | | | <sup>1.</sup> Guaranteed by characterization, not tested in production. <sup>2.</sup> The physical granularity of the memory is 4 bytes, so cycling is performed on 4 bytes even when a write/erase operation addresses a single byte. # 11.3.5 I/O port pin characteristics #### **General characteristics** Subject to general operating conditions for $V_{DD}$ and $T_A$ unless otherwise specified. All unused pins must be kept at a fixed voltage, using the output mode of the I/O for example or an external pull-up or pull-down resistor. Table 30. I/O static characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |---------------------------------|-------------------------------------------------|--------------------------------------------------------------------|-------------------------|--------------------------|-------------------------|------| | V <sub>IL</sub> | Input low level voltage | | -0.3 V | | 0.3 x V <sub>DD</sub> | V | | V <sub>IH</sub> | Input high level voltage | V <sub>DD</sub> = 5.0 V | 0.7 x V <sub>DD</sub> | | V <sub>DD</sub> + 0.3 V | V | | V <sub>hys</sub> | Hysteresis <sup>(1)</sup> | | | 0.1 x<br>V <sub>DD</sub> | | mV | | V <sub>OH</sub> | I = 3 mA | Standard I/0, V <sub>DD</sub> = 5 V | V <sub>DD</sub> - 0.5 V | | | V | | | I = 1.5 mA | Standard I/0, V <sub>DD</sub> = 3 V | V <sub>DD</sub> - 0.4 V | | | | | V <sub>OL</sub> | I = 8mA | High sink and true open drain I/0, V <sub>DD</sub> = 5 V | | | 0.5 | | | | I = 3 mA | Standard I/0, V <sub>DD</sub> = 5 V | | | 0.6 | | | | I = 1.5 mA | Standard I/0, V <sub>DD</sub> = 3 V | | | 0.4 | | | R <sub>pu</sub> | Pull-up resistor | $V_{DD} = 5 \text{ V}, V_{IN} = V_{SS}$ | 35 | 50 | 65 | kΩ | | t <sub>R</sub> , t <sub>F</sub> | Rise and fall time (10% - 90%) | Fast I/Os<br>Load = 50 pF | | | 20 <sup>(2)</sup> | ns | | | | Standard and high sink I/Os<br>Load = 50 pF | | | 125 <sup>(2)</sup> | ns | | I <sub>lkg</sub> | Input leakage<br>current,<br>analog and digital | V <sub>SS</sub> ≤V <sub>IN</sub> ≤V <sub>DD</sub> | | | ±1 <sup>(2)</sup> | μΑ | | I <sub>lkg ana</sub> | Analog input leakage current | $V_{SS} \le V_{IN} \le V_{DD}$<br>-40 °C < T <sub>A</sub> < 125 °C | | | ±250 <sup>(2)</sup> | nA | | I <sub>lkg(inj)</sub> | Leakage current in adjacent I/O <sup>(2)</sup> | Injection current ±4 mA | | | ±1 <sup>(2)</sup> | μΑ | <sup>1.</sup> Hysteresis voltage between Schmitt trigger switching levels. Based on characterization results, not tested in production. <sup>2.</sup> Data based on characterization results, not tested in production. Figure 21. Typical $V_{IL}$ and $V_{IH}$ vs $V_{DD}$ @ four temperatures ## Typical output level curves Figure 24 to Figure 33 show typical output level curves measured with output on a single pin. Figure 24. Typ. $V_{OL}$ @ $V_{DD}$ = 3.3 V (standard ports) Figure 25. Typ. $V_{OL}$ @ $V_{DD}$ = 5.0 V (standard ports) Figure 26. Typ. $V_{OL} @ V_{DD} = 3.3 \text{ V}$ (true open figure 27. Typ. $V_{OL} @ V_{DD} = 5.0 \text{ V}$ (true open drain ports) Figure 28. Typ. $V_{OL}$ @ $V_{DD}$ = 3.3 V (high sink Figure 29. Typ. $V_{OL}$ @ $V_{DD}$ = 5.0 V (high sink ports) 74/100 Figure 30. Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 3.3 V (standard ports) Figure 31. Typ. $V_{DD} - V_{OH} @ V_{DD} = 5.0 V$ (standard ports) Figure 32. Typ. $V_{DD} = V_{OH} @ V_{DD} = 3.3 \text{ V (high }$ Figure 33. Typ. $V_{DD} = V_{OH} @ V_{DD} = 5.0 \text{ V (high sink ports)}$ # 11.3.6 Reset pin characteristics Subject to general operating conditions for $V_{\mbox{\scriptsize DD}}$ and $T_{\mbox{\scriptsize A}}$ unless otherwise specified. Table 31. NRST pin characteristics | | <del>_</del> | | | | | | |-----------------------|----------------------------------------------|----------------------------------------|--------------------|--------------------|--------------------|------| | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | | $V_{IL(NRST)}$ | NRST input low level voltage <sup>(1)</sup> | | $V_{SS}$ | | TBD <sup>(2)</sup> | | | V <sub>IH(NRST)</sub> | NRST input high level voltage <sup>(1)</sup> | | TBD <sup>(2)</sup> | | $V_{DD}$ | V | | V <sub>OL(NRST)</sub> | NRST output low level voltage <sup>(1)</sup> | I <sub>OL</sub> =TBD <sup>(2)</sup> mA | | | TBD <sup>(2)</sup> | | | R <sub>PU(NRST)</sub> | NRST pull-up resistor <sup>(3)</sup> | | 30 | 40 | 60 | kΩ | | $V_{F(NRST)}$ | NRST input filtered pulse <sup>(4)</sup> | | | TBD <sup>(2)</sup> | | ns | | V <sub>NF(NRST)</sub> | NRST input not filtered pulse <sup>(4)</sup> | | | TBD <sup>(2)</sup> | | μs | - 1. Data based on characterization results, not tested in production. - 2. TBD = To be determined. - 3. The R<sub>PU</sub> pull-up equivalent resistor is based on a resistive transistor - 4. Data guaranteed by design, not tested in production. Figure 34. Typical NRST $V_{IL}$ and $V_{IH}$ vs $V_{DD}$ @ four temperatures Figure 35. Typical NRST pull-up resistance $R_{PU}$ vs $V_{DD}$ @ four temperatures Figure 36. Typical NRST pull-up current I<sub>pu</sub> vs V<sub>DD</sub> @ four temperatures The reset network shown in *Figure 37* protects the device against parasitic resets. The user must ensure that the level on the NRST pin can go below the $V_{IL}$ max. level specified in *Table 30*. Otherwise the reset is not taken into account internally. Figure 37. Recommended reset pin protection # 11.3.7 TIM 1, 2, 3, and 4 timer characteristics Subject to general operating conditions for $V_{\text{DD}}$ , $f_{\text{MASTER}}$ , and $T_{\text{A}}$ unless otherwise specified. Table 32. TIM 1, 2, 3 characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |------------------------|----------------------------------------------------------------------------|------------|-----|-----|--------|---------------------| | t <sub>w(ICAP)in</sub> | Input capture pulse time <sup>(1)</sup> | | 2 | | | T <sub>MASTER</sub> | | t <sub>res(TIM)</sub> | Timer resolution time <sup>(1)</sup> | | 1 | | | T <sub>MASTER</sub> | | f <sub>EXT</sub> | Timer external clock frequency <sup>(1)</sup> | | | | 24 | MHz | | Res <sub>TIM</sub> | Timer resolution <sup>(1)</sup> | | | 16 | | bit | | t <sub>COUNTER</sub> | 16-bit counter clock period when internal clock is selected <sup>(1)</sup> | | | 1 | | T <sub>MASTER</sub> | | t <sub>MAX_COUNT</sub> | Maximum possible count <sup>(1)</sup> | | | | 65 536 | T <sub>MASTER</sub> | <sup>1.</sup> Not tested in production ## 11.3.8 SPI serial peripheral interface Unless otherwise specified, the parameters given in *Table 33* are derived from tests performed under ambient temperature, $f_{MASTER}$ frequency and $V_{DD}$ supply voltage conditions. $t_{MASTER} = 1/f_{MASTER}$ . Refer to I/O port characteristics for more details on the input/output alternate function characteristics (NSS, SCK, MOSI, MISO). Table 33. SPI characteristics | Symbol | Parameter | Conditions | Min | Max | Unit | |------------------------------------------------------|------------------------------|--------------------------------------------------------------------------------------------|-----------------------|-----------------------|--------| | f <sub>SCK</sub> | SPI clock frequency | Master mode | 0 | 10 | MHz | | 1/t <sub>c(SCK)</sub> | SPI Clock frequency | Slave mode | 0 | 10 | IVIITZ | | t <sub>r(SCK)</sub><br>t <sub>f(SCK)</sub> | SPI clock rise and fall time | Capacitive load: C = 30 pF | | 25 | | | t <sub>su(NSS)</sub> <sup>(1)</sup> | NSS setup time | Slave mode | 4*T <sub>MASTER</sub> | | | | t <sub>h(NSS)</sub> <sup>(1)</sup> | NSS hold time | Slave mode | 70 | | | | t <sub>w(SCKH)</sub> (1)<br>t <sub>w(SCKL)</sub> (1) | SCK high and low time | Master mode,<br>f <sub>MASTER</sub> = 16 MHz, f <sub>SCK</sub> = 8 MHz | 110 | 140 | | | t <sub>su(MI)</sub> <sup>(1)</sup> | Data input actup time | Master mode | 5 | | | | $t_{su(MI)}^{(1)}$ $t_{su(SI)}^{(1)}$ | Data input setup time | Slave mode | 2 | | | | t <sub>h(MI)</sub> (1)<br>t <sub>h(SI)</sub> (1) | Data input hold time | Master mode,<br>f <sub>MASTER</sub> = 16 MHz, f <sub>SCK</sub> = 8 MHz | 7 | | | | t <sub>h(SI)</sub> (1) | Data input noid time | Slave mode,<br>f <sub>MASTER</sub> = 16 MHz, f <sub>SCK</sub> = 8 MHz | 3 | | ns | | t <sub>a(SO)</sub> (1)(2) | Data output access time | Slave mode,<br>f <sub>MASTER</sub> = 16 MHz, f <sub>SCK</sub> = 8 MHz | | 400 | | | | | Slave mode | | 4*t <sub>MASTER</sub> | | | t <sub>dis(SO)</sub> <sup>(1)(3)</sup> | Data output disable time | Slave mode | 25 | | | | t <sub>v(SO)</sub> <sup>(1)</sup> | Data output valid time | Slave mode (after enable edge),<br>f <sub>MASTER</sub> = 16 MHz, f <sub>SCK</sub> = 8 MHz | | 100 | | | t <sub>v(MO)</sub> <sup>(1)</sup> | Data output valid time | Master mode (after enable edge),<br>f <sub>MASTER</sub> = 16 MHz, f <sub>SCK</sub> = 8 MHz | | 3 | | | t <sub>h(SO)</sub> <sup>(1)</sup> | Data output hold time | Slave mode (after enable edge) | 100 | | | | t <sub>h(MO)</sub> <sup>(1)</sup> | Data output hold time | Master mode (after enable edge) | 6 | | | <sup>1.</sup> Values based on design simulation and/or characterization results, and not tested in production. 79/100 <sup>2.</sup> Min time is for the minimum time to drive the output and the max time is for the maximum time to validate the data. <sup>3.</sup> Min time is for the minimum time to invalidate the output and the max time is for the maximum time to put the data in Hi-Z. Figure 38. SPI timing diagram - slave mode and CPHA = 0 Figure 39. SPI timing diagram - slave mode and CPHA = $1^{(1)}$ 1. Measurement points are at CMOS levels: 0.3 $\rm V_{DD}$ and 0.7 $\rm V_{DD}$ 1. Measurement points are at CMOS levels: 0.3 $\rm V_{DD}$ and 0.7 $\rm V_{DD}$ # 11.3.9 I<sup>2</sup>C interface characteristics Table 34. I<sup>2</sup>C characteristics | Cumbal | Parameter | Standard | mode I <sup>2</sup> C | Fast mod | de I <sup>2</sup> C <sup>(1)</sup> | Unit | |-------------------------|-------------------------------------------------|--------------------|-----------------------|--------------------|------------------------------------|------| | Symbol | Parameter | Min <sup>(2)</sup> | Max <sup>(2)</sup> | Min <sup>(2)</sup> | Max <sup>(2)</sup> | Unit | | t <sub>w(SCLL)</sub> | SCL clock low time | 4.7 | | 1.3 | | | | t <sub>w(SCLH)</sub> | SCL clock high time | 4.0 | | 0.6 | | μs | | t <sub>su(SDA)</sub> | SDA setup time | 250 | | 100 | | | | t <sub>h(SDA)</sub> | SDA data hold time | 0(3) | | 0 <sup>(4)</sup> | 900 <sup>(3)</sup> | | | t <sub>r(SDA)</sub> | SDA and SCL rise time (V <sub>DD</sub> 3 5.5 V) | | 1000 | | 300 | ns | | t <sub>f(SDA)</sub> | SDA and SCL fall time (V <sub>DD</sub> 3 5.5 V) | | 300 | | 300 | | | t <sub>h(STA)</sub> | START condition hold time | 4.0 | | 0.6 | | | | t <sub>su(STA)</sub> | Repeated START condition setup time | 4.7 | | 0.6 | | μs | | t <sub>su(STO)</sub> | STOP condition setup time | 4.0 | | 0.6 | | μs | | t <sub>w(STO:STA)</sub> | STOP to START condition time (bus free) | 4.7 | | 1.3 | | μs | | C <sub>b</sub> | Capacitive load for each bus line | | 400 | | 400 | pF | <sup>1.</sup> $f_{MASTER}$ , must be at least 8 MHz to achieve max fast $I^2C$ speed (400 kHz) <sup>2.</sup> Data based on standard I<sup>2</sup>C protocol requirement, not tested in production The maximum hold time of the start condition has only to be met if the interface does not stretch the low time <sup>4.</sup> The device must internally provide a hold time of at least 300 ns for the SDA signal in order to bridge the undefined region of the falling edge of SCL ### 11.3.10 10-bit ADC characteristics Subject to general operating conditions for $V_{\text{DDA}}$ , $f_{\text{MASTER}}$ , and $T_{\text{A}}$ unless otherwise specified. Table 35. ADC characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |-------------------------------|--------------------------------------------------------------------------|------------------------------------------------------------------|-------------------|-----|-------------------|------| | f <sub>ADC</sub> | ADC clock frequency | | | 2 | | MHz | | V <sub>DDA</sub> | Analog supply | | 3 | | 5.5 | V | | V <sub>REF+</sub> | Positive reference voltage | | 2.75 | | $V_{DDA}$ | V | | V <sub>REF-</sub> | Negative reference voltage | | V <sub>SSA</sub> | | 0.5 | V | | | | | $V_{SSA}$ | | $V_{DDA}$ | V | | V <sub>AIN</sub> | Conversion voltage range <sup>(1)</sup> | Devices with external V <sub>REF+</sub> / V <sub>REF-</sub> pins | V <sub>REF-</sub> | | V <sub>REF+</sub> | V | | C <sub>ADC</sub> | Internal sample and hold capacitor | | | 3 | | pF | | t <sub>S</sub> <sup>(1)</sup> | Sampling time (3 x 1/f <sub>ADC</sub> ) | f <sub>ADC</sub> = 2 MHz | | 1.5 | | μs | | t <sub>STAB</sub> | Wake-up time from standby | | | 7 | | μs | | t <sub>CONV</sub> | Total conversion time including sampling time (14 x 1/f <sub>ADC</sub> ) | f <sub>ADC</sub> = 2 MHz | 7 | | μs | | During the sample time the input capacitance C<sub>AIN</sub> (3 pF max) can be charged/discharged by the external source. The internal resistance of the analog source must allow the capacitance to reach its final voltage level within t<sub>S</sub>. After the end of the sample time t<sub>S</sub>, changes of the analog input voltage have no effect on the conversion result. Values for the sample clock t<sub>S</sub> depend on programming. 83/100 Table 36. ADC accuracy with R<sub>AIN</sub> < 10 k $\Omega$ R<sub>AIN</sub>, V<sub>DDA</sub> = 3.3 V | | , AIII | AIN, DDA | | | | |-------------------|---------------------------------------------|--------------------------|----------|--------------------|------| | Symbol | Parameter | Conditions | Тур | Max | Unit | | IE <sub>T</sub> I | Total unadjusted error <sup>(1)</sup> | | 1.5 | TBD <sup>(1)</sup> | | | IE <sub>O</sub> I | Offset error <sup>(1)</sup> | | 1.1 | TBD <sup>(1)</sup> | | | IE <sub>G</sub> I | Gain error <sup>(1)</sup> | f <sub>ADC</sub> = 2 MHz | -0.2/0.6 | TBD <sup>(1)</sup> | LSB | | IE <sub>D</sub> I | Differential linearity error <sup>(1)</sup> | | 0.9 | TBD <sup>(1)</sup> | | | IE <sub>L</sub> I | Integral linearity error <sup>(1)</sup> | | 1 | TBD <sup>(1)</sup> | | <sup>1.</sup> TBD = To be determined Table 37. ADC accuracy with R<sub>AIN</sub> < 10 k $\Omega$ , V<sub>DDA</sub> = 5 V | Symbol | Parameter | Conditions | Тур | Max | Unit | |-------------------|---------------------------------------------|-------------------|-----|-----|------| | IE <sub>T</sub> I | Total unadjusted error <sup>(1)</sup> | | 1.4 | 3 | | | IE <sub>O</sub> I | Offset error <sup>(1)</sup> | | 0.8 | 2 | | | IE <sub>G</sub> I | Gain error <sup>(1)</sup> | $f_{ADC} = 2 MHz$ | 0.1 | 1 | LSB | | IE <sub>D</sub> I | Differential linearity error <sup>(1)</sup> | | 0.9 | 2 | | | IE <sub>L</sub> I | Integral linearity error <sup>(1)</sup> | | 0.7 | 2 | | ADC accuracy vs. injection current: Any positive or negative injection current within the limits specified for $I_{\text{INJ(PIN)}}$ and $\Sigma I_{\text{INJ(PIN)}}$ in *Section 11.3.5* does not affect the ADC accuracy. Figure 41. ADC accuracy characteristics - 1. Example of an actual transfer curve - The ideal transfer curve - End point correlation line - End point correlation line E<sub>T</sub> = Total unadjusted error: Maximum deviation between the actual and the ideal transfer curves. E<sub>O</sub> = Offset error: Deviation between the first actual transition and the first ideal one. E<sub>G</sub> = Gain error: Deviation between the last ideal transition and the last actual one. E<sub>D</sub> = Differential linearity error: Maximum deviation between actual steps and the ideal one. E<sub>L</sub> = Integral linearity error: Maximum deviation between any actual transition and the end point correlation line. RAIN AINX V<sub>T</sub> 0.6V V<sub>T</sub> 0.6V C<sub>AIN</sub> C<sub>ADC</sub> C<sub>ADC</sub> Figure 42. Typical application with ADC #### 11.3.11 EMC characteristics Susceptibility tests are performed on a sample basis during product characterization. ### Functional EMS (electromagnetic susceptibility) While executing a simple application (toggling 2 LEDs through I/O ports), the product is stressed by two electromagnetic events until a failure occurs (indicated by the LEDs). - ESD: Electrostatic discharge (positive and negative) is applied on all pins of the device until a functional disturbance occurs. This test conforms with the IEC 1000-4-2 standard. - FTB: A burst of fast transient voltage (positive and negative) is applied to V<sub>DD</sub> and V<sub>SS</sub> through a 100 pF capacitor, until a functional disturbance occurs. This test conforms with the IEC 1000-4-4 standard. A device reset allows normal operations to be resumed. The test results are given in the table below based on the EMS levels and classes defined in application note AN1709. #### Designing hardened software to avoid noise problems EMC characterization and optimization are performed at component level with a typical application environment and simplified MCU software. It should be noted that good EMC performance is highly dependent on the user application and the software in particular. Therefore it is recommended that the user applies EMC software optimization and prequalification tests in relation with the EMC level requested for his application. #### Software recommendations The software flowchart must include the management of runaway conditions such as: - Corrupted program counter - Unexpected reset - Critical data corruption (control registers...) #### **Prequalification trials** Most of the common failures (unexpected reset and program counter corruption) can be recovered by applying a low state on the NRST pin or the oscillator pins for 1 second. To complete these trials, ESD stress can be applied directly on the device, over the range of specification values. When unexpected behavior is detected, the software can be hardened to prevent unrecoverable errors occurring (see application note AN1015). Table 38. EMS data | Symbol | Parameter | Conditions | Level/class | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------| | V <sub>FESD</sub> | | $V_{DD} = 3.3 \text{ V}, T_A = 25 ^{\circ}\text{C},$<br>$f_{MASTER} = 16 \text{ MHz (HSI clock)},$<br>Conforms to IEC 1000-4-2 | 3B | | V <sub>EFTB</sub> | Fast transient voltage burst limits to be applied through 100 pF on V <sub>DD</sub> and V <sub>SS</sub> pins to induce a functional disturbance | $V_{DD}$ = 3.3 V, $T_{A}$ = 25 °C, $f_{MASTER}$ = 16 MHz (HSI clock), Conforms to IEC 1000-4-4 | 4A | #### **Electromagnetic interference (EMI)** Emission tests conform to the SAE J 1752/3 standard for test software, board layout and pin loading. Table 39. EMI data | Symbol | | | Conditions | | | | | | | |------------------|-----------|----------------------------------------------------------|-------------------|-------------------------------------|-----------|-----------|------|--|--| | | Parameter | | Monitored | Max f <sub>CPU</sub> <sup>(1)</sup> | | | Unit | | | | | | General conditions | frequency band | 8<br>MHz | 16<br>MHz | 24<br>MHz | | | | | | | Peak level $T_A = 25 ^{\circ}\text{C}$ , LQFP80 package | 0.1 MHz to 30 MHz | 15 | 17 | 22 | | | | | S <sub>EMI</sub> | | | 30 MHz to 130 MHz | 18 | 22 | 16 | dΒμV | | | | OEMI . | | | 130 MHz to 1 GHz | -1 | 3 | 5 | | | | | | | 1752/3 | | 2 | 2.5 | 2.5 | - | | | <sup>1.</sup> Data based on characterization results, not tested in production. #### Absolute maximum ratings (electrical sensitivity) Based on two different tests (ESD and LU) using specific measurement methods, the product is stressed to determine its performance in terms of electrical sensitivity. For more details, refer to the application note AN1181. #### Electrostatic discharge (ESD) Electrostatic discharges (3 positive then 3 negative pulses separated by 1 second) are applied to the pins of each sample according to each pin combination. The sample size depends on the number of supply pins in the device (3 parts\*(n+1) supply pin). This test conforms to the JESD22-A114A/A115A standard. For more details, refer to the application note AN1181. Maximum **Symbol Conditions** Class Unit **Ratings** value<sup>(1)</sup> $T_A = 25$ °C, conforming to Electrostatic discharge voltage ЗА V<sub>ESD(HBM)</sub> 4000 (Human body model) JESD22-A114 $T_A = 25$ °C, conforming to Electrostatic discharge voltage V<sub>ESD(CDM)</sub> 3 500 ٧ (Charge device model) JESD22-C101 $T_A = 25$ °C, conforming to Electrostatic discharge voltage В V<sub>ESD(MM)</sub> 200 (Machine model) JESD22-A115 Table 40. ESD absolute maximum ratings #### Static latch-up Two complementary static tests are required on 10 parts to assess the latch-up performance. - A supply overvoltage (applied to each power supply pin) and - A current injection (applied to each input, output and configurable I/O pin) are performed on each sample. This test conforms to the EIA/JESD 78 IC latch-up standard. For more details, refer to the application note AN1181. Table 41. Electrical sensitivities | Symbol | Parameter | Conditions | Class <sup>(1)</sup> | |--------|-----------------------|-------------------------|----------------------| | | | T <sub>A</sub> = 25 °C | Α | | LU | Static latch-up class | T <sub>A</sub> = 85 °C | Α | | LO | | T <sub>A</sub> = 125 °C | Α | | | | T <sub>A</sub> = 145 °C | Α | Class description: A Class is an STMicroelectronics internal specification. All its limits are higher than the JEDEC specifications, that means when a device belongs to class A it exceeds the JEDEC standard. B class strictly covers all the JEDEC criteria (international standard). **47/** <sup>1.</sup> Data based on characterization results, not tested in production ### 11.4 Thermal characteristics The maximum chip junction temperature (T<sub>Jmax</sub>) must never exceed the values given in *Table 17: General operating conditions on page 57*. The maximum chip-junction temperature, T<sub>Jmax</sub>, in degrees Celsius, may be calculated using the following equation: $$T_{Jmax} = T_{Amax} + (P_{Dmax} \times \Theta_{JA})$$ #### Where: - T<sub>Amax</sub> is the maximum ambient temperature in °C - $\Theta_{IA}$ is the package junction-to-ambient thermal resistance in $^{\circ}$ C/W - $P_{Dmax}$ is the sum of $P_{INTmax}$ and $P_{I/Omax}$ ( $P_{Dmax} = P_{INTmax} + P_{I/Omax}$ ) - P<sub>INTmax</sub> is the product of I<sub>DD</sub> and V<sub>DD</sub>, expressed in Watts. This is the maximum chip internal power. - P<sub>I/Omax</sub> represents the maximum power dissipation on output pins Where: $P_{I/Omax} = \Sigma \ (V_{OL}{}^*I_{OL}) + \Sigma ((V_{DD}{}^-V_{OH})^*I_{OH}),$ taking into account the actual $V_{OL}/I_{OL}$ and $V_{OH}/I_{OH}$ of the I/Os at low and high level in the application. Table 42. Thermal characteristics<sup>(1)</sup> | Symbol | Parameter | Value | Unit | |-------------------|----------------------------------------------------------|-------|------| | $\Theta_{\sf JA}$ | Thermal resistance junction-ambient LQFP 80 - 14 x 14 mm | | °C/W | | $\Theta_{\sf JA}$ | Thermal resistance junction-ambient LQFP 64 - 10 x 10 mm | 46 | °C/W | | $\Theta_{\sf JA}$ | Thermal resistance junction-ambient LQFP 48 - 7 x 7 mm | 57 | °C/W | | $\Theta_{\sf JA}$ | Thermal resistance junction-ambient LQFP 32 - 7 x 7 mm | 59 | °C/W | Thermal resistances are based on JEDEC JESD51-2 with 4-layer PCB in a natural convection environment ### 11.4.1 Reference document JESD51-2 integrated circuits thermal test method environment conditions - natural convection (still air). Available from www.jedec.org. ### 11.4.2 Selecting the product temperature range When ordering the microcontroller, the temperature range is specified in the order code (see *Figure 47: STM8A order codes on page 95*). The following example shows how to calculate the temperature range needed for a given application. Assuming the following application conditions: Maximum ambient temperature $T_{Amax}$ = 82 °C (measured according to JESD51-2), $I_{DDmax}$ = 8 mA, $V_{DD}$ = 5 V, maximum 20 I/Os used at the same time in output at low level with $I_{OL}$ = 8 mA, $V_{OL}$ = 0.4 V $$P_{INTmax} = 8 \text{ mA x 5 V} = 400 \text{ mW}$$ $P_{IOmax} = 20 \text{ x 8 mA x 0.4 V} = 64 \text{ mW}$ This gives: P<sub>INTmax</sub> = 400 mW and P<sub>IOmax</sub> 64 mW: $$P_{Dmax} = 400 \text{ mW} + 64 \text{ mW}$$ Thus: P<sub>Dmax</sub> = 464 mW Using the values obtained in *Table 42: Thermal characteristics on page 88* T<sub>Jmax</sub> is calculated as follows: For LQFP64 46°C/W $T_{Jmax} = 82^{\circ} C + (46^{\circ} C/W \times 464 \text{ mW}) = 82^{\circ}C + 21^{\circ}C = 103^{\circ} C$ This is within the range of the suffix B version parts (-40 < T<sub>.I</sub> < 105 $^{\circ}$ C). Parts must be ordered at least with the temperature range suffix B. # 12 Package characteristics To meet environmental requirements, ST offers these devices in ECOPACK<sup>®</sup> packages. These packages have a lead-free second level interconnect. The category of second level interconnect is marked on the package and on the inner box label, in compliance with JEDEC Standard JESD97. The maximum ratings related to soldering conditions are also marked on the inner box label. ECOPACK is an ST trademark. ECOPACK® specifications are available at www.st.com. # 12.1 Package mechanical data Figure 43. 80-pin low profile quad flat package (14 x 14) Table 43. 80-pin low profile quad flat package mechanical data | Dim | | mm | | | inches <sup>(1)</sup> | | |------|------|-------|------|--------|-----------------------|--------| | Dim. | Min | Тур | Max | Min | Тур | Max | | Α | | | 1.60 | | | 0.0630 | | A1 | 0.05 | | 0.15 | 0.0020 | | 0.0059 | | A2 | 1.35 | 1.40 | 1.45 | 0.0531 | 0.0551 | 0.0571 | | b | 0.22 | 0.32 | 0.38 | 0.0087 | 0.0126 | 0.0150 | | С | 0.09 | | 0.20 | 0.0035 | | 0.0079 | | D | | 16.00 | | | 0.6299 | | | D1 | | 14.00 | | | 0.5512 | | | E | | 16.00 | | | 0.6299 | | | E1 | | 14.00 | | | 0.5512 | | | е | | 0.65 | | | 0.0256 | | | θ | 0° | 3.5° | 7° | 0° | 3.5° | 7° | | L | 0.45 | 0.60 | 0.75 | 0.0177 | 0.0236 | 0.0295 | | L1 | | 1.00 | | | 0.0394 | | <sup>1.</sup> Values in inches are converted from mm and rounded to 4 decimal digits Figure 44. 64-pin low profile quad flat package (10 x 10) 1. Available only for STM8A products with up to 64 Kbytes Flash Table 44. 64-pin low profile quad flat package mechanical data | Dim. | mm | | | inches <sup>(1)</sup> | | | |------|------|-------|------|-----------------------|--------|--------| | | Min | Тур | Max | Min | Тур | Max | | А | | | 1.60 | | | 0.0630 | | A1 | 0.05 | | 0.15 | 0.0020 | | 0.0059 | | A2 | 1.35 | 1.40 | 1.45 | 0.0531 | 0.0551 | 0.0571 | | b | 0.17 | 0.22 | 0.27 | 0.0067 | 0.0087 | 0.0106 | | С | 0.09 | | 0.20 | 0.0035 | | 0.0079 | | D | | 12.00 | | | 0.4724 | | | D1 | | 10.00 | | | 0.3937 | | | E | | 12.00 | | | 0.4724 | | | E1 | | 10.00 | | | 0.3937 | | | е | | 0.50 | | | 0.0197 | | | θ | 0° | 3.5° | 7° | 0° | 3.5° | 7° | | L | 0.45 | 0.60 | 0.75 | 0.0177 | 0.0236 | 0.0295 | | L1 | | 1.00 | | | 0.0394 | | 1. Values in inches are converted from mm and rounded to 4 decimal digits Figure 45. 48-pin low profile quad flat package (7 x 7) Table 45. 48-pin low profile quad flat package mechanical data | Dim. | mm | | | inches <sup>(1)</sup> | | | |------|------|------|------|-----------------------|--------|--------| | | Min | Тур | Max | Min | Тур | Max | | Α | | | 1.60 | | | 0.0630 | | A1 | 0.05 | | 0.15 | 0.0020 | | 0.0059 | | A2 | 1.35 | 1.40 | 1.45 | 0.0531 | 0.0551 | 0.0571 | | b | 0.17 | 0.22 | 0.27 | 0.0067 | 0.0087 | 0.0106 | | С | 0.09 | | 0.20 | 0.0035 | | 0.0079 | | D | | 9.00 | | | 0.3543 | | | D1 | | 7.00 | | | 0.2756 | | | E | | 9.00 | | | 0.3543 | | | E1 | | 7.00 | | | 0.2756 | | | е | | 0.50 | | | 0.0197 | | | θ | 0° | 3.5° | 7° | 0° | 3.5° | 7° | | L | 0.45 | 0.60 | 0.75 | 0.0177 | 0.0236 | 0.0295 | | L1 | | 1.00 | | | 0.0394 | | <sup>1.</sup> Values in inches are converted from mm and rounded to 4 decimal digits Figure 46. 32-pin low profile quad flat package (7 x 7) Table 46. 32-pin low profile quad flat package mechanical data | Dim. | mm | | | inches <sup>(1)</sup> | | | |------|------|------|------|-----------------------|--------|--------| | | Min | Тур | Max | Min | Тур | Max | | Α | | | 1.60 | | | 0.0630 | | A1 | 0.05 | | 0.15 | 0.0020 | | 0.0059 | | A2 | 1.35 | 1.40 | 1.45 | 0.0531 | 0.0551 | 0.0571 | | b | 0.30 | 0.37 | 0.45 | 0.0118 | 0.0146 | 0.0177 | | С | 0.09 | | 0.20 | 0.0035 | | 0.0079 | | D | | 9.00 | | | 0.3543 | | | D1 | | 7.00 | | | 0.2756 | | | Е | | 9.00 | | | 0.3543 | | | E1 | | 7.00 | | | 0.2756 | | | е | | 0.80 | | | 0.0315 | | | θ | 0° | 3.5° | 7° | 0° | 3.5° | 7° | | L | 0.45 | 0.60 | 0.75 | 0.0177 | 0.0236 | 0.0295 | | L1 | | 1.00 | | | 0.0394 | | <sup>1.</sup> Values in inches are converted from mm and rounded to 4 decimal digits # 13 Ordering information Figure 47. STM8A order codes 1. Customer specific FASTROM code # 14 STM8 development tools Development tools for the STM8A microcontrollers include the - STice emulation system offering tracing and code profiling - STVD high-level language debugger including assembler and visual development environment - seamless integration of third party C compilers - STVP Flash programming software In addition, the STM8A comes with starter kits, evaluation boards and low-cost in-circuit debugging/programming tools. ## 14.1 Emulation and in-circuit debugging tools The STM8 tool line includes the STice emulation system offering a complete range of emulation and in-circuit debugging features on a platform that is designed for versatility and cost-effectiveness. In addition, STM8A application development is supported by a low-cost in-circuit debugger/programmer. The STice is the fourth generation of full-featured emulators from STMicroelectronics. It offers new advanced debugging capabilities including tracing, profiling and code coverage analysis to help detect execution bottlenecks and dead code. In addition, STice offers in-circuit debugging and programming of STM8A microcontrollers via the STM8 single wire interface module (SWIM), which allows non-intrusive debugging of an application while it runs on the target microcontroller. For improved cost effectiveness, STice is based on a modular design that allows you to order exactly what you need to meet your development requirements and to adapt your emulation system to support existing and future ST microcontrollers. #### STice key features - Program and data trace recording up to 128 K records - Advanced breakpoints with up to 4 levels of conditions - Data breakpoints - Real-time read/write of all device ressources during emulation - Occurrence and time profiling and code coverage analysis (new features) - In-circuit debugging/programming via SWIM protocol - 8-bit probe analyzer - 1 input and 2 output triggers - USB 2.0 high speed interface to host PC - Power supply follower managing application voltages between 1.62 to 5.5 V - Modularity that allows you to specify the components you need to meet your development requirements and adapt to future requirements - Supported by free software tools that include integrated development environment (IDE), programming software interface and assembler for STM8 #### 14.2 Software tools STM8 development tools are supported by a complete, free software package from STMicroelectronics that includes ST visual develop (STVD) IDE and the ST visual programmer (STVP) software interface. STVD provides seamless integration of the Cosmic C compiler for STM8, which is available in a free version that outputs up to 16 Kbytes of code. #### 14.2.1 STM8 toolset **STM8 toolset** with STVD integrated development environment and STVP programming software is available for free download at www.st.com/mcu. This package includes: ST visual develop – Full-featured integrated development environment from ST, featuring - Seamless integration of C and ASM toolsets - Full-featured debugger - Project management - Syntax highlighting editor - Integrated programming interface - Support of advanced emulation features for STice such as code profiling and coverage **ST visual programmer (STVP)** – Easy-to-use, unlimited graphical interface allowing read, write and verify of your STM8A microcontroller's Flash memory. STVP also offers project mode for saving programming configurations and automating programming sequences. ### 14.2.2 C and assembly toolchains Control of C and assembly toolchains is seamlessly integrated into the STVD integrated development environment, making it possible to configure and control the building of your application directly from an easy-to-use graphical interface. Available toolchains include: - **C compiler for STM8** Available in a free version that outputs up to 16 Kbytes of code. For more information, see www.cosmic-software.com, www.raisonance.com - STM8 assembler linker Free assembly toolchain included in the STM8 toolset, which allows you to assemble and link your application source code. # 14.3 Programming tools During the development cycle, STice provides in-circuit programming of the STM8A Flash microcontroller on your application board via the SWIM protocol. Additional tools are to include a low-cost in-circuit programmer as well as ST socket boards, which provide dedicated programming platforms with sockets for programming your STM8A. For production environments, programmers will include a complete range of gang and automated programming solutions from third-party tool developers already supplying programmers for the STM8 family. # 15 Revision history Table 47. Document revision history | Date | Revision | Changes | |-------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-Jan-2008 | Rev 1 | Initial release | | 22-Aug-2008 | Rev 2 | Added 'H' products to the datasheet (Flash no EEPROM). Features on page 1: Updated Memories, Reset and supply management, Communication interfaces and I/Os; reduced wakeup pins by 1. Table 1: Removed STM8AF6168, STM8AF6148, STM8AF6166, STM8AF6146, STM8AF5168. STM8AF5168. STM8AF5166. Section 1, Section 5, Section 6.2.1, Table 13, and Section 10: Updated reference documentation: RM0009, PM0047, and UM0470. Section 2: Added information about peak performance. Section 3: Removed STM8A common features table. Table 2: Removed STM8AF5186T, STM8AF5176T, STM8AF5168T, and STM8AF5166T. Table 3: Removed STM8AF6168T, STM8AF5166T, STM8AF6146T. Section 5: Made minor content changes and improved readability and layout. Section 5.4.3: Major modification, TMU included. Section 5.6.3: LSI as CPU clock added. Section 5.6.4. Section 5.6.5: Maximum frequency conditional 32 Kbyte/128 Kbyte. Section 5.6.5: Scan for 128 Kbyte removed. Section 5.9. Section 5.9.3: SPI 10 Mb/s. Figure 3, Figure 4, and Figure 5: Amended footnote 1. Table 5: HS output changed from 20 mA to 8 mA. Section 7: Corrected Figure 7: Register and memory map; removed address list; added Table 7. Section 11.3.1 Note on typical/WC values added. Table 10: Replaced the source blocks 'simple USART', 'very low-end timer (timer 4)', and 'EEPROM' with 'LINUART', 'timer4' and 'reserved' respectively, added TMU registers. Table 12: Updated OPT6 and NOPT6, added OPT7 to 17 (TMU, BL) Table 13: Updated OPT6 added OPT7 to 16 (TMU). Table 17: Added parameter 'voltage and current operating conditions'. Table 17: Added parameter 'voltage and current operating conditions'. Table 19: Replaced. Table 20: Amended maximum data and footnotes. Table 21: Replaced. Table 22: Added and amended I <sub>DD(RUN)</sub> data; amended I <sub>DD(WFI)</sub> data; amended footnotes. Table 23: Filled in, amended maximum data and footnotes. Table 24: Modified I <sub>HSE</sub> ext data and added V <sub>HSEdnI</sub> data. | Table 47. Document revision history (continued) | Date | Revision | Changes | |-------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 22-Aug-2008 | Rev 2<br>cont'd | Table 26: Removed ACC <sub>HSI</sub> parameters and replaced with ACC <sub>HS</sub> parameters; amended data and footnotes. Table 28: Amended data. Table 29: Updated names and data of N <sub>RW</sub> and t <sub>RET</sub> parameters. Table 30: Added V <sub>OH</sub> and V <sub>OL</sub> parameters; Updated I <sub>lkg ana</sub> parameter. Removed: Output driving current (standard ports), Output driving current (true open drain ports), and Output driving current (high sink ports). Table 35: Updated f <sub>ADC</sub> , t <sub>S</sub> , and t <sub>CONV</sub> data. Table 36: Removed the 4-MHz condition from all parameters. Table 37: Removed the 4-MHz condition from all parameters; updated footnote 1 and removed footnote 2. Table 41: Added data for T <sub>A</sub> = 145 °C. Figure 47: Updated memory size, pin count and package type information. | #### Please Read Carefully: Information in this document is provided solely in connection with ST products. STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, modifications or improvements, to this document, and the products and services described herein at any time, without notice. All ST products are sold pursuant to ST's terms and conditions of sale. Purchasers are solely responsible for the choice, selection and use of the ST products and services described herein, and ST assumes no liability whatsoever relating to the choice, selection or use of the ST products and services described herein. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted under this document. If any part of this document refers to any third party products or services it shall not be deemed a license grant by ST for the use of such third party products or services, or any intellectual property contained therein or considered as a warranty covering the use in any manner whatsoever of such third party products or services or any intellectual property contained therein. UNLESS OTHERWISE SET FORTH IN ST'S TERMS AND CONDITIONS OF SALE ST DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY WITH RESPECT TO THE USE AND/OR SALE OF ST PRODUCTS INCLUDING WITHOUT LIMITATION IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE (AND THEIR EQUIVALENTS UNDER THE LAWS OF ANY JURISDICTION), OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT. UNLESS EXPRESSLY APPROVED IN WRITING BY AN AUTHORIZED ST REPRESENTATIVE, ST PRODUCTS ARE NOT RECOMMENDED, AUTHORIZED OR WARRANTED FOR USE IN MILITARY, AIR CRAFT, SPACE, LIFE SAVING, OR LIFE SUSTAINING APPLICATIONS, NOR IN PRODUCTS OR SYSTEMS WHERE FAILURE OR MALFUNCTION MAY RESULT IN PERSONAL INJURY, DEATH, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE. ST PRODUCTS WHICH ARE NOT SPECIFIED AS "AUTOMOTIVE GRADE" MAY ONLY BE USED IN AUTOMOTIVE APPLICATIONS AT USER'S OWN RISK. Resale of ST products with provisions different from the statements and/or technical features set forth in this document shall immediately void any warranty granted by ST for the ST product or service described herein and shall not create or extend in any manner whatsoever, any liability of ST. ST and the ST logo are trademarks or registered trademarks of ST in various countries. Information in this document supersedes and replaces all information previously supplied. The ST logo is a registered trademark of STMicroelectronics. All other names are the property of their respective owners. © 2008 STMicroelectronics - All rights reserved STMicroelectronics group of companies Australia - Belgium - Brazil - Canada - China - Czech Republic - Finland - France - Germany - Hong Kong - India - Israel - Italy - Japan - Malaysia - Malta - Morocco - Singapore - Spain - Sweden - Switzerland - United Kingdom - United States of America www.st.com