# STM8S007C8 Value line, 24 MHz STM8S 8-bit MCU, 64 Kbytes Flash, true data EEPROM, 10-bit ADC, timers, 2 UARTs, SPI, I<sup>2</sup>C ### **Features** #### ■ Core - Max $f_{CPU}$ : up to 24 MHz, 0 wait states @ $f_{CPU} \le 16$ MHz - Advanced STM8 core with Harvard architecture and 3-stage pipeline - Extended instruction set - Max 20 MIPS @ 24 MHz #### ■ Memories - Program: 64 Kbytes Flash; data retention 20 years at 55 °C after 100 cycles - Data: 128 bytes true data EEPROM; endurance 100 kcycles - RAM: 6 Kbytes - Clock, reset and supply management - 2.95 to 5.5 V operating voltage - Low power crystal resonator oscillator - External clock input - Internal, user-trimmable 16 MHz RC - Internal low power 128 kHz RC - Clock security system with clock monitor - Wait, active-halt, & halt low power modes - Peripheral clocks switched off individually - Permanently active, low consumption power-on and power-down reset ### ■ Interrupt management - Nested interrupt controller with 32 interrupts - Up to 37 external interrupts on 6 vectors #### ■ Timers - 2x 16-bit general purpose timers, with 2+3 CAPCOM channels (IC, OC or PWM) - Advanced control timer: 16-bit, 4 CAPCOM channels, 3 complementary outputs, deadtime insertion and flexible synchronization - 8-bit basic timer with 8-bit prescaler - Auto wakeup timer - Window watchdog, independent watchdog ### ■ Communications interfaces - UART with clock output for synchronous operation LIN master mode - UART with LIN 2.1 compliant, master/slave modes and automatic resynchronization - SPI interface up to 10 Mbit/s - I<sup>2</sup>C interface up to 400 Kbit/s - 10-bit ADC with up to 16 channels #### ■ I/Os - 38 I/Os including 16 high sink outputs - Highly robust I/O design, immune against current injection - Development support - Single wire interface module (SWIM) and debug module (DM) January 2012 Doc ID 022171 Rev 2 1/90 Contents STM8S007C8 # **Contents** | 1 | Intro | duction | 8 | |---|-------|-----------------------------------------------------------|----| | 2 | Desc | eription | 9 | | 3 | Bloc | k diagram | 10 | | 4 | Prod | uct overview | 11 | | | 4.1 | Central processing unit STM8 | 11 | | | 4.2 | Single wire interface module (SWIM) and debug module (DM) | 12 | | | 4.3 | Interrupt controller | 12 | | | 4.4 | Flash program and data EEPROM memory | 12 | | | 4.5 | Clock controller | 14 | | | 4.6 | Power management | 15 | | | 4.7 | Watchdog timers | 15 | | | 4.8 | Auto wakeup counter | 16 | | | 4.9 | Beeper | 16 | | | 4.10 | TIM1 - 16-bit advanced control timer | 16 | | | 4.11 | TIM2, TIM3 - 16-bit general purpose timers | 16 | | | 4.12 | TIM4 - 8-bit basic timer | 17 | | | 4.13 | Analog-to-digital converter (ADC2) | 17 | | | 4.14 | Communication interfaces | 17 | | | | 4.14.1 UART1 | 18 | | | | 4.14.2 UART3 | 18 | | | | 4.14.3 SPI | 19 | | | | 4.14.4 I <sup>2</sup> C | 20 | | 5 | Pino | uts and pin description | 21 | | | 5.1 | Alternate function remapping | 25 | | 6 | Mem | ory and register map | 26 | | | 6.1 | Memory map | 26 | | | 6.2 | Register map | 27 | | | | | | STM8S007C8 Contents | 7 | Inter | rupt ved | ctor mapping | 37 | | | | | |-------------|---------------------|-----------|---------------------------------------------------|------|--|--|--|--| | 8 | Optio | on bytes | s | 38 | | | | | | 9 | Elect | trical ch | aracteristics | 42 | | | | | | | 9.1 | Parame | eter conditions | 42 | | | | | | | | 9.1.1 | Minimum and maximum values | 42 | | | | | | | | 9.1.2 | Typical values | 42 | | | | | | | | 9.1.3 | Typical curves | 42 | | | | | | | | 9.1.4 | Typical current consumption | 42 | | | | | | | | 9.1.5 | Pin loading conditions | 43 | | | | | | | | 9.1.6 | Loading capacitor | 43 | | | | | | | | 9.1.7 | Pin input voltage | 43 | | | | | | | 9.2 | Absolu | te maximum ratings | 44 | | | | | | | 9.3 | Operat | ing conditions | 46 | | | | | | | | 9.3.1 | VCAP external capacitor | | | | | | | | | 9.3.2 | Supply current characteristics | | | | | | | | | 9.3.3 | External clock sources and timing characteristics | | | | | | | | | 9.3.4 | Internal clock sources and timing characteristics | | | | | | | | | 9.3.5 | Memory characteristics | 59 | | | | | | | | 9.3.6 | I/O port pin characteristics | 60 | | | | | | | | 9.3.7 | Reset pin characteristics | 68 | | | | | | | | 9.3.8 | SPI serial peripheral interface | 71 | | | | | | | | 9.3.9 | I <sup>2</sup> C interface characteristics | 74 | | | | | | | | 9.3.10 | 10-bit ADC characteristics | 76 | | | | | | | | 9.3.11 | EMC characteristics | 79 | | | | | | 10 | Pack | age cha | aracteristics | 82 | | | | | | | 10.1 | Packag | ge mechanical data | 83 | | | | | | | 10.2 | _ | al characteristics | | | | | | | | | 10.2.1 | Reference document | | | | | | | | | 10.2.2 | Selecting the product temperature range | | | | | | | 11 | STM | 8 develo | opment tools | 86 | | | | | | | 11.1 | Emulat | ion and in-circuit debugging tools | 86 | | | | | | | 11.2 Software tools | | | | | | | | | | | 11.2.1 | STM8 toolset | | | | | | | <b>\7</b> / | | | Doc ID 022171 Rev 2 | 3/90 | | | | | | Contents | | | STM8S007 | C8 | |----------|-------|-----------|---------------------------|----| | | | 11.2.2 | C and assembly toolchains | 87 | | | 11.3 | Progran | mming tools | 87 | | 12 | Orde | ring info | ormation | 88 | | 13 | Revie | sion his | tory | 29 | **577** STM8S007C8 List of tables # List of tables | Table 1. | STM8S007xx value line features | . 9 | |-----------|-----------------------------------------------------------------------------------------------------|-----| | Table 2. | Peripheral clock gating bit assignments in CLK_PCKENR1/2 registers | 14 | | Table 3. | TIM timer features | | | Table 4. | Legend/abbreviations for LQFP48 pin description table | | | Table 5. | LQFP48 pin description | | | Table 6. | Flash, Data EEPROM and RAM boundary addresses | | | Table 7. | I/O port hardware register map | | | Table 8. | General hardware register map | | | Table 9. | CPU/SWIM/debug module/interrupt controller registers | | | Table 10. | Interrupt mapping | | | Table 11. | Option bytes | | | Table 12. | Option byte description | | | Table 13. | Voltage characteristics | | | Table 14. | Current characteristics | | | Table 15. | Thermal characteristics | | | Table 16. | General operating conditions | | | Table 17. | Operating conditions at power-up/power-down | | | Table 18. | Total current consumption with code execution in run mode at $V_{DD} = 5 \text{ V}$ | 48 | | Table 19. | Total current consumption with code execution in run mode at V <sub>DD</sub> = 3.3 V | 49 | | Table 20. | Total current consumption in wait mode at V <sub>DD</sub> = 5 V | | | Table 21. | Total current consumption in wait mode at V <sub>DD</sub> = 3.3 V | 50 | | Table 22. | Total current consumption in active halt mode at V <sub>DD</sub> = 5 V, T <sub>A</sub> -40 to 85° C | 51 | | Table 23. | Total current consumption in active halt mode at V <sub>DD</sub> = 3.3 V | | | Table 24. | Total current consumption in halt mode at $V_{DD} = 5 \text{ V}$ , $T_A$ -40 to 85° C | | | Table 25. | Total current consumption in halt mode at V <sub>DD</sub> = 3.3 V | | | Table 26. | Wakeup times | | | Table 27. | Total current consumption and timing in forced reset state | | | Table 28. | Peripheral current consumption | | | Table 29. | HSE user external clock characteristics | | | Table 30. | HSE oscillator characteristics | | | Table 31. | HSI oscillator characteristics | | | Table 32. | LSI oscillator characteristics | | | Table 33. | RAM and hardware registers | | | Table 34. | Flash program memory/data EEPROM memory | | | Table 35. | I/O static characteristics | | | Table 36. | Output driving current (standard ports) | | | Table 37. | Output driving current (true open drain ports) | | | Table 38. | Output driving current (high sink ports) | | | Table 39. | NRST pin characteristics | | | Table 40. | SPI characteristics | | | Table 41. | I <sup>2</sup> C characteristics | | | Table 42. | ADC characteristics | | | Table 43. | ADC accuracy with $R_{AIN}$ < 10 k $\Omega$ , $V_{DDA}$ = 5 V | | | Table 44. | ADC accuracy with $R_{AIN}$ < 10 k $\Omega$ $R_{AIN}$ , $V_{DDA}$ = 3.3 V | | | Table 45. | EMS data | | | Table 46. | EMI data | | | Table 47. | ESD absolute maximum ratings | | | Table 48. | Electrical sensitivities | δl | | | | | Doc ID 022171 Rev 2 5/90 | ist of tables | STM8S007C8 | |---------------|------------| | Table 49. | 48-pin low profile quad flat package mechanical data | 83 | |-----------|------------------------------------------------------|----| | Table 50. | Thermal characteristics | 84 | | Table 51. | Document revision history | 89 | 477 STM8S007C8 List of figures # **List of figures** | Figure 1. | STM8S00/xx value line block diagram10 | |------------|----------------------------------------------------------------------| | Figure 2. | Flash memory organisation | | Figure 3. | LQFP 48-pin pinout | | Figure 4. | Memory map | | Figure 5. | Supply current measurement conditions | | Figure 6. | Pin loading conditions43 | | Figure 7. | Pin input voltage | | Figure 8. | f <sub>CPUmax</sub> versus V <sub>DD</sub> 47 | | Figure 9. | External capacitor C <sub>FXT</sub> | | Figure 10. | Typ. $I_{DD(RUN)}$ vs $V_{DD}$ , HSI RC osc, $f_{CPU} = 16$ MHz | | Figure 11. | Typ. $I_{DD(WFI)}$ vs $V_{DD}$ , HSI RC osc, $f_{CPU} = 16$ MHz | | Figure 12. | HSE external clock source | | Figure 13. | HSE oscillator circuit diagram56 | | Figure 14. | Typical HSI frequency variation vs V <sub>DD</sub> at 3 temperatures | | Figure 15. | Typical LSI frequency variation vs V <sub>DD</sub> @ 25 °C | | Figure 16. | Typical $V_{IL}$ and $V_{IH}$ vs $V_{DD}$ @ 3 temperatures | | Figure 17. | Typical pull-up resistance vs V <sub>DD</sub> @ 3 temperatures | | Figure 18. | Typical pull-up current vs V <sub>DD</sub> @ 3 temperatures | | Figure 19. | Typ. $V_{OL} @ V_{DD} = 5 V$ (standard ports) | | Figure 20. | Typ. $V_{OL} @ V_{DD} = 3.3 \text{ V (standard ports)}.$ 64 | | Figure 21. | Typ. V <sub>OL</sub> @ V <sub>DD</sub> = 5 V (true open drain ports) | | Figure 22. | Typ. $V_{OL} @ V_{DD} = 3.3 \text{ V}$ (true open drain ports) | | Figure 23. | Typ. $V_{OL} @ V_{DD} = 5 V$ (high sink ports) | | Figure 24. | Typ. $V_{OL} @ V_{DD} = 3.3 \text{ V (high sink ports)} \dots 66$ | | Figure 25. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 5 V (standard ports) | | Figure 26. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 3.3 V (standard ports) | | Figure 27. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 5 V (high sink ports) | | Figure 28. | Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 3.3 V (high sink ports) | | Figure 29. | Typical NRST $V_{IL}$ and $V_{IH}$ vs $V_{DD}$ @ 3 temperatures | | Figure 30. | Typical NRST pull-up resistance vs V <sub>DD</sub> @ 3 temperatures | | Figure 31. | Typical NRST pull-up current vs V <sub>DD</sub> @ 3 temperatures | | Figure 32. | Recommended reset pin protection | | Figure 33. | SPI timing diagram - slave mode and CPHA = 0 | | Figure 34. | SPI timing diagram - slave mode and CPHA = 1 <sup>(1)</sup> | | Figure 35. | SPI timing diagram - master mode <sup>(1)</sup> | | Figure 36. | Typical application with I <sup>2</sup> C bus and timing diagram | | Figure 37. | ADC accuracy characteristics | | Figure 38. | Typical application with ADC | | Figure 39. | 48-pin low profile quad flat package (7 x 7) | | Figure 40. | STM8S007xx value line ordering information scheme <sup>(1)</sup> | Introduction STM8S007C8 #### Introduction 1 This datasheet contains the description of the STM8S007xx value line features, pinout, electrical characteristics, mechanical data and ordering information. - For complete information on the STM8S microcontroller memory, registers and peripherals, please refer to the STM8S and STM8A microcontroller families reference manual (RM0016). - For information on programming, erasing and protection of the internal Flash memory please refer to the PM0051 (How to program STM8S and STM8A Flash program memory and data EEPROM). - 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). 8/90 Doc ID 022171 Rev 2 STM8S007C8 Description # 2 Description The STM8S007xx value line 8-bit microcontrollers offer 64 Kbytes Flash program memory. They are referred to as high-density devices in the STM8S microcontroller family reference manual. All devices of the STM8S007xx value line provide the following benefits: reduced system cost, performance robustness, short development cycles, and product longevity. The system cost is reduced thanks to a true data EEPROM for up to 100 k write/erase cycles and a high system integration level with internal clock oscillators, watchdog, and brown-out reset. Device performance is ensured by 20 MIPS at 24 MHz CPU clock frequency 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 modular peripherals. Full documentation is offered with a wide choice of development tools. Product longevity is ensured in the STM8S family thanks to their advanced core which is made in a state-of-the art technology for applications with 2.95 V to 5.5 V operating supply. Table 1. STM8S007xx value line features | Features | STM8S007C8 | |-----------------------------------|------------| | Pin count | 48 | | Max. number of GPIOs (I/O) | 38 | | External interrupt pins | 35 | | Timer CAPCOM channels | 9 | | Timer complementary outputs | 3 | | A/D converter channels | 10 | | HIgh sink I/Os | 16 | | High density Flash program memory | 64 Kbytes | | Data EEPROM | 128 bytes | | RAM | 6 Kbytes | Block diagram STM8S007C8 # 3 Block diagram Figure 1. STM8S007xx value line block diagram Reset block XTAL 1-24 MHz Clock controller Reset RC int. 16 MHz Detector POR BOR RC int. 128 kHz Clock to peripherals and core Window WDG STM8 core Independent WDG Single wire Debug/SWIM 64 Kbytes high debug interf. density program Flash 400 Kbit/s < I<sup>2</sup>C 128 bytes data EEPROM Address and data bus 10 Mbit/s < SPI 6 Kbytes RAM LIN master SPI emul. Boot ROM UART1 Up to 4 CAPCOM 16-bit advanced control channels Master/slave UART3 timer (TIM1) + 3 complementary autosynchro outputs 16-bit general purpose timers (TIM2, TIM3) ADC2 16 channels 5 CAPCOM channels 1/2/4 kHz Beeper 8-bit basic timer beep (TIM4) 10/90 Doc ID 022171 Rev 2 AWU timer STM8S007C8 Product overview ### 4 Product overview The following section intends to give an overview of the basic features of the STM8S007xx value line functional modules and peripherals. For more detailed information please refer to the corresponding family reference manual (RM0016). # 4.1 Central processing unit STM8 The 8-bit STM8 core is designed for code efficiency and performance. It contains 6 internal registers which are directly addressable in each execution context, 20 addressing modes including indexed indirect and relative addressing and 80 instructions. #### Architecture and registers - Harvard architecture - 3-stage pipeline - 32-bit wide program memory bus 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 16-Mbyte linear memory space - 16-bit stack pointer access to a 64 K-level stack - 8-bit condition code register 7 condition flags for the result of the last instruction #### Addressing - 20 addressing modes - Indexed indirect addressing mode for look-up tables located anywhere in the address space - Stack pointer relative addressing mode for local variables and parameter passing ### 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 Product overview STM8S007C8 # 4.2 Single wire interface module (SWIM) and debug module (DM) The single wire interface module and debug module permits non-intrusive, real-time incircuit debugging and fast memory programming. #### **SWIM** Single wire interface module for direct access to the debug module and memory programming. The interface can be activated in all device operation modes. The maximum data transmission speed is 145 bytes/ms. #### **Debug module** The non-intrusive debugging module features a performance close to a full-featured emulator. Beside memory and peripherals, also CPU operation can be monitored in real-time by means of shadow registers. - R/W to RAM and peripheral registers in real-time - R/W access to all resources by stalling the CPU - Breakpoints on all program-memory instructions (software breakpoints) - Two advanced breakpoints, 23 predefined configurations # 4.3 Interrupt controller - Nested interrupts with three software priority levels - 32 interrupt vectors with hardware priority - Up to 33 external interrupts on six vectors including TLI - Trap and reset interrupts # 4.4 Flash program and data EEPROM memory - 64 Kbytes of high density Flash program single voltage Flash memory - 128 bytes true data EEPROM - Read while write: Writing in data memory possible while executing code in program memory. - User option byte area #### Write protection (WP) Write protection of Flash program memory and data EEPROM is provided to avoid unintentional overwriting of memory that could result from a user software malfunction. There are two levels of write protection. The first level is known as MASS (memory access security system). MASS is always enabled and protects the main Flash program memory, data EEPROM and option bytes. To perform in-application programming (IAP), this write protection can be removed by writing a MASS key sequence in a control register. This allows the application to write to data EEPROM, modify the contents of main program memory or the device option bytes. A second level of write protection, can be enabled to further protect a specific area of memory known as UBC (user boot code). Refer to *Figure 2*. 12/90 Doc ID 022171 Rev 2 STM8S007C8 Product overview The size of the UBC is programmable through the UBC option byte (*Table 12*), in increments of 1 page (512 bytes) by programming the UBC option byte in ICP mode. This divides the program memory into two areas: - Main program memory: 64 Kbytes minus UBC - User-specific boot code (UBC): Configurable up to 64 Kbytes The UBC area remains write-protected during in-application programming. This means that the MASS keys do not unlock the UBC area. It protects the memory used to store the boot program, specific code libraries, reset and interrupt vectors, the reset routine and usually the IAP and communication routines. ### Read-out protection (ROP) The read-out protection blocks reading and writing the Flash program memory and data EEPROM memory in ICP mode (and debug mode). Once the read-out protection is activated, any attempt to toggle its status triggers a global erase of the program and data memory. Even if no protection can be considered as totally unbreakable, the feature provides a very high level of protection for a general purpose microcontroller. Product overview STM8S007C8 ### 4.5 Clock controller The clock controller distributes the system clock (f<sub>MASTER)</sub> coming from different oscillators to the core and the peripherals. It also manages clock gating for low power modes and ensures clock robustness. #### **Features** - Clock prescaler: To get the best compromise between speed and current consumption the clock frequency to the CPU and peripherals can be adjusted by a programmable prescaler. - **Safe clock switching:** Clock sources can be changed safely on the fly in run mode through a configuration register. The clock signal is not switched until the new clock source is ready. The design guarantees glitch-free switching. - Clock management: To reduce power consumption, the clock controller can stop the clock to the core, individual peripherals or memory. - Master clock sources: Four different clock sources can be used to drive the master clock: - 1-24 MHz high-speed external crystal (HSE) - Up to 24 MHz high-speed user-external clock (HSE user-ext) - 16 MHz high-speed internal RC oscillator (HSI) - 128 kHz low-speed internal RC (LSI) - **Startup clock**: After reset, the microcontroller restarts by default with an internal 2 MHz clock (HSI/8). The prescaler ratio and clock source can be changed by the application program as soon as the code execution starts. - Clock security system (CSS): This feature can be enabled by software. If an HSE clock failure occurs, the internal RC (16 MHz/8) is automatically selected by the CSS and an interrupt can optionally be generated. - Configurable main clock output (CCO): This outputs an external clock for use by the application. Table 2. 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 | UART3 | PCKEN27 | Reserved | PCKEN23 | ADC | | PCKEN16 | TIM3 | PCKEN12 | UART1 | PCKEN26 | Reserved | PCKEN22 | AWU | | PCKEN15 | TIM2 | PCKEN11 | SPI | PCKEN25 | Reserved | PCKEN21 | Reserved | | PCKEN14 | TIM4 | PCKEN10 | I <sup>2</sup> C | PCKEN24 | Reserved | PCKEN20 | Reserved | STM8S007C8 Product overview ## 4.6 Power management 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: In this mode the microcontroller uses the least power. The CPU and peripheral clocks are stopped, the main voltage regulator is powered off. Wakeup is triggered by external event or reset. # 4.7 Watchdog timers The watchdog system is based on two independent timers providing maximum security to the applications. Activation of the watchdog timers is controlled by option bytes or by software. Once activated, the watchdogs cannot be disabled by the user program without performing a reset. ### Window watchdog timer The window watchdog is used to detect the occurrence of a software fault, usually generated by external interferences or by unexpected logical conditions, which cause the application program to abandon its normal sequence. The window function can be used to trim the watchdog behavior to match the application perfectly. The application software must refresh the counter before time-out and during a limited time window. A reset is generated in two situations: - 1. Timeout: At 16 MHz CPU clock the time-out period can be adjusted between 75 $\mu$ s up to 64 ms. - 2. Refresh out of window: The downcounter is refreshed before its value is lower than the one stored in the window register. Product overview STM8S007C8 ### Independent watchdog timer The independent watchdog peripheral can be used to resolve processor malfunctions due to hardware or software failures. It is clocked by the 128 kHZ LSI internal RC clock source, and thus stays active even in case of a CPU clock failure The IWDG time base spans from 60 µs to 1 s. ## 4.8 Auto wakeup counter - Used for auto wakeup from active halt mode - Clock source: 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 # 4.9 Beeper The beeper function outputs a signal on the BEEP pin for sound generation. The signal is in the range of 1, 2 or 4 kHz. #### 4.10 TIM1 - 16-bit 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 half-bridge driver - 16-bit up, down and up/down autoreload counter with 16-bit prescaler - Four independent capture/compare channels (CAPCOM) configurable as input capture, output compare, PWM generation (edge and center aligned mode) and single pulse mode output - Synchronization module to control the timer with external signals - Break input to force the timer outputs into a defined state - Three complementary outputs with adjustable dead time - Encoder mode - Interrupt sources: 3 x input capture/output compare, 1 x overflow/update, 1 x break # 4.11 TIM2, TIM3 - 16-bit general purpose timers - 16-bit autoreload (AR) up-counter - 15-bit prescaler adjustable to fixed power of 2 ratios 1...32768 - Timers with 3 or 2 individually configurable capture/compare channels - PWM mode - Interrupt sources: 2 or 3 x input capture/output compare, 1 x overflow/update **577** STM8S007C8 Product overview ### 4.12 TIM4 - 8-bit basic timer • 8-bit autoreload, adjustable prescaler ratio to any power of 2 from 1 to 128 Clock source: CPU clock Interrupt source: 1 x overflow/update Table 3. TIM timer features | Timer | Counter<br>size<br>(bits) | Prescaler | Counting mode | CAPCOM channels | Complem. outputs | Ext.<br>trigger | Timer<br>synchr-<br>onization/<br>chaining | |-------|---------------------------|--------------------------------|---------------|-----------------|------------------|-----------------|--------------------------------------------| | TIM1 | 16 | Any integer from 1 to 65536 | Up/down | 4 | 3 | Yes | | | TIM2 | 16 | Any power of 2 from 1 to 32768 | Up | 3 | 0 | No | No | | TIM3 | 16 | Any power of 2 from 1 to 32768 | Up | 2 | 0 | No | INO | | TIM4 | 8 | Any power of 2 from 1 to 128 | Up | 0 | 0 | No | | # 4.13 Analog-to-digital converter (ADC2) STM8S007xx value line products contain a 10-bit successive approximation A/D converter (ADC2) with up to 10 multiplexed input channels and the following main features: Input voltage range: 0 to V<sub>DDA</sub> Conversion time: 14 clock cycles Single and continuous modes External trigger input Trigger from TIM1 TRGO End of conversion (EOC) interrupt ### 4.14 Communication interfaces The following communication interfaces are implemented: - UART1: Full feature UART, SPI emulation, LIN2.1 master capability, Smartcard mode, IrDA mode, single wire mode. - UART3: Full feature UART, LIN2.1 master/slave capability SPI: Full and half-duplex, 10 Mbit/s I<sup>2</sup>C: Up to 400 Kbit/s Product overview STM8S007C8 #### 4.14.1 UART1 #### Main features - One Mbit/s full duplex SCI - SPI emulation - High precision baud rate generator - Smartcard emulation - IrDA SIR encoder decoder - LIN master mode - Single wire half duplex mode ### Asynchronous communication (UART mode) - Full duplex communication NRZ standard format (mark/space) - Programmable transmit and receive baud rates up to 1 Mbit/s (f<sub>CPU</sub>/16) and capable of following any standard baud rate regardless of the input frequency - Separate enable bits for transmitter and receiver - Two receiver wakeup modes: - Address bit (MSB) - Idle line (interrupt) - Transmission error detection with interrupt generation - Parity control ### Synchronous communication - Full duplex synchronous transfers - SPI master operation - 8-bit data communication - Maximum speed: 1 Mbit/s at 16 MHz (f<sub>CPU</sub>/16) #### LIN master mode - Emission: Generates 13-bit synch break frame - Reception: Detects 11-bit break frame #### 4.14.2 UART3 #### Main features - 1 Mbit/s full duplex SCI - LIN master capable - High precision baud rate generator Downloaded from Elcodis.com electronic components distributor STM8S007C8 Product overview ### Asynchronous communication (UART mode) - Full duplex communication NRZ standard format (mark/space) - Programmable transmit and receive baud rates up to 1 Mbit/s (f<sub>CPU</sub>/16) and capable of following any standard baud rate regardless of the input frequency - Separate enable bits for transmitter and receiver - Two receiver wakeup modes: - Address bit (MSB) - Idle line (interrupt) - Transmission error detection with interrupt generation - Parity control #### LIN master capability - Emission: Generates 13-bit synch break frame - Reception: Detects 11-bit break frame #### LIN slave mode - Autonomous header handling one single interrupt per valid message header - Automatic baud rate synchronization maximum tolerated initial clock deviation ±15 % - Synch delimiter checking - 11-bit LIN synch break detection break detection always active - Parity check on the LIN identifier field - LIN error management - Hot plugging support ### 4.14.3 SPI - Maximum speed: 10 Mbit/s (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/master selection input pin Product overview STM8S007C8 # 4.14.4 I<sup>2</sup>C - I<sup>2</sup>C master features: - Clock generation - Start and stop generation - I<sup>2</sup>C slave features: - Programmable I<sup>2</sup>C address detection - Stop bit detection - Generation and detection of 7-bit/10-bit addressing and general call - Supports different communication speeds: - Standard speed (up to 100 kHz) - Fast speed (up to 400 kHz) # 5 Pinouts and pin description Figure 3. LQFP 48-pin pinout - (HS) high sink capability. - 2. (T) True open drain (P-buffer and protection diode to $V_{DD}$ not implemented). - [] alternate function remapping option (If the same alternate function is shown twice, it indicates an exclusive choice not a duplication of the function). Table 4. Legend/abbreviations for LQFP48 pin description table | Туре | I = input, O | = input, O = output, S = power supply | | | | | | | | |-------------------------------------------------------------------------------------------------------|-------------------------------------------------|-----------------------------------------------------------------------|--|--|--|--|--|--|--| | | floating | | | | | | | | | | Input | wpu = weak pull-up | | | | | | | | | | | Ext. interrup | ot = external interrupt | | | | | | | | | | HS = high s | ink | | | | | | | | | | | O1 = Slow (up to 2 MHz) | | | | | | | | | Output | Speed | O3 = Fast/slow programmability with slow as default state after reset | | | | | | | | | Output | | O4 = Fast/slow programmability with fast as default state after reset | | | | | | | | | | OD = open drain | | | | | | | | | | | PP = push pull | | | | | | | | | | Reset state | Bold X (pin state after internal reset release) | | | | | | | | | | Unless otherwise specified, the pin state is the same during the resafter the internal reset release. | | | | | | | | | | Table 5. LQFP48 pin description | _ | _ | | Input | | t | Output | | | | E ( | | | |------------|-----------------------------|------|----------|----------|----------------|-----------|-------|----|----|--------------------------------|----------------------------------|------------------------------------------------------| | Pin number | Pin name | Туре | floating | ndw | Ext. interrupt | High sink | Speed | αo | ЬР | Main function<br>(after reset) | Default<br>alternate<br>function | Alternate<br>function<br>after remap<br>[option bit] | | 1 | NRST | I/O | | <u>X</u> | | | | | | Reset | | | | 2 | PA1/OSCIN | I/O | X | Χ | | | 01 | Х | х | Port A1 | Resonator/<br>crystal in | | | 3 | PA2/OSCOUT | I/O | <u>X</u> | Χ | Х | | 01 | Х | х | Port A2 | Resonator/<br>crystal out | | | 4 | V <sub>SSIO_1</sub> | S | | | | | | | | I/O groun | d | | | 5 | V <sub>SS</sub> | S | | | | | | | | Digital ground | | | | 6 | VCAP | S | | | | | | | | 1.8 V regulator capacitor | | | | 7 | V <sub>DD</sub> | S | | | | | | | | Digital power supply | | | | 8 | V <sub>DDIO_1</sub> | S | | | | | | | | I/O powe | r supply | | | 9 | PA3/TIM2_CH3 | I/O | <u>X</u> | X | Х | | 01 | Х | х | Port A3 | Timer 2 -<br>channel3 | TIM3_CH1<br>[AFR1] | | 10 | PA4/UART1_RX <sup>(1)</sup> | I/O | <u>X</u> | Х | Х | HS | О3 | Х | Χ | Port A4 | UART1 receive | | | 11 | PA5/UART1_TX | I/O | <u>x</u> | Х | Х | HS | О3 | Х | х | Port A5 | UART1<br>transmit | | | 12 | PA6/UART1_CK | I/O | <u>X</u> | Х | Х | HS | О3 | Х | х | Port A6 | UART1<br>synchronous<br>clock | | | 13 | $V_{DDA}$ | S | | | | | | | | Analog p | ower supply | | 22/90 Doc ID 022171 Rev 2 Table 5. LQFP48 pin description (continued) | _ | | | | Inpu | t | | Out | put | | <b>c</b> _ | | | |------------|---------------------|------|----------|------|----------------|-----------|-------|-----|----|--------------------------------|----------------------------------|------------------------------------------------------| | Pin number | Pin name | Туре | floating | ndw | Ext. interrupt | High sink | Speed | ОО | ЬР | Main function<br>(after reset) | Default<br>alternate<br>function | Alternate<br>function<br>after remap<br>[option bit] | | 14 | V <sub>SSA</sub> | S | | | | | | | | Analog gı | round | | | 15 | PB7/AIN7 | I/O | X | Х | Х | | 01 | Х | Х | Port B7 | Analog<br>input 7 | | | 16 | PB6/AIN6 | I/O | <u>X</u> | X | Χ | | 01 | X | Х | Port B6 | Analog<br>input 6 | | | 17 | PB5/AIN5 | I/O | <u>X</u> | X | X | | 01 | X | Х | Port B5 | Analog<br>input 5 | I <sup>2</sup> C_SDA<br>[AFR6] | | 18 | PB4/AIN4 | I/O | <u>X</u> | X | X | | 01 | X | Х | Port B4 | Analog<br>input 4 | I <sup>2</sup> C_SCL<br>[AFR6] | | 19 | PB3/AIN3 | I/O | X | X | Χ | | 01 | X | Х | Port B3 | Analog<br>input 3 | TIM1_ETR<br>[AFR5] | | 20 | PB2/AIN2 | I/O | X | Х | X | | O1 | X | Х | Port B2 | Analog<br>input 2 | TIM1_<br>CH3N<br>[AFR5] | | 21 | PB1/AIN1 | I/O | X | x | х | | O1 | x | Х | Port B1 | Analog<br>input 1 | TIM1_<br>CH2N<br>[AFR5] | | 22 | PB0/AIN0 | I/O | <u>X</u> | х | Х | | O1 | X | Х | Port B0 | Analog<br>input 0 | TIM1_<br>CH1N<br>[AFR5] | | 23 | PE7/AIN8 | I/O | X | Х | Х | | 01 | Χ | Х | Port E7 | Analog input 8 | | | 24 | PE6/AIN9 | I/O | <u>X</u> | Х | Х | | 01 | Χ | Χ | Port E6 | Analog input 9 | | | 25 | PE5/SPI_NSS | I/O | <u>X</u> | Х | х | | O1 | Х | Х | Port E5 | SPI<br>master/slave<br>select | | | 26 | PC1/TIM1_CH1 | I/O | <u>x</u> | Х | Х | HS | О3 | Х | х | Port C1 | Timer 1 -<br>channel 1 | | | 27 | PC2/TIM1_CH2 | I/O | X | Х | Х | HS | О3 | Х | х | Port C2 | Timer 1-<br>channel 2 | | | 28 | PC3/TIM1_CH3 | I/O | <u>X</u> | Х | Х | HS | О3 | Х | Х | Port C3 | Timer 1 -<br>channel 3 | | | 29 | PC4/TIM1_CH4 | I/O | <u>x</u> | Х | Х | HS | О3 | Х | Х | Port C4 | Timer 1 -<br>channel 4 | | | 30 | PC5/SPI_SCK | I/O | X | Χ | Χ | HS | О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 | r supply | | **577** Doc ID 022171 Rev 2 Input Output Main function (after reset) number **Alternate** Default Ext. interrupt Type High sink function floating Pin name alternate after remap 0 Ь function [option bit] SPI master PC6/SPI\_MOSI I/O 33 <u>X</u> Х Х HS О3 Χ Χ Port C6 out/ slave in SPI master in/ 34 PC7/SPI MISO I/O <u>X</u> Χ Х HS О3 Χ Χ Port C7 slave out 35 PG0 I/O <u>X</u> Χ 01 Χ Х Port G0 36 PG1 I/O <u>X</u> Χ 01 Х Χ Port G1 Timer 1 -I/O Χ Х 01 Χ 37 PE3/TIM1\_BKIN <u>X</u> Χ Port E3 break input PE2/I<sup>2</sup>C SDA I/O Χ 01 $T^{(2)}$ I<sup>2</sup>C data 38 <u>X</u> Port E2 T<sup>(2)</sup> PE1/I2C\_SCL I/O Χ 01 I<sup>2</sup>C clock 39 <u>X</u> Port E1 Configurable 40 PE0/CLK\_CCO I/O <u>X</u> Х Χ HS О3 Х Χ Port E0 clock output TIM1\_BKIN [AFR3]/ Timer 3 -41 PD0/TIM3\_CH2 I/O X Χ Х HS О3 Х Х Port D0 CLK\_CCO channel 2 [AFR2] SWIM data 42 PD1/SWIM<sup>(3)</sup> I/O Χ X HS 04 Х Port D1 Χ Χ interface Timer 3 -TIM2\_CH3 43 PD2/TIM3\_CH1 I/O <u>X</u> Χ HS О3 Χ Port D2 Х Х channel 1 [AFR1] Timer 2 -ADC\_ETR 44 PD3/TIM2\_CH2 I/O <u>X</u> Χ Χ HS О3 Χ Χ Port D3 channel 2 [AFR0] PD4/TIM2\_CH1/B BEEP output Timer 2 -I/O 45 <u>X</u> Χ Χ HS О3 Χ Χ Port D4 **EEP** channel 1 [AFR7] UART3 data 46 PD5/ UART3 TX I/O X Х Х 01 Χ Х Port D5 transmit PD6/ UART3 data 47 I/O X Х Х 01 Χ Χ Port D6 UART3 RX<sup>(1)</sup> receive Table 5. LQFP48 pin description (continued) 01 | X | X Note: The slope control of true open drain pins cannot be programmed and by default is limited to 2 MHz. 24/90 Doc ID 022171 Rev 2 I/O | <u>X</u> | X | X Top level interrupt Port D7 48 PD7/TLI The default state of UART1\_RX and UART3\_RX pins is controlled by the ROM bootloader. These pins are pulled up as part of the bootloader activation process and returned to the floating state before a return from the bootloader. <sup>2.</sup> In the open-drain output column, 'T' defines a true open-drain I/O (P-buffer, weak pull-up, and protection diode to $V_{DD}$ are not implemented). <sup>3.</sup> The PD1 pin is in input pull-up during the reset phase and after the internal reset release. # 5.1 Alternate function remapping As shown in the rightmost column of the pin description table, 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 8: Option bytes*. 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 family reference manual, RM0016). # 6 Memory and register map # 6.1 Memory map Figure 4. Memory map 26/90 Doc ID 022171 Rev 2 *Table 6* lists the boundary addresses for each memory size. The top of the stack is at the RAM end address in each case. Table 6. Flash, Data EEPROM and RAM boundary addresses | Memory area | Size (bytes) | Start address | End address | |----------------------|--------------|---------------|-------------| | Flash program memory | 64 K | 0x00 8000 | 0x01 7FFF | | RAM | 6 K | 0x00 0000 | 0x00 17FF | | Data EEPROM | 128 | 0x00 4000 | 0x00 407F | # 6.2 Register map Table 7. I/O port hardware register map | Address | Block | Register label | Register name | Reset<br>status | |-----------|--------|----------------|-----------------------------------|-----------------| | 0x00 5000 | | PA_ODR | Port A data output latch register | 0x00 | | 0x00 5001 | | PA_IDR | Port A input pin value register | 0x00 | | 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 | Port B | PB_IDR | Port B input pin value register | 0x00 | | 0x00 5007 | | 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 | 0x00 | | 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 | 0x00 | | 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 | Table 7. I/O port hardware register map (continued) | Address | Block | Register label | Register name | Reset<br>status | |-----------|--------|----------------|-----------------------------------|-----------------| | 0x00 5014 | | PE_ODR | Port E data output latch register | 0x00 | | 0x00 5015 | | PE_IDR | Port E input pin value register | 0x00 | | 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 | 0x00 | | 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 | | 0x00 501E | | PG_ODR | Port G data output latch register | 0x00 | | 0x00 501F | | PG_IDR | Port G input pin value register | 0x00 | | 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 | | 0x00 5023 | | PH_ODR | Port H data output latch register | 0x00 | | 0x00 5024 | | PH_IDR | Port H input pin value register | 0x00 | | 0x00 5025 | Port H | PH_DDR | Port H data direction register | 0x00 | | 0x00 5026 | | PH_CR1 | Port H control register 1 | 0x00 | | 0x00 5027 | | PH_CR2 | Port H control register 2 | 0x00 | | 0x00 5028 | | PI_ODR | Port I data output latch register | 0x00 | | 0x00 5029 | | PI_IDR | Port I input pin value register | 0x00 | | 0x00 502A | Port I | PI_DDR | Port I data direction register | 0x00 | | 0x00 502B | | PI_CR1 | Port I control register 1 | 0x00 | | 0x00 502C | | PI_CR2 | Port I control register 2 | 0x00 | 28/90 Doc ID 022171 Rev 2 Table 8. General hardware register map | Address | Block | Register label | Register name | Reset<br>status | |---------------------------|-------|----------------|--------------------------------------------------|-------------------| | 0x00 5050 to<br>0x00 5059 | | | Reserved area (10 bytes) | | | 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 | 0x00 | | 0x00 5060 to<br>0x00 5061 | | | Reserved area (2 bytes) | | | 0x00 5062 | Flash | FLASH _PUKR | Flash Program memory unprotection register | 0x00 | | 0x00 5063 | | | Reserved area (1 byte) | • | | 0x00 5064 | Flash | FLASH _DUKR | Data EEPROM unprotection register | 0x00 | | 0x00 5065 to<br>0x00 509F | | | Reserved area (59 bytes) | | | 0x00 50A0 | ITC | EXTI_CR1 | External interrupt control register 1 | 0x00 | | 0x00 50A1 | | EXTI_CR2 | External interrupt control register 2 | 0x00 | | 0x00 50A2 to<br>0x00 50B2 | | | Reserved area (17 bytes) | | | 0x00 50B3 | RST | RST_SR | Reset status register | 0xXX <sup>(</sup> | | 0x00 50B4 to<br>0x00 50BF | | | Reserved area (12 bytes) | | | 0x00 50C0 | CLIK | CLK_ICKR | Internal clock control register | 0x01 | | 0x00 50C1 | CLK | CLK_ECKR | External clock control register | 0x00 | | 0x00 50C2 | | | Reserved area (1 byte) | • | | 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 | CLIK | CLK_CKDIVR | Clock divider register | 0x18 | | 0x00 50C7 | CLK | CLK_PCKENR1 | Peripheral clock gating register 1 | 0xFF | | 0x00 50C8 | 7 | CLK_CSSR | Clock security system register | 0x00 | | 0x00 50C9 | 7 | CLK_CCOR | Configurable clock control register | 0x00 | | 0x00 50CA | | CLK_PCKENR2 | Peripheral clock gating register 2 | 0xFF | | 0x00 50CB | | • | Reserved area (1 byte) | | 47/ Doc ID 022171 Rev 2 29/90 Table 8. General hardware register map (continued) | Table 6. Gel | iciai naiawaic | register map (con | T. T | | | | |---------------------------|------------------|-------------------------|--------------------------------------------|---------------------|--|--| | Address | Block | Register label | Register name | Reset status | | | | 0x00 50CC | | CLK_HSITRIMR | HSI clock calibration trimming register | 0x00 | | | | 0x00 50CD | CLK | CLK_SWIMCCR | SWIM clock control register | 0bXXXX<br>XXX0 | | | | 0x00 50CE to<br>0x00 50D0 | | Reserved area (3 bytes) | | | | | | 0x00 50D1 | MANDO | WWDG_CR | WWDG control register | 0x7F | | | | 0x00 50D2 | WWDG | WWDG_WR | WWDR window register | 0x7F | | | | 0x00 50D3 to<br>0x00 50DF | | | Reserved 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 | | | Reserved 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 | | | Reserved area (12 bytes) | | | | | 0x00 5200 | | SPI_CR1 | SPI control register 1 | 0x00 | | | | 0x00 5201 | | SPI_CR2 | SPI control register 2 | 0x00 | | | | 0x00 5202 | | SPI_ICR | SPI interrupt control register | 0x00 | | | | 0x00 5203 | SPI | SPI_SR | SPI status register | 0x02 | | | | 0x00 5204 | 351 | 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 | | | Reserved area (8 bytes) | | | | | 0x00 5210 | | I2C_CR1 | I <sup>2</sup> C control register 1 | 0x00 | | | | 0x00 5211 | | I2C_CR2 | I <sup>2</sup> C control register 2 | 0x00 | | | | 0x00 5212 | l <sup>2</sup> C | I2C_FREQR | I <sup>2</sup> C frequency register | 0x00 | | | | 0x00 5213 | | I2C_OARL | I <sup>2</sup> C own address register low | 0x00 | | | | 0x00 5214 | | I2C_OARH | I <sup>2</sup> C own address register high | 0x00 | | | | 0x00 5215 | | | Reserved | <u></u> | | | 30/90 Doc ID 022171 Rev 2 Table 8. General hardware register map (continued) | Address | Block | Register label | Register name | Reset status | |---------------------------|------------------|----------------|----------------------------------------------|--------------| | 0x00 5216 | | I2C_DR | I <sup>2</sup> C data register | 0x00 | | 0x00 5217 | | I2C_SR1 | I <sup>2</sup> C status register 1 | 0x00 | | 0x00 5218 | | I2C_SR2 | I <sup>2</sup> C status register 2 | 0x00 | | 0x00 5219 | l <sup>2</sup> C | I2C_SR3 | I <sup>2</sup> C status register 3 | 0x00 | | 0x00 521A | | I2C_ITR | I <sup>2</sup> C interrupt control register | 0x00 | | 0x00 521B | | I2C_CCRL | I <sup>2</sup> C clock control register low | 0x00 | | 0x00 521C | | I2C_CCRH | I <sup>2</sup> C clock control register high | 0x00 | | 0x00 521D | | I2C_TRISER | I <sup>2</sup> C TRISE register | 0x02 | | 0x00 521E to<br>0x00 522F | | R | eserved area (18 bytes) | | | 0x00 5230 | | UART1_SR | UART1 status register | 0xC0 | | 0x00 5231 | | UART1_DR | UART1 data register | 0xXX | | 0x00 5232 | | UART1_BRR1 | UART1 baud rate register 1 | 0x00 | | 0x00 5233 | | UART1_BRR2 | UART1 baud rate register 2 | 0x00 | | 0x00 5234 | | UART1_CR1 | UART1 control register 1 | 0x00 | | 0x00 5235 | UART1 | UART1_CR2 | UART1 control register 2 | 0x00 | | 0x00 5236 | | UART1_CR3 | UART1 control register 3 | 0x00 | | 0x00 5237 | | UART1_CR4 | UART1 control register 4 | 0x00 | | 0x00 5238 | | UART1_CR5 | UART1 control register 5 | 0x00 | | 0x00 5239 | | UART1_GTR | UART1 guard time register | 0x00 | | 0x00 523A | | UART1_PSCR | UART1 prescaler register | 0x00 | | 0x00 523B to<br>0x00 523F | | F | Reserved area (5 bytes) | | | 0x00 5240 | | UART3_SR | UART3 status register | C0h | | 0x00 5241 | | UART3_DR | UART3 data register | 0xXX | | 0x00 5242 | | UART3_BRR1 | UART3 baud rate register 1 | 0x00 | | 0x00 5243 | | UART3_BRR2 | UART3 baud rate register 2 | 0x00 | | 0x00 5244 | LIADTO | UART3_CR1 | UART3 control register 1 | 0x00 | | 0x00 5245 | UART3 | UART3_CR2 | UART3 control register 2 | 0x00 | | 0x00 5246 | | UART3_CR3 | UART3 control register 3 | 0x00 | | 0x00 5247 | | UART3_CR4 | UART3 control register 4 | 0x00 | | 0x00 5248 | | | Reserved | I | | 0x00 5249 | | UART3_CR6 | UART3 control register 6 | 0x00 | | 0x00 524A to<br>0x00 524F | | F | Reserved area (6 bytes) | | 47/ Doc ID 022171 Rev 2 31/90 Table 8. General hardware register map (continued) | Table 6. Gene | | register map (con | | | |---------------------------|--------|-------------------|----------------------------------------|-----------------| | Address | Block | Register label | Register name | Reset<br>status | | 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_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 | TIN 44 | TIM1_CNTRL | TIM1 counter low | 0x00 | | 0x00 5260 | TIM1 | 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 | | 0x00 5265 | | 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 | | F | Reserved area (147 bytes) | 1 | 32/90 Doc ID 022171 Rev 2 Table 8. General hardware register map (continued) | Address | Block | Register label | Register name | Reset status | |---------------------------|-------|-----------------------|----------------------------------------------------------|--------------| | 0x00 5300 | | TIM2_CR1 | TIM2 control register 1 | 0x00 | | 0x00 5301 | | TIM2_IER | TIM2 interrupt enable register | 0x00 | | 0x00 5302 | | 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 | 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 | | 0x00 5314 | | TIM2_CCR3L | TIM2 capture/compare register 3 low | 0x00 | | 0x00 5315 to<br>0x00 531F | | ŀ | Reserved area (11 bytes) | | | 0x00 5320 | | 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 | TIM3_CCMR1 | TIM3 capture/compare mode register 1 | 0x00 | | | | TIM3_CCMR2 | TIM3 capture/compare mode register 2 | 0x00 | | 0x00 5326 | | | | | | 0x00 5326<br>0x00 5327 | | TIM3_CCER1 | TIM3 capture/compare enable register 1 | 0x00 | | | | TIM3_CCER1 TIM3_CNTRH | TIM3 capture/compare enable register 1 TIM3 counter high | 0x00<br>0x00 | | 0x00 5327 | | | · · · · · · · · · · · · · · · · · · · | | 47/ Doc ID 022171 Rev 2 33/90 Table 8. General hardware register map (continued) | Address | Block | Register label | Register name | Reset status | | | |---------------------------|-------|----------------|-------------------------------------------|--------------|--|--| | 0x00 532B | | TIM3_ARRH | TIM3 auto-reload register high | 0xFF | | | | 0x00 532C | TIM3 | 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 53FF | | F | Reserved area (185 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 | ADC2 | ADC_CR3 | ADC configuration register 3 | 0x00 | | | | 0x00 5404 | ADC2 | ADC_DRH | ADC data register high | 0xXX | | | | 0x00 5405 | | ADC_DRL | ADC data register low | 0xXX | | | | 0x00 5406 | | ADC_TDRH | ADC Schmitt trigger disable register high | 0x00 | | | | 0x00 5407 | | ADC_TDRL | ADC Schmitt trigger disable register low | 0x00 | | | | 0x00 5408 to<br>0x00 57FF | | R | eserved area (1016 bytes) | | | | <sup>1.</sup> Depends on the previous reset source. <sup>2.</sup> Write only register. Table 9. CPU/SWIM/debug module/interrupt controller registers | Address | Block | Register Label | Register Name | Reset<br>Status | | | |---------------------------|-------------------------|----------------|----------------------------------------|---------------------|--|--| | 0x00 7F00 | | Α | Accumulator | 0x00 | | | | 0x00 7F01 | _ | PCE | Program counter extended | 0x00 | | | | 0x00 7F02 | | PCH | Program counter high | 0x00 | | | | 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 | | CCR | 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_SPR3 | Interrupt software priority register 3 | 0xFF | | | | 0x00 7F73 | ITO | ITC_SPR4 | Interrupt software priority register 4 | 0xFF | | | | 0x00 7F74 | ITC | ITC_SPR5 | Interrupt software priority register 5 | 0xFF | | | | 0x00 7F75 | | ITC_SPR6 | Interrupt software priority register 6 | 0xFF | | | | 0x00 7F76 | | ITC_SPR7 | Interrupt software priority register 7 | 0xFF | | | | 0x00 7F77 | | ITC_SPR8 | Interrupt software priority register 8 | 0xFF | | | | 0x00 7F78 to<br>0x00 7F79 | Reserved area (2 bytes) | | | | | | | 0x00 7F80 | SWIM | SWIM_CSR | SWIM control status register | 0x00 | | | | 0x00 7F81 to<br>0x00 7F8F | | | Reserved area (15 bytes) | <u>'</u> | | | Table 9. CPU/SWIM/debug module/interrupt controller registers (continued) | Address | Block | Register Label | Register Name | Reset<br>Status | | | |---------------------------|-------------------------|----------------|-------------------------------------------|-----------------|--|--| | 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 <sup>2.</sup> Product dependent value, see Figure 4: Memory map. # 7 Interrupt vector mapping Table 10. Interrupt mapping | IRQ<br>no. | Source<br>block | Description | Wakeup from<br>Halt mode | Wakeup from<br>Active-halt mode | Vector address | | | |------------|------------------|----------------------------------------------|--------------------------|---------------------------------|----------------|--|--| | | RESET | Reset | Yes | Yes | 0x00 8000 | | | | | TRAP | Software interrupt | - | - | 0x00 8004 | | | | 0 | TLI | External top level interrupt | - | - | 0x00 8008 | | | | 1 | AWU | Auto wake up from halt | - | Yes | 0x00 800C | | | | 2 | CLK | Clock controller | - | - | 0x00 8010 | | | | 3 | EXTI0 | Port A external interrupts | Yes <sup>(1)</sup> | Yes <sup>(1)</sup> | 0x00 8014 | | | | 4 | EXTI1 | Port B external interrupts | Yes | Yes | 0x00 8018 | | | | 5 | EXTI2 | Port C external interrupts | Yes | Yes | 0x00 801C | | | | 6 | EXTI3 | Port D external interrupts | Yes | Yes | 0x00 8020 | | | | 7 | EXTI4 | Port E external interrupts Yes Yes | | 0x00 8024 | | | | | 8 | 8 Reserved | | | | | | | | 9 | | 0x00 802C | | | | | | | 10 | SPI | End of transfer | Yes | Yes | 0x00 8030 | | | | 11 | TIM1 | TIM1 update/overflow/underflow/trigger/break | - | - | 0x00 8034 | | | | 12 | TIM1 | TIM1 capture/compare | - | - | 0x00 8038 | | | | 13 | TIM2 | TIM2 update /overflow | - | - | 0x00 803C | | | | 14 | TIM2 | TIM2 capture/compare | - | - | 0x00 8040 | | | | 15 | TIM3 | Update/overflow | - | - | 0x00 8044 | | | | 16 | TIM3 | Capture/compare | - | - | 0x00 8048 | | | | 17 | UART1 | Tx complete | - | - | 0x00 804C | | | | 18 | UART1 | Receive register DATA FULL | - | - | 0x00 8050 | | | | 19 | I <sup>2</sup> C | I <sup>2</sup> C interrupt | Yes | Yes | 0x00 8054 | | | | 20 | UART3 | Tx complete | - | - | 0x00 8058 | | | | 21 | UART3 | Receive register DATA FULL | - | - | 0x00 805C | | | | 22 | ADC2 | ADC2 end of conversion | - | - | 0x00 8060 | | | | 23 | TIM4 | TIM4 update/overflow | - | - | 0x00 8064 | | | | 24 | Flash | EOP/WR_PG_DIS | - | - | 0x00 8068 | | | | 1 | Reserved | | | | | | | <sup>1.</sup> Except PA1 **577** Option bytes STM8S007C8 # 8 Option bytes Option bytes contain configurations for device hardware features as well as the memory protection of the device. They are stored in a dedicated block of the memory. Except for the ROP (read-out protection) byte, each option byte has to be stored twice, in a regular form (OPTx) and a complemented one (NOPTx) for redundancy. Option bytes can be modified in ICP mode (via SWIM) by accessing the EEPROM address shown in *Table 11: Option bytes* below. Option bytes can also be modified 'on the fly' by the application in IAP mode, except the ROP option that can only be modified in ICP mode (via SWIM). Refer to the STM8S Flash programming manual (PM0051) and STM8 SWIM communication protocol and debug module user manual (UM0470) for information on SWIM programming procedures. Table 11. Option bytes | | Option | Option byte no. | Option bits | | | | | | Factory | | | |-------|---------------------------------|-----------------|-------------|----------------------|-------|-------------|--------------|---------------|----------------|---------------|--------------------| | Addr. | name | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | default<br>setting | | 4800h | Read-out<br>protection<br>(ROP) | ОРТ0 | | ROP[7:0] | | | | | | 00h | | | 4801h | User boot | OPT1 | | UBC[7:0] | | | | | | 00h | | | 4802h | code(UBC) | NOPT1 | | | | NU | JBC[7:0] | | | | FFh | | 4803h | Alternate | OPT2 | AFR7 | AFR6 | AFR5 | Reserved | AFR3 | AFR2 | AFR1 | AFR0 | 00h | | 4804h | function<br>remapping<br>(AFR) | NOPT2 | NAFR7 | NAFR6 | NAFR5 | NAFR4 | NAFR3 | NAFR2 | NAFR1 | NAFR0 | FFh | | 4805h | Watchdog | ОРТ3 | | Reserved | | | LSI<br>_EN | IWDG<br>_HW | WWDG<br>_HW | WWDG<br>_HALT | 00h | | 4806h | option | NOPT3 | Reserved | | | NLSI<br>_EN | NIWDG<br>_HW | NWWDG_<br>HW | NWWDG<br>_HALT | FFh | | | 4807h | Clark ontion | OPT4 | | Rese | erved | | EXT<br>CLK | CKAWU<br>SEL | PRS<br>C1 | PRS<br>C0 | 00h | | 4808h | Clock option | NOPT4 | | Rese | erved | | NEXT<br>CLK | NCKAWUS<br>EL | NPR<br>SC1 | NPR<br>SC0 | FFh | | 4809h | HSE clock | OPT5 | | | | HSE | ECNT[7:0] | | | | 00h | | 480Ah | startup | NOPT5 | | | | NHS | SECNT[7:0] | | | | FFh | | 480Bh | | OPT6 | | | | R | eserved | | | | 00h | | 480Ch | Reserved | NOPT6 | | Reserved | | | | | | FFh | | | 480Dh | Flash wait | OPT7 | | Reserved Wait state | | | | | | 00h | | | 480Eh | states | NOPT7 | | Reserved Nwait state | | | | | | FFh | | | 487Eh | 5 | OPTBL | | | | BL[7:0] | | | 00h | | | | 487Fh | Bootloader | NOPTBL | | | | N | IBL[7:0] | | | | FFh | STM8S007C8 Option bytes Table 12. 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 family reference manual (RM0016) section on Flash/EEPROM memory readout protection for details. | | OPT1 | UBC[7:0] User boot code area 0x00: no UBC, no write-protection 0x01: Pages 0 to 1 defined as UBC, memory write-protected 0x02: Pages 0 to 3 defined as UBC, memory write-protected 0x03: Pages 0 to 4 defined as UBC, memory write-protected 0xFE: Pages 0 to 255 defined as UBC, memory write-protected 0xFF: Reserved Note: Refer to the family 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²C_SDA, port B4 alternate function = I²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 alternate function remapping option 4 Reserved AFR3 Alternate function remapping option 3 0: Port D0 alternate function = TIM3_CH2 1: Port D0 alternate function = TIM3_CH2 1: Port D0 alternate function = TIM3_CH2 1: Port D0 alternate function = TIM3_CH2 1: Port D0 alternate function = TIM2_CH3, port D2 alternate function TIM3_CH1 1: Port A3 alternate function = TIM3_CH1, port D2 alternate function TIM3_CH3 AFR0 Alternate function remapping option 0 0: Port D3 alternate function = TIM2_CH2 1: Port D3 alternate function = TIM2_CH2 1: Port D3 alternate function = TIM2_CH2 1: Port D3 alternate function = ADC_ETR | Option bytes STM8S007C8 Table 12. Option byte description (continued) | Option byte no. | Description | |-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | LSI_EN: Low speed internal clock enable 0: LSI clock is not available as CPU clock source 1: LSI clock is available as CPU clock source | | ODTO | IWDG_HW: Independent watchdog 0: IWDG Independent watchdog activated by software 1: IWDG Independent watchdog activated by hardware | | OPT3 | WWDG_HW: Window watchdog activation 0: WWDG window watchdog activated by software 1: WWDG window watchdog activated by hardware | | | WWDG_HALT: Window watchdog reset on halt 0: No reset generated on halt if WWDG active 1: Reset generated on halt if WWDG active | | | EXTCLK: External clock selection 0: External crystal connected to OSCIN/OSCOUT 1: External clock signal on OSCIN | | OPT4 | CKAWUSEL: Auto wakeup unit/clock 0: LSI clock source selected for AWU 1: HSE clock with prescaler selected as clock source for for AWU | | | PRSC[1:0] AWU clock prescaler 00: 24 MHz to 128 kHz prescaler 01: 16 MHz to 128 kHz prescaler 10: 8 MHz to 128 kHz prescaler 11: 4 MHz to 128 kHz prescaler | | OPT5 | HSECNT[7:0]: HSE crystal oscillator stabilization time This configures the stabilisation time. 0x00: 2048 HSE cycles 0xB4: 128 HSE cycles 0xD2: 8 HSE cycles 0xE1: 0.5 HSE cycles | | OPT6 | Reserved | | OPT7 | WAITSTATE Wait state configuration This option configures the number of wait states inserted when reading from the Flash/data EEPROM memory. 1 wait state is required if f <sub>CPU</sub> > 16 MHz. 0: No wait state 1: 1 wait state | STM8S007C8 Option bytes Table 12. Option byte description (continued) | Option byte no. | Description | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OPTBL | BL[7:0] Bootloader option byte For STM8S products, this option is checked by the boot ROM code after reset. Depending on the content of addresses 0x487E, 0x487F, and 0x8000 (reset vector), the CPU jumps to the bootloader or to the reset vector. Refer to the UM0560 (STM8L/S bootloader manual) for more details. For STM8L products, the bootloader option bytes are on addresses 0xXXXX and 0xXXXXX+1 (2 bytes). These option bytes control whether the bootloader is active or not. For more details, refer to the UM0560 (STM8L/S bootloader manual) for more details. | # 9 Electrical characteristics # 9.1 Parameter conditions Unless otherwise specified, all voltages are referred to V<sub>SS</sub>. #### 9.1.1 Minimum and maximum values Unless otherwise specified the minimum and maximum values are guaranteed in the worst conditions of ambient temperature, supply voltage and frequencies by tests in production on 100 % of the devices with an ambient temperature at $T_A = 25$ °C and $T_A = T_{Amax}$ (given by the selected temperature range). Data based on characterization results, design simulation and/or technology characteristics are indicated in the table footnotes and are not tested in production. Based on characterization, the minimum and maximum values refer to sample tests and represent the mean value plus or minus three times the standard deviation (mean $\pm$ 3 $\Sigma$ ). # 9.1.2 Typical values Unless otherwise specified, typical data are based on $T_A = 25$ °C, $V_{DD} = 5$ 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, where 95% of the devices have an error less than or equal to the value indicated (mean $\pm$ 2 $\Sigma$ ). # 9.1.3 Typical curves Unless otherwise specified, all typical curves are given only as design guidelines and are not tested. # 9.1.4 Typical current consumption For typical current consumption measurements, $V_{DD}$ , $V_{DDIO}$ and $V_{DDA}$ are connected together in the configuration shown in *Figure 5*. Figure 5. Supply current measurement conditions # 9.1.5 Pin loading conditions # 9.1.6 Loading capacitor The loading conditions used for pin parameter measurement are shown in *Figure 6*. Figure 6. Pin loading conditions # 9.1.7 Pin input voltage The input voltage measurement on a pin of the device is described in Figure 7. Figure 7. Pin input voltage # 9.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 13. 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 <sub>IN</sub> | Input voltage on true open drain pins (PE1, PE2) <sup>(2)</sup> | V <sub>SS</sub> - 0.3 | 6.5 | V | | | Input voltage on any other pin <sup>(2)</sup> | V <sub>SS</sub> - 0.3 | V <sub>DD</sub> + 0.3 | | | IV <sub>DDx</sub> - V <sub>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<br>ratings (electrical<br>sensitivity) on page 80 | | | All power (V<sub>DD</sub>, V<sub>DDIO</sub>, V<sub>DDA</sub>) and ground (V<sub>SS</sub>, V<sub>SSIO</sub>, V<sub>SSA</sub>) pins must always be connected to the external power supply I<sub>INJ(PIN)</sub> must never be exceeded. This is implicitly insured if V<sub>IN</sub> maximum is respected. If V<sub>IN</sub> maximum cannot be respected, the injection current must be limited externally to the I<sub>INJ(PIN)</sub> value. A positive injection is induced by V<sub>IN</sub>>V<sub>DD</sub> while a negative injection is induced by V<sub>IN</sub><V<sub>SS</sub>. For true open-drain pads, there is no positive injection current, and the corresponding V<sub>IN</sub> maximum must always be respected Table 14. Current characteristics | Symbol | Ratings | Max. <sup>(1)</sup> | Unit | |---------------------------------------|-------------------------------------------------------------------------------------------------------------------|---------------------|------| | I <sub>VDD</sub> | Total current into V <sub>DD</sub> power lines (source) <sup>(2)</sup> | 60 | | | I <sub>VSS</sub> | Total current out of V <sub>SS</sub> ground lines (sink) <sup>(2)</sup> | 60 | | | | Output current sunk by any I/O and control pin | 20 | | | I <sub>IO</sub> | Output current source by any I/Os and control pin | 20 | | | | Total output current sourced (sum of all I/O and control pins) for devices with two ${\rm V_{DDIO}pins^{(3)}}$ | 200 | | | ΣΙ | Total output current sourced (sum of all I/O and control pins) for devices with one $V_{DDIO}$ pin <sup>(3)</sup> | 100 | mA | | Σl <sub>IO</sub> | Total output current sunk (sum of all I/O and control pins) for devices with two $\rm V_{SSIO}$ pins $^{(3)}$ | 160 | ША | | | Total output current sunk (sum of all I/O and control pins) for devices with one $V_{SSIO} pin^{(3)}$ | 80 | | | | Injected current on NRST pin | ±4 | | | I <sub>INJ(PIN)</sub> (4)(5) | Injected current on OSCIN pin | ±4 | | | | Injected current on any other pin <sup>(6)</sup> | ±4 | | | ΣΙ <sub>ΙΝJ(PIN)</sub> <sup>(4)</sup> | Total injected current (sum of all I/O and control pins) <sup>(6)</sup> | ±20 | | - 1. Data based on characterization results, not tested in production. - 2. 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. - I/O pins used simultaneously for high current source/sink must be uniformly spaced around the package between the V<sub>DDIO</sub>/V<sub>SSIO</sub> pins. - 4. 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 - Negative injection disturbs the analog performance of the device. See note in Section 9.3.10: 10-bit ADC characteristics on page 76. - 6. When several inputs are submitted to a current injection, the maximum ΔI<sub>INJ(PIN)</sub> is the absolute sum of the positive and negative injected currents (instantaneous values). These results are based on characterization with ΔI<sub>INJ(PIN)</sub> maximum current injection on four I/O port pins of the device. Table 15. Thermal characteristics | Symbol | Ratings | Value | Unit | |------------------|------------------------------|------------------------------|------| | T <sub>STG</sub> | Storage temperature range | temperature range -65 to 150 | | | T <sub>J</sub> | Maximum junction temperature | 150 | °C | # 9.3 Operating conditions The device must be used in operating conditions that respect the parameters in *Table 16*. In addition, full account must be taken of all physical capacitor characteristics and tolerances. Table 16. General operating conditions | Symbol | Parameter | Conditions | Min | Max | Unit | |---------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|------|------|------| | f. | Internal CPU clock frequency | | 0 | 24 | MHz | | f <sub>CPU</sub> | internal of o clock frequency | | 0 | 16 | MHz | | $V_{\rm DD/}V_{\rm DD\_IO}$ | Standard operating voltage | | 2.95 | 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 | Ohm | | | ESL of external capacitor | ACTIVILIZA | | 15 | nH | | P <sub>D</sub> <sup>(3)</sup> | Power dissipation at T <sub>A</sub> = 85° C for suffix 6 | 48-pin devices, with output<br>on 8 standard ports, 2 high<br>sink ports and 2 open drain<br>ports simultaneously <sup>(4)</sup> | | 443 | mW | | T <sub>A</sub> | Ambient temperature for 6 suffix version | Maximum power dissipation | -40 | 85 | °C | | T <sub>J</sub> | Junction temperature range | | -40 | 105 | | 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 specifications 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 the design of the internal regulator. <sup>3.</sup> To calculate $P_{Dmax}(T_A)$ , use the formula $P_{Dmax} = (T_{Jmax} - T_A)/\Theta_{JA}$ (see Section 10.2: Thermal characteristics on page 84) with the value for $T_{Jmax}$ given in Table 16 above and the value for $\Theta_{JA}$ given in Table 50: Thermal characteristics. <sup>4.</sup> Refer to Section 10.2: Thermal characteristics on page 84 for the calculation method. Figure 8. f<sub>CPUmax</sub> versus V<sub>DD</sub> Table 17. Operating conditions at power-up/power-down | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |-----------------------|--------------------------------|------------------------|------------------|------|--------------------|-------| | + | V <sub>DD</sub> rise time rate | | 2 <sup>(1)</sup> | | ∞ | μs/V | | t <sub>VDD</sub> | V <sub>DD</sub> fall time rate | | 2 <sup>(1)</sup> | | 8 | μ5/ ν | | t <sub>TEMP</sub> | Reset release delay | V <sub>DD</sub> rising | | | 1.7 <sup>(1)</sup> | ms | | V <sub>IT+</sub> | Power-on reset threshold | | 2.65 | 2.8 | 2.95 | V | | V <sub>IT-</sub> | Brown-out reset threshold | | 2.58 | 2.73 | 2.88 | V | | V <sub>HYS(BOR)</sub> | Brown-out reset hysteresis | | | 70 | | mV | <sup>1.</sup> Guaranteed by design, not tested in production. # 9.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 16*. Care should be taken to limit the series inductance to less than 15 nH. Figure 9. External capacitor C<sub>EXT</sub> <sup>1.</sup> Legend: ESR is the equivalent series resistance and ESL is the equivalent inductance. Doc ID 022171 Rev 2 47/90 # 9.3.2 Supply current characteristics The current consumption is measured as described in Figure 5 on page 42. ### Total current consumption in run mode The MCU is placed under the following conditions: - $\bullet \quad$ All I/O pins in input mode with a static value at $V_{DD}$ or $V_{SS}$ (no load) - All peripherals are disabled (clock stopped by Peripheral Clock Gating registers) except if explicitly mentioned. - When the MCU is clocked at 24 MHz, $T_A \le 85$ °C and the WAITSTATE option bit is set. Subject to general operating conditions for $V_{DD}$ and $T_A$ . Table 18. Total current consumption with code execution in run mode at $V_{DD} = 5 \text{ V}$ | Symbol | Parameter | Conditions | | | Max | Unit | |-----------------------|-------------------|-------------------------------------------------------------|---------------------------------------|------|---------------------|------| | | | f f 04 MH= | HSE crystal osc. (24 MHz) | 4.4 | | | | | | $f_{CPU} = f_{MASTER} = 24 \text{ MHz}$ | HSE user ext. clock (24 MHz) | 3.7 | 7.3 <sup>(1)</sup> | | | | | | HSE crystal osc. (16 MHz) | 3.3 | | | | | Supply current in | f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | HSE user ext. clock (16 MHz) | 2.7 | 5.8 | | | | run mode, | | HSI RC osc. (16 MHz) | 2.5 | 3.4 | | | | code<br>executed | f | HSE user ext. clock (16 MHz) | 1.2 | 4.1 <sup>(1)</sup> | | | | from RAM | $f_{CPU} = f_{MASTER}/128 = 125 \text{ kHz}$ | HSI RC osc. (16 MHz) | 1.0 | 1.3 <sup>(1)</sup> | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> /128 =<br>15.625 kHz | HSI RC osc. (16 MHz/8) | 0.55 | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> = 128 kHz | LSI RC osc. (128 kHz) | 0.45 | | mA | | I <sub>DD</sub> (RUN) | | f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | HSE crystal osc. (24 MHz) | 11.4 | | | | | | | HSE user ext. clock (24 MHz) | 10.8 | 18 <sup>(1)</sup> | | | | | | HSE crystal osc. (16 MHz) | 9.0 | | | | | Supply current in | f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | HSE user ext. clock (16 MHz) | 8.2 | 15.2 <sup>(1)</sup> | | | | run mode, | | HSI RC osc.(16 MHz) | 8.1 | 13.2 <sup>(1)</sup> | | | | code<br>executed | f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | HSI RC osc. (16 MHz/8) <sup>(2)</sup> | 1.5 | | | | | from Flash | f <sub>CPU</sub> = f <sub>MASTER</sub> /128 = 125 kHz | HSI RC osc. (16 MHz) | 1.1 | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> /128 =<br>15.625 kHz | HSI RC osc. (16 MHz/8) | 0.6 | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> = 128 kHz | LSI RC osc. (128 kHz) | 0.55 | | | <sup>1.</sup> Data based on characterization results, not tested in production. <sup>2.</sup> Default clock configuration measured with all peripherals off. Table 19. Total current consumption with code execution in run mode at $V_{DD} = 3.3 \text{ V}$ | Symbol | Parameter | Condi | Conditions | | | Unit | | |----------------------|-------------------|-------------------------------------------------------------|-------------------------------------------------------------|-----------------------|------|------|--| | | | f f 04 MH- | HSE crystal osc. (24 MHz) | 4.0 | | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | HSE user ext. clock (24 MHz) | 3.7 | 7.3 | | | | | | | HSE crystal osc. (16 MHz) | 2.9 | | | | | | Supply current in | f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | HSE user ext. clock (16 MHz) | 2.7 | 5.8 | | | | | run mode, | | HSI RC osc. (16 MHz) | 2.5 | 3.4 | | | | | code<br>executed | f f _ /108 _ 105 kHz | HSE user ext. clock (16 MHz) | 1.2 | 4.1 | | | | | from RAM | $f_{CPU} = f_{MASTER}/128 = 125 \text{ kHz}$ | HSI RC osc. (16 MHz) | 1.0 | 1.3 | | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> /128 =<br>15.625 kHz | HSI RC osc. (16MHz/8) | 0.55 | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> = 128 kHz | LSI RC osc. (128 kHz) | 0.45 | | mA | | | I <sub>DD(RUN)</sub> | | f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | HSE crystal osc. (24 MHz) | 11.0 | | | | | | | | HSE user ext. clock (24 MHz) | 10.8 | 18.0 | | | | | | | HSE crystal osc. (16 MHz) | 8.4 | | 1 | | | | Supply current in | f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | HSE user ext. clock (16 MHz) | 8.2 | 15.2 | | | | | run mode, | | HSI RC osc. (16 MHz) | 8.1 | 13.2 | | | | | code<br>executed | f <sub>CPU</sub> = f <sub>MASTER</sub> = 2 MHz | HSI RC osc. (16 MHz/8) <sup>(2)</sup> | 1.5 | | | | | | from Flash | $f_{CPU} = f_{MASTER}/128 = 125 \text{ kHz}$ | HSI RC osc. (16 MHz) | 1.1 | | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> /128 =<br>15.625 kHz | HSI RC osc. (16 MHz/8) | 0.6 | | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> = 128 kHz | LSI RC osc. (128 kHz) | 0.55 | | | | <sup>1.</sup> Data based on characterization results, not tested in production. <sup>2.</sup> Default clock configuration. # Total current consumption in wait mode Table 20. Total current consumption in wait mode at $V_{DD} = 5 V$ | Symbol | Parameter | Conditions | | | Max <sup>(1)</sup> | Unit | |----------------------|----------------------|-------------------------------------------------------------|---------------------------------------|------|--------------------|------| | | | f f O4 MHz | HSE crystal osc. (24 MHz) | 2.4 | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | HSE user ext. clock (24 MHz) | 1.8 | 4.7 | | | | | HSE crystal osc. (16 MHz) | 2.0 | | | | | | Supply | $f_{CPU} = f_{MASTER} = 16 \text{ MHz}$ | HSE user ext. clock (16 MHz) | 1.4 | 4.4 | | | I <sub>DD(WFI)</sub> | current in wait mode | | HSI RC osc. (16 MHz) | 1.2 | 1.6 | mA | | | wait mode | f <sub>CPU</sub> = f <sub>MASTER</sub> /128 = 125 kHz | HSI RC osc. (16 MHz) | 1.0 | | | | | 1 | f <sub>CPU</sub> = f <sub>MASTER</sub> /128 =<br>15.625 kHz | HSI RC osc. (16 MHz/8) <sup>(2)</sup> | 0.55 | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> = 128 kHz | LSI RC osc. (128 kHz) | 0.5 | | | <sup>1.</sup> Data based on characterization results, not tested in production. Table 21. Total current consumption in wait mode at $V_{DD} = 3.3 \text{ V}$ | Symbol | Parameter | Condit | ions | Тур | Max <sup>(1)</sup> | Unit | |----------------------|------------|-------------------------------------------------------------|---------------------------------------|------|--------------------|------| | | | f <sub>CPU</sub> = f <sub>MASTER</sub> = 24 MHz | HSE crystal osc. (24 MHz) | 2.0 | | | | | | HSE user ext. clock (24 I | HSE user ext. clock (24 MHz) | 1.8 | 4.7 | | | | | HSE crystal osc. (16 MHz) | 1.6 | | | | | | Supply | f <sub>CPU</sub> = f <sub>MASTER</sub> = 16 MHz | HSE user ext. clock (16 MHz) | 1.4 | 4.4 | | | I <sub>DD(WFI)</sub> | current in | | HSI RC osc. (16 MHz) | 1.2 | 1.6 | mA | | | wait mode | $f_{CPU} = f_{MASTER}/128 = 125 \text{ kHz}$ | HSI RC osc. (16 MHz) | 1.0 | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> /128 =<br>15.625 kHz | HSI RC osc. (16 MHz/8) <sup>(2)</sup> | 0.55 | | | | | | f <sub>CPU</sub> = f <sub>MASTER</sub> /128 =<br>15.625 kHz | LSI RC osc. (128 kHz) | 0.5 | | | <sup>1.</sup> Data based on characterization results, not tested in production. <sup>2.</sup> Default clock configuration measured with all peripherals off. <sup>2.</sup> Default clock configuration measured with all peripherals off. # Total current consumption in active halt mode Table 22. Total current consumption in active halt mode at $V_{DD}$ = 5 V, $T_A$ -40 to 85° C | | | | Condition | s | | | | |---------------------|------------------------------------|---------------------------------------------------|---------------------------------|---------------------------------|-----|--------------------|------| | Symbol | Parameter | Main voltage<br>regulator<br>(MVR) <sup>(2)</sup> | Flash mode <sup>(3)</sup> | Clock source | Тур | Max <sup>(1)</sup> | Unit | | | | | HSE crystal oscillator (16 MHz) | 1000 | | | | | | | On | Operating mode | LSI RC oscillator<br>(128 kHz) | 200 | 260 | | | I <sub>DD(AH)</sub> | Supply current in active halt mode | On | Powerdown mode | HSE crystal oscillator (16 MHz) | 940 | | μΑ | | | | Powerdown mode | LSI RC oscillator<br>(128 kHz) | 140 | | | | | | | Off | Operating mode | LSI RC oscillator | 68 | | | | | | | Off Powerdown mode | 128 kHz) | 11 | 45 | | - 1. Data based on characterization results, not tested in production. - 2. Configured by the REGAH bit in the CLK\_ICKR register. - 3. Configured by the AHALT bit in the FLASH\_CR1 register. Table 23. Total current consumption in active halt mode at $V_{DD}$ = 3.3 V | | | | Condition | ons | | | |------------------|-------------------|---------------------------------------------------|---------------------------|---------------------------|--------------------|------| | Symbol Parameter | | Main voltage<br>regulator<br>(MVR) <sup>(2)</sup> | Flash mode <sup>(3)</sup> | Clock source | Typ <sup>(1)</sup> | Unit | | | | | Operating mode | HSE crystal osc. (16 MHz) | 600 | | | | | On | Operating mode | LSI RC osc. (128 kHz) | 200 | | | ļ. | Supply current in | On | Powerdown mode | HSE crystal osc. (16 MHz) | 540 | | | IDD(AH) | active halt mode | | Fowerdown mode | LSI RC osc. (128 kHz) | 140 | μA | | | Off | Operating mode | | 66 | | | | | | | Powerdown mode | LSI RC osc. (128 kHz) | 9 | | - 1. Data based on characterization results, not tested in production. - 2. Configured by the REGAH bit in the CLK\_ICKR register. - 3. Configured by the AHALT bit in the FLASH\_CR1 register. # Total current consumption in halt mode Table 24. Total current consumption in halt mode at $V_{DD}$ = 5 V, $T_A$ -40 to 85° C | Symbol | Parameter | Conditions | Тур | Max | Unit | |-----------------------------|-------------------------------------------------|-------------------------------------------------|-----|-----|------| | Cumply gurrent in halt made | Flash in operating mode, HSI clock after wakeup | 63.5 | | μА | | | IDD(H) | Supply current in mait mode | Flash in powerdown mode, HSI clock after wakeup | 6.5 | 35 | μΑ | Table 25. Total current consumption in halt mode at $V_{DD} = 3.3 \text{ V}$ | Symbol | Parameter | Conditions | Тур | Unit | |------------------------|-----------------------------|-------------------------------------------------|------|------| | Consider consisting to | Supply current in halt mode | Flash in operating mode, HSI clock after wakeup | 61.5 | • | | IDD(H) | Supply current in hait mode | Flash in powerdown mode, HSI clock after wakeup | 4.5 | μΑ | ### Low power mode wakeup times Table 26. Wakeup times | Symbol | Parameter | | Conditions | | | Max <sup>(1)</sup> | Unit | |----------------------|-------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------------------|------------|-------------------|----------------------------|------| | t <sub>WU(WFI)</sub> | Wakeup time from wait mode to run mode <sup>(3)</sup> | | | | | See<br>note <sup>(2)</sup> | | | - ( ) | mode to full mode. | f <sub>CPU</sub> = f <sub>MASTER</sub> = | <sub>PU</sub> = f <sub>MASTER</sub> = 16 MHz. | | | | | | | | MVR voltage | Flash in operating mode <sup>(5)</sup> | | 1 <sup>(6)</sup> | 2 <sup>(6)</sup> | | | | Wakeup time active halt | regulator on <sup>(4)</sup> | Flash in powerdown mode <sup>(5)</sup> | HSI (after | 3(6) | μs | | | t <sub>WU(AH)</sub> | mode to run mode. (3) | MVR voltage | Flash in operating mode <sup>(5)</sup> | wakeup) | 48 <sup>(6)</sup> | | | | | | regulator off <sup>(4)</sup> Flash in powerdow mode <sup>(5)</sup> | | | 50 <sup>(6)</sup> | | | | + | Wakeup time from halt | Flash in operating | ng mode <sup>(5)</sup> | | 52 | | | | t <sub>WU(H)</sub> | mode to run mode <sup>(3)</sup> | Flash in powerdov | wn mode <sup>(5)</sup> | | 54 | | | - 1. Data guaranteed by design, not tested in production. - 2. $t_{WU(WFI)} = 2 \times 1/f_{master} + 7 \times 1/f_{CPU}$ - 3. Measured from interrupt event to interrupt vector fetch. - 4. Configured by the REGAH bit in the CLK\_ICKR register. - 5. Configured by the AHALT bit in the FLASH\_CR1 register. - 6. Plus 1 LSI clock depending on synchronization. ### Total current consumption and timing in forced reset state Table 27. Total current consumption and timing in forced reset state | Symbol | Parameter | Conditions | Тур | Max <sup>(1)</sup> | Unit | |----------------------|------------------------------------------|-------------------------|-----|--------------------|------| | Supply ourror | Supply ourrent in react state | V <sub>DD</sub> = 5 V | 1.6 | | mΛ | | IDD(R) | Supply current in reset state | V <sub>DD</sub> = 3.3 V | 0.8 | | mA | | t <sub>RESETBL</sub> | Reset release to bootloader vector fetch | | | 150 | μs | <sup>1.</sup> Data guaranteed by design, not tested in production. ### **Current consumption of on-chip peripherals** Subject to general operating conditions for V<sub>DD</sub> and T<sub>A</sub>. HSI internal RC/ $f_{CPU} = f_{MASTER} = 16$ MHz. Table 28. Peripheral current consumption | Symbol | Parameter | Тур. | Unit | |-----------------------------------|----------------------------------------------------------------|------|------| | I <sub>DD(TIM1)</sub> | TIM1 supply current (1) | 220 | | | I <sub>DD(TIM2)</sub> | TIM2 supply current (1) | 120 | | | I <sub>DD(TIM3)</sub> | TIM3 timer supply current (1) | 100 | | | I <sub>DD(TIM4)</sub> | I <sub>DD(TIM4)</sub> TIM4 timer supply current <sup>(1)</sup> | | | | I <sub>DD(UART1)</sub> | UART1 supply current (2) | 90 | μΑ | | I <sub>DD(UART3)</sub> | UART3 supply current (2) | 110 | | | I <sub>DD(SPI)</sub> | SPI supply current <sup>(2)</sup> | 40 | | | I <sub>DD(I</sub> <sup>2</sup> C) | I <sup>2</sup> C supply current <sup>(2)</sup> | 50 | | | I <sub>DD(ADC2)</sub> | ADC2 supply current when converting (3) | 1000 | | Data based on a differential I<sub>DD</sub> measurement between reset configuration and timer counter running at 16 MHz. No IC/OC programmed (no I/O pads toggling). Not tested in production. Data based on a differential I<sub>DD</sub> measurement between the on-chip peripheral when kept under reset and not clocked and the on-chip peripheral when clocked and not kept under reset. No I/O pads toggling. Not tested in production. Data based on a differential I<sub>DD</sub> measurement between reset configuration and continuous A/D conversions. Not tested in production. # **Current consumption curves** *Figure 10* and *Figure 11* show typical current consumption measured with code executing in RAM. Figure 10. Typ. $I_{DD(RUN)}$ vs $V_{DD}$ , HSI RC osc, $f_{CPU} = 16$ MHz Figure 11. Typ. $I_{DD(WFI)}$ vs $V_{DD}$ , HSI RC osc, $f_{CPU} = 16$ MHz # 9.3.3 External clock sources and timing characteristics #### **HSE** user external clock Subject to general operating conditions for $V_{DD}$ and $T_A$ . Table 29. HSE user external clock characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |----------------------------------|--------------------------------------|-----------------------------------------------------|-----------------------|-----|-------------------------|------| | f <sub>HSE_ext</sub> | User external clock source frequency | | 0 | | 24 | MHz | | V <sub>HSEH</sub> <sup>(1)</sup> | OSCIN input pin high level voltage | | 0.7 x V <sub>DD</sub> | | V <sub>DD</sub> + 0.3 V | V | | V <sub>HSEL</sub> <sup>(1)</sup> | OSCIN input pin low level voltage | | V <sub>SS</sub> | | 0.3 x V <sub>DD</sub> | V | | I <sub>LEAK_HSE</sub> | OSCIN input leakage current | V <sub>SS</sub> < V <sub>IN</sub> < V <sub>DD</sub> | -1 | | 1 | μΑ | <sup>1.</sup> Data based on characterization results, not tested in production. Figure 12. HSE external clock source # HSE crystal/ceramic resonator oscillator The HSE clock can be supplied with a 1 to 24 MHz crystal/ceramic resonator oscillator. All the information given in this paragraph is based on characterization results with specified typical external components. In the application, the resonator and the load capacitors have to be placed as close as possible to the oscillator pins in order to minimize output distortion and start-up stabilization time. Refer to the crystal resonator manufacturer for more details (frequency, package, accuracy...). Table 30. HSE oscillator characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |-------------------------------------|------------------------------------------|-----------------------------------------|-----|-----|------------------------------------------------|------| | f <sub>HSE</sub> | External high speed oscillator frequency | | 1 | | 24 | MHz | | $R_F$ | Feedback resistor | | | 220 | | kΩ | | C <sup>(1)</sup> | Recommended load capacitance (2) | | | | 20 | pF | | | HSE oscillator power consumption | C = 20 pF,<br>f <sub>OSC</sub> = 24 MHz | | | 6 (startup)<br>2 (stabilized) <sup>(3)</sup> | mA | | IDD(HSE) | TIGE oscillator power consumption | C = 10 pF,<br>f <sub>OSC</sub> = 24 MHz | | | 6 (startup)<br>1.5 (stabilized) <sup>(3)</sup> | IIIA | | 9 <sub>m</sub> | Oscillator transconductance | | 5 | | | mA/V | | t <sub>SU(HSE)</sub> <sup>(4)</sup> | Startup time | V <sub>DD</sub> is stabilized | | 1 | | ms | - 1. C is approximately equivalent to 2 x crystal Cload. - The oscillator selection can be optimized in terms of supply current using a high quality resonator with small R<sub>m</sub> value. Refer to crystal manufacturer for more details - 3. Data based on characterization results, not tested in production. - 4. t<sub>SU(HSE)</sub> is the start-up time measured from the moment it is enabled (by software) to a stabilized 24 MHz oscillation is reached. This value is measured for a standard crystal resonator and it can vary significantly with the crystal manufacturer. Figure 13. HSE oscillator circuit diagram # HSE oscillator critical g<sub>m</sub> formula $$g_{mcrit} = (2 \times \Pi \times f_{HSE})^2 \times R_m (2Co + C)^2$$ R<sub>m</sub>: Notional resistance (see crystal specification) L<sub>m</sub>: Notional inductance (see crystal specification) C<sub>m</sub>: Notional capacitance (see crystal specification) Co: Shunt capacitance (see crystal specification) C<sub>L1</sub>=C<sub>L2</sub>=C: Grounded external capacitance g<sub>m</sub> >> g<sub>mcrit</sub> # 9.3.4 Internal clock sources and timing characteristics Subject to general operating conditions for $V_{DD}$ and $T_{A}.\ f_{\mbox{\scriptsize HSE}}$ # High speed internal RC oscillator (HSI) Table 31. HSI oscillator characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |----------------------|--------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------|-----|--------------------|------| | f <sub>HSI</sub> | Frequency | | | 16 | | MHz | | ACC <sub>HSI</sub> | Accuracy of HSI oscillator | Trimmed by the CLK_HSITRIMR register for given V <sub>DD</sub> and T <sub>A</sub> conditions | -1.0 <sup>(1)</sup> | | 1.0 | % | | 7.0 OHSI | Accuracy of HSI oscillator (factory calibrated) | V <sub>DD</sub> = 5 V, T <sub>A</sub> = 25 °C | -5 | | 5 | , • | | | | $V_{DD} = 5 \text{ V},$<br>25 °C ≤ $T_A \le 85 \text{ °C}$ | -5 | | 5 | | | t <sub>su(HSI)</sub> | HSI oscillator wakeup time including calibration | | | | 1.0 <sup>(1)</sup> | μs | | I <sub>DD(HSI)</sub> | HSI oscillator power consumption | | | 170 | 250 <sup>(2)</sup> | μΑ | <sup>1.</sup> Guaranteeed by design, not tested in production. <sup>2.</sup> Data based on characterization results, not tested in production # Low speed internal RC oscillator (LSI) Subject to general operating conditions for $V_{DD}$ and $T_{A}$ . Table 32. LSI oscillator characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |----------------------|----------------------------------|------------|-----|-----|------------------|------| | f <sub>LSI</sub> | Frequency | | | 128 | | kHz | | t <sub>su(LSI)</sub> | LSI oscillator wakeup time | | | | 7 <sup>(1)</sup> | μs | | I <sub>DD(LSI)</sub> | LSI oscillator power consumption | | | 5 | | μΑ | <sup>1.</sup> Guaranteeed by design, not tested in production. # 9.3.5 Memory characteristics # RAM and hardware registers Table 33. RAM and hardware registers | | Symbol | Parameter | Conditions | Min | Unit | |---|----------|------------------------------------|----------------------|------------------------------------|------| | Ī | $V_{RM}$ | Data retention mode <sup>(1)</sup> | Halt mode (or reset) | V <sub>IT-max</sub> <sup>(2)</sup> | V | Minimum supply voltage without losing data stored in RAM (in halt mode or under reset) or in hardware registers (only in halt mode). Guaranteed by design, not tested in production. ### Flash program memory/data EEPROM memory General conditions: $T_A = -40$ to 85 °C. Table 34. Flash program memory/data EEPROM memory | Symbol | Parameter | Conditions | Min <sup>(1)</sup> | Тур | Max | Unit | |--------------------|--------------------------------------------------------------------------------------------------|---------------------------|--------------------|-----|-----|----------| | $V_{DD}$ | Operating voltage (all modes, execution/write/erase) | f <sub>CPU</sub> ≤ 16 MHz | 2.95 | | 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.0 | 6.6 | ms | | | Fast programming time for 1 block (128 bytes) | | | 3.0 | 3.3 | ms | | t <sub>erase</sub> | Erase time for 1 block (128 bytes) | | | 3.0 | 3.3 | ms | | N | Erase/write cycles <sup>(2)</sup><br>(program memory) | T 05 °C | 100 | | | - cycles | | N <sub>RW</sub> | Erase/write cycles <sup>(2)</sup> (data memory) | T <sub>A</sub> = 85 °C | 100 k | | | | | | Data retention (program memory)<br>after 100 erase/write cycles at<br>T <sub>A</sub> = 85 °C | T <sub>RET</sub> = 55° C | 20 | | | | | t <sub>RET</sub> | Data retention (data memory) after 10 k erase/write cycles at T <sub>A</sub> = 85 °C | | 20 | | | years | | | Data retention (data memory) after 100 k erase/write cycles at T <sub>A</sub> = 85 °C | T <sub>RET</sub> = 85° C | 1 | | | | | I <sub>DD</sub> | Supply current (Flash programming or erasing for 1 to 128 bytes) | | | 2.0 | | mA | <sup>1.</sup> Data based on characterization results, not tested in production. <sup>2.</sup> Refer to *Table 17 on page 47* for the value of $V_{\text{IT-max}}$ . <sup>2.</sup> The physical granularity of the memory is 4 bytes, so cycling is performed on 4 bytes even when a write/erase operation addresses a single byte. # 9.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 35. I/O static characteristics | Symbol | Parameter | Conditions | Min | Тур | Max | Unit | |---------------------------------|-------------------------------------------|---------------------------------------------|-----------------------|-----|-------------------------|------| | V <sub>IL</sub> | Input low level voltage | | -0.3 | | 0.3 x V <sub>DD</sub> | V | | V <sub>IH</sub> | Input high level voltage | V <sub>DD</sub> = 5 V | 0.7 x V <sub>DD</sub> | | V <sub>DD</sub> + 0.3 V | V | | V <sub>hys</sub> | Hysteresis <sup>(1)</sup> | | | 700 | | mV | | R <sub>pu</sub> | Pull-up resistor | $V_{DD} = 5 \text{ V}, V_{IN} = V_{SS}$ | 30 | 55 | 80 | kΩ | | t <sub>R</sub> , t <sub>F</sub> | Rise and fall time (10% - 90%) | Fast I/Os<br>Load = 50 pF | | | 20 <sup>(2)</sup> | ns | | | | Standard and high sink I/Os<br>Load = 50 pF | | | 125 <sup>(2)</sup> | ns | | I <sub>lkg</sub> | Input leakage current, analog and digital | $V_{SS} \le V_{IN} \le V_{DD}$ | | | ±1 | μΑ | | I <sub>lkg ana</sub> | Analog input leakage current | $V_{SS} \le V_{IN} \le V_{DD}$ | | | ±250 <sup>(3)</sup> | nA | | I <sub>Ikg(inj)</sub> | Leakage current in adjacent I/O | Injection current ±4 mA | | | ±1 <sup>(3)</sup> | μΑ | <sup>1.</sup> Hysteresis voltage between Schmitt trigger switching levels. Based on characterization results, not tested in production. <sup>2.</sup> Guaranteed by design. <sup>3.</sup> Data based on characterization results, not tested in production. Figure 17. Typical pull-up resistance vs $V_{DD}$ @ 3 temperatures 577 Figure 18. Typical pull-up current vs V<sub>DD</sub> @ 3 temperatures 1. The pull-up is a pure resistor (slope goes through 0). Table 36. Output driving current (standard ports) | Symbol | Parameter | Conditions | Min | Max | Unit | |-----------------|---------------------------------------|-------------------------------------------------|--------------------|------------------|------| | V <sub>OL</sub> | Output low level with 8 pins sunk | I <sub>IO</sub> = 10 mA, V <sub>DD</sub> = 5 V | | 2 | V | | | Output low level with 4 pins sunk | $I_{IO} = 4 \text{ mA}, V_{DD} = 3.3 \text{ V}$ | | 1 <sup>(1)</sup> | V | | V <sub>OH</sub> | Output high level with 8 pins sourced | I <sub>IO</sub> = 10 mA, V <sub>DD</sub> = 5 V | 2.8 | | V | | | Output high level with 4 pins sourced | $I_{IO} = 4 \text{ mA}, V_{DD} = 3.3 \text{ V}$ | 2.1 <sup>(1)</sup> | | V | <sup>1.</sup> Data based on characterization results, not tested in production Table 37. Output driving current (true open drain ports) | Symbol | Parameter | Conditions | Max | Unit | |-----------------|-----------------------------------|--------------------------------------------------|--------------------|------| | V <sub>OL</sub> | Output low level with 2 pins sunk | $I_{IO} = 10 \text{ mA}, V_{DD} = 5 \text{ V}$ | 1 | | | | | I <sub>IO</sub> = 10 mA, V <sub>DD</sub> = 3.3 V | 1.5 <sup>(1)</sup> | V | | | | I <sub>IO</sub> = 20 mA, V <sub>DD</sub> = 5 V | 2 <sup>(1)</sup> | | <sup>1.</sup> Data based on characterization results, not tested in production Symbol **Parameter Conditions** Min Max Unit Output low level with 8 pins sunk $I_{IO} = 10 \text{ mA}, V_{DD} = 5 \text{ V}$ 8.0 1<sup>(1)</sup> $V_{OL}$ Output low level with 4 pins sunk $I_{IO} = 10 \text{ mA}, V_{DD} = 3.3 \text{ V}$ 1.5<sup>(1)</sup> Output low level with 4 pins sunk $I_{IO} = 20 \text{ mA}, V_{DD} = 5 \text{ V}$ ٧ $I_{IO} = 10 \text{ mA}, V_{DD} = 5 \text{ V}$ Output high level with 8 pins sourced 4.0 2.1<sup>(1)</sup> $I_{IO} = 10 \text{ mA}, V_{DD} = 3.3 \text{ V}$ $V_{\mathsf{OH}}$ Output high level with 4 pins sourced 3.3<sup>(1)</sup> Output high level with 4 pins sourced $I_{IO} = 20 \text{ mA}, V_{DD} = 5 \text{ V}$ Table 38. Output driving current (high sink ports) ### Typical output level curves *Figure 20* to *Figure 27* show typical output level curves measured with output on a single pin. <sup>1.</sup> Data based on characterization results, not tested in production Figure 21. Typ. $V_{OL} @ V_{DD} = 5 V$ (true open drain ports) 47/ Figure 25. Typ. $V_{DD} - V_{OH} @ V_{DD} = 5 V$ (standard ports) Figure 27. Typ. V<sub>DD</sub> - V<sub>OH</sub> @ V<sub>DD</sub> = 5 V (high sink ports) 2 1.75 1.25 2.5°C 1.5 2.5°C 1.5 0.5 0.5 0.5 0.5 0.25 I<sub>OH</sub> [mA] 20 25 MS19408V1 0 Figure 28. Typ. $V_{DD}$ - $V_{OH}$ @ $V_{DD}$ = 3.3 V (high sink ports) #### 9.3.7 Reset pin characteristics Subject to general operating conditions for $V_{\mbox{\scriptsize DD}}$ and $T_{\mbox{\scriptsize A}}$ unless otherwise specified. Table 39. **NRST** pin characteristics | Symbol | Parameter | Conditions | Min | Typ 1) | Max | Unit | |-------------------------|-----------------------------------|------------------------|-----------------------|--------|-----------------------|------| | V <sub>IL(NRST)</sub> | NRST Input low level voltage (1) | | -0.3 V | | 0.3 x V <sub>DD</sub> | | | V <sub>IH(NRST)</sub> | NRST Input high level voltage (1) | | 0.7 x V <sub>DD</sub> | | V <sub>DD</sub> + 0.3 | V | | V <sub>OL(NRST)</sub> | NRST Output low level voltage (1) | I <sub>OL</sub> = 2 mA | | | 0.5 | | | R <sub>PU(NRST)</sub> | NRST Pull-up resistor (2) | | 30 | 55 | 80 | kΩ | | t <sub>IFP(NRST)</sub> | NRST Input filtered pulse (3) | | | | 75 | ns | | t <sub>INFP(NRST)</sub> | NRST Input not filtered pulse (3) | | 500 | | | ns | | t <sub>OP(NRST)</sub> | NRST output pulse (1) | | 15 | | | μs | <sup>1.</sup> Data based on characterization results, not tested in production. <sup>2.</sup> The $R_{PU}$ pull-up equivalent resistor is based on a resistive transistor <sup>3.</sup> Data guaranteed by design, not tested in production. MS19410V1 Figure 31. Typical NRST pull-up current vs V<sub>DD</sub> @ 3 temperatures The reset network shown in *Figure 32* protects the device against parasitic resets. The user must ensure that the level on the NRST pin can go below the $V_{IL}$ max. level specified in *Table 35*. Otherwise the reset is not taken into account internally. For power consumption sensitive applications, the capacity of the external reset capacitor can be reduced to limit charge/discharge current. If the NRST signal is used to reset the external circuitry, care must be taken of the charge/discharge time of the external capacitor to fulfill the external device's reset timing conditions. The minimum recommended capacity is 10 nF. Figure 32. Recommended reset pin protection # 9.3.8 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 | Conditions | Min | Max | Unit | | |--------------------------------------------------|------------------------------|---------------------------------|--------------------------|--------------------------|---------|--| | f <sub>SCK</sub> | SPI clock frequency | Master mode | 0 | 10 | MHz | | | 1/t <sub>c(SCK)</sub> | SFI clock frequency | Slave mode | 0 | 6 | IVIITIZ | | | t <sub>r(SCK)</sub> | SPI clock rise and fall time | Capacitive load: C = 30 pF | | 25 | | | | t <sub>su(NSS)</sub> <sup>(1)</sup> | NSS setup time | Slave mode | 4 x t <sub>MASTER</sub> | | | | | t <sub>h(NSS)</sub> <sup>(1)</sup> | NSS hold time | Slave mode | 70 | | | | | $t_{w(SCKH)}^{(1)}$ | SCK high and low time | Master mode | t <sub>SCK</sub> /2 - 15 | t <sub>SCK</sub> /2 + 15 | | | | $t_{su(MI)}^{(1)} t_{su(SI)}^{(1)}$ | Data input setup time | Master mode | 5 | | | | | t <sub>su(SI)</sub> (1) | | Slave mode | 5 | | | | | t <sub>h(MI)</sub> (1)<br>t <sub>h(SI)</sub> (1) | Data input hold time | Master mode | 7 | | ns | | | t <sub>h(SI)</sub> (1) | Data input floid time | Slave mode | 10 | | | | | t <sub>a(SO)</sub> (1)(2) | Data output access time | Slave mode | | 3 x t <sub>MASTER</sub> | | | | t <sub>dis(SO)</sub> (1)(3) | Data output disable time | Slave mode | 25 | | | | | t <sub>v(SO)</sub> (1) | Data output valid time | Slave mode (after enable edge) | | 75 | | | | t <sub>v(MO)</sub> <sup>(1)</sup> | Data output valid time | Master mode (after enable edge) | | 30 | | | | t <sub>h(SO)</sub> <sup>(1)</sup> | Data output hold time | Slave mode (after enable edge) | 31 | | | | | t <sub>h(MO)</sub> <sup>(1)</sup> | Data output hold time | Master mode (after enable edge) | 12 | | | | <sup>1.</sup> Values based on design simulation and/or characterization results, and not tested in production. <sup>2.</sup> Min time is for the minimum time to drive the output and the max time is for the maximum time to validate the data. <sup>3.</sup> Min time is for the minimum time to invalidate the output and the max time is for the maximum time to put the data in Hi-Z. Figure 33. SPI timing diagram - slave mode and CPHA = 0 Figure 34. SPI timing diagram - slave mode and CPHA = $1^{(1)}$ 1. Measurement points are done at CMOS levels: 0.3 $V_{DD}$ and 0.7 $V_{DD.}$ Figure 35. SPI timing diagram - master mode<sup>(1)</sup> 1. Measurement points are done at CMOS levels: 0.3 $\rm V_{DD}$ and 0.7 $\rm V_{DD.}$ 577 Electrical characteristics STM8S007C8 # 9.3.9 I<sup>2</sup>C interface characteristics Table 41. I<sup>2</sup>C characteristics | Oh al | Davasatav | Standard | mode I <sup>2</sup> C | Fast mod | Fast mode I <sup>2</sup> C <sup>(1)</sup> | 11 !4 | |--------------------------------------------|-----------------------------------------|--------------------|-----------------------|--------------------|-------------------------------------------|-------| | Symbol | Parameter | Min <sup>(2)</sup> | Max <sup>(2)</sup> | Min <sup>(2)</sup> | Max <sup>(2)</sup> | Unit | | t <sub>w(SCLL)</sub> | SCL clock low time | 4.7 | | 1.3 | | | | t <sub>w(SCLH)</sub> | SCL clock high time | 4.0 | | 0.6 | | μs | | t <sub>su(SDA)</sub> | SDA setup time | 250 | | 100 | | | | t <sub>h(SDA)</sub> | SDA data hold time | 0(3) | | 0 <sup>(4)</sup> | 900 <sup>(3)</sup> | | | t <sub>r(SDA)</sub><br>t <sub>r(SCL)</sub> | SDA and SCL rise time | | 1000 | | 300 | ns | | t <sub>f(SDA)</sub><br>t <sub>f(SCL)</sub> | SDA and SCL fall time | | 300 | | 300 | | | t <sub>h(STA)</sub> | START condition hold time | 4.0 | | 0.6 | | | | t <sub>su(STA)</sub> | Repeated START condition setup time | 4.7 | | 0.6 | | μs | | t <sub>su(STO)</sub> | STOP condition setup time | 4.0 | | 0.6 | | μs | | t <sub>w(STO:STA)</sub> | STOP to START condition time (bus free) | 4.7 | | 1.3 | | μs | | C <sub>b</sub> | Capacitive load for each bus line | | 400 | | 400 | pF | <sup>1.</sup> $f_{MASTER}$ , must be at least 8 MHz to achieve max fast $I^2C$ speed (400kHz) <sup>2.</sup> Data based on standard I<sup>2</sup>C protocol requirement, not tested in production <sup>3.</sup> 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 Figure 36. Typical application with I<sup>2</sup>C bus and timing diagram 1. Measurement points are made at CMOS levels: 0.3 x $\rm V_{DD}$ and 0.7 x $\rm V_{DD}$ 57 Electrical characteristics STM8S007C8 # 9.3.10 10-bit ADC characteristics Subject to general operating conditions for $V_{\text{DDA}}$ , $f_{\text{MASTER}}$ , and $T_{\text{A}}$ unless otherwise specified. Table 42. ADC characteristics | Symbol | Parameter | Conditions | Min | Min Typ Max | | Unit | |-------------------------------|--------------------------------------------------------------------|---------------------------------|---------------------|-------------|--------------------|--------------------| | 4 | ADC clock frequency | V <sub>DDA</sub> = 3 to 5.5 V | 1 | | 4 | MHz | | f <sub>ADC</sub> | | V <sub>DDA</sub> = 4.5 to 5.5 V | 1 | | 6 | IVITIZ | | V <sub>DDA</sub> | Analog supply | | 3 | | 5.5 | V | | V <sub>REF+</sub> | Positive reference voltage | | 2.75 <sup>(1)</sup> | | $V_{DDA}$ | V | | V <sub>REF-</sub> | Negative reference voltage | | V <sub>SSA</sub> | | 0.5 <sup>(1)</sup> | V | | V <sub>AIN</sub> | Conversion voltage range <sup>(2)</sup> | | $V_{SSA}$ | | $V_{DDA}$ | V | | C <sub>ADC</sub> | Internal sample and hold capacitor | | | 3 | | pF | | t <sub>S</sub> <sup>(2)</sup> | Sampling time | f <sub>ADC</sub> = 4 MHz | | 0.75 | | 116 | | is. | Sampling time | f <sub>ADC</sub> = 6 MHz | | 0.5 | | μs | | t <sub>STAB</sub> | Wakeup time from standby | | | 7 | | μs | | | | f <sub>ADC</sub> = 4 MHz | 3.5 | | μs | | | t <sub>CONV</sub> | Total conversion time (including sampling time, 10-bit resolution) | f <sub>ADC</sub> = 6 MHz | | 2.33 | | μs | | | , , , | | | 14 | | 1/f <sub>ADC</sub> | <sup>1.</sup> Data guaranteed by design, not tested in production.. 76/90 Doc ID 022171 Rev 2 <sup>2.</sup> During the sample time the input capacitance $C_{AIN}$ (3 pF max) can be charged/discharged by the external source. The internal resistance of the analog source must allow the capacitance to reach its final voltage level within $t_S$ . After the end of the sample time $t_S$ , changes of the analog input voltage have no effect on the conversion result. Values for the sample clock $t_S$ depend on programming. Table 43. ADC accuracy with R<sub>AIN</sub> < 10 k $\Omega$ , V<sub>DDA</sub> = 5 V | Symbol | Parameter | Conditions | Тур | Max | Unit | |-------------------|----------------------------------|---------------------------|-----|-----|------| | | | f <sub>ADC</sub> = 2 MHz | 1 | 2.5 | | | IE <sub>T</sub> I | Total unadjusted error (1) | f <sub>ADC</sub> = 4 MHz | 1.4 | 3 | | | | | f <sub>ADC</sub> = 6 MHz | 1.6 | 3.5 | | | | | f <sub>ADC</sub> = 2 MHz | 0.6 | 2 | | | ΙΕ <sub>Ο</sub> Ι | Offset error (1) | f <sub>ADC</sub> = 4 MHz | 1.1 | 2.5 | | | | | f <sub>ADC</sub> = 6 MHz | 1.2 | 2.5 | | | | | f <sub>ADC</sub> = 2 MHz | 0.2 | 2 | | | IE <sub>G</sub> I | Gain error <sup>(1)</sup> | $f_{ADC} = 4 MHz$ | 0.6 | 2.5 | LSB | | | | $f_{ADC} = 6 \text{ MHz}$ | 0.8 | 2.5 | | | | | f <sub>ADC</sub> = 2 MHz | 0.7 | 1.5 | | | IE <sub>D</sub> I | Differential linearity error (1) | f <sub>ADC</sub> = 4 MHz | 0.7 | 1.5 | | | | | f <sub>ADC</sub> = 6 MHz | 0.8 | 1.5 | | | | | f <sub>ADC</sub> = 2 MHz | 0.6 | 1.5 | | | IE <sub>L</sub> I | Integral linearity error (1) | f <sub>ADC</sub> = 4 MHz | 0.6 | 1.5 | | | | | f <sub>ADC</sub> = 6 MHz | 0.6 | 1.5 | | ADC accuracy vs. negative injection current: Injecting negative current on any of the analog input pins should be avoided as this significantly reduces the accuracy of the conversion being performed on another analog input. It is recommended to add a Schottky diode (pin to ground) to standard analog pins which may potentially inject negative current. Any positive injection current within the limits specified for I<sub>INJ(PIN)</sub> and ΣI<sub>INJ(PIN)</sub> in Section 9.3.6 does not affect the ADC accuracy. Table 44. ADC accuracy with $R_{AIN}$ < 10 k $\Omega$ $R_{AIN}$ , $V_{DDA}$ = 3.3 V | Symbol | Parameter | Conditions | Тур | Max | Unit | |-------------------|---------------------------------------------|--------------------------|-----|-----|------| | IE <sub>T</sub> I | Total unadjusted error <sup>(1)</sup> | f <sub>ADC</sub> = 2 MHz | 1.1 | 2 | | | I IETI | Total unaujusted error | f <sub>ADC</sub> = 4 MHz | 1.6 | 2.5 | | | IE.I | Offset error <sup>(1)</sup> | f <sub>ADC</sub> = 2 MHz | 0.7 | 1.5 | | | IE <sub>O</sub> I | Oliset ellor | f <sub>ADC</sub> = 4 MHz | 1.3 | 2 | | | IE.I | E <sub>G</sub> l Gain error <sup>(1)</sup> | f <sub>ADC</sub> = 2 MHz | 0.2 | 1.5 | LSB | | ı⊏gı | | f <sub>ADC</sub> = 4 MHz | 0.5 | 2 | LOD | | IE <sub>D</sub> I | Differential linearity error <sup>(1)</sup> | f <sub>ADC</sub> = 2 MHz | 0.7 | 1 | | | ı⊏Dı | Differential lifearity error | $f_{ADC} = 4 MHz$ | 0.7 | 1 | | | IE I | Integral linearity error <sup>(1)</sup> | f <sub>ADC</sub> = 2 MHz | 0.6 | 1.5 | | | IE <sub>L</sub> I | integral linearity error | f <sub>ADC</sub> = 4 MHz | 0.6 | 1.5 | | **Electrical characteristics** STM8S007C8 Figure 37. ADC accuracy characteristics - 1. Example of an actual transfer curve. - The ideal transfer curve End point correlation line $E_T$ = Total unadjusted error: maximum deviation between the actual and the ideal transfer curves. $E_O$ = Offset error: deviation between the first actual transition and the first ideal one. $E_G$ = Gain error: deviation between the last ideal transition and the last actual one. $E_D$ = Differential linearity error: maximum deviation between actual steps and the ideal one. $E_L$ = Integral linearity error: maximum deviation between any actual transition and the end point correlation line. Figure 38. Typical application with ADC #### 9.3.11 EMC characteristics Susceptibility tests are performed on a sample basis during product characterization. # Functional EMS (electromagnetic susceptibility) While executing a simple application (toggling 2 LEDs through I/O ports), the product is stressed by two electromagnetic events until a failure occurs (indicated by the LEDs). - **ESD**: Electrostatic discharge (positive and negative) is applied on all pins of the device until a functional disturbance occurs. This test conforms with the IEC 61000-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 61000-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 45. 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} = 5$ V, $T_A = 25$ °C, $f_{MASTER} = 16$ MHz, conforming to IEC 61000-4-2 | 2B | | V <sub>EFTB</sub> | Fast transient voltage burst limits to be applied through 100pF on V <sub>DD</sub> and V <sub>SS</sub> pins to induce a functional disturbance | V <sub>DD</sub> = 5 V, T <sub>A</sub> = 25 °C,<br>f <sub>MASTER</sub> = 16 MHz,<br>conforming to IEC 61000-4-4 | 4A | Electrical characteristics STM8S007C8 ### **Electromagnetic interference (EMI)** Emission tests conform to the SAE IEC 61967-2 standard for test software, board layout and pin loading. Table 46. EMI data | | | | Conditions | | | | | |------------------|--------------------------------------|---------------------------------|-------------------|-------------------------------------------------------|-------------------|-----------------------------------------------|------| | Symbol | Parameter | | Monitored | Max f <sub>HSE</sub> /f <sub>CPU</sub> <sup>(1)</sup> | | 24 MHz/<br>24 MHz<br>24<br>17 dB <sub>1</sub> | Unit | | | | General conditions | frequency band | 16 MHz/<br>8 MHz | 16 MHz/<br>16 MHz | - | | | | | V 5V | 0.1MHz to 30 MHz | 14 | 13 | 24 | | | | Peak level | $V_{DD} = 5 V$<br>$T_A = 25 °C$ | 30 MHz to 130 MHz | 19 | 23 | 17 | dΒμV | | S <sub>EMI</sub> | LQFP48 package conforming to SAE IEC | 130 MHz to 1 GHz | -4 | -4 | 7 | | | | SAE EMI<br>level | | 61967-2 | SAE EMI level | 1.5 | 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 in order 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 47. ESD absolute maximum ratings | Symbol | Ratings | Ratings Conditions | | 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 JESD22-A114 | Α | 2000 | ٧ | | V <sub>ESD(CDM)</sub> | Electrostatic discharge voltage (Charge device model) | T <sub>A</sub> = 25°C, conforming to JESD22-C101 | IV | 1000 | ٧ | <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) - A current injection (applied to each input, output and configurable I/O pin) is 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 48. Electrical sensitivities | Symbol | Parameter | Conditions | Class <sup>(1)</sup> | |---------------------------|--------------------------|------------------------|----------------------| | III Static latch-up class | T <sub>A</sub> = 25 °C | Α | | | | LU Static latch-up class | T <sub>A</sub> = 85 °C | Α | Class description: A Class is an STMicroelectronics internal specification. All its limits are higher than the JEDEC specifications, that means when a device belongs to class A it exceeds the JEDEC standard. B class strictly covers all the JEDEC criteria (international standard). # 10 Package characteristics To meet environmental requirements, ST offers these devices in different grades of ECOPACK® packages, depending on their level of environmental compliance. ECOPACK® specifications, grade definitions and product status are available at <a href="https://www.st.com">www.st.com</a>. ECOPACK® is an ST trademark. Doc ID 022171 Rev 2 # 10.1 Package mechanical data Figure 39. 48-pin low profile quad flat package (7 x 7) Table 49. 48-pin low profile quad flat package mechanical data | Symbol | | mm | | | inches <sup>(1)</sup> | | |--------|-------|-------|-------|--------|-----------------------|--------| | Symbol | 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 | | | Е | 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 | | | L | 0.450 | 0.600 | 0.750 | 0.0177 | 0.0236 | 0.0295 | | L1 | | 1.000 | | | 0.0394 | | | k | 0.0° | 3.5° | 7.0° | 0.0° | 3.5° | 7.0° | | ccc | _ | | 0.080 | | | 0.0031 | <sup>1.</sup> Values in inches are converted from mm and rounded to four decimal places. **577** Doc ID 022171 Rev 2 83/90 # 10.2 Thermal characteristics The maximum chip junction temperature (T<sub>Jmax</sub>) must never exceed the values given in *Table 16: General operating conditions*. The maximum chip-junction temperature, T<sub>Jmax</sub>, in degrees Celsius, may be calculated using the following equation: $$T_{Jmax} = T_{Amax} + (P_{Dmax} \times \Theta_{JA})$$ #### Where: - T<sub>Amax</sub> is the maximum ambient temperature in °C - ullet $\Theta_{JA}$ 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_{I/Omax}$ represents the maximum power dissipation on output pins, where: $P_{I/Omax} = \Sigma (V_{OL}^*I_{OL}) + \Sigma ((V_{DD}^-V_{OH})^*I_{OH})$ , and taking account of the actual $V_{OL}^-I_{OL}$ and $V_{OH}^-I_{OH}^-I_{OH}$ of the I/Os at low and high level in the application. Table 50. Thermal characteristics<sup>(1)</sup> | Symbol | Parameter | Value | Unit | |---------------|--------------------------------------------------------|-------|------| | $\Theta_{JA}$ | Thermal resistance junction-ambient LQFP 48 - 7 x 7 mm | 57 | °C/W | Thermal resistances are based on JEDEC JESD51-2 with 4-layer PCB in a natural convection environment ### 10.2.1 Reference document JESD51-2 integrated circuits thermal test method environment conditions - natural convection (still air). Available from www.jedec.org. 57 ### 10.2.2 Selecting the product temperature range When ordering the microcontroller, the temperature range is specified in the order code (see *Figure 40: STM8S007xx value line ordering information scheme(1)*). The following example shows how to calculate the temperature range needed for a given application. Assuming the following application conditions: - Maximum ambient temperature T<sub>Amax</sub>= 82 °C (measured according to JESD51-2) - $I_{DDmax} = 15 \text{ mA}, V_{DD} = 5.5 \text{ V}$ - Maximum eight standard I/Os used at the same time in output at low level with $I_{OL} = 10$ mA, $V_{OL} = 2$ V - Maximum four high sink I/Os used at the same time in output at low level with $I_{OL} = 20$ mA, $V_{OL} = 1.5 \text{ V}$ - Maximum two true open drain I/Os used at the same time in output at low level with $I_{OL} = 20$ mA, $V_{OL} = 2$ V ``` P_{INTmax} = 15 \text{ mA x } 5.5 \text{ V} = 82.5 \text{ mW} ``` $P_{IOmax} = (10 \text{ mA x 2 V x 8}) + (20 \text{ mA x 2 V x 2}) + (20 \text{ mA x 1.5 V x 4}) = 360 \text{ mW}$ This gives: P<sub>INTmax</sub> = 82.5 mW and P<sub>IOmax</sub> 360 mW: $$P_{Dmax} = 82.5 \text{ mW} + 360 \text{ mW}$$ Thus: P<sub>Dmax</sub> = 443 mW Using the values obtained in *Table 50: Thermal characteristics on page 84* $T_{Jmax}$ is calculated as follows for LQFP64 10 x 10 mm = 46 °C/W: $$T_{\text{-lmax}} = 82 \,^{\circ}\text{C} + (46 \,^{\circ}\text{C/W} \times 443 \,^{\circ}\text{mW}) = 82 \,^{\circ}\text{C} + 20 \,^{\circ}\text{C} = 102 \,^{\circ}\text{C}$$ This is within the range of the suffix 6 version parts (-40 < $T_{.J}$ < 105 °C). In this case, parts must be ordered at least with the temperature range suffix 6. # 11 STM8 development tools Development tools for the STM8 microcontrollers include the full-featured STice emulation system supported by a complete software tool package including C compiler, assembler and integrated development environment with high-level language debugger. In addition, the STM8 is to be supported by a complete range of tools including starter kits, evaluation boards and a low-cost in-circuit debugger/programmer. # 11.1 Emulation and in-circuit debugging tools The STice emulation system offers a complete range of emulation and in-circuit debugging features on a platform that is designed for versatility and cost-effectiveness. In addition, STM8 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 profiling and coverage to help detect and eliminate bottlenecks in application execution and dead code when fine tuning an application. In addition, STice offers in-circuit debugging and programming of STM8 microcontrollers via the STM8 single wire interface module (SWIM), which allows non-intrusive debugging of an application while it runs on the target microcontroller. For improved cost effectiveness, STice is based on a modular design that allows you to order exactly what you need to meet your development requirements and to adapt your emulation system to support existing and future ST microcontrollers. #### STice key features - Occurrence and time profiling and code coverage (new features) - Advanced breakpoints with up to 4 levels of conditions - Data breakpoints - Program and data trace recording up to 128 KB records - Read/write on the fly of memory during emulation - In-circuit debugging/programming via SWIM protocol - 8-bit probe analyzer - 1 input and 2 output triggers - 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. **A**y/ # 11.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. A free version that outputs up to 32 Kbytes of code is available. ### 11.2.1 STM8 toolset **STM8 toolset** with STVD integrated development environment and STVP programming software is available for free download at www.st.com/mcu. This package includes: ST Visual Develop - Full-featured integrated development environment from ST, featuring - Seamless integration of C and ASM toolsets - Full-featured debugger - Project management - Syntax highlighting editor - Integrated programming interface - Support of advanced emulation features for STice such as code profiling and coverage **ST Visual Programmer (STVP)** – Easy-to-use, unlimited graphical interface allowing read, write and verify of your STM8 microcontroller's Flash program memory, data EEPROM and option bytes. STVP also offers project mode for saving programming configurations and automating programming sequences. # 11.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: - **Cosmic C compiler for STM8** One free version that outputs up to 32 Kbytes of code is available. For more information, see www.cosmic-software.com. - Raisonance C compiler for STM8 One free version that outputs up to 32 Kbytes of code. For more information, see www.raisonance.com. - **STM8 assembler linker** Free assembly toolchain included in the STVD toolset, which allows you to assemble and link your application source code. # 11.3 Programming tools During the development cycle, STice provides in-circuit programming of the STM8 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 STM8. 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. 57 Doc ID 022171 Rev 2 87/90 # 12 Ordering information 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 <sup>2.</sup> Refer to Table 1: STM8S007xx value line features for detailed description. STM8S007C8 Revision history # 13 Revision history Table 51. Document revision history | Date | Revision | Changes | | |-------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 31-Oct-2011 | 1 | Initial release. | | | 06-Jan-2012 | 2 | Table 34: Flash program memory/data EEPROM memory: updated V <sub>DD</sub> condition; updated t <sub>RET</sub> parameters. Table 39: NRST pin characteristics: updated typ and max values of the NRST Pull-up resistor. | | #### 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 90/90 Doc ID 022171 Rev 2