Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs. With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas. We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry! # Contact us Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China ### **STNRGxxxA** # Digital controller for power conversion applications with up to 6 programmable PWM generators, 96 MHz PLL Datasheet - production data #### **Features** - Up to 6 programmable PWM generators (SMED - "State Machine Event Driven") - 10 ns event detection and reaction - Max.1.3 ns PWM resolution - Single, coupled and two coupled operational modes - Up to 3 internal/external events per SMED - 4 analog comparators - 4 internal 4-bit references - Up to 4 external references - Less than 50 ns propagation time - Continuous comparison cycle - Configurable hysteresis voltage levels - ADCs (up to 8 channels) - 10-bit precision, with operational amplifier to extend resolution to 12-bit equivalent - Sequencer functionality - Input impedance: 1 M $\Omega$ - Configurable gain value: x1 and x4 - Integrated microcontroller - Advanced STM8<sup>®</sup> core with Harvard architecture and 3-stage pipeline - Max. f<sub>CPU</sub>: 16 MHz - Memories - Flash and E<sup>2</sup>PROM with read while write (RWW) and error correction code (ECC) - Program memory: 32 Kbytes Flash; data retention 15 years at 85 °C after 10 kcycles at 25 °C - Data memory: 1 Kbyte true data E<sup>2</sup>PROM; data retention:15 years at 85 °C after 100 kcycles at 85 °C - RAM: 6 Kbytes - Clock management - Internal 96 MHz PLL - Low power oscillator circuit for external crystal resonator or direct clock input - Internal, user-trimmable 16 MHz RC and low power 153.6 kHz RC oscillators - Clock security system with clock monitor - Basic peripherals - System, auxiliary and basic timers - IWDG/WWDG watchdog, AWU, ITC - · Reset and supply management - Multiple low power modes (wait, slow, autowakeup, Halt) with user definable clock gating - Low consumption power-on and powerdown reset - I/O - Multifunction bidirectional GPIO with highly robust design, immune against current injection - Fast digital input DIGIN, with configurable pull-up - Communication interfaces - UART asynchronous with SW flow control and bootloader support - I<sup>2</sup>C master/slave fast-slow speed rate - Operating temperature: -40 °C up to 105 °C. Table 1. Device summary | Part number | Package | |-------------|----------| | STNRG388A | TSSOP38 | | STNRG328A | VFQFPN32 | | STNRG288A | TSSOP28 | Contents STNRGxxxA ## **Contents** | 1 | Desc | ription | | 11 | |---|-------|----------|----------------------------------------------------------|----| | 2 | STNI | RG fam | ily features list | 12 | | 3 | Intro | ducing | SMED | 13 | | | Docu | mentatio | on | 13 | | 4 | Syst | em arcl | hitecture | 14 | | | Block | diagran | 1 | 15 | | 5 | Prod | luct ove | erview | 16 | | | 5.1 | | (state machine event driven): configurable PWM generator | | | | | 5.1.1 | SMED coupling schemes | 17 | | | | 5.1.2 | Connection matrix | 18 | | | 5.2 | Interna | al controller (CPU) | 20 | | | | 5.2.1 | Architecture and registers | | | | | 5.2.2 | Addressing | | | | | 5.2.3 | Instruction set | 20 | | | | 5.2.4 | Single wire interface module (SWIM) | 20 | | | | 5.2.5 | Debug module | 21 | | | 5.3 | Basic | peripherals | 21 | | | | 5.3.1 | Vectored interrupt controller | 21 | | | | 5.3.2 | Timers | 21 | | | | 5.3.3 | Flash program and data E <sup>2</sup> PROM | 23 | | | | 5.3.4 | Architecture | 23 | | | | 5.3.5 | Write protection (WP) | 23 | | | | 5.3.6 | Protection of user boot code (UBC) | 23 | | | | 5.3.7 | Read-out protection (ROP) | 24 | | | 5.4 | Clock | controller | 24 | | | | 5.4.1 | Internal 16 MHz RC oscillator (HSI) | 25 | | | | 5.4.2 | Internal 153.6 kHz RC oscillator (LSI) | 25 | | | | 5.4.3 | Internal 96 MHz PLL | 25 | | | | 5.4.4 | External clock input/crystal oscillator (HSE) | 25 | STNRGxxxA Contents | | 5.5 | Power management | 26 | |---|-------|-------------------------------------------------------------|----| | | 5.6 | Communication interfaces | 27 | | | | 5.6.1 Universal asynchronous receiver/transmitter (UART) | 27 | | | | 5.6.2 Inter-integrated circuit interface (I <sup>2</sup> C) | 27 | | | | 5.6.3 Digital addressable lighting interface (DALI) | 28 | | | 5.7 | Analog-to-digital converter (ADC) | 29 | | | 5.8 | Analog comparators | 29 | | 6 | Pino | ıt and pin description | 31 | | | 6.1 | Pinout | 31 | | | 6.2 | Pin description | 34 | | | 6.3 | Input/output specifications | 36 | | 7 | I/O n | ultifunction signal configuration | 37 | | | 7.1 | Multifunction configuration policy | 37 | | | 7.2 | Port P0 I/O multifunction configuration signal | 37 | | | | 7.2.1 Alternate function P0 configuration signals | | | | | 7.2.2 Port P0 diagnostic signals | | | | | 7.2.3 Port P0 I/O functional multiplexing signal | 39 | | | | 7.2.4 P0 interrupt capability | 39 | | | | 7.2.5 P0 programmable pull-up and speed feature | 39 | | | 7.3 | Port P1 I/O multifunction configuration signal | 40 | | | | 7.3.1 Port P1 I/O multiplexing signal | 41 | | | | 7.3.2 P1 interrupt capability | 41 | | | | 7.3.3 P1 programmable pull-up feature | 41 | | | 7.4 | Port P2 I/O multifunction configuration signal | 41 | | | | 7.4.1 P2 ADC hardware trigger | 42 | | | | 7.4.2 P2 interrupt capability | 42 | | | | 7.4.3 P2 programmable pull-up feature | 43 | | | 7.5 | Port P3 analog signal | 43 | | | | 7.5.1 P3 ADC conversion request | 43 | | | | 7.5.2 P3 interrupt capability | 43 | | | 7.6 | Multifun | ction port configuration registers44 | |---|--------|----------|-------------------------------------------------------| | | | MSC_IO | MXP0 (Port P1 I/O MUX control register) | | | | MSC_IO | MXP1 (Port P1 I/O MUX control register) | | | | MSC_IO | MXP2 (Port P2 I/O MUX control register) | | | | MSC_IN | PP2AUX1 (INPP aux register) | | 8 | Memo | ory and | register map | | | 8.1 | Memory | map overview | | | 8.2 | Register | r map | | | | 8.2.1 | General purpose I/O GPIO0 register map | | | | 8.2.2 | General purpose I/O GPIO1 register map | | | | 8.2.3 | Miscellaneous registers | | | | 8.2.4 | Flash and E <sup>2</sup> PROM non-volatile memories | | | | 8.2.5 | Reset register | | | | 8.2.6 | Clock controller register | | | | 8.2.7 | WWDG timers | | | | 8.2.8 | IWDG timers | | | | 8.2.9 | AWU timers | | | | 8.2.10 | Inter-integrated circuit interface (I <sup>2</sup> C) | | | | 8.2.11 | Universal asynchronous receiver/transmitter (UART) | | | | 8.2.12 | System timer registers | | | | 8.2.13 | Auxiliary timer registers | | | | 8.2.14 | Basic timer0 registers | | | | 8.2.15 | Basic timer1 registers | | | | 8.2.16 | Digital addressable lighting interface (DALI) | | | | 8.2.17 | DALI noise rejection filter registers | | | | 8.2.18 | Analog-to-digital converter (ADC)60 | | | | 8.2.19 | State machine event driven (SMEDs) | | | | 8.2.20 | CPU register | | | | 8.2.21 | Global configuration register | | | | 8.2.22 | Interrupt controller | | | | 8.2.23 | SWIM control register | | 9 | Interr | upt tabl | e | STNRGxxxA Contents | 10 | Optio | n bytes | | . 65 | |-------------|-------|----------|-------------------------------------------------------------------|-------| | | 10.1 | Option | byte register overview | . 66 | | | 10.2 | Option | byte register description | . 71 | | | | 10.2.1 | ROP (memory read-out protection register) | | | | | 10.2.2 | UBC (UBC user boot code register) | | | | | 10.2.3 | nUBC (UBC user boot code register protection) | . 72 | | | | 10.2.4 | GENCFG (general configuration register) | . 72 | | | | 10.2.5 | nGENCFG (general configuration register protection) | . 73 | | | | 10.2.6 | MISCUOPT (miscellaneous configuration register) | . 73 | | | | 10.2.7 | nMISCUOPT (miscellaneous configuration register protection) | . 74 | | | | 10.2.8 | CLKCTL (CKC configuration register) | . 74 | | | | 10.2.9 | nCLKCTL (CKC configuration register protection) | . 75 | | | | 10.2.10 | HSESTAB (HSE clock stabilization register) | . 75 | | | | 10.2.11 | nHSESTAB (HSE clock stabilization register protection) | . 76 | | | | 10.2.12 | ENHFEAT (EXP features configuration register) | . 76 | | | | 10.2.13 | nENHFEAT (EXP features configuration register) | . 77 | | | | 10.2.14 | WAITSTATE (Flash wait state register) | . 77 | | | | 10.2.15 | nWAITSTATE (Flash wait state register protection) | . 78 | | | | 10.2.16 | AFR_IOMXP0 (alternative Port0 configuration register) | . 78 | | | | 10.2.17 | nAFR_IOMXP0 (alternative Port0 configuration register protection) | . 79 | | | | 10.2.18 | AFR_IOMXP1 (alternative Port1 configuration register) | . 79 | | | | 10.2.19 | nAFR_IOMXP1 (alternative Port1 configuration register protection) | . 80 | | | | 10.2.20 | AFR_IOMXP2 (alternative Port2 configuration register) | . 80 | | | | 10.2.21 | nAFR_IOMXP2 (alternative Port2 configuration register protection) | . 81 | | | | 10.2.22 | MSC_OPT0 (miscellaneous configuration reg0) | . 81 | | | | 10.2.23 | nMSC_OPT0 (miscellaneous configuration reg0 protection) | . 82 | | | | 10.2.24 | OPTBL (option byte bootloader) | . 82 | | | | 10.2.25 | nOPTBL (option byte boot loader protection) | . 83 | | 11 | Devi | ce ident | ification | . 84 | | | 11.1 | Unique | ID | . 84 | | | 11.2 | Device | ID | . 85 | | 12 | Elect | rical ch | aracteristics | . 86 | | | 12.1 | Parame | eter conditions | 86 | | | 1 | 12.1.1 | Minimum and maximum values | | | | | 12.1.2 | Typical values | | | <b>\7</b> / | | | DocID027799 Rev 2 | 5/131 | | | | 12.1.3 | Typical curves | 86 | |-----|-------|------------|---------------------------------------------------|------------| | | | 12.1.4 | Typical current consumption | 86 | | | | 12.1.5 | Loading capacitors | 87 | | | | 12.1.6 | Pin output voltage | 87 | | | 12.2 | Absolut | te maximum ratings | 88 | | | 12.3 | Operati | ng conditions | 89 | | | | 12.3.1 | VOUT external capacitor | 90 | | | | 12.3.2 | Supply current characteristics | 90 | | | | 12.3.3 | Low power mode wake-up time | 00 | | | | 12.3.4 | External clock sources and timing characteristics | 00 | | | | 12.3.5 | Internal clock sources and timing characteristics | 03 | | | | 12.3.6 | Memory characteristics | 04 | | | | 12.3.7 | I/O port pin characteristics | 05 | | | | 12.3.8 | Typical output level curves | 07 | | | | 12.3.9 | Reset pin characteristics | 13 | | | | 12.3.10 | I <sup>2</sup> C interface characteristics | 13 | | | | 12.3.11 | 10-bit SAR ADC characteristics | 14 | | | | 12.3.12 | Analog comparator characteristics | 19 | | | | 12.3.13 | DAC characteristics | 20 | | | 12.4 | EMC ch | naracteristics | 21 | | | | 12.4.1 | Electrostatic discharge (ESD) | 21 | | | | 12.4.2 | Static latch-up | 21 | | 13 | Ther | mal cha | racteristics | 22 | | 14 | Pack | age info | ormation | 23 | | | 14.1 | TSSOP | 238 package information | 23 | | | 14.2 | VFQFP | N32 package information | 25 | | | 14.3 | | 228 package information | | | 15 | STNF | RG deve | elopment tools | 29 | | 16 | Orde | r codes | | 29 | | 17 | | | tory | | | . / | 1/641 | 31011 1113 | wiy | <b>,</b> 0 | STNRGxxxA List of tables # List of tables | Table 1. | Device summary | . 1 | |-----------|-------------------------------------------------------------|-----| | Table 2. | STNRG family features list | 12 | | Table 3. | Connection matrix interconnection | | | Table 4. | Pin description | 34 | | Table 5. | Multifunction configuration registers | | | Table 6. | P0 internal multiplexing signals | | | Table 7. | Port P1 I/O multiplexing signal | | | Table 8. | Port P2 I/O multiplexing signal | | | Table 9. | MSC_IOMXP0 (Port P1 I/O MUX control register) | | | Table 10. | MSC_IOMXP1 (Port P1 I/O MUX control register) | | | Table 11. | MSC_IOMXP2 (Port P2 I/O MUX control register) | | | Table 12. | MSC_INPP2AUX1 (INPP aux register) | | | Table 13. | Internal memory map | | | Table 14. | General purpose I/O GPIO0 register map | | | Table 15. | General purpose I/O GPIO0 register map | | | Table 16. | Miscellaneous direct register address mode | | | Table 17. | Miscellaneous indirect register address mode | | | Table 18. | Non-volatile memory register map | | | Table 19. | RST_SR register map | | | Table 20. | Clock controller register map | | | Table 21. | WWDG timer register map | | | Table 22. | IWDG timer register map | | | Table 23. | AWU timer register map | | | Table 24. | I <sup>2</sup> C register map | | | Table 25. | UART register map | | | Table 26. | System timer register map | | | Table 27. | Auxiliary timer register map | | | Table 28. | Basic timer0 register map | | | Table 29. | Basic timer1 register map | | | Table 30. | DALI register map | | | Table 31. | DALI filter register map | | | Table 32. | ADC register map and reset value | | | Table 33. | SMED register map | | | Table 34. | CPU register map | | | Table 35. | CFG_GCR register map | | | Table 36. | Interrupt software priority register map | | | Table 37. | SWIM register map | | | Table 38. | Interrupt vector exception | | | Table 39. | Option byte register overview - STNRG388A | | | Table 40. | Option byte register overview - STNRG328A | | | Table 41. | Option byte register overview - STNRG288A | | | Table 42. | ROP (memory read-out protection register) | | | Table 43. | UBC (UBC user boot code register) | | | Table 44. | nUBC (UBC user boot code register protection) | | | Table 45. | GENCFG (general configuration register) | | | Table 46. | nGENCFG (general configuration register protection) | | | Table 47. | MISCUOPT (miscellaneous configuration register) | | | Table 48. | nMISCUOPT (miscellaneous configuration register protection) | | | | 2 2 2 (missonanesas somgaration registor proteotion) | | List of tables STNRGxxxA | Table 49. | CLKCTL (CKC configuration register) | 74 | |-----------|------------------------------------------------------------------------------------|-------| | Table 50. | nCLKCTL (CKC configuration register protection) | | | Table 51. | HSESTAB (HSE clock stabilization register) | | | Table 52. | nHSESTAB (HSE clock stabilization register protection) | 76 | | Table 53. | ENHFEAT (EXP features configuration register) | 76 | | Table 54. | nENHFEAT (EXP features configuration protection) | 77 | | Table 55. | WAITSTATE (Flash wait state register) | 77 | | Table 56. | nWAITSTATE (Flash wait state protection) | | | Table 57. | AFR_IOMXP0 (alternative Port0 configuration register) | 78 | | Table 58. | nAFR_IOMXP0 (alternative Port0 configuration register protection) | 79 | | Table 59. | AFR_IOMXP1 (alternative Port1 configuration register) | | | Table 60. | nAFR_IOMXP1 (alternative Port1 configuration register protection) | 80 | | Table 61. | AFR_IOMXP2 (alternative Port2 configuration register) | | | Table 62. | nAFR_IOMXP2 (alternative Port2 configuration register protection) | 81 | | Table 63. | MSC_OPT0 (miscellaneous configuration reg0) | | | Table 64. | nMSC_OPT0 (miscellaneous configuration reg0 protection) | 82 | | Table 65. | OPTBL (option byte bootloader) | | | Table 66. | nOPTBL (option byte boot loader protection) | 83 | | Table 67. | Unique ID register overview | 84 | | Table 68. | Dev ID register overview | 85 | | Table 69. | Device revision model overview | 85 | | Table 70. | Voltage characteristics | 88 | | Table 71. | Current characteristics | 88 | | Table 72. | Thermal characteristics | 89 | | Table 73. | General operating conditions | 89 | | Table 74. | Operating conditions at power-up/power-down | 90 | | Table 75. | Supply base current consumption at V <sub>DD</sub> /V <sub>DDA</sub> = 3.3/5 V | | | Table 76. | Supply low power consumption at V <sub>DD</sub> /V <sub>DDA</sub> = 3.3/5 V | | | Table 77. | Peripheral supply current consumption at V <sub>DD</sub> /V <sub>DDA</sub> = 3.3 V | | | Table 78. | Peripheral supply current consumption at V <sub>DD</sub> /V <sub>DDA</sub> = 5 V | | | Table 79. | Wake-up times | | | Table 80. | HSE user external clock characteristics | | | Table 81. | HSE crystal/ceramic resonator oscillator | | | Table 82. | HSI RC oscillator | | | Table 83. | LSI RC oscillator | | | Table 84. | PLL internal source clock | | | Table 85. | Flash program memory/data E <sup>2</sup> PROM memory | | | Table 86. | Voltage DC characteristics | | | Table 87. | Current DC characteristics | | | Table 88. | Operating frequency characteristics | | | Table 89. | NRST pin characteristics | | | Table 90. | I <sup>2</sup> C interface characteristics | | | Table 91. | ADC characteristics | . 114 | | Table 92. | ADC accuracy characteristics at V <sub>DD</sub> /V <sub>DDA</sub> 3.3 V | . 115 | | Table 93. | ADC accuracy characteristics at V <sub>DD</sub> /V <sub>DDA</sub> 5 V | | | Table 94. | Analog comparator characteristics | . 119 | | Table 95. | Analog comparator hysteresis at V <sub>DD</sub> /V <sub>DDA</sub> 3.3 V | . 119 | | Table 96. | Analog comparator hysteresis at V <sub>DD</sub> /V <sub>DDA</sub> 5 V | | | Table 97. | DAC characteristics | | | Table 98. | ESD absolute maximum ratings | | | Table 99. | Electrical sensitivity | . 121 | | Table 100 | Package mermal characteristics | コノン | | STNRGxxxA | List of tables | |-----------|----------------| | | | | Table 101. | TSSOP38 package mechanical data | 124 | |------------|----------------------------------|-----| | Table 102. | VFQFPN32 package mechanical data | 126 | | Table 103. | TSSOP28 package mechanical data | 128 | | Table 104. | Ordering information | 129 | | Table 105. | Document revision history | 130 | List of figures STNRGxxxA # **List of figures** | Figure 1. | STNRG internal design | . 14 | |------------|-----------------------------------------------------------------------------------------------|------| | Figure 2. | Internal block diagram | . 15 | | Figure 3. | Coupled SMED overview | . 17 | | Figure 4. | SMED subsystem overview | . 18 | | Figure 5. | Flash and E <sup>2</sup> PROM internal memory organizations | . 23 | | Figure 6. | STNRG388A - TSSOP38 pinout | . 31 | | Figure 7. | STNRG328A - VFQFPN32 pinout | . 32 | | Figure 8. | STNRG288A - TSSOP28 pinout | . 33 | | Figure 9. | Port P0 I/O functional multiplexing scheme | . 39 | | Figure 10. | Port P1 I/O multiplexing scheme | . 41 | | Figure 11. | Supply current measurement conditions | | | Figure 12. | Pin loading conditions | | | Figure 13. | Pin input voltage | . 87 | | Figure 14. | External capacitor C <sub>VOUT</sub> | . 90 | | Figure 15. | PWM current consumption with $f_{SMED}$ = PLL $f_{PWM}$ = 0.5 MHz at $V_{DD}/V_{DDA}$ = 3.3 V | . 98 | | Figure 16. | PWM current consumption with $f_{SMED}$ = PLL $f_{PWM}$ = 0.5 MHz at $V_{DD}/V_{DDA}$ = 5 V | . 98 | | Figure 17. | PWM current consumption with $f_{SMED}$ = HSI $f_{PWM}$ = 0.5 MHz at $V_{DD}/V_{DDA}$ = 3.3 V | . 99 | | Figure 18. | PWM current consumption with $f_{SMED}$ = HSI $f_{PWM}$ = 0.5 MHz at $V_{DD}/V_{DDA}$ = 5 V | . 99 | | Figure 19. | HSE external clock source | 101 | | Figure 20. | HSE oscillator circuit diagram | 102 | | Figure 21. | V <sub>OH</sub> standard pad at 3.3 V | 107 | | Figure 22. | V <sub>OL</sub> standard pad at 3.3 V | 107 | | Figure 23. | V <sub>OH</sub> standard pad at 5 V | 108 | | Figure 24. | V <sub>OL</sub> standard pad at 5 V | 108 | | Figure 25. | V <sub>OH</sub> fast pad at 3.3 V | 109 | | Figure 26. | V <sub>OL</sub> fast pad at 3.3 V | 109 | | Figure 27. | V <sub>OH</sub> fast pad at 5 V | 110 | | Figure 28. | V <sub>OL</sub> fast pad at 5 V | 110 | | Figure 29. | V <sub>OH</sub> high speed pad at 3.3 V | | | Figure 30. | V <sub>OL</sub> high speed pad at 3.3 V | | | Figure 31. | V <sub>OH</sub> high speed pad at 5 V | | | Figure 32. | V <sub>OL</sub> high speed pad at 5 V | 112 | | Figure 33. | ADC equivalent input circuit | | | Figure 34. | ADC conversion accuracy | | | Figure 35. | TSSOP38 package outline | | | Figure 36. | VFQFPN32 package outline | 125 | | Figure 37. | TSSOP28 package outline | 127 | STNRGxxxA Description ## 1 Description STNRG devices are a part of the STNRG family of STMicroelectronics<sup>®</sup> digital devices designed for advanced power conversion applications. The STNRG improves the design of the successful STLUX™ family, now integrated in a wide range of LED driver architectures, to support industrial power conversion applications such as PFC+LLC, interleaved LC DC/DC, interleaved PFC for smart power supplies as well as the full bridge for pilot line drivers for electric vehicles. # 2 STNRG family features list All devices of the STNRG family provide the following features: Table 2. STNRG family features list | _ | *4 !!-4 | Device | | | |-------------------------|-----------------------------|------------------|------------------|------------------| | <b>'</b> | eature list | STNRG388A | STNRG328A | STNRG288A | | Package | | TSSOP38 | VFQFPN32 | TSSOP28 | | Pin count | | 38 | 32 | 28 | | SMED numbers | | 6 | 6 | 6 | | SMED PWM output | pins | 6 | 5 | 4 | | Fast digital inputs pir | าร | 6 | 5 <sup>(1)</sup> | 3 <sup>(2)</sup> | | Positive comparator | input pin | 4 | 4 | 4 <sup>(3)</sup> | | Negative comparato | r input pins | 3 <sup>(4)</sup> | 1 | 1 <sup>(3)</sup> | | Comparator hysteres | sis | Yes | Yes | Yes | | Internal DACs | | 4 | 4 | 4 | | ADC input pins | | 8 | 6 | 6 | | ADC gain | | x1 - x4 | x1 | x1 | | ADC hardware trigge | er | Yes | Yes | Yes | | GPIO Port 0 pins | | 6 | 4 | 4 | | | UART peripheral | Yes | Yes | Yes | | Communication | I <sup>2</sup> C peripheral | Yes | Yes | Yes | | | DALI peripheral | Yes | Yes | Yes | | HSE function | | Yes | Yes | Yes | | | System timer | 1 | 1 | 1 | | Timers | Auxiliary timer | 1 | 1 | 1 | | | Basic timer | 2 | 2 | 2 | | Auto-wakeup timer | | 1 | 1 | 1 | | Watchdoo | Window watchdog timer | 1 | 1 | 1 | | Watchdog | Independent watchdog timer | 1 | 1 | 1 | | Flash program mem | ory | 32 Kbytes | 32 Kbytes | 32 Kbytes | | EEPROM data mem | ory | 1 Kbytes | 1 Kbytes | 1 Kbytes | | RAM | | 6 Kbytes | 6 Kbytes | 6 Kbytes | | SWIM pin | | Mixed | Mixed | Mixed | <sup>1.</sup> DIGIN2 - DIGIN3 are connected to the same pin. 12/131 DocID027799 Rev 2 <sup>2.</sup> DIGIN0 - DIGIN1, DIGIN2 - DIGIN3 and DIGIN4 - DIGIN5 are connected to the same pin. <sup>3.</sup> CPP2 and CPM3are connected to the same pin. <sup>4.</sup> Some CPM pin is shared with other signals. STNRGxxxA Introducing SMED ### 3 Introducing SMED The heart of the STNRG controller family is the SMED (state machine event driven) technology which allows the device to pilot six independently configurable PWM clocks with a maximum resolution of 1.3 ns. A SMED is a powerful autonomous state machine, which is programmed to react to both external and internal events and may evolve without any software intervention. The SMED reaction time can be as low as 10.4 ns, giving the STNRG the ability of operating in time critical applications. The SMEDs offer superior performances when compared to traditional, timer based, PWM generators. Each SMED is configured via the STNRG internal microcontroller. The integrated controller extends the STNRG reliability and guarantees more than 15 years of both operating lifetime and memory data retention for program and data memory after cycling. A set of dedicated peripherals complete the STNRG device: - 4 analog comparators with configurable references and 50 ns max. propagation delay. It is ideal to implement zero current detection algorithms or detect current peaks. - 10-bit ADC with configurable op amp and 8-channel sequencer. - 96 MHz PLL for high output signal resolution. #### **Documentation** This datasheet contains the description of features, pinout, pin assignment, electrical characteristics, mechanical data and ordering information. - For information on programming, erasing and protection of the internal Flash memory, please refer to the STM8S reference in the programming manual "How to program STM8S and STM8A Flash program memory and data EEPROM" (PM0051). - For information on the debug and SWIM (single wire interface module) interface 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). System architecture STNRGxxxA ### 4 System architecture The STNRG device generates and controls PWM signals by means of a state machine, called SMED (state machine event driven). *Figure 1* gives an overview of the internal architecture. Figure 1. STNRG internal design The core of the device is the SMED unit: a hardware state machine driven by system events. The SMED includes 4 states (S0, S1, S2 and S3) available during running operations. A special HOLD state is provided as well. The SMED allows the user to configure, for every state, which system events will trigger a transaction to a new state. During a transaction from one state to the other, the PWM output signal level can be updated. Once a SMED is configured and running, it becomes an autonomous unit, so no interaction is required since the SMED automatically reacts to system events. Thanks to the SMED's 96 MHz operating frequency and their automatic dithering function, the PWM maximum resolution is 1.3 ns. The STNRG family has 6 SMEDs available. Multiple SMEDs can operate independently from each other or they can be grouped together to form a more powerful state machine. The STNRG also integrates a low power STM8 microcontroller which is used to configure and monitor the SMED activity and to supply external communication such as the UART, I<sup>2</sup>C or DALI. The STM8 controller has full access to all the STNRG subsystems, including the SMEDs. The STNRG family also features a sequential ADC, which can be configured to continuously sample up to 8 channels. Section: Block diagram illustrates the overall system block and shows how SMEDs have been implemented in the STNRG architecture. 14/131 DocID027799 Rev 2 ### **Block diagram** Figure 2. Internal block diagram LSI int. oscillator Reset controller Clock controller POR HSI int. oscillator MVR MLVD PLL 96 MHz DLVD LVR Clock controller HSE ext. oscillator Reset control power management 32 KB Flash DALI program memory Р 1 KB E<sup>2</sup>PROM UART data memory GPIO0 6 KB RAM 0 2KB ROM $I^2C$ boot loader Р MSC (Misc. registers) 2 Internal Address and data bus n controller 6 Digital input lines t. 0 4 Comparator & DAC В Connection Box SWIM & DM (debug module) u s SMED0 (PWM0) ITC (Interrupt Ctrl) SMED1 (PWM1) AWU SMED2 (PWM2) (Auto-wakeup) 1 SMED3 (PWM3) WWDG SMED4 (PWM4) (Win. watchdog) SMED5 (PWM5) 0 (Ind. watchdog) GPIO1 **TIMERS** - System timer - Aux timer ADC with OPAMP - Basic0 timer - Basic1 timer AM03911v1 #### 5 Product overview Section 5.1 describes the features implemented in the product device. # 5.1 SMED (state machine event driven): configurable PWM generator The SMED is an advanced programmable PWM generator signal. The SMED (state machine event driven) is a state machine device controllable by both external events (primary I/O signals) and internal events (counter timers), which generate an output signal (PWM) depending on the evolution of the internal state machine. The PWM signal generated by the SMED is therefore shaped by external events and not only by a simple timer. This mechanism allows to generate controlled high frequency PWM signals. The SMED is also autonomous: once it has been configured by the STNRG internal controller, the SMED can operate without any software interaction. The STNRG family provides 6 SMED units. Multiple SMEDs can operate independently from each other or they can be grouped together to form a more powerful state machine. The main features of a SMED are described here below: - · Configurable state machine generating a PWM signal - · More than 10.4 ns PWM native resolution - Up to 1.3 ns PWM resolution when using SMED dithering - 6 states available in each SMED: IDLE, S0, S1, S2, S3 plus a special HOLD state - Transactions triggered by synchronous and asynchronous external events or an internal timer - Each transaction can generate an interrupt - Fifteen registers available to configure the state machine behavior - Four 16-bit configurable time registers, one for each running state (T0, T1, T2, T3) - · Internal resources accessible through the processor interface - Eight interrupt request lines - Configurable ADC HW trigger request - PWM pseudo open drain features configurable through GPIO1 registers 57 #### 5.1.1 SMED coupling schemes The SMED coupling extends the capability of the single SMED, preserving the independence of each "Finite State Machine" (FSM) programmed state evolution. The coupling scheme allows the SMED pulse signals to be interleaved on their own PWM or on a merged single PWM output. The STNRG supports the following coupled configuration schemes: - Single SMED configuration - Synchronous coupled SMED - Asynchronous coupled SMED - Synchronous two coupled SMEDs - Asynchronous two coupled SMEDs - External controlled SMED The SMED units may be configured in different coupled schemes through the SMDx\_GLBCONF and SMDx\_DRVOUT bit fields of MSC\_SMEDCFGxy registers. An outline of the SMED subsystem is shown in Figure 3. Figure 3. Coupled SMED overview 1. The PWM4 and PWM5 output pins are not present on all STNRG devices. #### 5.1.2 Connection matrix The connection matrix extends the input connectivity of each SMED unit so that a SMED can receive events from a wide range of sources. Through the matrix, it's possible to connect the SMED inputs to various signal families such as digital inputs, comparator output signals, SW events, and three PWM internal feedback signals as shown in *Figure 4*. The list of the available event sources is the following: - DIGIN [5:0] digital input lines - CPM [3:0] analog comparator outputs - PWM [5:0] output signals of SMEDs (only PWM 0, 1 and 5 are accessible) - SW [5:0] software events *Figure 4* shows the connection matrix and signal interconnections as they are implemented in the STNRG family. The CPP2 and CMP3 inputs are connected together in some STNRG devices. #### Connection matrix interconnection Every SMED unit has three input selection lines, one for each In\_Sig input, configurable via the MSC\_CBOXS (5:0) register. The selection lines choose the interconnection between one of possible four connection matrix signals for each SMED input event In\_Sig (Y). *Table 3* shows the layout of the connection matrix interconnection signals as implemented in the STNRG family. Table 3. Connection matrix interconnection | Conb_s(x)_(y)(z) | | | | | | |------------------|------------|---------------------------------|------|------|------| | SMED number | SMED input | SMED input signal selection (z) | | | | | (x) | (y) | 00 | 01 | 10 | 11 | | 0 | 0 | CP0 | DIG0 | DIG2 | DIG5 | | | 1 | CP1 | DIG0 | DIG3 | CP3 | | | 2 | CP2 | DIG1 | DIG4 | SW0 | | 1 | 0 | CP1 | DIG1 | DIG3 | DIG0 | | | 1 | CP2 | DIG1 | DIG4 | CP3 | | | 2 | CP0 | DIG2 | DIG5 | SW1 | | 2 | 0 | CP2 | DIG2 | DIG4 | DIG1 | | | 1 | CP0 | DIG2 | DIG5 | PWM0 | | | 2 | CP1 | DIG3 | DIG0 | SW2 | | 3 | 0 | CP0 | DIG3 | DIG5 | DIG2 | | | 1 | CP1 | DIG3 | DIG0 | PWM1 | | | 2 | CP2 | DIG4 | DIG1 | SW3 | | 4 | 0 | CP1 | DIG4 | DIG0 | DIG3 | | | 1 | CP2 | DIG4 | DIG1 | PWM5 | | | 2 | CP0 | DIG5 | DIG2 | SW4 | | 5 | 0 | CP2 | DIG5 | DIG1 | DIG4 | | | 1 | CP0 | DIG5 | DIG2 | CP3 | | | 2 | CP1 | DIG0 | DIG3 | SW5 | #### Connection matrix legend: - X represents the SMED [5:0] number - Y represents the SMED input signal number (In\_Sig [2:0]) - Z represents the In\_Sig (Y) selection signal Note: Each SMED input has independent connection matrix selection signals. The DIGO and DIG1 signal are interconnected together, the pin DIGIN [1\_0] on the STNRG288A. The DIG2 and DIG3 signals are interconnected together, the pin DIGIN [3\_2] on the STNRG328A and STNRG288A. The DIG4 and DIG5 signal are interconnected together, the pin DIGIN [5\_4] on the STNRG288A. #### 5.2 Internal controller (CPU) The STNRG family integrates a programmable STM8 controller acting as a device supervisor. The STM8 is a modern CISC core and has been designed for code efficiency and performance. It contains 21 internal registers (six of them directly addressable in each execution context), 20 addressing modes including indexed indirect and relative addressing and 80 instructions. #### 5.2.1 Architecture and registers - Harvard architecture with 3-stage pipeline - 32-bit wide program memory bus with single cycle fetching for most instructions - X and Y 16-bit index registers, enabling indexed addressing modes with or without offset and read-modify-write type data manipulations - 8-bit accumulator - 24-bit program counter with 16 Mbyte linear memory space - 16-bit stack pointer with access to a 64-Kbyte stack - 8-bit condition code register with seven condition flags updated with the results of last executed instruction #### 5.2.2 Addressing - 20 addressing modes - Indexed indirect addressing mode for lookup tables located in the entire address space - Stack pointer relative addressing mode for efficient implementation of local variables and parameter passing #### 5.2.3 Instruction set - 80 instructions with 2-byte average instruction size - Standard data movement and logic/arithmetic functions - 8-bit by 8-bit multiplication - 16-bit by 8-bit and 16-bit by 16-bit division - Bit manipulation - Data transfer between stack and accumulator (push/pop) with direct stack access - Data transfer using the X and Y registers or direct memory-to-memory transfers #### 5.2.4 Single wire interface module (SWIM) The single wire interface module (SWIM), together with the integrated debug module (DM), allows non-intrusive, real-time in-circuit debugging and fast memory programming. The interface can be activated in all device operation modes and can be connected to a running device (hot plugging). The maximum data transmission speed is 145 byte/ms. The SWIM pin is a multifunction signal. For further details refer to *Table 7: Port P1 I/O multiplexing signal* in *Section 7.3 on page 40*. 20/131 DocID027799 Rev 2 #### 5.2.5 Debug module The non-intrusive debugging module is fully controllable through the external target emulator. Besides memory and peripheral operation, the CPU operation can also be monitored in real-time by means of shadow registers. - R/W of RAM and peripheral registers in real-time - R/W for all resources when the application is stopped - Breakpoints on all program-memory instructions (software breakpoints), except for the interrupt vector table - Two advanced breakpoints and 23 predefined breakpoint configurations ### 5.3 Basic peripherals Section 5.3.1 and Section 5.3.2 describe the basic peripherals accessed by the internal CPU controller. #### 5.3.1 Vectored interrupt controller - Nested interrupts with three software priority levels - 21 interrupt vectors with hardware priority - Two vectors for 12 external maskable or un-maskable interrupt request lines - Trap and reset interrupts #### 5.3.2 Timers The STNRG family provides several timers which are used by software and do not interact directly with the SMED and the PWM generation. #### System timers The system timer consists of a 16-bit autoreload counter driven by a programmable prescaled clock and operating in one shoot or free running operating mode. The timer is used to provide the IC time base system clock, with an interrupt generation on timer overflow events. #### **Basic timers** The IC device includes two independent 6-bit timers programmable through the miscellaneous indirect register area. The time base frequency is configurable with different source clocks. The timers have the following functionalities: - Free running mode - Timer prescaler 8-bits - Counter register 6-bits - Programmable time base clock (HSI, HSE, LSI, PLL) - Interrupt timer capability: - Vectored interrupt - Interrupt IRQ/NMI or polling mode #### **Auxiliary timer** The auxiliary timer is a light timer with elementary functionality. The time base frequency is provided by the CCO clock logic (configurable with a different source clock and prescale division factors), while the interrupt functionality is supplied by an interrupt edge detection logic similarly to the solution adopted for the Port P0/P2. The timer has the following main features: - Free running mode - Up counter - Timer prescaler 8-bit - Interrupt timer capability: - Vectored interrupt - Interrupt IRQ/NMI or Polling mode - Timer pulse configurable as a clock output signal via the CCO primary pin Thanks to the great configurability of the CCO frequency, the timer can cover a wide range of interval time to fit better the target application requirements. #### Auto-wakeup timer The AWU timer is used to cyclically wake-up the IC device from the active halt state. The AWU frequency time base $f_{AWU}$ can be selected between the following clock sources: LSI (153.6 kHz) and the external clock HSE scaled down to 128 kHz clock. By default the f<sub>AWU</sub> clock is provided by the LSI internal source clock. #### Watchdog timers The watchdog system is based on two independent timers providing a high level of robustness to the applications. The watchdog timer activity is controlled by the application program or by suitable option bytes. Once the watchdog is activated, it cannot be disabled by the user program without going through reset. #### Window watchdog timer The window watchdog is used to detect the occurrence of a software fault, usually generated by external interferences or by unexpected logical conditions, which causes the application program to break the normal operating sequence. The window function can be used to adjust the watchdog intervention period in order to match the application timing perfectly. The application software must refresh the counter before timeout and during a limited time window. If the counter is refreshed outside this time window, a reset is issued. #### Independent watchdog timer The independent watchdog peripheral can be used to solve malfunctions due to hardware or software failures. It is clocked by the 153.6 kHz LSI internal RC clock source. By properly setting the hardware watchdog feature associated option bits, the watchdog is automatically enabled at power-on, and generates a reset unless the key register is written by software before the counter reaches the end of the count. 22/131 DocID027799 Rev 2 ### 5.3.3 Flash program and data E<sup>2</sup>PROM Embedded Flash and E<sup>2</sup>PROM with the memory ECC code correction and protection mechanism preventing embedded program hacking. - 32 Kbyte of single voltage program Flash memory - 1 Kbyte true (not emulated) data E<sup>2</sup>PROM - Read while write: writing in the data memory is possible while executing code program memory - The device setup is stored in a user option area in the non-volatile memory. #### 5.3.4 Architecture Figure 5. Flash and E<sup>2</sup>PROM internal memory organizations - The memory is organized in blocks of 128 bytes each - Read granularity: 1 word = 4 bytes - Write/erase granularity: 1 word (4 bytes) or 1 block (128 bytes) in parallel - Writing, erasing, word and block management is handled automatically by the memory interface. #### 5.3.5 Write protection (WP) Write protection in application mode is intended to avoid unintentional overwriting of the memory. The write protection can be removed temporarily by executing a specific sequence in the user software. #### 5.3.6 Protection of user boot code (UBC) In STNRG devices a memory area of 32 Kbyte can be protected from overwriting at a user option level. In addition to the standard write protection, the UBC protection can be modified by the embedded program or via debug interface when the ROP protection is enabled. The UBC memory area contains the reset and interrupt vectors and its size can be adjusted in increments of 512 bytes by programming the UBC and nUBC option bytes. Note: If users choose to update the boot code in the application programming (IAP), this has to be protected so to prevent unwanted modification. #### 5.3.7 Read-out protection (ROP) The STNRG family provides a read-out protection of the code and data memory which can be activated by an option byte setting. The read-out protection prevents reading and writing program memory, data memory and option bytes via the debug module and SWIM interface. This protection is active in all device operation modes. Any attempt to remove the protection by overwriting the ROP option byte triggers a global erase of the program and data memory contents. #### 5.4 Clock controller The clock controller distributes the system clock provided by different oscillators to the core and the peripherals. It also manages clock gating for low- power modes and ensures clock robustness. The main clock controller features are: - Clock sources - Internal 16 MHz and 153.6 kHz RC oscillators - External source clock: - Crystal/resonator oscillator - External clock input - Internal PLL at 96 MHz (not used as the f<sub>MASTER</sub> source clock) - Reset: after the reset the microcontroller restarts by default with the HSI internal clock scaled at 2 MHz (16 MHz/8). The clock source and speed can be changed by the application program as soon as the code execution starts. - Safe clock switching: clock sources can be changed safely on the fly in run mode through a configuration register. The clock signal is not switched until the new clock source is ready. The design guarantees glitch-free switching. - Clock management: to reduce power consumption, the clock controller can stop the clock to the core or individual peripherals. - Wakeup: In in case the device wakes up from low- power modes, the internal RC oscillator (16 MHz/8) is used for a quick startup. After a stabilization time, the device brings back the clock source that was selected before Halt mode was entered. - Clock security system (CSS): the CSS permits monitoring of external clock sources and automatic switching to the internal RC (16 MHz/8) in case of a clock failure. - Configurable main clock output (CCO): this feature permits to output an internal clock source signal for application usage. 577 #### 5.4.1 Internal 16 MHz RC oscillator (HSI) The high speed internal (HSI) clock is the default master clock line, generated by an internal RC oscillator and with nominal frequency of 16 MHz. It has the following major features: - RC architecture - Glitch-free oscillation - 3-bit user calibration circuit. #### 5.4.2 Internal 153.6 kHz RC oscillator (LSI) The low speed internal (LSI) clock is a low speed clock line provided by an internal RC circuit. It drives both the independent watchdog (IWDG) circuit and the auto-wakeup unit (AWU). It can also be used as a low power clock line for the master clock f<sub>MASTER</sub>. #### 5.4.3 Internal 96 MHz PLL The PLL provides a high frequency 96 MHz clock used to generate high frequency and accurate PWM waveforms. The input reference clock must be 16 MHz and may be sourced either by the internal HSI signal or by the external HSE auxiliary input crystal oscillator line. The internal PLL prescaled clock cannot be selected as f<sub>MASTER</sub>. Note: When the application requires a PWM signal with a custom defined long term stability it is suggested to use an external clock source connected to the HSE auxiliary clock line as the PLL input reference clock. In this case, the external clock source accuracy determines the PWM output stability. #### 5.4.4 External clock input/crystal oscillator (HSE) The high speed external clock (HSE) allows the connection of an external clock generated, for example, by a highly accurate crystal oscillator. The HSE is interconnected with the $f_{MASTER}$ clock line and to several peripherals. It allows users to provide a custom clock characterized by a high level of precision and stability to meet the application requirements. The HSE supports two possible external clock sources with a maximum of 24 MHz: - Crystal/ceramic resonator interconnected with the HseOscin/HseOscout signals - Direct drive clock interconnected with the HseOscin signal The HseOscin and HseOscout signals are multifunction pins configurable through the I/O multiplex mechanism; for further information refer to Section 6 on page 30. Note: When the HSE is configured as the $f_{MASTER}$ source clock, the HSE input frequency cannot be higher than 16 MHz. When the HSE is the PLL input reference clock, then the HSE input frequency must be equal to 16 MHz. If the HSE is the reference for the SMED or the ADC logic, the input frequency can be configured up to 24 MHz.