## STM8AF6x26/4x/66/68 Automotive 8-bit MCU, with up to 32 Kbytes Flash, data EEPROM, 10-bit ADC, timers, LIN, SPI, I2C, 3 to 5.5 V Datasheet - production data #### **Features** #### ■ Core - Max f<sub>CPU</sub>: 16 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 - Flash Program memory: 16 to 32 Kbytes Flash; data retention 20 years at 55 °C after 1 kcycle - Data memory: 0.5 to 1 Kbyte true data EEPROM; endurance 300 kcycles - RAM: 1 to 2 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 - Wait/auto-wakeup/Halt low-power modes with user definable clock gating - Low consumption power-on and powerdown reset #### ■ Interrupt management - Nested interrupt controller with 32 vectors - Up to 34 external interrupts on 5 vectors #### ■ Timers - Up to 2 general purpose 16-bit PWM timers with up to 3 CAPCOM channels each (IC, OC or PWM) - Advanced control timer: 16-bit, 4 CAPCOM channels, 3 complementary outputs, deadtime insertion and flexible synchronization - 8-bit AR basic timer with 8-bit prescaler - Auto-wakeup timer - Window and independent watchdog timers - Communication interfaces - LINUART - LIN 2.1 compliant, master/slave modes with automatic resynchronization - SPI interface up to 10 Mbit/s or f<sub>MASTER</sub>/2 - I<sup>2</sup>C interface up to 400 Kbit/s #### ■ Analog-to-digital converter (ADC) - 10-bit accuracy, 2LSB TUE accuracy, 2LSB TUE linearity ADC and up to 10 multiplexed channels with individual data buffer - Analog watchdog, scan and continuous sampling mode #### ■ I/Os - Up to 38 user pins including 10 HS I/Os - Highly robust I/O design, immune against current injection - Operating temperature up to 150 °C - Qualification conforms to AEC-Q100 rev G #### Table 1. Device summary<sup>(1)</sup> Part numbers: STM8AF622x/4x STM8AF6266/68 STM8AF6268, STM8AF6248, STM8AF6266, STM8AF6246, STM8AF6226 Part numbers: STM8AF612x/4x(2) STM8AF6166/68(2) ${\tt STM8AF6168, STM8AF6148, STM8AF6166, STM8AF6146, STM8AF6126}$ - In the order code, 'F' applies to devices with Flash program memory and data EEPROM while 'H' refers to devices with Flash program memory only. 'F' is replaced by 'P' for devices with FASTROM (see Tables 2 and 3, and Figure 47). - 2. Not recommended for new design. # **Contents** | 1 | Introd | luction | | . 8 | |---|--------|-----------|-----------------------------------------------------|------| | 2 | Descr | iption . | | . 9 | | 3 | Produ | ıct line- | up | 10 | | 4 | Block | diagrar | n | 11 | | 5 | Produ | ict over | view | 12 | | | 5.1 | STM8A | central processing unit (CPU) | 12 | | | | 5.1.1 | Architecture and registers | . 12 | | | | 5.1.2 | Addressing | . 12 | | | | 5.1.3 | Instruction set | . 12 | | | 5.2 | Single w | vire interface module (SWIM) and debug module (DM) | 13 | | | | 5.2.1 | SWIM | . 13 | | | | 5.2.2 | Debug module | . 13 | | | 5.3 | Interrupt | t controller | 13 | | | 5.4 | Flash pr | ogram and data EEPROM | 13 | | | | 5.4.1 | Architecture | . 13 | | | | 5.4.2 | Write protection (WP) | . 14 | | | | 5.4.3 | Protection of user boot code (UBC) | . 14 | | | | 5.4.4 | Read-out protection (ROP) | . 14 | | | 5.5 | Clock co | ontroller | 15 | | | | 5.5.1 | Features | . 15 | | | | 5.5.2 | 16 MHz high-speed internal RC oscillator (HSI) | . 15 | | | | 5.5.3 | 128 kHz low-speed internal RC oscillator (LSI) | . 16 | | | | 5.5.4 | 16 MHz high-speed external crystal oscillator (HSE) | . 16 | | | | 5.5.5 | External clock input | . 16 | | | | 5.5.6 | Clock security system (CSS) | . 16 | | | 5.6 | Low-pov | ver operating modes | 17 | | | 5.7 | Timers | | 17 | | | | 5.7.1 | Watchdog timers | . 17 | | | | 5.7.2 | Auto-wakeup counter | . 18 | | | | 5.7.3 | Beeper | . 18 | | | | 5.7.4 | Advanced control and general purpose timers | 18 | |---------|----------------------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------| | | | 5.7.5 | Basic timer | 19 | | | 5.8 | Analog | -to-digital converter (ADC) | . 20 | | | 5.9 | Comm | unication interfaces | . 20 | | | | 5.9.1 | Serial peripheral interface (SPI) | 21 | | | | 5.9.2 | Inter integrated circuit (I <sup>2</sup> C) interface | 21 | | | | 5.9.3 | Universal asynchronous receiver/transmitter with LIN support (LINUART) | 22 | | | 5.10 | Input/o | utput specifications | . 23 | | 6 | Pino | uts and | pin description | . 24 | | | 6.1 | Packag | ge pinouts | . 24 | | | 6.2 | Alterna | te function remapping | . 28 | | 7 | Mem | ory and | l register map | . 29 | | | 7.1 | Memor | y map | . 29 | | | 7.2 | Registe | er map | . 30 | | 8 | Interi | runt tah | le | 40 | | 0 | iiiteii | upt tab | MC | | | | | | S | | | 9 | Optic | on bytes | S | . 41 | | 9 | Optio<br>Elect | on bytes | aracteristics | . 41 | | 9 | Optic | on bytes | s | . <b>41</b><br>. <b>46</b> | | 9 | Optio<br>Elect | on bytes<br>rical ch | aracteristics | . <b>41</b> . <b>46</b> . 46 | | 9 | Optio<br>Elect | rical ch<br>Parame | aracteristics eter conditions Minimum and maximum values | . <b>41</b> . <b>46</b> . 46 . 46 | | 9 | Optio<br>Elect | rical ch<br>Parame<br>10.1.1<br>10.1.2 | aracteristics eter conditions Minimum and maximum values Typical values | . 41 . 46 . 46 . 46 . 46 | | 9 | Optio<br>Elect | Parame<br>10.1.1<br>10.1.2<br>10.1.3 | aracteristics eter conditions Minimum and maximum values Typical values Typical curves | . 41<br>. 46<br>. 46<br>. 46<br>. 46<br>. 46 | | 9 | Optio<br>Elect | Parame<br>10.1.1<br>10.1.2<br>10.1.3<br>10.1.4<br>10.1.5 | aracteristics eter conditions Minimum and maximum values Typical values Typical curves Loading capacitor | . 41 . 46 . 46 . 46 . 46 . 46 . 47 | | 9 | Option Electron 10.1 | Parame<br>10.1.1<br>10.1.2<br>10.1.3<br>10.1.4<br>10.1.5<br>Absolu | aracteristics eter conditions Minimum and maximum values Typical values Typical curves Loading capacitor Pin input voltage | . 41 . 46 . 46 . 46 . 46 . 47 | | 9 | Option Electron 10.1 | Parame<br>10.1.1<br>10.1.2<br>10.1.3<br>10.1.4<br>10.1.5<br>Absolu | aracteristics eter conditions Minimum and maximum values Typical values Typical curves Loading capacitor Pin input voltage te maximum ratings | . 41 . 46 . 46 . 46 . 46 . 47 . 47 | | 9 | Option Electron 10.1 | Parame<br>10.1.1<br>10.1.2<br>10.1.3<br>10.1.4<br>10.1.5<br>Absolu<br>Operat | aracteristics eter conditions Minimum and maximum values Typical values Typical curves Loading capacitor Pin input voltage te maximum ratings ing conditions | . 41 . 46 . 46 . 46 . 46 . 47 . 47 . 49 . 51 | | 9 | Option Electron 10.1 | Parame<br>10.1.1<br>10.1.2<br>10.1.3<br>10.1.4<br>10.1.5<br>Absolu<br>Operat<br>10.3.1 | aracteristics eter conditions Minimum and maximum values Typical values Typical curves Loading capacitor Pin input voltage te maximum ratings ing conditions VCAP external capacitor | . 41 . 46 . 46 . 46 . 47 . 47 . 49 . 51 | | 9 | Option Electron 10.1 | Parame<br>10.1.1<br>10.1.2<br>10.1.3<br>10.1.4<br>10.1.5<br>Absolu<br>Operat<br>10.3.1<br>10.3.2 | seter conditions Minimum and maximum values Typical values Typical curves Loading capacitor Pin input voltage te maximum ratings ing conditions VCAP external capacitor Supply current characteristics | . 41 . 46 . 46 . 46 . 47 . 47 . 49 . 51 . 51 | | 9 | Option Electron 10.1 | Parame<br>10.1.1<br>10.1.2<br>10.1.3<br>10.1.4<br>10.1.5<br>Absolu<br>Operat<br>10.3.1<br>10.3.2<br>10.3.3 | Agracteristics eter conditions Minimum and maximum values Typical values Typical curves Loading capacitor Pin input voltage te maximum ratings ing conditions VCAP external capacitor Supply current characteristics External clock sources and timing characteristics | . 41 . 46 . 46 . 46 . 46 . 47 . 47 . 49 . 51 . 51 . 54 | | 9<br>10 | Option Electron 10.1 | Parame<br>10.1.1<br>10.1.2<br>10.1.3<br>10.1.4<br>10.1.5<br>Absolu<br>Operat<br>10.3.1<br>10.3.2<br>10.3.3<br>10.3.4 | eter conditions Minimum and maximum values Typical values Typical curves Loading capacitor Pin input voltage te maximum ratings ing conditions VCAP external capacitor Supply current characteristics External clock sources and timing characteristics Internal clock sources and timing characteristics | . 41 . 46 . 46 . 46 . 47 . 47 . 49 . 51 . 54 . 56 . 58 | | | | 10.3.7 | Reset pin characteristics | |----|-------|-----------|--------------------------------------------| | | | 10.3.8 | TIM 1, 2, 3, and 4 timer specifications | | | | 10.3.9 | SPI serial peripheral interface | | | | 10.3.10 | I <sup>2</sup> C interface characteristics | | | | 10.3.11 | 10-bit ADC characteristics | | | | 10.3.12 | EMC characteristics | | | 10.4 | Therma | al characteristics | | | | 10.4.1 | Reference document74 | | | | 10.4.2 | Selecting the product temperature range | | 11 | Pack | age cha | racteristics | | | 11.1 | Packag | e mechanical data76 | | 12 | Orde | ring info | ormation 81 | | 13 | STM | 3 develo | pment tools | | | 13.1 | Emulati | on and in-circuit debugging tools | | | | 13.1.1 | STice key features82 | | | 13.2 | Softwar | re tools | | | | 13.2.1 | STM8 toolset | | | | 13.2.2 | C and assembly toolchains83 | | | 13.3 | Prograr | mming tools | | 14 | Revis | sion his | tory | # **List of tables** | Table 1. | Device summary | 1 | |-----------|------------------------------------------------------------------------------|----| | Table 2. | STM8AF62xx product line-up | | | Table 3. | STM8AF/H61xx product line-up | | | Table 4. | Peripheral clock gating bit assignments in CLK_PCKENR1/2 registers | 16 | | Table 5. | Advanced control and general purpose timers | | | Table 6. | TIM4 | | | Table 7. | ADC naming | 20 | | Table 8. | Communication peripheral naming correspondence | 20 | | Table 9. | Legend/abbreviation | | | Table 10. | STM8AF61xx/62xx (32 Kbytes) microcontroller pin description | | | Table 11. | Memory model for the devices covered in this datasheet | | | Table 12. | I/O port hardware register map | | | Table 13. | General hardware register map | | | Table 14. | CPU/SWIM/debug module/interrupt controller registers | | | Table 15. | Temporary memory unprotection registers | | | Table 16. | STM8A interrupt table | | | Table 17. | Option bytes | 41 | | Table 18. | Option byte description | | | Table 19. | Voltage characteristics | 47 | | Table 20. | Current characteristics | 48 | | Table 21. | Thermal characteristics | 48 | | Table 22. | Operating lifetime | 48 | | Table 23. | General operating conditions | 49 | | Table 24. | Operating conditions at power-up/power-down | 50 | | Table 25. | Total current consumption in Run, Wait and Slow mode. | | | | General conditions for V <sub>DD</sub> apply, T <sub>A</sub> = -40 to 150 °C | 51 | | Table 26. | Total current consumption in Halt and Active-halt modes. | | | | General conditions for V <sub>DD</sub> apply, T <sub>A</sub> = -40 to 55 °C | | | Table 27. | Oscillator current consumption | | | Table 28. | Programming current consumption | | | Table 29. | Typical peripheral current consumption V <sub>DD</sub> = 5.0 V | 53 | | Table 30. | HSE user external clock characteristics | | | Table 31. | HSE oscillator characteristics | | | Table 32. | HSI oscillator characteristics | | | Table 33. | LSI oscillator characteristics | | | Table 34. | Flash program memory/data EEPROM memory | | | Table 35. | Flash program memory | | | Table 36. | Data memory | | | Table 37. | I/O static characteristics | | | Table 38. | NRST pin characteristics | | | Table 39. | TIM 1, 2, 3, and 4 electrical specifications | | | Table 40. | SPI characteristics | | | Table 41. | I <sup>2</sup> C characteristics | | | Table 42. | ADC characteristics | | | Table 43. | ADC accuracy for V <sub>DDA</sub> = 5 V | | | Table 44. | EMS data | | | Table 45. | EMI data | | | Table 46. | ESD absolute maximum ratings | 72 | ### STM8AF61xx, STM8AF62xx #### List of tables | Table 47. | Electrical sensitivities | . 73 | |-----------|---------------------------------------------------------------|------| | Table 48. | Thermal characteristics | . 74 | | | VFQFPN 32-lead very thin fine pitch quad flat no-lead package | | | | mechanical data | . 76 | | Table 50. | LQFP 48-pin low profile quad flat package mechanical data | . 77 | | Table 51. | LQFP 32-pin low profile quad flat package mechanical data | . 79 | | Table 52. | Document revision history | . 85 | # **List of figures** | Figure 1. | STM8A block diagram | | |------------|------------------------------------------------------------------------------------------------|----| | Figure 2. | Flash memory organization of STM8A products | 14 | | Figure 3. | VFQFPN/LQFP 32-pin pinout | | | Figure 4. | LQFP 48-pin pinout | 25 | | Figure 5. | Register and memory map of STM8A products | 29 | | Figure 6. | Pin loading conditions | 46 | | Figure 7. | Pin input voltage | 47 | | Figure 8. | f <sub>CPUmax</sub> versus V <sub>DD</sub> | 50 | | Figure 9. | External capacitor C <sub>FXT</sub> | 51 | | Figure 10. | Typ. I <sub>DD(RUN)HSE</sub> vs. V <sub>DD</sub> @f <sub>CPU</sub> = 16 MHz, peripheral = on | 53 | | Figure 11. | Typ. $I_{DD(RUN)HSE}$ vs. $f_{CPU}$ @ $V_{DD} = 5.0$ V, peripheral = on | 53 | | Figure 12. | Typ. I <sub>DD(RUN)HSI</sub> vs. V <sub>DD</sub> @ f <sub>CPU</sub> = 16 MHz, peripheral = off | 54 | | Figure 13. | Typ. I <sub>DD(WFI)HSE</sub> vs. V <sub>DD</sub> @ f <sub>CPU</sub> = 16 MHz, peripheral = on | 54 | | Figure 14. | Typ. $I_{DD(WFI)HSE}$ vs. $f_{CPU}$ @ $V_{DD} = 5.0$ V, peripheral = on | | | Figure 15. | Typ. I <sub>DD(WFI)HSI</sub> vs. V <sub>DD</sub> @ f <sub>CPU</sub> = 16 MHz, peripheral = off | 54 | | Figure 16. | HSE external clock source | | | Figure 17. | HSE oscillator circuit diagram | 55 | | Figure 18. | Typical HSI frequency vs V <sub>DD</sub> | 57 | | Figure 19. | Typical LSI frequency vs V <sub>DD</sub> | 57 | | Figure 20. | Typical V <sub>IL</sub> and V <sub>IH</sub> vs V <sub>DD</sub> @ four temperatures | 60 | | Figure 21. | Typical pull-up resistance R <sub>PU</sub> vs V <sub>DD</sub> @ four temperatures | 60 | | Figure 22. | Typical pull-up current I <sub>pu</sub> vs V <sub>DD</sub> @ four temperatures | 61 | | Figure 23. | Typ. $V_{OL}$ @ $V_{DD}$ = 3.3 $V$ (standard ports) | | | Figure 24. | Typ. $V_{OL}$ @ $V_{DD}$ = 5.0 V (standard ports) | 61 | | Figure 25. | Typ. V <sub>OL</sub> @ V <sub>DD</sub> = 3.3 V (true open drain ports) | 61 | | Figure 26. | Typ. V <sub>OL</sub> @ V <sub>DD</sub> = 5.0 V (true open drain ports) | 61 | | Figure 27. | Typ. $V_{OL}$ @ $V_{DD}$ = 3.3 V (high sink ports) | 62 | | Figure 28. | Typ. $V_{OL}$ @ $V_{DD}$ = 5.0 V (high sink ports) | 62 | | Figure 29. | Typ. V <sub>DD</sub> - V <sub>OH</sub> @ V <sub>DD</sub> = 3.3 V (standard ports) | 62 | | Figure 30. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 5.0 V (standard ports) | 62 | | Figure 31. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 3.3 V (high sink ports) | 62 | | Figure 32. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 5.0 V (high sink ports) | 62 | | Figure 33. | Typical NRST V <sub>IL</sub> and V <sub>IH</sub> vs V <sub>DD</sub> @ four temperatures | 63 | | Figure 34. | Typical NRST pull-up resistance R <sub>PU</sub> vs V <sub>DD</sub> | | | Figure 35. | Typical NRST pull-up current I <sub>pu</sub> vs V <sub>DD</sub> | 64 | | Figure 36. | Recommended reset pin protection | | | Figure 37. | SPI timing diagram where slave mode and CPHA = 0 | | | Figure 38. | SPI timing diagram where slave mode and CPHA = 1 | 66 | | Figure 39. | SPI timing diagram - master mode | | | Figure 40. | Typical application with ADC | 69 | | Figure 41. | ADC accuracy characteristics | 70 | | Figure 42. | VFQFPN 32-lead very thin fine pitch quad flat no-lead package (5 x 5) | 76 | | Figure 43. | LQFP 48-pin low profile quad flat package (7 x 7) | 77 | | Figure 44. | LQFP 48-pin recommended footprint | 78 | | Figure 45. | LQFP 32-pin low profile quad flat package (7 x 7) | | | Figure 46. | LQFP 32-pin recommended footprint | 80 | | Figure 47. | Ordering information scheme <sup>(1)</sup> | 81 | ### 1 Introduction This datasheet refers to the STM8AF61xx (STM8AF612x, STM8AF614x, STM8AF6166, and STM8AF6168) and STM8AF62xx products with 16 to 32 Kbytes of Flash program memory. In the order code, the letter 'F' refers to product versions with data EEPROM and 'H' refers to product versions without data EEPROM. The identifiers 'F' and 'H' do not coexist in a given 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 STM8S and STM8A microcontroller families reference manual (RM0016). - For information on programming, erasing and protection of the internal Flash memory please refer to the STM8 Flash programming manual (PM0051). - 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 STM8AF61xx and STM8AF62xx automotive 8-bit microcontrollers offer from 16 to 32 Kbytes of Flash program memory and integrated true data EEPROM. They are referred to as medium density STM8A devices in the STM8S and STM8A microcontroller families reference manual (RM0016). All devices of the STM8A product line provide the following benefits: reduced system cost, performance and robustness, short development cycles, and product longevity. The system cost is reduced thanks to an integrated true data EEPROM for up to 300 k write/erase cycles and a high system integration level with internal clock oscillators, watchdog, and brown-out reset. Device performance is ensured by a clock frequency of up to 16 MHz CPU and enhanced characteristics which include robust I/O, independent watchdogs (with a separate clock source), and a clock security system. Short development cycles are guaranteed due to application scalability across a common family product architecture with compatible pinout, memory map and and modular peripherals. Full documentation is offered with a wide choice of development tools. Product longevity is ensured in the STM8A family thanks to their advanced core which is made in a state-of-the art technology for automotive applications with 3.3 V to 5 V operating 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. # 3 Product line-up Table 2. STM8AF62xx product line-up | Order code | Package | Medium<br>density<br>Flash<br>program<br>memory<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/P6268 | LOEDAO | 32 K | 2 K | 1 K | | 1x8-bit: TIM4 | LINI/LIA DT\ | | | STM8AF/P6248 | LQFP48<br>(7x7) | 16 K | 2 K | 0.5 K | 10 | 3x16-bit: TIM1,<br>TIM2, TIM3<br>(9/9/9) | LIN(UART),<br>SPI, I <sup>2</sup> C | 38/35 | | STM8AF/P6266 | | 32 K | 2 K | 1 K | | 1x8-bit: TIM4 | | | | STM8AF/P6246 | LQFP32<br>(7x7) | 16 K | 2 K | 0.5 K | 7 | 3x16-bit: TIM1,<br>TIM2, TIM3 | LIN(UART),<br>SPI. I <sup>2</sup> C | 25/23 | | STM8AF/P6226 | | 8 K | 2 K | 384 | | (8/8/8) | - , - | | | STM8AF/P6266 | | 32 K | 2 K | 1 K | 7 | 1x8-bit: TIM4 | | | | STM8AF/P6246 | VFQFPN32 | 16 K | 2 K | 0.5 K | | 3x16-bit: TIM1,<br>TIM2, TIM3<br>(8/8/8) | LIN(UART),<br>SPI, I <sup>2</sup> C | 25/23 | Table 3. STM8AF/H61xx product line-up<sup>(1)</sup> | Order code | Package | Medium<br>density<br>Flash<br>program<br>memory<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/H/P6168 | 1.055.40 | 32 K | 2 K | 1 K | | 1x8-bit: TIM4 | LINI(LIA DT) | | | STM8AF/H/P6148 | (7x7) | QFP48<br>(7x7) 16 K 1 K 0 | | 0.5 K | 10 | 3x16-bit: TIM1,<br>TIM2, TIM3<br>(9/9/9) | LIN(UART),<br>SPI, I <sup>2</sup> C | 38/35 | | STM8AF/H/P6166 | | 32 K | 2 K | 1 K | | 1x8-bit: TIM4 | | | | STM8AF/H/P6146 | LQFP32<br>(7x7) | 16 K | 1 K | 0.5 K | 7 | 3x16-bit: TIM1,<br>TIM2, TIM3 | LIN(UART),<br>SPI, I <sup>2</sup> C | 25/23 | | STM8AF/H/P6126 | , | 8 K | 512 | 384 | | (8/8/8) | ,,,, | | <sup>1.</sup> These devices are not recommended for new design. #### **Block diagram** 4 STM8A block diagram Legend: ADC: Analog-to-digital converter beCAN: Controller area network **BOR: Brownout reset** I2C: Inter-integrated circuit multimaster interface IWDG: Independent window watchdog LINUART: Local interconnect network universal asynchronous receiver transmitter POR: Power on reset SPI: Serial peripheral interface SWIM: Single wire interface module USART: Universal synchronous asynchronous receiver transmitter Window WDG: Window watchdog ### 5 Product overview This section is intended to describe the family features that are actually implemented in the products covered by this datasheet. For more detailed information on each feature please refer to the STM8S and STM8A microcontroller families reference manual (RM0016). ### 5.1 STM8A central processing unit (CPU) The 8-bit STM8A core is a modern CISC core and has been 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 efficient implementation of 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 (DM) #### 5.2.1 SWIM The single wire interface module, SWIM, together with an integrated debug module, permits non-intrusive, real-time in-circuit debugging and fast memory programming. The interface can be activated in all device operation modes and can be connected to a running device (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-flavored 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 interrupt vector table - Two advanced breakpoints and 23 predefined breakpoint configurations ### 5.3 Interrupt controller - Nested interrupts with three software priority levels - 21 interrupt vectors with hardware priority - Five vectors for external interrupts (up to 34 depending on the package) - Trap and reset interrupts ### 5.4 Flash program and data EEPROM - 8 Kbytes to 32 Kbytes of medium density single voltage program Flash memory - Up to 1 Kbytes true (not emulated) data EEPROM - Read while write: writing in the data memory is possible while executing code in the Flash program memory The whole Flash program memory and data EEPROM are factory programmed with 0x00. #### 5.4.1 Architecture - The memory is 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 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. The write protection can be removed temporarily by executing a specific sequence in the user software. #### 5.4.3 Protection of user boot code (UBC) If the user chooses to update the Flash program memory using a specific boot code to perform in application programming (IAP), this boot code needs to be protected against unwanted modification. In the STM8A a memory area of up to 32 Kbytes can be protected from overwriting at user option level. Other than the standard write protection, the UBC protection can exclusively be modified via the debug interface, the user software cannot modify the UBC protection status. The UBC memory area contains the reset and interrupt vectors and its size can be adjusted in increments of 512 bytes by programming the UBC and NUBC option bytes (see Section 9: Option bytes on page 41). Figure 2. Flash memory organization of STM8A products #### 5.4.4 Read-out protection (ROP) The STM8A provides a read-out protection of the code and data memory which can be activated by an option byte setting (see the ROP option byte in section 10). The read-out protection prevents reading and writing Flash program memory, data memory and option bytes 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 ROP option byte triggers a global erase of the program and data memory. The ROP circuit may provide a temporary access for debugging or failure analysis. The temporary read access is protected by a user defined, 8-byte keyword stored in the option byte area. This keyword must be entered via the SWIM interface to temporarily unlock the device. 14/89 Doc ID 14952 Rev 6 If desired, the temporary unlock mechanism can be permanently disabled by the user through OPT6/NOPT6 option bytes. #### 5.5 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.5.1 Features #### Clock sources: - 16 MHz high-speed internal RC oscillator (HSI) - 128 kHz low-speed internal RC (LSI) - 1-16 MHz high-speed external crystal (HSE) - Up to 16 MHz high-speed user-external clock (HSE user-ext) - Reset: After reset the microcontroller restarts by default with an internal 2-MHz clock (16 MHz/8). The clock source and speed 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 or individual peripherals. - Wakeup: In case the device wakes up from low-power modes, the internal RC oscillator (16 MHz/8) is used for quick startup. After a stabilization time, the device switches to the clock source that was selected before Halt mode was 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 feature permits to outputs a clock signal for use by the application. #### 5.5.2 16 MHz high-speed internal RC oscillator (HSI) - Default clock after reset 2 MHz (16 MHz/8) - Fast wakeup time #### **User trimming** The register CLK\_HSITRIMR with three trimming bits plus one additional bit for the sign permits frequency tuning by the application program. The adjustment range covers all possible frequency variations versus supply voltage and temperature. This trimming does not change the initial production setting. For reason of compatibility with other devices from the STM8A family, a special mode with only two trimming bits plus sign can be selected. This selection is controlled with the HSITRIM0 bit in the option byte registers OPT3 and NOPT3. #### 5.5.3 128 kHz low-speed internal RC oscillator (LSI) The frequency of this clock is 128 kHz and it is independent from the main clock. It drives the independent watchdog or the AWU wakeup 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/OPT3N, bit LSI\_EN). ### 5.5.4 16 MHz high-speed external crystal oscillator (HSE) The external high-speed crystal oscillator can be selected to deliver the main clock in normal Run mode. It operates with quartz crystals and ceramic resonators. - Frequency range: 1 MHz to 16 MHz - Crystal oscillation mode: preferred fundamental - I/Os: standard I/O pins multiplexed with OSCIN, OSCOUT ### 5.5.5 External clock input An external clock signal can be applied to the OSCIN input pin of the crystal oscillator. The frequency range is 0 to 16 MHz. ### 5.5.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). Table 4. Peripheral clock gating bit assignments in CLK\_PCKENR1/2 registers | Bit | Peripheral clock | Bit | Peripheral clock | Bit | Peripheral clock | Bit | Peripheral clock | |---------|------------------|---------|------------------|---------|------------------|---------|------------------| | PCKEN17 | TIM1 | PCKEN13 | LINUART | PCKEN27 | Reserved | PCKEN23 | ADC | | PCKEN16 | TIM3 | PCKEN12 | Reserved | PCKEN26 | Reserved | PCKEN22 | AWU | | PCKEN15 | TIM2 | PCKEN11 | SPI | PCKEN25 | Reserved | PCKEN21 | Reserved | | PCKEN14 | TIM4 | PCKEN10 | I <sup>2</sup> C | PCKEN24 | Reserved | PCKEN20 | Reserved | ### 5.6 Low-power operating modes For efficient power management, the application can be put in one of four different low power modes. You can configure each mode to obtain the best compromise between lowest power consumption, fastest start-up time and available wakeup sources. - Wait mode - In this mode, the CPU is stopped but peripherals are kept running. The wakeup is performed by an internal or external interrupt or reset. - Active-halt mode with regulator on - In this mode, the CPU and peripheral clocks are stopped. An internal wakeup is generated at programmable intervals by the auto wake up unit (AWU). The main voltage regulator is kept powered on, so current consumption is higher than in Active-halt mode with regulator off, but the wakeup time is faster. Wakeup is triggered by the internal AWU interrupt, external interrupt or reset. - Active-halt mode with regulator off - This mode is the same as Active-halt with regulator on, except that the main voltage regulator is powered off, so the wake up time is slower. - Halt mode - CPU and peripheral clocks are stopped, the main voltage regulator is powered off. Wakeup is triggered by external event or reset. 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.7 Timers #### 5.7.1 Watchdog timers The watchdog system is based on two independent timers providing maximum security to the applications. The watchdog 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 going through 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 timing perfectly. The application software must refresh the counter before time-out and during a limited time window. If the counter is refreshed outside this time window, a reset is issued. #### Independent watchdog timer The independent watchdog peripheral can be used to resolve 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. ### 5.7.2 Auto-wakeup counter This counter is used to cyclically wakeup the device in Active-halt mode. It can be clocked by the internal 128 kHz internal low-frequency RC oscillator or external clock. LSI clock can be internally connected to TIM3 input capture channel 1 for calibration. ### 5.7.3 Beeper This function generates a rectangular signal in the range of 1, 2 or 4 kHz which can be output on a pin. This is useful when audible sounds without interference need to be generated for use in the application. ### 5.7.4 Advanced control and general purpose timers STM8A devices described in this datasheet, contain up to three 16-bit advanced control and general purpose timers providing nine CAPCOM channels in total. A CAPCOM channel can be used either as input compare, output compare or PWM channel. These timers are named TIM1, TIM2 and TIM3. Table 5. Advanced control and general purpose timers | Timer | Counter width | Counter<br>type | Prescaler factor | Channels | Inverted outputs | Repetition counter | trigger<br>unit | External trigger | Break<br>input | |-------|---------------|-----------------|-------------------------------|----------|------------------|--------------------|-----------------|------------------|----------------| | TIM1 | 16-bit | Up/down | 1 to 65536 | 4 | 3 | Yes | Yes | Yes | Yes | | TIM2 | 16-bit | Up | 2 <sup>n</sup><br>n = 0 to 15 | 3 | None | No | No | No | No | | TIM3 | 16-bit | Up | 2 <sup>n</sup><br>n = 0 to 15 | 2 | None | No | No | No | No | #### TIM1: Advanced control 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 bridge driver. - 16-bit up, down and up/down AR (auto-reload) counter with 16-bit fractional 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 TIM1 with other on-chip peripherals. In the present implementation it is possible to trigger the ADC upon a timer event. - External trigger to change the timer behavior depending on external signals - 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 #### TIM2 and TIM3: 16-bit general purpose 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.5 Basic timer The typical usage of this timer (TIM4) is the generation of a clock tick. Table 6. TIM4 | Timer | Counter width | Counter type | Prescaler factor | Channels | Inverted outputs | Repetition counter | trigger<br>unit | External trigger | Break<br>input | |-------|---------------|--------------|------------------------------|----------|------------------|--------------------|-----------------|------------------|----------------| | TIM4 | 8-bit | Up | 2 <sup>n</sup><br>n = 0 to 7 | 0 | None | No | No | No | No | - 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 Analog-to-digital converter (ADC) The STM8A products described in this datasheet contain a 10-bit successive approximation ADC with up to 16 multiplexed input channels, depending on the package. The ADC name differs between the datasheet and the STM8A/S reference manual (see *Table 7*). Table 7. ADC naming | Peripheral name in datasheet | Peripheral name in reference manual (RM0016) | |------------------------------|----------------------------------------------| | ADC | ADC1 | #### **ADC** features - 10-bit resolution - Single and continuous conversion modes - Programmable prescaler: f<sub>MASTER</sub> divided by 2 to 18 - Conversion trigger on timer events and external events - Interrupt generation at end of conversion - Selectable alignment of 10-bit data in 2 x 8 bit result register - Shadow registers for data consistency - ADC input range: V<sub>SSA</sub> ≤V<sub>IN</sub> ≤V<sub>DDA</sub> - Analog watchdog - Schmitt-trigger on analog inputs can be disabled to reduce power consumption - Scan mode (single and continuous) - Dedicated result register for each conversion channel - Buffer mode for continuous conversion Note: An additional AIN12 analog input is not selectable in ADC scan mode or with analog watchdog. Values converted from AIN12 are stored only into the ADC\_DRH/ADC\_DRL registers. #### 5.9 Communication interfaces The following sections give a brief overview of the communication peripheral. Some peripheral names differ between the datasheet and the STM8A/S reference manual (see *Table 8*). Table 8. Communication peripheral naming correspondence | Peripheral name in datasheet | Peripheral name in reference manual (RM0016) | |------------------------------|----------------------------------------------| | LINUART | UART2 | ### 5.9.1 Serial peripheral interface (SPI) The devices covered by this datasheet contain one SPI. The SPI is available on all the supported packages. - Maximum speed: 10 Mbit/s or f<sub>MASTER</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 mode/master mode management by hardware or software for both master and slave - Programmable clock polarity and phase - Programmable data order with MSB-first or LSB-first shifting - Dedicated transmission and reception flags with interrupt capability - SPI bus busy status flag - Hardware CRC feature for reliable communication: - CRC value can be transmitted as last byte in Tx mode - CRC error checking for last received byte ### 5.9.2 Inter integrated circuit (I<sup>2</sup>C) interface The devices covered by this datasheet contain one I<sup>2</sup>C interface. The interface is available on all the supported packages. - 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) - Status flags: - Transmitter/receiver mode flag - End-of-byte transmission flag - I<sup>2</sup>C busy flag - Error flags: - Arbitration lost condition for master mode - Acknowledgement failure after address/data transmission - Detection of misplaced start or stop condition - Overrun/underrun if clock stretching is disabled - Interrupt: - Successful address/data communication - Error condition - Wakeup from Halt - Wakeup from Halt on address detection in slave mode # 5.9.3 Universal asynchronous receiver/transmitter with LIN support (LINUART) The devices covered by this datasheet contain one LINUART interface. The interface is available on all the supported packages. The LINUART is an asynchronous serial communication interface which supports extensive LIN functions tailored for LIN slave applications. In LIN mode it is compliant to the LIN standards rev 1.2 to rev 2.1. Detailed feature list: #### LIN mode #### Master mode: - LIN break and delimiter generation - LIN break and delimiter detection with separate flag and interrupt source for read back checking. #### Slave mode: - Autonomous header handling one single interrupt per valid header - Mute mode to filter responses - Identifier parity error checking - LIN automatic resynchronization, allowing operation with internal RC oscillator (HSI) clock source - Break detection at any time, even during a byte reception - Header errors detection: - Delimiter too short - Synch field error - Deviation error (if automatic resynchronization is enabled) - Framing error in synch field or identifier field - Header time-out #### **UART** mode - Full duplex, asynchronous communications NRZ standard format (mark/space) - High-precision baud rate generator - A common programmable transmit and receive baud rates up to f<sub>MASTER</sub>/16 - Programmable data word length (8 or 9 bits) 1 or 2 stop bits parity control - Separate enable bits for transmitter and receiver - Error detection flags - Reduced power consumption mode - Multi-processor communication enter 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.10 Input/output specifications The product features four different I/O types: - Standard I/O 2 MHz - Fast I/O up to 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. The analog inputs are equipped with a low leakage analog switch. Additionally, the schmitt-trigger input stage on the analog I/Os can be disabled in order to reduce the device standby consumption. 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. Thanks to this feature, external protection diodes against current injection are no longer required. # 6 Pinouts and pin description ### 6.1 Package pinouts Figure 3. VFQFPN/LQFP 32-pin pinout 1. (HS) high sink capability. Figure 4. LQFP 48-pin pinout 2. (HS) high sink capability. Table 9. Legend/abbreviation | Туре | I= input, O = output, S = power supply | | | | | | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--|--|--|--|--| | Level | Input | CM = CMOS (standard for all I/Os) | | | | | | | | Output | HS = High sink (8 mA) | | | | | | | Output speed | O1 = Standard (up to 2 MHz) O2 = Fast (up to 10 MHz) O3 = Fast/slow programmability with slow as default state after reset O4 = Fast/slow programmability with fast as default state after reset | | | | | | | | Port and control | Input | float = floating, wpu = weak pull-up | | | | | | | configuration | Output | t T = true open drain, OD = open drain, PP = push pull | | | | | | | Reset state | Bold X (pin state after reset release). Unless otherwise specified, the pin state is the same during the reset phase ( "under reset") and after internal reset release (i.e. at reset state). | | | | | | | Table 10. STM8AF61xx/62xx (32 Kbytes) microcontroller pin description<sup>(1)(2)</sup> | P<br>num | | | | | Inpu | | , | Out | | | | description | | |----------|---------------|-----------------------------|------|----------|------|----------------|-----------|-------|----|----|--------------------------------|-------------------------------|------------------------------------------------------| | LQFP48 | VFQFPN/LQFP32 | Pin name | Туре | floating | ndw | Ext. interrupt | High sink | Speed | QO | dd | Main function<br>(after reset) | Default alternate<br>function | Alternate<br>function after<br>remap<br>[option bit] | | 1 | 1 | NRST | I/O | - | X | - | - | - | - | - | Reset | | _ | | 2 | 2 | PA1/OSCIN <sup>(3)</sup> | I/O | X | X | 1 | ı | 01 | X | Χ | Port A1 | Resonator/crystal in | _ | | 3 | З | PA2/OSCOUT | I/O | X | X | Χ | ı | 01 | X | Χ | Port A2 | Resonator/crystal out | _ | | 4 | - | V <sub>SSIO_1</sub> | S | 1 | - | - | - | - | - | - | I/O groun | d | _ | | 5 | 4 | V <sub>SS</sub> | S | - | ı | 1 | - | - | ı | - | Digital gro | ound | _ | | 6 | 5 | VCAP | S | - | ı | - | - | - | 1 | - | 1.8 V regi | ulator capacitor | _ | | 7 | 6 | $V_{DD}$ | S | - | ı | ı | ı | ı | ı | • | Digital po | wer supply | | | 8 | 7 | V <sub>DDIO_1</sub> | S | - | • | - | - | - | • | - | I/O power | supply | _ | | - | 8 | PF4/AIN12 <sup>(4)(5)</sup> | I/O | X | Х | | - | 01 | Х | Χ | Port F4 | Analog input 12 | _ | | 9 | - | PA3/TIM2_CH3 | I/O | X | Χ | Х | - | 01 | X | Х | Port A3 | Timer 2 - channel 3 | TIM3_CH1<br>[AFR1] | | 10 | - | PA4 | I/O | X | Х | Х | - | О3 | Х | Χ | Port A4 | | _ | | 11 | - | PA5 | I/O | Х | Х | Х | - | О3 | Х | Χ | Port A5 | | _ | | 12 | 1 | PA6 | I/O | X | Х | Χ | - | О3 | Х | Χ | Port A6 | | _ | | 13 | 9 | $V_{DDA}$ | S | - | ı | 1 | 1 | 1 | ı | • | Analog po | ower supply | _ | | 14 | 10 | V <sub>SSA</sub> | S | - | ı | ı | ı | ı | ı | • | Analog gr | ound | | | 15 | - | PB7/AIN7 | I/O | X | Х | Χ | - | 01 | Х | Χ | Port B7 | Analog input 7 | _ | | 16 | 1 | PB6/AIN6 | I/O | X | X | Χ | 1 | 01 | X | Χ | Port B6 | Analog input 6 | _ | | 17 | 11 | PB5/AIN5 | I/O | X | X | Х | - | 01 | X | Х | Port B5 | Analog input 5 | I <sup>2</sup> C_SDA<br>[AFR6] | | 18 | 12 | PB4/AIN4 | I/O | X | Х | Х | - | 01 | Х | Х | Port B4 | Analog input 4 | I <sup>2</sup> C_SCL<br>[AFR6] | | 19 | 13 | PB3/AIN3 | I/O | X | Х | Х | - | 01 | Х | Х | Port B3 | Analog input 3 | TIM1_ETR<br>[AFR5] | | 20 | 14 | PB2/AIN2 | I/O | X | х | х | 1 | O1 | Х | Х | Port B2 | Analog input | TIM1_<br>NCC3<br>[AFR5] | | 21 | 15 | PB1/AIN1 | I/O | X | X | Х | - | 01 | Х | Х | Port B1 | Analog input 1 | TIM1_<br>NCC2<br>[AFR5] | | 22 | 16 | PB0/AIN0 | I/O | X | Х | х | - | O1 | Х | Х | Port B0 | Analog input 0 | TIM1_<br>NCC1<br>[AFR5] | 26/89 Doc ID 14952 Rev 6 Table 10. STM8AF61xx/62xx (32 Kbytes) microcontroller pin description<sup>(1)(2)</sup> (continued) | P<br>nun | | | | | Inpu | t | | Out | put | | E ( | | - | |----------|---------------|--------------------------|------|----------|------|----------------|-----------|-------|------------------|----|--------------------------------|-------------------------------|------------------------------------------------------| | LQFP48 | VFQFPN/LQFP32 | Pin name | Туре | floating | ndw | Ext. interrupt | High sink | Speed | ОО | ЬР | Main function<br>(after reset) | Default alternate<br>function | Alternate<br>function after<br>remap<br>[option bit] | | 23 | - | PE7/AIN8 | I/O | X | Χ | | - | 01 | Χ | Χ | Port E7 | Analog input 8 | _ | | 24 | | PE6/AIN9 | I/O | X | Χ | Χ | - | 01 | Χ | Χ | Port E7 | Analog input 9 | _ | | 25 | 17 | PE5/SPI_NSS | I/O | X | Χ | Χ | - | 01 | Χ | Χ | Port E5 | SPI master/slave select | _ | | 26 | 18 | PC1/TIM1_CH1 | I/O | X | Χ | Χ | HS | О3 | Χ | Χ | Port C1 | Timer 1 - channel 1 | _ | | 27 | 19 | PC2/TIM1_CH2 | I/O | X | Χ | Х | HS | О3 | Х | Χ | Port C2 | Timer 1- channel 2 | _ | | 28 | 20 | PC3/TIM1_CH3 | I/O | X | Χ | X | HS | О3 | Х | Χ | Port C3 | Timer 1 - channel 3 | _ | | 29 | 21 | PC4/TIM1_CH4 | I/O | X | Χ | Χ | HS | О3 | Χ | Χ | Port C4 | Timer 1 - channel 4 | _ | | 30 | 22 | PC5/SPI_SCK | I/O | X | Χ | Χ | | О3 | Χ | Χ | Port C5 | SPI clock | _ | | 31 | | V <sub>SSIO_2</sub> | S | | | - | | | - | - | I/O groun | d | _ | | 32 | - | V <sub>DDIO_2</sub> | S | - | - | - | - | - | - | - | I/O power | supply | _ | | 33 | 23 | PC6/SPI_MOSI | I/O | X | Х | Х | - | О3 | Х | Х | Port C6 | SPI master out/<br>slave in | _ | | 34 | 24 | PC7/SPI_MISO | I/O | X | Χ | Χ | 1 | О3 | Х | Χ | Port C7 | SPI master in/ slave out | _ | | 35 | - | PG0 | I/O | X | Χ | - | - | 01 | Χ | Χ | Port G0 | - | _ | | 36 | - | PG1 | I/O | X | Χ | - | - | 01 | Χ | Χ | Port G1 | - | _ | | 37 | 1 | PE3/TIM1_BKIN | I/O | X | Χ | Χ | 1 | 01 | Х | Χ | Port E3 | Timer 1 - break input | _ | | 38 | ı | PE2/I <sup>2</sup> C_SDA | I/O | X | ı | X | ı | 01 | T <sup>(6)</sup> | - | Port E2 | I <sup>2</sup> C data | _ | | 39 | - | PE1/I <sup>2</sup> C_SCL | I/O | X | - | Χ | - | 01 | T <sup>(6)</sup> | - | Port E1 | I <sup>2</sup> C clock | _ | | 40 | - | PE0/CLK_CCO | I/O | X | Χ | Х | - | О3 | Х | Χ | Port E0 | Configurable clock output | _ | | 41 | 25 | PD0/TIM3_CH2 | I/O | X | Х | Х | HS | О3 | Х | Х | Port D0 | Timer 3 - channel 2 | TIM1_BKIN<br>[AFR3]/<br>CLK_CCO<br>[AFR2] | | 42 | 26 | PD1/SWIM <sup>(7)</sup> | I/O | Χ | X | Χ | HS | 04 | Χ | Χ | Port D1 | SWIM data interface | _ | | 43 | 27 | PD2/TIM3_CH1 | I/O | X | Х | Х | HS | О3 | Х | Х | Port D2 | Timer 3 - channel 1 | TIM2_CH3<br>[AFR1] | | 44 | 28 | PD3/TIM2_CH2 | I/O | X | Х | Х | HS | О3 | Х | Х | Port D3 | Timer 2 - channel 2 | ADC_ETR<br>[AFR0] | | 45 | 29 | PD4/TIM2_CH1/<br>BEEP | I/O | X | Х | Х | HS | О3 | Х | Х | Port D4 | Timer 2 - channel 1 | BEEP output<br>[AFR7] | | 46 | 30 | PD5/<br>LINUART_TX | I/O | X | Х | Х | - | 01 | Х | Х | Port D5 | LINUART data transmit | _ | | P<br>nun | in<br>nber | | Input | | t | Output | | | | u ( | | | | | |----------|---------------|------------------------|-------|----------|-----|----------------|-----------|-------|----|-----|--------------------------------|----------------------------|--------|------------------------------------------------------| | LQFP48 | VFQFPN/LQFP32 | Pin name | Туре | floating | ndw | Ext. interrupt | High sink | Speed | ОО | ЬР | Main function<br>(after reset) | Default a<br>func | | Alternate<br>function after<br>remap<br>[option bit] | | 47 | 31 | PD6/<br>LINUART_RX | I/O | x | Х | Х | - | 01 | Х | Х | Port D6 | LINUART<br>data<br>receive | | _ | | 48 | 32 | PD7/TLI <sup>(8)</sup> | I/O | X | Χ | Χ | - | 01 | Χ | Х | Port D7 | Top level inte | errupt | _ | Table 10. STM8AF61xx/62xx (32 Kbytes) microcontroller pin description<sup>(1)(2)</sup> (continued) - 1. Refer to *Table 9* for the definition of the abbreviations. - 2. Reset state is shown in bold. - 3. In Halt/Active-halt mode this pad behaves in the following way: - the input/output path is disabled - if the HSE clock is used for wakeup, the internal weak pull up is disabled - if the HSE clock is off, internal weak pull up setting from corresponding OR bit is used By managing the OR bit correctly, it must be ensured that the pad is not left floating during Halt/Active-halt. - 4. On this pin, a pull-up resistor as specified in *Table 37*. I/O static characteristics is enabled during the reset phase of the - 5. AIN12 is not selectable in ADC scan mode or with analog watchdog. - In the open-drain output column, 'T' defines a true open-drain I/O (P-buffer, week pull-up, and protection diode to V<sub>DD</sub> are not implemented) - 7. The PD1 pin is in input pull-up during the reset phase and after reset release. - 8. If this pin is configured as interrupt pin, it will trigger the TLI. ### 6.2 Alternate function remapping As shown in the rightmost column of *Table 10*, 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 9: Option bytes on page 41*. 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 STM8S and STM8A microcontroller families reference manual, RM0016). # 7 Memory and register map ### 7.1 Memory map Figure 5. Register and memory map of STM8A products Table 11. Memory model for the devices covered in this datasheet | Flash program<br>memory size | Flash program<br>memory end<br>address | RAM size | RAM end address | Stack roll-over address | |------------------------------|----------------------------------------|----------|-----------------|-------------------------| | 32K | 0x00 0FFFF | | | | | 16K | 0x00 0BFFF | 2K | 0x00 07FF | 0x00 0600 | | 8K | 0x00 09FFF | | | | # 7.2 Register map In this section the memory and register map of the devices covered by this datasheet is described. For a detailed description of the functionality of the registers, refer to the reference manual RM0016. Table 12. I/O port hardware register map | Address | Block | Register label | Register name | Reset status | |-----------|--------|----------------|-----------------------------------|---------------------| | 0x00 5000 | | PA_ODR | Port A data output latch register | 0x00 | | 0x00 5001 | | PA_IDR | Port A input pin value register | 0xXX <sup>(1)</sup> | | 0x00 5002 | Port A | PA_DDR | Port A data direction register | 0x00 | | 0x00 5003 | | PA_CR1 | Port A control register 1 | 0x00 | | 0x00 5004 | | PA_CR2 | Port A control register 2 | 0x00 | | 0x00 5005 | | PB_ODR | Port B data output latch register | 0x00 | | 0x00 5006 | | PB_IDR | Port B input pin value register | 0xXX <sup>(1)</sup> | | 0x00 5007 | Port B | PB_DDR | Port B data direction register | 0x00 | | 0x00 5008 | | PB_CR1 | Port B control register 1 | 0x00 | | 0x00 5009 | | PB_CR2 | Port B control register 2 | 0x00 | | 0x00 500A | | PC_ODR | Port C data output latch register | 0x00 | | 0x00 500B | | PB_IDR | Port C input pin value register | 0xXX <sup>(1)</sup> | | 0x00 500C | Port C | PC_DDR | Port C data direction register | 0x00 | | 0x00 500D | | PC_CR1 | Port C control register 1 | 0x00 | | 0x00 500E | | PC_CR2 | Port C control register 2 | 0x00 | | 0x00 500F | | PD_ODR | Port D data output latch register | 0x00 | | 0x00 5010 | | PD_IDR | Port D input pin value register | 0xXX <sup>(1)</sup> | | 0x00 5011 | Port D | PD_DDR | Port D data direction register | 0x00 | | 0x00 5012 | | PD_CR1 | Port D control register 1 | 0x02 | | 0x00 5013 | | PD_CR2 | Port D control register 2 | 0x00 | | 0x00 5014 | | PE_ODR | Port E data output latch register | 0x00 | | 0x00 5015 | | PE_IDR | Port E input pin value register | 0xXX <sup>(1)</sup> | | 0x00 5016 | Port E | PE_DDR | Port E data direction register | 0x00 | | 0x00 5017 | | PE_CR1 | Port E control register 1 | 0x00 | | 0x00 5018 | | PE_CR2 | Port E control register 2 | 0x00 | | 0x00 5019 | | PF_ODR | Port F data output latch register | 0x00 | | 0x00 501A | | PF_IDR | Port F input pin value register | 0xXX <sup>(1)</sup> | | 0x00 501B | Port F | PF_DDR | Port F data direction register | 0x00 | | 0x00 501C | | PF_CR1 | Port F control register 1 | 0x00 | | 0x00 501D | | PF_CR2 | Port F control register 2 | 0x00 | Table 12. I/O port hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | |-----------|--------|----------------|-----------------------------------|---------------------| | 0x00 501E | | PG_ODR | Port G data output latch register | 0x00 | | 0x00 501F | | PG_IDR | Port G input pin value register | 0xXX <sup>(1)</sup> | | 0x00 5020 | Port G | PG_DDR | Port G data direction register | 0x00 | | 0x00 5021 | | PG_CR1 | Port G control register 1 | 0x00 | | 0x00 5022 | | PG_CR2 | Port G control register 2 | 0x00 | <sup>1.</sup> Depends on the external circuitry. Table 13. General hardware register map | Address | Block | Register label | Register name | Reset<br>status | | | | |---------------------------|-------|--------------------------|--------------------------------------------------|---------------------|--|--|--| | 0x00 505A | | FLASH_CR1 | Flash control register 1 | 0x00 | | | | | 0x00 505B | | FLASH_CR2 | Flash control register 2 | 0x00 | | | | | 0x00 505C | | FLASH_NCR2 | Flash complementary control register 2 | 0xFF | | | | | 0x00 505D | Flash | FLASH_FPR | Flash protection register | 0x00 | | | | | 0x00 505E | | FLASH_NFPR | Flash complementary protection register | 0xFF | | | | | 0x00 505F | | FLASH_IAPSR | Flash in-application programming status register | 0x40 | | | | | 0x00 5060 to<br>0x00 5061 | | Reserved area (2 bytes) | | | | | | | 0x00 5062 | Flash | FLASH_PUKR | Flash Program memory unprotection register | 0x00 | | | | | 0x00 5063 | | F | Reserved area (1 byte) | | | | | | 0x00 5064 | Flash | FLASH_DUKR | Data EEPROM unprotection register | 0x00 | | | | | 0x00 5065 to<br>0x00 509F | | Re | eserved area (59 bytes) | | | | | | 0x00 50A0 | ITC | EXTI_CR1 | External interrupt control register 1 | 0x00 | | | | | 0x00 50A1 | 110 | EXTI_CR2 | External interrupt control register 2 | 0x00 | | | | | 0x00 50A2 to<br>0x00 50B2 | | Re | eserved area (17 bytes) | | | | | | 0x00 50B3 | RST | RST_SR | Reset status register | 0xXX <sup>(1)</sup> | | | | | 0x00 50B4 to<br>0x00 50BF | | Reserved area (12 bytes) | | | | | | | 0x00 50C0 | CLK | CLK_ICKR | Internal clock control register | 0x01 | | | | | 0x00 50C1 | CLK | CLK_ECKR | External clock control register | 0x00 | | | | | 0x00 50C2 | | F | Reserved area (1 byte) | | | | | Table 13. General hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | | | | |---------------------------|-------|-------------------------|--------------------------------------------|---------------------|--|--|--| | 0x00 50C3 | | CLK_CMSR | Clock master status register | 0xE1 | | | | | 0x00 50C4 | | CLK_SWR | Clock master switch register | 0xE1 | | | | | 0x00 50C5 | • | CLK_SWCR | Clock switch control register | 0xXX | | | | | 0x00 50C6 | CLK | CLK_CKDIVR | Clock divider register | 0x18 | | | | | 0x00 50C7 | CLK | CLK_PCKENR1 | Peripheral clock gating register 1 | 0xFF | | | | | 0x00 50C8 | | CLK_CSSR | Clock security system register | 0x00 | | | | | 0x00 50C9 | | CLK_CCOR | Configurable clock control register | 0x00 | | | | | 0x00 50CA | | CLK_PCKENR2 | Peripheral clock gating register 2 | 0xFF | | | | | 0x00 50CB | | F | Reserved area (1 byte) | | | | | | 0x00 50CC | | CLK_HSITRIMR | HSI clock calibration trimming register | 0x00 | | | | | 0x00 50CD | CLK | CLK_SWIMCCR | SWIM clock control register | 0bXXXX<br>XXX0 | | | | | 0x00 50CE<br>to 0x00 50D0 | | Reserved area (3 bytes) | | | | | | | 0x00 50D1 | WWDG | WWDG_CR | WWDG control register | 0x7F | | | | | 0x00 50D2 | WWDG | WWDG_WR | WWDR window register | 0x7F | | | | | 0x00 50D3 to<br>0x00 50DF | | Re | eserved area (13 bytes) | | | | | | 0x00 50E0 | | IWDG_KR | IWDG key register | 0xXX <sup>(2)</sup> | | | | | 0x00 50E1 | IWDG | IWDG_PR | IWDG prescaler register | 0x00 | | | | | 0x00 50E2 | | IWDG_RLR | IWDG reload register | 0xFF | | | | | 0x00 50E3 to<br>0x00 50EF | | Re | eserved area (13 bytes) | | | | | | 0x00 50F0 | | AWU_CSR1 | AWU control/status register 1 | 0x00 | | | | | 0x00 50F1 | AWU | AWU_APR | AWU asynchronous prescaler buffer register | 0x3F | | | | | 0x00 50F2 | • | AWU_TBR | AWU timebase selection register | 0x00 | | | | | 0x00 50F3 | BEEP | BEEP_CSR | BEEP control/status register | 0x1F | | | | | 0x00 50F4 to<br>0x00 50FF | | Re | eserved area (12 bytes) | | | | | Table 13. General hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | | | |---------------------------|--------------------------|----------------|---------------------------------|-----------------|--|--| | 0x00 5200 | | SPI_CR1 | SPI control register 1 | 0x00 | | | | 0x00 5201 | | SPI_CR2 | SPI control register 2 | 0x00 | | | | 0x00 5202 | SPI | SPI_ICR | SPI interrupt control register | 0x00 | | | | 0x00 5203 | | SPI_SR | SPI status register | 0x02 | | | | 0x00 5204 | | SPI_DR | SPI data register | 0x00 | | | | 0x00 5205 | | SPI_CRCPR | SPI CRC polynomial register | 0x07 | | | | 0x00 5206 | | SPI_RXCRCR | SPI Rx CRC register | 0xFF | | | | 0x00 5207 | | SPI_TXCRCR | SPI Tx CRC register | 0xFF | | | | 0x00 5208 to<br>0x00 520F | | R | eserved area (8 bytes) | | | | | 0x00 5210 | | I2C_CR1 | I2C control register 1 | 0x00 | | | | 0x00 5211 | | I2C_CR2 | I2C control register 2 | 0x00 | | | | 0x00 5212 | | I2C_FREQR | I2C frequency register | 0x00 | | | | 0x00 5213 | | I2C_OARL | I2C own address register low | 0x00 | | | | 0x00 5214 | | I2C_OARH | I2C own address register high | 0x00 | | | | 0x00 5215 | | | Reserved area (1 byte) | | | | | 0x00 5216 | I2C | I2C_DR | I2C data register | 0x00 | | | | 0x00 5217 | 120 | I2C_SR1 | I2C status register 1 | 0x00 | | | | 0x00 5218 | | I2C_SR2 | I2C status register 2 | 0x00 | | | | 0x00 5219 | | I2C_SR3 | I2C status register 3 | 0x00 | | | | 0x00 521A | | I2C_ITR | I2C interrupt control register | 0x00 | | | | 0x00 521B | | I2C_CCRL | I2C clock control register low | 0x00 | | | | 0x00 521C | | I2C_CCRH | I2C clock control register high | 0x00 | | | | 0x00 521D | | I2C_TRISER | I2C TRISE register | 0x02 | | | | 0x00 521E to<br>0x00 523F | Reserved area (24 bytes) | | | | | | Table 13. General hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | |---------------------------|---------|----------------|----------------------------------------|-----------------| | 0x00 5240 | | UART2_SR | LINUART status register | 0xC0 | | 0x00 5241 | | UART2_DR | LINUART data register | 0xXX | | 0x00 5242 | | UART2_BRR1 | LINUART baud rate register 1 | 0x00 | | 0x00 5243 | | UART2_BRR2 | LINUART baud rate register 2 | 0x00 | | 0x00 5244 | LINUART | UART2_CR1 | LINUART control register 1 | 0x00 | | 0x00 5245 | | UART2_CR2 | LINUART control register 2 | 0x00 | | 0x00 5246 | | UART2_CR3 | LINUART control register 3 | 0x00 | | 0x00 5247 | | UART2_CR4 | LINUART control register 4 | 0x00 | | 0x00 5248 | | | Reserved | | | 0x00 5249 | | UART2_CR6 | LINUART control register 6 | 0x00 | | 0x00 524A to<br>0x00 524F | | R | eserved area (6 bytes) | | | 0x00 5250 | | TIM1_CR1 | TIM1 control register 1 | 0x00 | | 0x00 5251 | | TIM1_CR2 | TIM1 control register 2 | 0x00 | | 0x00 5252 | | TIM1_SMCR | TIM1 slave mode control register | 0x00 | | 0x00 5253 | | TIM1_ETR | TIM1 external trigger register | 0x00 | | 0x00 5254 | | TIM1_IER | TIM1 Interrupt enable register | 0x00 | | 0x00 5255 | | TIM1_SR1 | TIM1 status register 1 | 0x00 | | 0x00 5256 | | TIM1_SR2 | TIM1 status register 2 | 0x00 | | 0x00 5257 | · | TIM1_EGR | TIM1 event generation register | 0x00 | | 0x00 5258 | | TIM1_CCMR1 | TIM1 capture/compare mode register 1 | 0x00 | | 0x00 5259 | | TIM1_CCMR2 | TIM1 capture/compare mode register 2 | 0x00 | | 0x00 525A | | TIM1_CCMR3 | TIM1 capture/compare mode register 3 | 0x00 | | 0x00 525B | TIM1 | TIM1_CCMR4 | TIM1 capture/compare mode register 4 | 0x00 | | 0x00 525C | | TIM1_CCER1 | TIM1 capture/compare enable register 1 | 0x00 | | 0x00 525D | | TIM1_CCER2 | TIM1 capture/compare enable register 2 | 0x00 | | 0x00 525E | • | TIM1_CNTRH | TIM1 counter high | 0x00 | | 0x00 525F | | TIM1_CNTRL | TIM1 counter low | 0x00 | | 0x00 5260 | | TIM1_PSCRH | TIM1 prescaler register high | 0x00 | | 0x00 5261 | | TIM1_PSCRL | TIM1 prescaler register low | 0x00 | | 0x00 5262 | | TIM1_ARRH | TIM1 auto-reload register high | 0xFF | | 0x00 5263 | | TIM1_ARRL | TIM1 auto-reload register low | 0xFF | | 0x00 5264 | | TIM1_RCR | TIM1 repetition counter register | 0x00 | Table 13. General hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | | | |---------------------------|---------------------------|----------------|----------------------------------------|-----------------|--|--| | 0x00 5265 | TIM1 | TIM1_CCR1H | TIM1 capture/compare register 1 high | 0x00 | | | | 0x00 5266 | | TIM1_CCR1L | TIM1 capture/compare register 1 low | 0x00 | | | | 0x00 5267 | | TIM1_CCR2H | TIM1 capture/compare register 2 high | 0x00 | | | | 0x00 5268 | | TIM1_CCR2L | TIM1 capture/compare register 2 low | 0x00 | | | | 0x00 5269 | | TIM1_CCR3H | TIM1 capture/compare register 3 high | 0x00 | | | | 0x00 526A | | TIM1_CCR3L | TIM1 capture/compare register 3 low | 0x00 | | | | 0x00 526B | | TIM1_CCR4H | TIM1 capture/compare register 4 high | 0x00 | | | | 0x00 526C | | TIM1_CCR4L | TIM1 capture/compare register 4 low | 0x00 | | | | 0x00 526D | | TIM1_BKR | TIM1 break register | 0x00 | | | | 0x00 526E | | TIM1_DTR | TIM1 dead-time register | 0x00 | | | | 0x00 526F | | TIM1_OISR | TIM1 output idle state register | 0x00 | | | | 0x00 5270 to<br>0x00 52FF | Reserved area (147 bytes) | | | | | | | 0x00 5300 | | TIM2_CR1 | TIM2 control register 1 | 0x00 | | | | 0x00 5301 | | TIM2_IER | TIM2 interrupt enable register | 0x00 | | | | 0x00 5302 | TIM2 | TIM2_SR1 | TIM2 status register 1 | 0x00 | | | | 0x00 5303 | | TIM2_SR2 | TIM2 status register 2 | 0x00 | | | | 0x00 5304 | | TIM2_EGR | TIM2 event generation register | 0x00 | | | | 0x00 5305 | | TIM2_CCMR1 | TIM2 capture/compare mode register 1 | 0x00 | | | | 0x00 5306 | | TIM2_CCMR2 | TIM2 capture/compare mode register 2 | 0x00 | | | | 0x00 5307 | | TIM2_CCMR3 | TIM2 capture/compare mode register 3 | 0x00 | | | | 0x00 5308 | | TIM2_CCER1 | TIM2 capture/compare enable register 1 | 0x00 | | | | 0x00 5309 | | TIM2_CCER2 | TIM2 capture/compare enable register 2 | 0x00 | | | | 0x00 530A | | TIM2_CNTRH | TIM2 counter high | 0x00 | | | | 0x00 530B | | TIM2_CNTRL | TIM2 counter low | 0x00 | | | | 00 530C0x | | TIM2_PSCR | TIM2 prescaler register | 0x00 | | | | 0x00 530D | | TIM2_ARRH | TIM2 auto-reload register high | 0xFF | | | | 0x00 530E | • | TIM2_ARRL | TIM2 auto-reload register low | 0xFF | | | | 0x00 530F | | TIM2_CCR1H | TIM2 capture/compare register 1 high | 0x00 | | | | 0x00 5310 | | TIM2_CCR1L | TIM2 capture/compare register 1 low | 0x00 | | | | 0x00 5311 | | TIM2_CCR2H | TIM2 capture/compare reg. 2 high | 0x00 | | | | 0x00 5312 | | TIM2_CCR2L | TIM2 capture/compare register 2 low | 0x00 | | | | 0x00 5313 | | TIM2_CCR3H | TIM2 capture/compare register 3 high | 0x00 | | | Table 13. General hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | | | |---------------------------|---------------------------|----------------|----------------------------------------|-----------------|--|--| | 0x00 5314 | TIM2 | TIM2_CCR3L | TIM2 capture/compare register 3 low | 0x00 | | | | 0x00 5315 to<br>0x00 531F | Reserved area (11 bytes) | | | | | | | 0x00 5320 | TIM3 | TIM3_CR1 | TIM3 control register 1 | 0x00 | | | | 0x00 5321 | | TIM3_IER | TIM3 interrupt enable register | 0x00 | | | | 0x00 5322 | | TIM3_SR1 | TIM3 status register 1 | 0x00 | | | | 0x00 5323 | | TIM3_SR2 | TIM3 status register 2 | 0x00 | | | | 0x00 5324 | | TIM3_EGR | TIM3 event generation register | 0x00 | | | | 0x00 5325 | | TIM3_CCMR1 | TIM3 capture/compare mode register 1 | 0x00 | | | | 0x00 5326 | | TIM3_CCMR2 | TIM3 capture/compare mode register 2 | 0x00 | | | | 0x00 5327 | | TIM3_CCER1 | TIM3 capture/compare enable register 1 | 0x00 | | | | 0x00 5328 | | TIM3_CNTRH | TIM3 counter high | 0x00 | | | | 0x00 5329 | | TIM3_CNTRL | TIM3 counter low | 0x00 | | | | 0x00 532A | | TIM3_PSCR | TIM3 prescaler register | 0x00 | | | | 0x00 532B | | TIM3_ARRH | TIM3 auto-reload register high | 0xFF | | | | 0x00 532C | | TIM3_ARRL | TIM3 auto-reload register low | 0xFF | | | | 0x00 532D | | TIM3_CCR1H | TIM3 capture/compare register 1 high | 0x00 | | | | 0x00 532E | | TIM3_CCR1L | TIM3 capture/compare register 1 low | 0x00 | | | | 0x00 532F | | TIM3_CCR2H | TIM3 capture/compare register 2 high | 0x00 | | | | 0x00 5330 | | TIM3_CCR2L | TIM3 capture/compare register 2 low | 0x00 | | | | 0x00 5331 to<br>0x00 533F | Reserved area (15 bytes) | | | | | | | 0x00 5340 | | TIM4_CR1 | TIM4 control register 1 | 0x00 | | | | 0x00 5341 | | TIM4_IER | TIM4 interrupt enable register | 0x00 | | | | 0x00 5342 | | TIM4_SR | TIM4 status register | 0x00 | | | | 0x00 5343 | TIM4 | TIM4_EGR | TIM4 event generation register | 0x00 | | | | 0x00 5344 | | TIM4_CNTR | TIM4 counter | 0x00 | | | | 0x00 5345 | | TIM4_PSCR | TIM4 prescaler register | 0x00 | | | | 0x00 5346 | | TIM4_ARR | TIM4 auto-reload register | 0xFF | | | | 0x00 5347 to<br>0x00 53DF | Reserved area (185 bytes) | | | | | | Table 13. General hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | |---------------------------|-------|----------------|-------------------------------------------|-----------------| | 0x00 53E0 | | ADC _DB0RH | ADC data buffer register 0 high | 0x00 | | 0x00 53E1 | | ADC _DB0RL | ADC data buffer register 0 low | 0x00 | | 0x00 53E2 | | ADC _DB1RH | ADC data buffer register 1 high | 0x00 | | 0x00 53E3 | | ADC _DB1RL | ADC data buffer register 1 low | 0x00 | | 0x00 53E4 | | ADC _DB2RH | ADC data buffer register 2 high | 0x00 | | 0x00 53E5 | | ADC _DB2RL | ADC data buffer register 2 low | 0x00 | | 0x00 53E6 | | ADC _DB3RH | ADC data buffer register 3 high | 0x00 | | 0x00 53E7 | • | ADC _DB3RL | ADC data buffer register 3 low | 0x00 | | 0x00 53E8 | • | ADC _DB4RH | ADC data buffer register 4 high | 0x00 | | 0x00 53E9 | ADC | ADC _DB4RL | ADC data buffer register 4 low | 0x00 | | 0x00 53EA | ADC | ADC _DB5RH | ADC data buffer register 5 high | 0x00 | | 0x00 53EB | • | ADC _DB5RL | ADC data buffer register 5 low | 0x00 | | 0x00 53EC | | ADC _DB6RH | ADC data buffer register 6 high | 0x00 | | 0x00 53ED | • | ADC _DB6RL | ADC data buffer register 6 low | 0x00 | | 0x00 53EE | | ADC _DB7RH | ADC data buffer register 7 high | 0x00 | | 0x00 53EF | | ADC _DB7RL | ADC data buffer register 7 low | 0x00 | | 0x00 53F0 | | ADC _DB8RH | ADC data buffer register 8 high | 0x00 | | 0x00 53F1 | | ADC _DB8RL | ADC data buffer register 8 low | 0x00 | | 0x00 53F2 | | ADC _DB9RH | ADC data buffer register 9 high | 0x00 | | 0x00 53F3 | | ADC _DB9RL | ADC data buffer register 9 low | 0x00 | | 0x00 53F4 to<br>0x00 53FF | | Re | eserved area (12 bytes) | | | 0x00 5400 | | ADC _CSR | ADC control/status register | 0x00 | | 0x00 5401 | | ADC_CR1 | ADC configuration register 1 | 0x00 | | 0x00 5402 | | ADC_CR2 | ADC configuration register 2 | 0x00 | | 0x00 5403 | | ADC_CR3 | ADC configuration register 3 | 0x00 | | 0x00 5404 | | ADC_DRH | ADC data register high | 0xXX | | 0x00 5405 | 400 | ADC_DRL | ADC data register low | 0xXX | | 0x00 5406 | ADC | ADC_TDRH | ADC Schmitt trigger disable register high | 0x00 | | 0x00 5407 | | ADC_TDRL | ADC Schmitt trigger disable register low | 0x00 | | 0x00 5408 | | ADC _HTRH | ADC high threshold register high | 0xFF | | 0x00 5409 | | ADC_HTRL | ADC high threshold register low | 0x03 | | 0x00 540A | | ADC _LTRH | ADC low threshold register high | 0x00 | Table 13. General hardware register map (continued) | Address | Block | Register label Register name | | Reset<br>status | | |---------------------------|----------------------------------------------|------------------------------|------------------------------------|-----------------|--| | 0x00 540B | | ADC_LTRL | ADC low threshold register low | 0x00 | | | 0x00 540C | · | ADC _AWSRH | ADC watchdog status register high | 0x00 | | | 0x00 540D | ADC | ADC_AWSRL | ADC watchdog status register low | 0x00 | | | 0x00 540E | | ADC _AWCRH | ADC watchdog control register high | 0x00 | | | 0x00 540F | ADC _AWCRH ADC watchdog control register low | | 0x00 | | | | 0x00 5410 to<br>0x00 541F | Reserved area (16 bytes) | | | | | <sup>1.</sup> Depends on the previous reset source. Table 14. CPU/SWIM/debug module/interrupt controller registers | Address | Block | Register label | label Register name | | |---------------------------|-------------------------|----------------|----------------------------------------|---------------------| | 0x00 7F00 | A | | Accumulator | 0x00 | | 0x00 7F01 | | PCE | Program counter extended | 0x00 | | 0x00 7F02 | | PCH | Program counter high | 0x80 | | 0x00 7F03 | | PCL | Program counter low | 0x00 | | 0x00 7F04 | | XH | X index register high | 0x00 | | 0x00 7F05 | CPU <sup>(1)</sup> | XL | X index register low | 0x00 | | 0x00 7F06 | | YH | Y index register high | 0x00 | | 0x00 7F07 | | YL | Y index register low | 0x00 | | 0x00 7F08 | | SPH | Stack pointer high | 0x17 <sup>(2)</sup> | | 0x00 7F09 | | SPL | Stack pointer low | 0xFF | | 0x00 7F0A | | CC | Condition code register | 0x28 | | 0x00 7F0B to<br>0x00 7F5F | | | Reserved area (85 bytes) | | | 0x00 7F60 | CPU | CFG_GCR | Global configuration register | 0x00 | | 0x00 7F70 | | ITC_SPR1 | Interrupt software priority register 1 | 0xFF | | 0x00 7F71 | | ITC_SPR2 | Interrupt software priority register 2 | 0xFF | | 0x00 7F72 | ITC | ITC_SPR3 | Interrupt software priority register 3 | 0xFF | | 0x00 7F73 | 110 | ITC_SPR4 | Interrupt software priority register 4 | 0xFF | | 0x00 7F74 | | ITC_SPR5 | Interrupt software priority register 5 | 0xFF | | 0x00 7F75 | | ITC_SPR6 | Interrupt software priority register 6 | 0xFF | | 0x00 7F76 to<br>0x00 7F79 | Reserved area (4 bytes) | | | | | 0x00 7F80 | SWIM | SWIM_CSR | SWIM_CSR SWIM control status register | | <sup>2.</sup> Write only register. Table 14. CPU/SWIM/debug module/interrupt controller registers (continued) | Address | Block | Register label | Register name | Reset<br>status | | |---------------------------|-------------------------|--------------------------|-------------------------------------------|-----------------|--| | 0x00 7F81 to<br>0x00 7F8F | | Reserved area (15 bytes) | | | | | 0x00 7F90 | | DM_BK1RE | DM breakpoint 1 register extended byte | 0xFF | | | 0x00 7F91 | | DM_BK1RH | DM breakpoint 1 register high byte | 0xFF | | | 0x00 7F92 | | DM_BK1RL | DM breakpoint 1 register low byte | 0xFF | | | 0x00 7F93 | DM_BK2RE | | DM breakpoint 2 register extended byte | 0xFF | | | 0x00 7F94 | | DM_BK2RH | DM breakpoint 2 register high byte | 0xFF | | | 0x00 7F95 | DM | DM_BK2RL | DM breakpoint 2 register low byte | 0xFF | | | 0x00 7F96 | | DM_CR1 | DM debug module control register 1 | 0x00 | | | 0x00 7F97 | | DM_CR2 | DM debug module control register 2 | 0x00 | | | 0x00 7F98 | | DM_CSR1 | DM debug module control/status register 1 | 0x10 | | | 0x00 7F99 | | DM_CSR2 | DM debug module control/status register 2 | 0x00 | | | 0x00 7F9A | | DM_ENFCTR | DM enable function register | 0xFF | | | 0x00 7F9B to<br>0x00 7F9F | Reserved area (5 bytes) | | | | | <sup>1.</sup> Accessible by debug module only Table 15. Temporary memory unprotection registers | Address | Block | Register label | Register name | Reset<br>status | |-----------|---------|----------------|-----------------------------------------------------------|-----------------| | 0x00 5800 | | TMU_K1 | Temporary memory unprotection key register 1 | 0x00 | | 0x00 5801 | | TMU_K2 | Temporary memory unprotection key register 2 | 0x00 | | 0x00 5802 | | TMU_K3 | Temporary memory unprotection key register 3 | 0x00 | | 0x00 5803 | | TMU_K4 | Temporary memory unprotection key register 4 | 0x00 | | 0x00 5804 | TMU | TMU_K5 | Temporary memory unprotection key register 5 | 0x00 | | 0x00 5805 | | TMU_K6 | Temporary memory unprotection key register 6 | 0x00 | | 0x00 5806 | | TMU_K7 | Temporary memory unprotection key register 7 | 0x00 | | 0x00 5807 | | TMU_K8 | Temporary memory unprotection key register 8 | 0x00 | | 0x00 5808 | TMU_CSR | | Temporary memory unprotection control and status register | 0x00 | <sup>2.</sup> Product dependent value, see Figure 5: Register and memory map of STM8A products. # 8 Interrupt table Table 16. STM8A interrupt table | Priority | Source<br>block | Description | Interrupt vector address | Wakeup<br>from Halt | Comments | |----------|-------------------------|--------------------------------------------------|--------------------------|---------------------|---------------------| | _ | Reset | Reset | 0x00 6000 | Yes | Reset vector in ROM | | _ | TRAP | SW interrupt | 0x00 8004 | _ | _ | | 0 | TLI | External top level interrupt | 0x00 8008 | _ | _ | | 1 | AWU | Auto-wakeup from Halt | 0x00 800C | Yes | _ | | 2 | Clock<br>controller | Main clock controller | 0x00 8010 | _ | _ | | 3 | MISC | Ext interrupt E0 | 0x00 8014 | Yes | Port A interrupts | | 4 | MISC | Ext interrupt E1 | 0x00 8018 | Yes | Port B interrupts | | 5 | MISC | Ext interrupt E2 | 0x00 801C | Yes | Port C interrupts | | 6 | MISC | Ext interrupt E3 | 0x00 8020 | Yes | Port D interrupts | | 7 | MISC | Ext interrupt E4 | 0x00 8024 | Yes | Port E interrupts | | 8 | Reserved <sup>(1)</sup> | _ | _ | _ | _ | | 9 | Reserved <sup>(1)</sup> | _ | _ | _ | _ | | 10 | SPI | End of transfer | 0x00 8030 | Yes | _ | | 11 | Timer 1 | Update/overflow/<br>trigger/break | 0x00 8034 | _ | _ | | 12 | Timer 1 | Capture/compare | 0x00 8038 | _ | _ | | 13 | Timer 2 | Update/overflow | 0x00 803C | _ | _ | | 14 | Timer 2 | Capture/compare | 0x00 8040 | _ | _ | | 15 | Timer 3 | Update/overflow | 0x00 8044 | _ | _ | | 16 | Timer 3 | Capture/compare | 0x00 8048 | _ | _ | | 17 | Reserved <sup>(1)</sup> | _ | _ | _ | _ | | 18 | Reserved <sup>(1)</sup> | _ | _ | _ | _ | | 19 | I <sup>2</sup> C | I <sup>2</sup> C interrupts | 0x00 8054 | Yes | _ | | 20 | LINUART | Tx complete/error | 0x00 8058 | _ | _ | | 21 | LINUART | Receive data full reg. | 0x00 805C | _ | _ | | 22 | ADC | End of conversion | 0x00 8060 | _ | _ | | 23 | Timer 4 | Update/overflow | 0x00 8064 | _ | | | 24 | EEPROM | End of Programming/<br>Write in not allowed area | 0x00 8068 | _ | _ | <sup>1.</sup> All reserved and unused interrupts must be initialized with 'IRET' for robust programming. # 9 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. Each option byte has to be stored twice, for redundancy, in a regular form (OPTx) and a complemented one (NOPTx), except for the ROP (read-out protection) option byte and option bytes 8 to 16. Option bytes can be modified in ICP mode (via SWIM) by accessing the EEPROM address shown in *Table 17: 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 (PM0051) and STM8 SWIM communication protocol and debug module user manual (UM0470) for information on SWIM programming procedures. Table 17. Option bytes | Addr. | Option | Option | | Option bits | | | | | Factory default | | | |--------------|---------------------------------|----------|-----------|-------------|-----------|-----------------|-------------|---------------|-----------------|---------------|---------| | Addi. | name | byte no. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | setting | | 0x00<br>4800 | Read-out<br>protection<br>(ROP) | OPT0 | | ROP[7:0] | | | | | | 0x00 | | | 0x00<br>4801 | User boot code | OPT1 | Rese | erved | | | UBC | C[5:0] | | | 0x00 | | 0x00<br>4802 | (UBC) | NOPT1 | Rese | Reserved | | | NUB | C[5:0] | | | 0xFF | | 0x00<br>4803 | Alternate function | OPT2 | AFR7 | AFR6 | AFR5 | AFR4 | AFR3 | AFR2 | AFR1 | AFR0 | 0x00 | | 0x00<br>4804 | remapping<br>(AFR) | NOPT2 | NAFR<br>7 | NAFR<br>6 | NAFR<br>5 | NAFR<br>4 | NAFR<br>3 | NAFR<br>2 | NAFR<br>1 | NAFR<br>0 | 0xFF | | 0x00<br>4805 | Watchdog | ОРТ3 | | Reserved | d | 16MHZ<br>TRIM0 | LSI<br>_EN | IWDG<br>_HW | WWDG<br>_HW | WWDG<br>_HALT | 0x00 | | 0x00<br>4806 | option | NOPT3 | | Reserved | d | N16MHZ<br>TRIM0 | NLSI<br>_EN | NIWDG<br>_HW | NWWD<br>G_HW | NWWG<br>_HALT | 0xFF | | 0x00<br>4807 | Clock | OPT4 | | Res | served | | EXT<br>CLK | CKAWU<br>SEL | PRS<br>C1 | PRS<br>C0 | 0x00 | | 0x00<br>4808 | option | NOPT4 | Reserved | | | | NEXT<br>CLK | NCKAW<br>USEL | NPR<br>SC1 | NPR<br>SC0 | 0xFF | | 0x00<br>4809 | HSE clock | OPT5 | | HSECNT[7:0] | | | | | | 0x00 | | | 0x00<br>480A | startup | NOPT5 | | | | NHSE | CNT[7:0] | | | | 0xFF | Table 17. Option bytes (continued) | A -1 -1 | Option | Option | | | | Opti | on bits | | | | Factory | |----------------------------|-----------------------|----------|---|------------------|---|----------|-------------|---|------|----------------|--------------------| | Addr. | name | byte no. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | default<br>setting | | 0x00<br>480B | TMU | ОРТ6 | | TMU[3:0] | | | | | | | 0x00 | | 0x00<br>480C | TIVIO | NOPT6 | | | | NTN | /IU[3:0] | | | | 0xFF | | 0x00<br>480D | Flash wait | OPT7 | | | | Reserve | ed | | | WAIT<br>STATE | 0x00 | | 0x00<br>480E | states | NOPT7 | | | | Reserve | ed | | | NWAIT<br>STATE | 0xFF | | 0x00<br>480F | | | | | | Reserved | | | | | | | 0x00<br>4810 | | ОРТ8 | | | | TMU_k | (EY 1 [7:0] | | | | 0x00 | | 0x00<br>4811 | | ОРТ9 | | | | TMU_k | (EY 2 [7:0] | ] | | | 0x00 | | 0x00<br>4812 | | OPT10 | | TMU_KEY 3 [7:0] | | | | | | 0x00 | | | 0x00<br>4813 | | OPT11 | | TMU_KEY 4 [7:0] | | | | | 0x00 | | | | 0x00<br>4814 | TMU | OPT12 | | TMU_KEY 5 [7:0] | | | | | 0x00 | | | | 0x00<br>4815 | | OPT13 | | | | TMU_k | (EY 6 [7:0] | ] | | | 0x00 | | 0x00<br>4816 | | OPT14 | | | | TMU_k | (EY 7 [7:0] | ] | | | 0x00 | | 0x00<br>4817 | | OPT15 | | | | TMU_k | (EY 8 [7:0] | ] | | | 0x00 | | 0x00<br>4818 | | OPT16 | | TMU_MAXATT [7:0] | | | | | | 0xC7 | | | 0x00<br>4819<br>to<br>487D | | | | | | Reserved | | | | | | | 0x00<br>487E | Boot- | OPT17 | | | | BL | [7:0] | | | | 0x00 | | 0x00<br>487F | loader <sup>(1)</sup> | NOPT17 | | | | NB | BL[7:0] | | | | 0xFF | This option consists of two bytes that must have a complementary value in order to be valid. If the option is invalid, it has no effect on EMC reset. Table 18. Option byte description | Option byte no. | Description | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OPT0 | ROP[7:0]: Memory readout protection (ROP) 0xAA: Enable readout protection (write access via SWIM protocol) Note: Refer to the STM8S and STM8A microcontroller families reference manual (RM0016) section on Flash/EEPROM memory readout protection for details. | | OPT1 | UBC[5:0]: User boot code area 0x00: No UBC, no write-protection 0x01: Page 0 to 1 defined as UBC, memory write-protected 0x02: Page 0 to 3 defined as UBC, memory write-protected 0x03 to 0x3F: Pages 4 to 63 defined as UBC, memory write-protected Note: Refer to the STM8S and STM8A microcontroller families reference manual (RM0016) section on Flash/EEPROM write protection for more details. | | OPT2 | AFR7: Alternate function remapping option 7 0: Port D4 alternate function = TIM2_CH1 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 B0 alternate function = AIN0. 1: Port B3 alternate function = TIM1_ETR, port B2 alternate function = TIM1_CH3N, port B1 alternate function = TIM1_CH2N, port B0 alternate function = TIM1_CH3N, port B1 alternate function = TIM1_CH2N, port B0 alternate function = TIM1_CH2N, bort B0 alternate function = TIM1_CH2N, port B0 alternate function = TIM1_CH2N, port B0 alternate function = TIM1_CH2N, port B0 alternate function = TIM1_CH2N, port B0 alternate function = TIM3_CH2 1: Port D0 alternate function = TIM3_CH2 1: Port D0 alternate function = TIM3_CH2 1: Port D0 alternate function = CLK_CCO Note: AFR2 option has priority over AFR3 if both are activated AFR1: Alternate function remapping option 1 0: Port A3 alternate function = TIM2_CH3, port D2 alternate function TIM3_CH1. 1: Port A3 alternate function = TIM3_CH1, port D2 alternate function TIM2_CH3. AFR0: Alternate function remapping option 0 0: Port D3 alternate function = TIM2_CH2 1: Port D3 alternate function = ADC_ETR | Table 18. Option byte description (continued) | Option byte no. | Description | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | HSITRIM: Trimming option for 16 MHz internal RC oscillator 0: 3-bit on-the-fly trimming (compatible with devices based on the 128K silicon) 1: 4-bit on-the-fly trimming | | | 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 | | OPT3 | IWDG_HW: Independent watchdog 0: IWDG independent watchdog activated by software 1: IWDG independent watchdog activated by hardware | | | 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-wakeup unit/clock 0: LSI clock source selected for AWU 1: HSE clock with prescaler selected as clock source for AWU | | | PRSC[1:0]: AWU clock prescaler 00: Reserved 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 stabilization time to 0.5, 8, 128, and 2048 HSE cycles with corresponding option byte values of 0xE1, 0xD2, 0xB4, and 0x00. | | OPT6 | TMU[3:0]: Enable temporary memory unprotection 0101: TMU disabled (permanent ROP). Any other value: TMU enabled. | | OPT7 | Reserved | | OPT8 | TMU_KEY 1 [7:0]: Temporary unprotection key 0 Temporary unprotection key: Must be different from 0x00 or 0xFF | | OPT9 | TMU_KEY 2 [7:0]: Temporary unprotection key 1 Temporary unprotection key: Must be different from 0x00 or 0xFF | | OPT10 | TMU_KEY 3 [7:0]: Temporary unprotection key 2 Temporary unprotection key: Must be different from 0x00 or 0xFF | | OPT11 | TMU_KEY 4 [7:0]: Temporary unprotection key 3 Temporary unprotection key: Must be different from 0x00 or 0xFF | Table 18. Option byte description (continued) | Option byte no. | Description | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OPT12 | TMU_KEY 5 [7:0]: Temporary unprotection key 4 Temporary unprotection key: Must be different from 0x00 or 0xFF | | OPT13 | TMU_KEY 6 [7:0]: Temporary unprotection key 5 Temporary unprotection key: Must be different from 0x00 or 0xFF | | OPT14 | TMU_KEY 7 [7:0]: Temporary unprotection key 6 Temporary unprotection key: Must be different from 0x00 or 0xFF | | OPT15 | TMU_KEY 8 [7:0]: Temporary unprotection key 7 Temporary unprotection key: Must be different from 0x00 or 0xFF | | OPT16 | TMU_MAXATT [7:0]: TMU access failure counter TMU_MAXATT can be initialized with the desired value only if TMU is disabled (TMU[3:0]=0101 in OPT6 option byte). When TMU is enabled, any attempt to temporary remove the readout protection by using wrong key values increments the counter. When the option byte value reaches 0x08, the Flash memory and data EEPROM are erased. | | OPT17 | BL [7:0]: Bootloader enable If this option byte is set to 0x55 (complementary value 0xAA) the bootloader program is activated also in case of a programmed code memory (for more details, see the bootloader user manual, UM0560). | # 10 Electrical characteristics #### 10.1 Parameter conditions Unless otherwise specified, all voltages are referred to V<sub>SS</sub>. #### 10.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 = -40$ °C, $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. # 10.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. # 10.1.3 Typical curves Unless otherwise specified, all typical curves are given only as design guidelines and are not tested. # 10.1.4 Loading capacitor The loading conditions used for pin parameter measurement are shown in Figure 6. Figure 6. Pin loading conditions # 10.1.5 Pin input voltage The input voltage measurement on a pin of the device is described in Figure 7. Figure 7. Pin input voltage # 10.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 19. Voltage characteristics | Symbol | Ratings | Min | Max | Unit | | |---------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------------|------|--| | V <sub>DDx</sub> - V <sub>SS</sub> | Supply voltage (including V <sub>DDA and</sub> V <sub>DDIO</sub> ) <sup>(1)</sup> | -0.3 | 6.5 | V | | | V | Input voltage on true open drain pins (PE1, PE2) <sup>(2)</sup> | V <sub>SS</sub> - 0.3 | 6.5 | V | | | V <sub>IN</sub> | Input voltage on any other pin <sup>(2)</sup> | V <sub>SS</sub> - 0.3 | V <sub>DD</sub> + 0.3 | V | | | IV <sub>DDx</sub> - V <sub>DD</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 | IIIV | | | V <sub>ESD</sub> | Electrostatic discharge voltage | see Absolute maximum rating<br>(electrical sensitivity) on<br>page 72 | | • | | <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 <sup>2.</sup> 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 20. Current characteristics | Symbol | Ratings | Max. | Unit | |--------------------------------------|----------------------------------------------------------------------------------|------|------| | I <sub>VDDIO</sub> | Total current into V <sub>DDIO</sub> power lines (source) <sup>(1)(2)(3)</sup> | 100 | | | I <sub>VSSIO</sub> | Total current out of V <sub>SS IO</sub> ground lines (sink) <sup>(1)(2)(3)</sup> | 100 | | | | Output current sunk by any I/O and control pin | 20 | A | | IIO | Output current source by any I/Os and control pin | -20 | mA | | I <sub>INJ(PIN)</sub> <sup>(4)</sup> | Injected current on any pin | ±10 | | | I <sub>INJ(TOT)</sub> | Sum of injected currents | 50 | ] | - 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. - V<sub>DDIO</sub> includes the sum of the positive injection currents. V<sub>SSIO</sub> includes the sum of the negative injection currents. - 4. This condition 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>IN,I/(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 allowed and the corresponding V<sub>IN</sub> maximum must always be respected. Table 21. Thermal characteristics | Symbol | Ratings | Value | Unit | |------------------|------------------------------|----------------------------|------| | T <sub>STG</sub> | Storage temperature range | -65 to 150 | °C | | T <sub>J</sub> | Maximum junction temperature | n junction temperature 160 | | Table 22. Operating lifetime<sup>(1)</sup> | Symbol | Ratings | Value | Unit | |--------|------------------------------|---------------|---------| | OLF | Conforming to AEC-Q100 rev G | -40 to 125 °C | Grade 1 | | | Conforming to AEC-Q100 fev G | -40 to 150 °C | Grade 0 | 1. For detailed mission profile analysis, please contact your local ST Sales Office. # 10.3 Operating conditions Table 23. General operating conditions | | able 20. General operating conditions | | | | | | |------------------------------------|------------------------------------------------------|-----------------------------------|----------|------|------|----| | Symbol | Parameter | Conditions | Min | Max | Unit | | | f <sub>CPU</sub> | Internal CPU clock frequency | T <sub>A</sub> = -40 °C to 150 °C | 0 | 16 | MHz | | | V <sub>DD/</sub> V <sub>DDIO</sub> | Standard operating voltage | - | 3.0 | 5.5 | V | | | (1) | C <sub>EXT</sub> : capacitance of external capacitor | | 470 | 3300 | nF | | | V <sub>CAP</sub> <sup>(1)</sup> | ESR of external capacitor | at 1 MHz <sup>(2)</sup> | - | 0.3 | Ω | | | | ESL of external capacitor | - מנו ואורוב <i>י</i> י | - | 15 | nΗ | | | P <sub>D</sub> | Power dissipation (all temperature ranges) | LQFP32 | - | 85 | | | | | | | VFQFPN32 | - | 200 | mW | | | | LQFP48 | - | 88 | | | | | | Suffix A | | 85 | | | | _ | Ambient temperature | Suffix B | | 105 | | | | T <sub>A</sub> | Ambient temperature | Suffix C | | 125 | | | | | | Suffix D <sup>(3)</sup> | -40 | 150 | °C | | | | | Suffix A | -40 | 90 | C | | | ТЈ | lunation tomporature resea | Suffix B | | 110 | | | | | Junction temperature range | Suffix C | | 130 | | | | | | Suffix D <sup>(3)</sup> | | 155 | | | Care should be taken when selecting the capacitor, due to its tolerance, as well as the parameter dependency on temperature, DC bias and frequency in addition to other factors. The parameter maximum value must be respected for the full application range. <sup>2.</sup> This frequency of 1 MHz as a condition for $V_{CAP}$ parameters is given by design of internal regulator. <sup>3.</sup> Available on STM8AF62xx devices only. Figure 8. f<sub>CPUmax</sub> versus V<sub>DD</sub> 1. This figure is valid only for STM8AF62xx devices. Table 24. Operating conditions at power-up/power-down | in a position of position approximation and position | | | | | | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------------------|------------------|-------------------|------|------|--| | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | | | t <sub>VDD</sub> | V <sub>DD</sub> rise time rate | - | 2 <sup>(1)</sup> | - | ∞ | πο// | | | | V <sub>DD</sub> fall time rate | - | 2 <sup>(1)</sup> | - | ∞ | μs/V | | | | Reset release delay | V <sub>DD</sub> rising | - | 3 | - | ms | | | t <sub>TEMP</sub> | Reset generation delay | V <sub>DD</sub> falling | - | 3 | - | μs | | | V <sub>IT+</sub> | Power-on reset<br>threshold <sup>(2)</sup> | - | 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 | | <sup>1.</sup> Guaranteed by design, not tested in production <sup>2.</sup> If $V_{DD}$ is below 3 V, the code execution is guaranteed above the $V_{IT}$ and $V_{IT+}$ thresholds. RAM content is kept. The EEPROM programming sequence must not be initiated. # 10.3.1 VCAP external capacitor Stabilization for the main regulator is achieved connecting an external capacitor $C_{\text{EXT}}$ to the $V_{\text{CAP}}$ pin. $C_{\text{EXT}}$ is specified in *Table 23*. Care should be taken to limit the series inductance to less than 15 nH. Figure 9. External capacitor C<sub>EXT</sub> 1. Legend: ESR is the equivalent series resistance and ESL is the equivalent inductance. # 10.3.2 Supply current characteristics The current consumption is measured as described in *Figure 6 on page 46* and *Figure 7 on page 47*. If not explicitly stated, general conditions of temperature and voltage apply. Table 25. Total current consumption in Run, Wait and Slow mode. General conditions for $V_{DD}$ apply, $T_A = -40$ to 150 °C | Symbol | Parameter | Condi | tions | Тур | Max | Unit | |--------------------------------------|------------------------|-------------------------------------------------------|-------------------------------------------------|------|---------------------|------| | | | All peripherals | f <sub>CPU</sub> = 16 MHz | 7.4 | 14 | | | (1) | Supply | clocked, code<br>executed from Flash | f <sub>CPU</sub> = 8 MHz | 4.0 | 7.4 <sup>(2)</sup> | | | I <sub>DD(RUN)</sub> <sup>(1)</sup> | current in<br>Run mode | program memory,<br>HSE external clock | f <sub>CPU</sub> = 4 MHz | 2.4 | 4.1 <sup>(2)</sup> | | | | | (without resonator) | f <sub>CPU</sub> = 2 MHz | 1.5 | 2.5 | | | | | All peripherals | f <sub>CPU</sub> = 16 MHz | 3.7 | 5.0 | | | (1) | Supply current in | clocked, code<br>executed from RAM | f <sub>CPU</sub> = 8 MHz | 2.2 | 3.0 <sup>(2)</sup> | | | I <sub>DD(RUN)</sub> <sup>(1)</sup> | Run mode | and EEPROM, HSE external clock (without resonator) | f <sub>CPU</sub> = 4 MHz | 1.4 | 2.0 <sup>(2)</sup> | | | | | | f <sub>CPU</sub> = 2 MHz | 1.0 | 1.5 | mA | | | | | f <sub>CPU</sub> = 16 MHz | 1.65 | 2.5 | | | I <sub>DD(WFI)</sub> <sup>(1)</sup> | Supply current in | CPU stopped, all peripherals off, HSE | f <sub>CPU</sub> = 8 MHz | 1.15 | 1.9 <sup>(2)</sup> | | | 'DD(WFI)` | Wait mode | external clock | f <sub>CPU</sub> = 4 MHz | 0.90 | 1.6 <sup>(2)</sup> | | | | | | f <sub>CPU</sub> = 2 MHz | 0.80 | 1.5 | | | (1) | Supply current in | f <sub>CPU</sub> scaled down,<br>all peripherals off, | Ext. clock 16 MHz<br>f <sub>CPU</sub> = 125 kHz | 1.50 | 1.95 | | | I <sub>DD(SLOW)</sub> <sup>(1)</sup> | Slow mode | code executed from RAM | LSI internal RC<br>f <sub>CPU</sub> = 128 kHz | 1.50 | 1.80 <sup>(2)</sup> | | <sup>1.</sup> The current due to I/O utilization is not taken into account in these values. <sup>2.</sup> Values not tested in production. Design guidelines only. Table 26. Total current consumption in Halt and Active-halt modes. General conditions for $V_{DD}$ apply, $T_A$ = -40 to 55 °C | | | Conditions | | | | | | | |---------------------|----------------------------------------------------------|------------------------------------------------------|----------------------------------------------|----------------------------------------------------|-------------------------------------------|--------------------|------|--| | Symbol | Parameter | Main<br>voltage<br>regulator<br>(MVR) <sup>(1)</sup> | Flash specific temperature condition | | Тур | Max | Unit | | | | Power- | | Clocks stopped | 5 | 35 <sup>(3)</sup> | | | | | I <sub>DD(H)</sub> | Supply current in Halt mode | Off down | | Supply current in Halt mode I Off I i i i i i I | Clocks stopped,<br>T <sub>A</sub> = 25 °C | 5 | 25 | | | | Supply current in Active-halt mode with regulator on | On | Power-<br>down | Ext. clock 16 MHz<br>f <sub>MASTER</sub> = 125 kHz | 770 | 900 <sup>(3)</sup> | μA | | | | | | down | LSI clock 128 kHz | 150 | 230 <sup>(3)</sup> | - | | | I <sub>DD(AH)</sub> | Supply current in Active-halt | Off Power-down | Dower | LSI clock 128 kHz | 25 | 42 <sup>(3)</sup> | | | | | Supply current in Active-halt mode with regulator off | | LSI clock 128 kHz,<br>T <sub>A</sub> = 25 °C | 25 | 30 | | | | | t | Wakeup time from Active-<br>halt mode with regulator on | On | Operating | T <sub>A</sub> = -40 to 150 °C | 10 | 30 <sup>(3)</sup> | μs | | | t <sub>WU(AH)</sub> | Wakeup time from Active-<br>halt mode with regulator off | Off | mode | 1 <sub>A</sub> = -40 to 130 °C | 50 | 80 <sup>(3)</sup> | μδ | | - 1. Configured by the REGAH bit in the CLK\_ICKR register. - 2. Configured by the AHALT bit in the FLASH\_CR1 register. - 3. Data based on characterization results. Not tested in production. # **Current consumption for on-chip peripherals** Table 27. Oscillator current consumption | Symbol | Parameter | Con | ditions | Тур | Max <sup>(1)</sup> | Unit | |----------------------|----------------------------------------------------------------------------------------------------------------------|---------------------------------------|---------------------------|------|--------------------|------| | | | Quartz or | f <sub>OSC</sub> = 24 MHz | 1 | 2.0 <sup>(3)</sup> | | | I <sub>DD(OSC)</sub> | $I_{DD(OSC)}$ HSE oscillator current consumption <sup>(2)</sup> ceramic resonator, CL = 33 pF $V_{DD} = 5 \text{ V}$ | | f <sub>OSC</sub> = 16 MHz | 0.6 | - | | | DD(030) | | | f <sub>OSC</sub> = 8 MHz | 0.57 | 1 | - mA | | | | Quartz or | f <sub>OSC</sub> = 24 MHz | 0.5 | 1.0 <sup>(3)</sup> | IIIA | | I <sub>DD(OSC)</sub> | consumption <sup>(2)</sup> re | ceramic resonator, | f <sub>OSC</sub> = 16 MHz | 0.25 | - | | | -DD(OSC) | | CL = 33 pF<br>V <sub>DD</sub> = 3.3 V | f <sub>OSC</sub> = 8 MHz | 0.18 | ı | | - 1. During startup, the oscillator current consumption may reach 6 mA. - 2. The supply current of the oscillator can be further optimized by selecting a high quality resonator with small $R_{\rm m}$ value. Refer to crystal manufacturer for more details - 3. Informative data. Table 28. Programming current consumption | Symbol | Parameter | Conditions | Тур | Max | Unit | |-----------------------|---------------------|-----------------------------------------------------------------------------------------------------|-----|-----|------| | I <sub>DD(PROG)</sub> | Programming current | V <sub>DD</sub> = 5 V, -40 °C to 150 °C,<br>erasing and programming data<br>or Flash program memory | 1.0 | 1.7 | mA | Table 29. Typical peripheral current consumption $V_{DD} = 5.0 V^{(1)}$ | Symbol | Parameter | Typ. f <sub>master</sub> = 2 MHz | Typ. f <sub>master</sub> =<br>16 MHz | Unit | |---------------------------------|---------------------------------------------------|----------------------------------|--------------------------------------|------| | I <sub>DD(TIM1)</sub> | TIM1 supply current <sup>(2)</sup> | 0.03 | 0.23 | | | I <sub>DD(TIM2)</sub> | TIM2 supply current (2) | 0.02 | 0.12 | | | I <sub>DD(TIM3)</sub> | TIM3 supply current <sup>(2)</sup> | 0.01 | 0.1 | | | I <sub>DD(TIM4)</sub> | TIM4 supply current <sup>(2)</sup> | 0.004 | 0.03 | | | I <sub>DD(LINUART)</sub> | LINUART supply current <sup>(2)</sup> | 0.03 | 0.11 | | | I <sub>DD(SPI)</sub> | SPI supply current <sup>(2)</sup> | 0.01 | 0.04 | mA | | I <sub>DD(I<sup>2</sup>C)</sub> | I <sup>2</sup> C supply current <sup>(2)</sup> | 0.02 | 0.06 | | | I <sub>DD(AWU)</sub> | AWU supply current <sup>(2)</sup> | 0.003 | 0.02 | | | I <sub>DD(TOT_DIG)</sub> | All digital peripherals on | 0.22 | 1 | | | I <sub>DD(ADC)</sub> | ADC supply current when converting <sup>(3)</sup> | 0.93 | 0.95 | | 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. ### **Current consumption curves** *Figure 10* to *Figure 15* show typical current consumption measured with code executing in RAM. Figure 10. Typ. $I_{DD(RUN)HSE}$ vs. $V_{DD}$ @ $f_{CPU}$ = 16 MHz, peripheral = on Figure 11. Typ. $I_{DD(RUN)HSE}$ vs. $f_{CPU}$ @ $V_{DD}$ = 5.0 V, peripheral = on <sup>2.</sup> Data based on a differential $I_{DD}$ measurement between no peripheral clocked and a single active peripheral. 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. Figure 12. Typ. $I_{DD(RUN)HSI}$ vs. $V_{DD}$ @ $f_{CPU}$ = 16 MHz, peripheral = off Figure 13. Typ. $I_{DD(WFI)HSE}$ vs. $V_{DD}$ @ $f_{CPU}$ = 16 MHz, peripheral = on Figure 14. Typ. $I_{DD(WFI)HSE}$ vs. $f_{CPU}$ @ $V_{DD}$ = 5.0 V, peripheral = on Figure 15. Typ. $I_{DD(WFI)HSI}$ vs. $V_{DD}$ @ $f_{CPU}$ = 16 MHz, peripheral = off # 10.3.3 External clock sources and timing characteristics #### **HSE** user external clock Subject to general operating conditions for V<sub>DD</sub> and T<sub>A</sub>. Table 30. 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> is -40 to<br>150 °C | 0 <sup>(1)</sup> | - | 16 | MHz | | $V_{HSEdHL}$ | Comparator hysteresis | - | 0.1 x V <sub>DD</sub> | 1 | - | | | V <sub>HSEH</sub> | OSCIN input pin high level voltage | - | 0.7 x V <sub>DD</sub> | - | $V_{DD}$ | V | | V <sub>HSEL</sub> | OSCIN input pin low level voltage | - | $V_{SS}$ | - | 0.3 x V <sub>DD</sub> | | | I <sub>LEAK_HSE</sub> | OSCIN input leakage current | $V_{SS} < V_{IN} < V_{DD}$ | -1 | - | +1 | μΑ | <sup>1.</sup> In CSS is used, the external clock must have a frequency above 500 kHz. Figure 16. HSE external clock source # HSE crystal/ceramic resonator oscillator The HSE clock can be supplied using a crystal/ceramic resonator oscillator of up to 16 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 startup stabilization time. Refer to the crystal resonator manufacturer for more details (frequency, package, accuracy...). Table 31. HSE oscillator characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |-------------------------------------------------|------------------------------|----------------------------------|-----|-----|-----|------| | R <sub>F</sub> | Feedback resistor | - | - | 220 | - | kΩ | | C <sub>L1</sub> /C <sub>L2</sub> <sup>(1)</sup> | Recommended load capacitance | - | - | - | 20 | pF | | g <sub>m</sub> | Oscillator transconductance | - | 5 | - | - | mA/V | | t <sub>SU(HSE)</sub> <sup>(2)</sup> | Startup time | V <sub>DD</sub> is<br>stabilized | - | 2.8 | - | ms | <sup>1.</sup> The oscillator needs two load capacitors, $C_{L1}$ and $C_{L2}$ , to act as load for the crystal. The total load capacitance ( $C_{load}$ ) is $(C_{L1} * C_{L2})/(C_{L1} + C_{L2})$ . If $C_{L1} = C_{L2}$ , $C_{load} = C_{L1}$ / 2. Some oscillators have built-in load capacitors, $C_{L1}$ and $C_{L2}$ . Figure 17. HSE oscillator circuit diagram <sup>2.</sup> This value is the startup time, measured from the moment it is enabled (by software) until a stabilized 16 MHz oscillation is reached. It can vary with the crystal type that is used. # HSE oscillator critical g<sub>m</sub> formula The crystal characteristics have to be checked with the following formula: $$g_m \gg g_{mcrit}$$ where $\mathbf{g}_{\text{mcrit}}$ can be calculated with the crystal parameters as follows: $$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 # 10.3.4 Internal clock sources and timing characteristics Subject to general operating conditions for $V_{DD}$ and $T_{A}$ . # High speed internal RC oscillator (HSI) Table 32. HSI oscillator characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |----------------------|----------------------------------------------|-------------------------------------------------------------------------------------|---------------------|-----|--------------------|------| | f <sub>HSI</sub> | Frequency | | - | 16 | - | MHz | | ACC <sub>HS</sub> | HSI oscillator user | Trimmed by the application | -1 <sup>(1)</sup> | - | 1 <sup>(1)</sup> | | | | trimming accuracy | for any V <sub>DD</sub> and T <sub>A</sub> conditions | -0.5 <sup>(1)</sup> | - | 0.5 <sup>(1)</sup> | % | | | HSI oscillator accuracy (factory calibrated) | $V_{DD} = 3.0 \text{ V} \le V_{DD} \le 5.5 \text{ V},$<br>-40 °C \le T_A \le 150 °C | -5 | - | 5 | | | t <sub>su(HSI)</sub> | HSI oscillator wakeup time | | - | - | 2 <sup>(2)</sup> | μs | - 1. Depending on option byte setting (OPT3 and NOPT3) - 2. Guaranteed by characterization, not tested in production Figure 18. Typical HSI frequency vs $V_{\rm DD}$ # Low speed internal RC oscillator (LSI) Subject to general operating conditions for $V_{DD}$ and $T_{A}$ . Table 33. 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 wakeup time | - | - | - | 7 <sup>(1)</sup> | μs | <sup>1.</sup> Data based on characterization results, not tested in production. # 10.3.5 Memory characteristics # Flash program memory/data EEPROM memory General conditions: $T_A = -40$ to 150 °C. Table 34. Flash program memory/data EEPROM memory | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |--------------------|--------------------------------------------------------------------------------------------------|----------------------------------------------|-------|-----|-----|------| | $V_{DD}$ | Operating voltage (all modes, execution/write/erase) | f <sub>CPU</sub> is 0 to 16 MHz<br>with 0 ws | 3.0 - | | 5.5 | V | | V <sub>DD</sub> | Operating voltage (code execution) | f <sub>CPU</sub> is 0 to 16 MHz<br>with 0 ws | 2.6 | - | 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 | | | Fast programming time for 1 block (128 bytes) | - | - | 3 | 3.3 | | | t <sub>erase</sub> | Erase time for 1 block (128 bytes) | - | - | 3 | 3.3 | ms | Table 35. Flash program memory | Symbol | Parameter | Condition | Min | Max | Unit | |------------------|--------------------------------------------------------------------|------------------------|------|-----|-------------------| | T <sub>WE</sub> | Temperature for writing and erasing | - | -40 | 150 | °C | | N <sub>WE</sub> | Flash program memory endurance (erase/write cycles) <sup>(1)</sup> | T <sub>A</sub> = 25 °C | 1000 | - | cycles | | t <sub>RET</sub> | Data retention time | T <sub>A</sub> = 25 °C | 40 | i | veare | | | Data retention time | T <sub>A</sub> = 55 °C | 20 | - | cycles<br>- years | The physical granularity of the memory is four bytes, so cycling is performed on four bytes even when a write/erase operation addresses a single byte. Table 36. Data memory | Symbol | Parameter | Condition | Min | Max | Unit | |------------------|--------------------------------------|--------------------------|----------------------|-----|--------| | T <sub>WE</sub> | Temperature for writing and erasing | | -40 | 150 | °C | | N <sub>WE</sub> | Data memory endurance <sup>(1)</sup> | T <sub>A</sub> = 25 °C | 300 k | - | cycles | | | (erase/write cycles) | $T_A = -40$ °C to 125 °C | 100 k <sup>(2)</sup> | - | Cycles | | t <sub>RET</sub> | Data retention time | T <sub>A</sub> = 25 °C | 40 <sup>(2)(3)</sup> | - | vooro | | | Data retention time | T <sub>A</sub> = 55 °C | 20 <sup>(2)(3)</sup> | - | years | The physical granularity of the memory is four bytes, so cycling is performed on four bytes even when a write/erase operation addresses a single byte. <sup>2.</sup> More information on the relationship between data retention time and number of write/erase cycles is available in a separate technical document. <sup>3.</sup> Retention time for 256B of data memory after up to 1000 cycles at 125 $^{\circ}$ C. # 10.3.6 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 37. I/O static characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | | |---------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------|--------------------------|-------------------------|------------|--| | $V_{IL}$ | Input low level voltage | | -0.3 V | | 0.3 x V <sub>DD</sub> | | | | V <sub>IH</sub> | Input high level voltage | | 0.7 x V <sub>DD</sub> | | V <sub>DD</sub> + 0.3 V | | | | V <sub>hys</sub> | Hysteresis <sup>(1)</sup> | | - | 0.1 x<br>V <sub>DD</sub> | - | _ | | | V <sub>OH</sub> | Output high level voltage | Standard I/0, V <sub>DD</sub> = 5 V,<br>I = 3 mA | V <sub>DD</sub> - 0.5 V | ı | - | | | | VOH | Output high level voltage | Standard I/0, $V_{DD} = 3 V$ , I = 1.5 mA | V <sub>DD</sub> - 0.4 V | - | - | | | | | | High sink and true open<br>drain I/0, V <sub>DD</sub> = 5 V<br>I = 8 mA | ı | 1 | 0.5 | | | | V <sub>OL</sub> | Output low level voltage | Standard I/0, $V_{DD} = 5 \text{ V}$<br>I = 3 mA | - | - | 0.6 | V | | | | | Standard I/0, V <sub>DD</sub> = 3 V<br>I = 1.5 mA | - | - | 0.4 | | | | R <sub>pu</sub> | Pull-up resistor | $V_{DD} = 5 \text{ V}, V_{IN} = V_{SS}$ | 35 | 50 | 65 | kΩ | | | | | Fast I/Os<br>Load = 50 pF | - | - | 35 <sup>(2)</sup> | | | | | Rise and fall time | Standard and high sink I/Os<br>Load = 50 pF | - | - | 125 <sup>(2)</sup> | ns | | | t <sub>R</sub> , t <sub>F</sub> | (10% - 90%) | Fast I/Os<br>Load = 20 pF | | | 20 <sup>(2)</sup> | 115 | | | | | Standard and high sink I/Os<br>Load = 20 pF | | | 50 <sup>(2)</sup> | | | | I <sub>lkg</sub> | Digital input pad leakage current | $V_{SS} \leq V_{IN} \leq V_{DD}$ | - | - | ±1 | μΑ | | | | Analog input pad leakage | $V_{SS} \le V_{IN} \le V_{DD}$<br>-40 °C < $T_A$ < 125 °C | - | - | ±250 | <b>π</b> Λ | | | I <sub>Ikg</sub> ana | current | $V_{SS} \le V_{IN} \le V_{DD}$<br>-40 °C < $T_A$ < 150 °C | - | - | ±500 | nA | | | I <sub>lkg(inj)</sub> | Leakage current in adjacent I/O <sup>(3)</sup> | Injection current ±4 mA | - | - | ±1 <sup>(3)</sup> | μΑ | | | I <sub>DDIO</sub> | Total current on either V <sub>DDIO</sub> or V <sub>SSIO</sub> | Including injection currents | - | - | 60 | mA | | <sup>1.</sup> Hysteresis voltage between Schmitt trigger switching levels. Based on characterization results, not tested in production. - 2. Guaranteed by design. - 3. Data based on characterization results, not tested in production. Figure 20. Typical $\rm V_{IL}$ and $\rm V_{IH}$ vs $\rm V_{DD}$ @ four temperatures Figure 21. Typical pull-up resistance $\rm R_{PU}$ vs $\rm V_{DD}$ @ four temperatures #### Typical output level curves Figure 23 to Figure 32 show typical output level curves measured with output on a single pin. Figure 25. Typ. $V_{OL}$ @ $V_{DD}$ = 3.3 V (true open Figure 26. Typ. $V_{OL}$ @ $V_{DD}$ = 5.0 V (true open drain ports) drain ports) Figure 27. Typ. $V_{OL}$ @ $V_{DD}$ = 3.3 V (high sink ports) Figure 28. Typ. $V_{OL}$ @ $V_{DD}$ = 5.0 V (high sink ports) Figure 29. Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 3.3 V (standard ports) Figure 30. Typ. $V_{DD} \cdot V_{OH} @ V_{DD} = 5.0 V$ (standard ports) Figure 31. Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 3.3 V (high Figure 32. Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 5.0 V (high sink ports) # 10.3.7 Reset pin characteristics Subject to general operating conditions for $V_{\mbox{\scriptsize DD}}$ and $T_{\mbox{\scriptsize A}}$ unless otherwise specified. Table 38. NRST pin characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |------------------------|-------------------------------------------------------|------------------------|-----------------------|-----|-----------------------|------| | V <sub>IL(NRST)</sub> | NRST input low level voltage <sup>(1)</sup> | - | $V_{SS}$ | - | 0.3 x V <sub>DD</sub> | | | V <sub>IH(NRST)</sub> | NRST input high level voltage <sup>(1)</sup> | - | 0.7 x V <sub>DD</sub> | - | $V_{DD}$ | | | V <sub>OL(NRST)</sub> | NRST output low level voltage <sup>(1)</sup> | I <sub>OL</sub> = 3 mA | - | - | 0.6 | V | | R <sub>PU(NRST)</sub> | NRST pull-up resistor | - | 30 | 40 | 60 | kΩ | | t <sub>IFP</sub> | NRST input filtered pulse <sup>(1)</sup> | - | 85 | - | 315 | ns | | t <sub>IFP(NRST)</sub> | NRST Input not filtered pulse duration <sup>(2)</sup> | | 500 | | | ns | - 1. Data based on characterization results, not tested in production. - 2. Data guaranteed by design, not tested in production. Figure 33. Typical NRST $V_{IL}$ and $V_{IH}$ vs $V_{DD}$ @ four temperatures Figure 34. Typical NRST pull-up resistance R<sub>PU</sub> vs V<sub>DD</sub> Figure 35. Typical NRST pull-up current I<sub>pu</sub> vs V<sub>DD</sub> The reset network shown in Figure 36 protects the device against parasitic resets. The user must ensure that the level on the NRST pin can go below $V_{IL(NRST)}$ max (see *Table 38: NRST pin characteristics*), otherwise the reset is not taken into account internally. STM8A $V_{\text{DD}}$ External NRS1 reset Internal reset Filter circuit (optional) 0.1µF Figure 36. **Recommended reset pin protection** # 10.3.8 TIM 1, 2, 3, and 4 timer specifications Subject to general operating conditions for $V_{DD}$ , $f_{MASTER}$ , and $T_A$ unless otherwise specified. Table 39. TIM 1, 2, 3, and 4 electrical specifications | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |------------------|-----------------------------------------------|------------|-----|-----|-----|------| | f <sub>EXT</sub> | Timer external clock frequency <sup>(1)</sup> | - | - | - | 16 | MHz | <sup>1.</sup> Not tested in production. On 64 Kbyte devices, the frequency is limited to 16 MHz. # 10.3.9 SPI serial peripheral interface Unless otherwise specified, the parameters given in *Table 40* 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 40. SPI characteristics | Symbol | Parameter | Cond | ditions | Min | Max | Unit | |---------------------------------------------------------------------|------------------------------|---------------------------------|----------------------------------|--------------------------|--------------------------|------| | | | Master mode | | 0 | 10 | | | f <sub>SCK</sub><br>1/t <sub>c(SCK)</sub> | SPI clock frequency | Slave mode | V <sub>DD</sub> < 4.5 V | 0 | 6 <sup>(1)</sup> | MHz | | W C(SCK) | | Slave mode | V <sub>DD</sub> = 4.5 V to 5.5 V | 0 | 8 <sup>(1)</sup> | | | t <sub>r(SCK</sub> )<br>t <sub>f(SCK)</sub> | SPI clock rise and fall time | Capacitive load: C = 30 pF | | - | 25 <sup>(2)</sup> | | | t <sub>su(NSS)</sub> <sup>(3)</sup> | NSS setup time | Slave mode | | 4 * t <sub>MASTER</sub> | - | | | t <sub>h(NSS)</sub> <sup>(3)</sup> | NSS hold time | Slave mode | | 70 | - | | | t <sub>w(SCKH)</sub> (3)<br>t <sub>w(SCKL)</sub> (3) | SCK high and low time | Master mode | | t <sub>SCK</sub> /2 - 15 | t <sub>SCK</sub> /2 + 15 | | | $\begin{array}{c} t_{su(MI)}^{(3)} \\ t_{su(SI)}^{(3)} \end{array}$ | Data input setup time | Master mode | | 5 | - | | | t <sub>su(SI)</sub> (3) | Data input setup time | Slave mode | | 5 | - | | | t <sub>h(MI)</sub> (3)<br>t <sub>h(SI)</sub> (3) | Data input hold time | Master mode | | 7 | - | ns | | t <sub>h(SI)</sub> (3) | Data input noid time | Slave mode | | 10 | - | | | t <sub>a(SO)</sub> (3)(4) | Data output access time | Slave mode | | - | 3* t <sub>MASTER</sub> | | | t <sub>dis(SO)</sub> (3)(5) | Data output disable time | Slave mode | | 25 | | | | | Data output valid time | Slave mode | V <sub>DD</sub> < 4.5 V | - | 75 | | | t <sub>v(SO)</sub> <sup>(3)</sup> | Data output valid time | (after enable edge) | V <sub>DD</sub> = 4.5 V to 5.5 V | - | 53 | | | t <sub>v(MO)</sub> <sup>(3)</sup> | Data output valid time | Master mode (after enable edge) | | - | 30 | | | t <sub>h(SO)</sub> (3) | Data output hold time | Slave mode (after enable edge) | | 31 | - | | | t <sub>h(MO)</sub> (3) | Data output noid time | Master mode (after | enable edge) | 12 | - | | <sup>1.</sup> $f_{SCK} < f_{MASTER}/2$ . <sup>2.</sup> The pad has to be configured accordingly (fast mode). <sup>3.</sup> Values based on design simulation and/or characterization results, and not tested in production. - 4. Min time is for the minimum time to drive the output and the max time is for the maximum time to validate the data. - 5. 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 37. SPI timing diagram where slave mode and CPHA = 0 1. Measurement points are at CMOS levels: 0.3 $V_{DD}$ and 0.7 $V_{DD}$ . Figure 38. SPI timing diagram where slave mode and CPHA = 1 1. Measurement points are at CMOS levels: 0.3 $\rm V_{DD}$ and 0.7 $\rm V_{DD}$ Figure 39. SPI timing diagram - master mode 1. Measurement points are at CMOS levels: 0.3 $\rm V_{DD}$ and 0.7 $\rm V_{DD}$ # 10.3.10 I<sup>2</sup>C interface characteristics Table 41. I<sup>2</sup>C characteristics | Symbol | Parameter | Standard | mode I <sup>2</sup> C | Fast mod | le I <sup>2</sup> C <sup>(1)</sup> | Unit | |--------------------------------------------------------|------------------------------------------------------|--------------------|-----------------------|--------------------|------------------------------------|-------| | Symbol | r al allielei | Min <sup>(2)</sup> | Max <sup>(2)</sup> | Min <sup>(2)</sup> | Max <sup>(2)</sup> | Oilit | | 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><br>t <sub>r(SCL)</sub> | SDA and SCL rise time (V <sub>DD</sub> = 3 to 5.5 V) | - | 1000 | - | 300 | ns | | $\begin{matrix} t_{f(SDA)} \\ t_{f(SCL)} \end{matrix}$ | SDA and SCL fall time (V <sub>DD</sub> = 3 to 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 | рF | <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^2C$ 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 # 10.3.11 10-bit ADC characteristics Subject to general operating conditions for $V_{\text{DDA}}$ , $f_{\text{MASTER}}$ , and $T_{\text{A}}$ unless otherwise specified. Table 42. ADC characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |-------------------------------|---------------------------------------------|------------------------------------------------------------------|-------------------|------|-------------------|---------| | f <sub>ADC</sub> | ADC clock frequency | - | 111 kHz | - | 4 MHz | kHz/MHz | | V <sub>DDA</sub> | Analog supply | - | 3 | - | 5.5 | | | 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 <sub>AIN</sub> | | - | $V_{SSA}$ | - | $V_{DDA}$ | | | | 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> | | | C <sub>samp</sub> | Internal sample and hold capacitor | - | - | - | 3 | pF | | t <sub>S</sub> <sup>(1)</sup> | Sampling time | f <sub>ADC</sub> = 2 MHz | - | 1.5 | - | | | is. | (3 x 1/f <sub>ADC</sub> ) | f <sub>ADC</sub> = 4 MHz | - | 0.75 | - | | | +. | Wakaun timo from standhy | f <sub>ADC</sub> = 2 MHz | - | 7 | - | | | t <sub>STAB</sub> | Wakeup time from standby | f <sub>ADC</sub> = 4 MHz | - | 3.5 | - | μs | | | Total conversion time including | f <sub>ADC</sub> = 2 MHz | - | 7 | - | | | t <sub>CONV</sub> | sampling time<br>(14 x 1/f <sub>ADC</sub> ) | f <sub>ADC</sub> = 4 MHz | - | 3.5 | - | | | R <sub>switch</sub> | Equivalent switch resistance | - | - | - | 30 | kΩ | During the sample time, the sampling capacitance, C<sub>samp</sub> (3 pF typ), 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. Figure 40. Typical application with ADC 1. Legend: $R_{AIN}$ = external resistance, $C_{AIN}$ = capacitors, $C_{samp}$ = internal sample and hold capacitor. Table 43. ADC accuracy for $V_{DDA} = 5 \text{ V}$ | Symbol | Parameter | Conditions | Тур | Max <sup>(1)</sup> | Unit | |-------------------|---------------------------------------------|--------------------------|--------------------|--------------------|------| | IE <sub>T</sub> I | Total unadjusted error <sup>(2)</sup> | | 1.4 | 3 <sup>(3)</sup> | | | IE <sub>O</sub> I | Offset error <sup>(2)</sup> | | 0.8 | 3 | | | IE <sub>G</sub> I | Gain error <sup>(2)</sup> | f <sub>ADC</sub> = 2 MHz | 0.1 | 2 | | | IE <sub>D</sub> I | Differential linearity error <sup>(2)</sup> | | 0.9 | 1 | | | IE <sub>L</sub> I | Integral linearity error <sup>(2)</sup> | | 0.7 | 1.5 | | | IE <sub>T</sub> I | Total unadjusted error <sup>(2)</sup> | | 1.9 <sup>(4)</sup> | 4 <sup>(4)</sup> | LSB | | IE <sub>O</sub> I | Offset error <sup>(2)</sup> | | 1.3 <sup>(4)</sup> | 4 <sup>(4)</sup> | | | IE <sub>G</sub> I | Gain error <sup>(2)</sup> | f <sub>ADC</sub> = 4 MHz | 0.6 <sup>(4)</sup> | 3 <sup>(4)</sup> | | | IE <sub>D</sub> I | Differential linearity error <sup>(2)</sup> | | 1.5 <sup>(4)</sup> | 2 <sup>(4)</sup> | | | IE <sub>L</sub> I | Integral linearity error <sup>(2)</sup> | | 1.2 <sup>(4)</sup> | 1.5 <sup>(4)</sup> | | - 1. Max value is based on characterization, not tested in production. - 2. ADC accuracy vs. injection current: Any positive or negative injection current within the limits specified for $I_{INJ(PIN)}$ and $\Sigma I_{INJ(PIN)}$ in *Section 10.3.6* does not affect the ADC accuracy. - TUE 2LSB can be reached on specific salestypes on the whole temperature range. - 4. Target values. Figure 41. ADC accuracy characteristics - Example of an actual transfer curve - 2. The ideal transfer curve - 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. #### 10.3.12 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 44. EMS data | Symbol | Parameter | Conditions | Level/class | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|-------------| | V <sub>FESD</sub> | Voltage limits to be applied on any I/O pin to induce a functional disturbance | $V_{DD}$ = 3.3 V, $T_A$ = 25 °C,<br>$f_{MASTER}$ = 16 MHz (HSI clock),<br>Conforms to IEC 1000-4-2 | ЗВ | | 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 45. EMI data | Symbol | Parameter | Conditions | | | | | |------------------|---------------|------------------------------------------------------------------------------------------------------|--------------------------|-------------------------------------|-----------|--------| | | | General conditions | Monitored frequency band | Max f <sub>CPU</sub> <sup>(1)</sup> | | Unit | | | | | | 8<br>MHz | 16<br>MHz | | | S <sub>EMI</sub> | Peak level | V <sub>DD</sub> = 5 V,<br>T <sub>A</sub> = 25 °C,<br>LQFP80 package<br>conforming to SAE J<br>1752/3 | 0.1 MHz to 30 MHz | 15 | 17 | - dBμV | | | | | 30 MHz to 130 MHz | 18 | 22 | | | | | | 130 MHz to 1 GHz | -1 | 3 | | | | SAE EMI level | | _ | 2 | 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. Table 46. ESD absolute maximum ratings | Symbol | Ratings | Conditions | Class | Maximum<br>value <sup>(1)</sup> | Unit | |-----------------------|-------------------------------------------------------|-----------------------------------------------------|-------|---------------------------------|------| | V <sub>ESD(HBM)</sub> | Electrostatic discharge voltage (Human body model) | T <sub>A</sub> = 25°C, conforming to<br>JESD22-A114 | ЗА | 4000 | | | V <sub>ESD(CDM)</sub> | Electrostatic discharge voltage (Charge device model) | T <sub>A</sub> = 25°C, conforming to<br>JESD22-C101 | 3 | 500 | ٧ | | V <sub>ESD(MM)</sub> | Electrostatic discharge voltage (Machine model) | T <sub>A</sub> = 25°C, conforming to<br>JESD22-A115 | В | 200 | | <sup>1.</sup> Data based on characterization results, not tested in production ## 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 47. Electrical sensitivities | Symbol | Parameter | Conditions | Class <sup>(1)</sup> | | |--------|-----------------------|----------------------------------------|----------------------|--| | LU | Static latch-up class | T <sub>A</sub> = 25 °C | | | | | | T <sub>A</sub> = 85 °C | Α | | | | | T <sub>A</sub> = 125 °C | A | | | | | T <sub>A</sub> = 150 °C <sup>(2)</sup> | | | 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). ## 10.4 Thermal characteristics In case the maximum chip junction temperature (T<sub>Jmax</sub>) specified in *Table 23: General operating conditions on page 49* is exceeded, the functionality of the device cannot be guaranteed. T<sub>.lmax</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. <sup>2.</sup> Available on STM8AF62xx devices only. **Symbol** Value Unit **Parameter** Thermal resistance junction-ambient 57 °C/W $\Theta_{JA}$ LQFP 48 - 7 x 7 mm Thermal resistance junction-ambient $\Theta_{JA}$ 59 °C/W LQFP 32 - 7 x 7 mm Thermal resistance junction-ambient 25 °C/W $\Theta_{JA}$ VFQFPN32 Table 48. Thermal characteristics<sup>(1)</sup> #### 10.4.1 Reference document JESD51-2 integrated circuits thermal test method environment conditions - natural convection (still air). Available from www.jedec.org. ### 10.4.2 Selecting the product temperature range When ordering the microcontroller, the temperature range is specified in the order code (see *Section 12: Ordering information*). 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}$ = 14 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} = 14 \text{ mA x 5 V} = 70 \text{ mW}$ $P_{IOmax} = 20 \times 8 \text{ mA} \times 0.4 \text{ V} = 64 \text{ mW}$ This gives: P<sub>INTmax</sub> = 70 mW and P<sub>IOmax</sub> 64 mW: $P_{Dmax} = 70 \text{ mW} + 64 \text{ mW}$ Thus: $P_{Dmax} = 134 \text{ mW}.$ Using the values obtained in *Table 48: Thermal characteristics on page 74* $T_{Jmax}$ is calculated as follows: For LQFP64 46 °C/W $$T_{Jmax} = 82 \, ^{\circ}C + (46 \, ^{\circ}C/W \, x \, 134 \, mW) = 82 \, ^{\circ}C + 6 \, ^{\circ}C = 88 \, ^{\circ}C$$ This is within the range of the suffix B version parts (-40 < $T_J$ < 105 °C). Parts must be ordered at least with the temperature range suffix B. Thermal resistances are based on JEDEC JESD51-2 with 4-layer PCB in a natural convection environment. # 11 Package characteristics In order to meet environmental requirements, ST offers these devices in different grades of ECOPACK<sup>®</sup> packages, depending on their level of environmental compliance. ECOPACK<sup>®</sup> specifications, grade definitions and product status are available at: <a href="https://www.st.com">www.st.com</a>. ECOPACK<sup>®</sup> is an ST trademark. #### 11.1 Package mechanical data VFQFPN 32-lead very thin fine pitch quad flat no-lead package (5 x 5) VFQFPN 32-lead very thin fine pitch quad flat no-lead package Table 49. mechanical data | Dim. | mm | | | inches <sup>(1)</sup> | | | |------|-------|-------|-------|-----------------------|--------|--------| | | Min | Тур | Max | Min | Тур | Max | | Α | 0.800 | 0.900 | 1.000 | 0.0315 | 0.0354 | 0.0394 | | A1 | 0.000 | 0.020 | 0.050 | 0.000 | 0.0008 | 0.0020 | | A3 | _ | 0.200 | _ | _ | 0.0079 | _ | | b | 0.180 | 0.250 | 0.300 | 0.0071 | 0.0098 | 0.0118 | | D | 4.850 | 5.000 | 5.150 | 0.1909 | 0.1969 | 0.2028 | | D2 | 3.400 | 3.450 | 3.500 | 0.1339 | 0.1358 | 0.1378 | | Е | 4.850 | 5.000 | 5.150 | 0.1909 | 0.1969 | 0.2028 | | E2 | 3.400 | 3.450 | 3.500 | 0.1339 | 0.1358 | 0.1378 | | е | | 0.500 | _ | _ | 0.0197 | _ | | L | 0.300 | 0.400 | 0.500 | 0.0118 | 0.0157 | 0.0197 | | ddd | _ | _ | 0.080 | _ | _ | 0.0031 | <sup>1.</sup> Values in inches are converted from mm and rounded to 4 decimal digits Figure 43. LQFP 48-pin low profile quad flat package (7 x 7) Table 50. LQFP 48-pin low profile quad flat package mechanical data | Table 50: Eq. ( 40-pin low profite quad hat package mechanical data | | | | | | | |---------------------------------------------------------------------|-------|-------|-------|-----------------------|--------|--------| | Dim. | mm | | | inches <sup>(1)</sup> | | | | | Min | Тур | Max | Min | Тур | Max | | А | _ | _ | 1.600 | _ | _ | 0.0630 | | A1 | 0.050 | _ | 0.150 | 0.0020 | _ | 0.0059 | | A2 | 1.350 | 1.400 | 1.450 | 0.0531 | 0.0551 | 0.0571 | | b | 0.170 | 0.220 | 0.270 | 0.0067 | 0.0087 | 0.0106 | | С | 0.090 | _ | 0.200 | 0.0035 | _ | 0.0079 | | D | 8.800 | 9.000 | 9.200 | 0.3465 | 0.3543 | 0.3622 | | D1 | 6.800 | 7.000 | 7.200 | 0.2677 | 0.2756 | 0.2835 | | D3 | _ | 5.500 | _ | _ | 0.2165 | _ | | E | 8.800 | 9.000 | 9.200 | 0.3465 | 0.3543 | 0.3622 | | E1 | 6.800 | 7.000 | 7.200 | 0.2677 | 0.2756 | 0.2835 | | E3 | _ | 5.500 | _ | _ | 0.2165 | _ | | е | _ | 0.500 | _ | _ | 0.0197 | _ | | θ | 0° | 3.5° | 7° | 0° | 3.5° | 7° | | L | 0.450 | 0.600 | 0.750 | 0.0177 | 0.0236 | 0.0295 | | L1 | _ | 1.000 | _ | _ | 0.0394 | _ | | ccc | _ | | 0.080 | _ | _ | 0.0031 | <sup>1.</sup> Values in inches are converted from mm and rounded to 4 decimal digits Figure 44. LQFP 48-pin recommended footprint 1. Drawing is not to scale. Dimensions are in millimeters. Figure 45. LQFP 32-pin low profile quad flat package (7 x 7) Table 51. LQFP 32-pin low profile quad flat package mechanical data | Dim. | mm | | | inches <sup>(1)</sup> | | | |------|-------|-------|-------|-----------------------|--------|--------| | | Min | Тур | Max | Min | Тур | Max | | Α | _ | _ | 1.600 | _ | _ | 0.0630 | | A1 | 0.050 | _ | 0.150 | 0.0020 | _ | 0.0059 | | A2 | 1.350 | 1.400 | 1.450 | 0.0531 | 0.0551 | 0.0571 | | b | 0.300 | 0.370 | 0.450 | 0.0118 | 0.0146 | 0.0177 | | С | 0.090 | _ | 0.200 | 0.0035 | _ | 0.0079 | | D | 8.800 | 9.000 | 9.200 | 0.3465 | 0.3543 | 0.3622 | | D1 | 6.800 | 7.000 | 7.200 | 0.2677 | 0.2756 | 0.2835 | | D3 | _ | 5.600 | _ | _ | 0.2205 | _ | | Е | 8.800 | 9.000 | 9.200 | 0.3465 | 0.3543 | 0.3622 | | E1 | 6.800 | 7.000 | 7.200 | 0.2677 | 0.2756 | 0.2835 | | E3 | _ | 5.600 | _ | _ | 0.2205 | _ | | е | _ | 0.800 | _ | _ | 0.0315 | _ | | θ | 0° | 3.5° | 7° | 0° | 3.5° | 7° | | L | 0.450 | 0.600 | 0.750 | 0.0177 | 0.0236 | 0.0295 | | L1 | _ | 1.000 | _ | _ | 0.0394 | _ | | CCC | _ | _ | 0.100 | _ | _ | 0.0039 | <sup>1.</sup> Values in inches are converted from mm and rounded to 4 decimal digits Figure 46. LQFP 32-pin recommended footprint 1. Drawing is not to scale. Dimensions are in millimeters. # 12 Ordering information Figure 47. Ordering information scheme<sup>(1)</sup> - For a list of available options (e.g. memory size, package) and orderable part numbers or for further information on any aspect of this device, please go to www.st.com or contact the ST Sales Office nearest to you. - Customer specific FASTROM code or custom device configuration. This field shows 'SSS' if the device contains a super set silicon, usually equipped with bigger memory and more I/Os. This silicon is supposed to be replaced later by the target silicon. - 3. Not recommended for new design. - 4. Available on STM8AF62xx devices. # 13 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. ## 13.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. #### 13.1.1 STice key features 82/89 - 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 resources 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. ### 13.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 and Raisonance C compilers for STM8. #### 13.2.1 STM8 toolset The STM8 toolset with STVD integrated development environment and STVP programming software is available for free download at www.st.com. This package includes: #### ST visual develop Full-featured integrated development environment from STMicroelectronics, 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 verification of the STM8A microcontroller's Flash memory. STVP also offers project mode for saving programming configurations and automating programming sequences. ## 13.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 All compilers are available in free version with a limited code size depending on the compiler. For more information, refer to www.cosmic-software.com, www.raisonance.com, and www.iar.com. #### STM8 assembler linker Free assembly toolchain included in the STM8 toolset, which allows you to assemble and link your application source code. # 13.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. 84/89 Doc ID 14952 Rev 6 # 14 Revision history Table 52. Document revision history | Date | Revision | Changes | |-------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 22-Aug-2008 | 1 | Initial release | | 10-Aug-2009 | 2 | Document revised as the following: Updated Features on page 1; Updated Table 1: Device summary; Updated Section 3: Product line-up; Changed Section 5: Product overview; Updated Section 6: Pinouts and pin description; Changed Section 7.2: Register map; Updated Section 8: Interrupt table; Updated Section 9: Option bytes; Updated Section 10: Electrical characteristics; Updated Section 11: Package characteristics; Updated Section 12: Ordering information; Added Section 13: STM8 development tools. | | 22-Oct-2009 | 3 | Adapted Table 10: STM8AF61xx/62xx (32 Kbytes) microcontroller pin description. Added Section 13.4.5: LIN header error when automatic resynchronization is enabled. | | 08-Jul-2010 | 4 | Updated title on cover page. Added VFQFPN32 5x 5 mm package. Added STM8AF62xx devices, and modified cover page header to clarify the part numbers covered by the datasheets. Updated <i>Note 1</i> below <i>Table 1: Device summary</i> . Updated D temperature range to -40 to 150°C. Content of <i>Section 5: Product overview</i> reorganized. Renamed <i>Section 7 Memory and register map</i> , and content merged with Register map section. Renamed BL_EN and NBL_EN, BL and NBL, respectively, in <i>Table 17: Option bytes</i> . Added <i>Table 22: Operating lifetime</i> . Added CEXT and P <sub>D</sub> (power dissipation) in <i>Table 23: General operating conditions</i> , and <i>Section 10.3.1: VCAP external capacitor</i> . Suffix D maximum junction temperature (T <sub>J</sub> ) updated in <i>Table 23: General operating conditions</i> . Update tvdd in <i>Table 24: Operating conditions at power-up/power-down</i> . Moved <i>Table 29: Typical peripheral current consumption VDD = 5.0 V</i> to <i>Section : Current consumption for on-chip peripherals</i> and removed I <sub>DD(CAN)</sub> . Updated <i>Section 12: Ordering information</i> for the devices supported by the datasheet. Updated <i>Section 13: STM8 development tools</i> . | Table 52. Document revision history (continued) | Date | Revision | Changes | | | |--------------|----------|--------------------------------------------------------------------------------------------------------------------------|--|--| | | | Modified references to reference manual, and Flash programming | | | | | | manual in the whole document. | | | | | | Added reference to AEC Q100 standard on cover page. | | | | | | Renamed timer types as follows: | | | | | | Auto-reload timer to general purpose timer | | | | | | Multipurpose timer to advanced control timer | | | | | | System timer to basic timer | | | | | | Introduced concept of medium density Flash program memory. | | | | | | Updated timer names in Figure 1: STM8A block diagram. | | | | | | Added TMU brief description in Section 5.4: Flash program and data | | | | | | EEPROM, and updated TMU_MAXATT description in Table 18: | | | | | | Option byte description. | | | | | | Updated clock sources in clock controller features (Section 5.5.1). | | | | | | Changed 16MHZTRIM0 to HSITRIM bit in Section: User trimming. | | | | | 5 | Added Table 4: Peripheral clock gating bits in Section 5.5.6. | | | | | | Updated Section 5.6: Low-power operating modes. | | | | | | Added calibration using TIM3 in Section 5.7.2: Auto-wakeup counter | | | | 31-Jan-2011 | | Added Table 7: ADC naming and Table 8: Communication periphera naming correspondence. | | | | 01 0011 2011 | | Added <i>Note 1</i> related AIN12 pin in <i>Section 5.8: Analog-to-digital</i> | | | | | | converter (ADC)and Table 10: STM8AF61xx/62xx (32 Kbytes) | | | | | | microcontroller pin description. | | | | | | Updated SPI data rate to 10 Mbit/s or f <sub>MASTER</sub> /2 in <i>Section 5.9.1: Serial peripheral interface (SPI).</i> | | | | | | Added we at the in Table O. I arrand/abbreviation | | | | | | Added reset state in <i>Table 9: Legend/abbreviation</i> . | | | | | | Table 10: STM8AF61xx/62xx (32 Kbytes) microcontroller pin | | | | | | description: added Note 7 related to PD1/SWIM, modified Note 6, | | | | | | corrected wpu input for PE1 and PE2, and renamed TIMn_CCx and | | | | | | TIMn_NCCx to TIMn_CHx and TIMn_CHxN, respectively. | | | | | | Section 7.2: Register map: | | | | | | Replaced tables describing register maps and reset values for non- | | | | | | volatile memory, global configuration, reset status, clock controller, | | | | | | interrupt controller, timers, communication interfaces, and ADC, by <i>Table 13: General hardware register map</i> . | | | | | | Added <i>Note 1</i> for Px_IDR registers in <i>Table 12: I/O port hardware</i> | | | | | | register map. Updated register reset values for Px_IDR registers. | | | | | | Added SWIM and debug module register map. | | | 86/89 Doc ID 14952 Rev 6 Table 52. Document revision history (continued) | Date | Revision | Changes | |-------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-Jan-2011 | 5<br>(continued) | Renamed Fast Active Halt mode to Active-halt mode with regulator on, and Slow Active Halt mode to Active-halt mode with regulator off. Updated <i>Table 26: Total current consumption in Halt and Active-halt modes. General conditions for VDD apply, TA = -40 to 55 °C, in particular <math>I_{DD(FAH)}</math> and <math>I_{DD(SAH)}</math> renamed <math>I_{DD(AH)}</math>; <math>t_{WU(FAH)}</math> and <math>t_{WU(SAH)}</math> renamed <math>t_{WU(AH)}</math>, and temperature condition added. Removed <math>I_{DD(USART)}</math> from <i>Table 29: Typical peripheral current consumption VDD = 5.0 V.</i> Updated general conditions in <i>Section 10.3.5: Memory</i></i> | | | | characteristics. Modified T <sub>WE</sub> maximum value in <i>Table 35: Flash</i> program memory and <i>Table 36: Data memory</i> . Update I <sub>Ikq ana</sub> maximum value for T <sub>A</sub> ranging from -40 to 150 °C in | | | | Table 37: Ĭ/O static characteristics. | | | | Added $t_{\text{IFP(NRST)}}$ and renamed $V_{\text{F(NRST)}}$ $t_{\text{IFP}}$ in <i>Table 38: NRST pin characteristics</i> . Added recommendations concerning NRST pin level above <i>Figure 36: Recommended reset pin protection</i> , and updated external capacitor value. | | | | Added Raisonance compiler in <i>Section 13.2: Software tools</i> . Moved know limitations to separate errata sheet. | | | | Updated wildcards of document part numbers. | | | 6 | Table 1: Device summary: updated footnote 1 and added footnote 2 to all STM8AF61xx part numbers. | | | | Section 1: Introduction: small text change in first paragraph. | | | | Table 2: STM8AF62xx product line-up: added "P" version for all order codes; updated RAM. | | | | Table 3: STM8AF/H61xx product line-up: added "P" version for all order codes. | | | | Figure 1: STM8A block diagram: updated POR, BOR and WDG; updated LINUART input; added legend. | | | | Section 5.4: Flash program and data EEPROM: removed nonrelevant bullet points and added a sentence about the factory programme. | | 18-Jul-2012 | | Table 4: Peripheral clock gating bit assignments in CLK_PCKENR1/2 registers: updated | | | | ADC features: updated ADC input range. | | | | Table 11: Memory model for the devices covered in this datasheet: updated 16 Kbyte and 8 Kbyte information. | | | | Table 17: Option bytes: updated factory default setting for NOPT17; added footnote 1. | | | | Section 10.1.1: Minimum and maximum values: T <sub>A</sub> = -40 °C (not 40 °C). | | | | Table 23: General operating conditions: updated V <sub>CAP</sub> | | | | Table 25: Total current consumption in Run, Wait and Slow mode. General conditions for VDD apply, TA = -40 to 150 °C: updated conditions for I <sub>DD(RUN)</sub> . | | | | Table 37: I/O static characteristics: added new condition and new max values for rise and fall time; updated footnote 2. | Table 52. Document revision history (continued) | Date | Revision | Changes | | | |-------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 18-Jul-2012 | 6<br>(continued) | Section 10.3.7: Reset pin characteristics: updated text below Figure 35: Typical NRST pull-up current Ipu vs VDD. Figure 36: Recommended reset pin protection: updated unit of capacitor. Table 40: SPI characteristics: updated SCK high and low time conditions and values. Figure 39: SPI timing diagram - master mode: replaced 'SCK input' signals with 'SCK output' signals. Updated Table 49: VFQFPN 32-lead very thin fine pitch quad flat nolead package mechanical data, Table 50: LQFP 48-pin low profile quad flat package mechanical data, and Table 51: LQFP 32-pin low profile quad flat package mechanical data. Replaced Figure 43: LQFP 48-pin low profile quad flat package (7 x 7) and Figure 45: LQFP 32-pin low profile quad flat package (7 x 7). Added Figure 44: LQFP 48-pin recommended footprint and Figure 46: LQFP 32-pin recommended footprint. Figure 47: Ordering information scheme(1): added footnote 1, added "xxx" and footnote 2, updated example and device family; added FASTROM. Section 13.2.2: C and assembly toolchains: added www.iar.com | | | #### 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 TWO AUTHORIZED ST REPRESENTATIVES, 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. © 2012 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 - Philippines - Singapore - Spain - Sweden - Switzerland - United Kingdom - United States of America www.st.com