AN4515 Application note Maximizing power efficiency using STM32F411xx Batch Acquisition Mode (BAM) Introduction The STM32F411 line is part of the STM32 Dynamic Efficiency™ microcontrollers. These devices are the entry level to the High-performance F4 Series and offer the best balance of dynamic power consumption and processing performance, while achieving outstanding lowpower consumption in Run, Sleep and Stop modes. With the new Batch Acquisition Mode (BAM) which allows optimizing power consumption for data batching, the STM32F411xx microcontrollers brings the Dynamic Efficiency to a new level. This application note guides you to achieve the expected power consumptions on STM32F411xx microcontrollers through an application case. It also provides an example of how to implement the BAM. This application note is provided with STSW-STM32154 firmware package. Table 1. Applicable products and software Type Part numbers Microcontrollers STM32F411 line Software STSW-STM32154 December 2014 DocID026482 Rev 1 1/24 www.st.com 1 Contents AN4515 Contents 1 2 3 Application Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 1.1 Hardware high level description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 1.2 Low-power modes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 1.3 Batch Acquisition Mode (BAM) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 1.3.1 Principle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 1.3.2 BAM use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 1.3.3 How to implement BAM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 1.3.4 How to execute code from RAM using Keil® MDK-ARM™ toolchain . . 11 1.3.5 How to execute code from RAM using IAR-EWARM toolchain . . . . . . . 13 Application note use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 2.1 Block diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 2.2 STM32F411xx used peripherals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 2.3 Functional description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 Application current consumption . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 3.1 Hardware requirements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 3.2 Software settings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 3.3 Measured current consumption . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 4 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 5 Revision history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 2/24 DocID026482 Rev 1 AN4515 List of tables List of tables Table 1. Table 2. Table 3. Table 4. Table 5. Applicable products and software . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Summary of methods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 Master and sensor board connection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 Current consumption example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 Document revision history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 DocID026482 Rev 1 3/24 3 List of figures AN4515 List of figures Figure 1. Figure 2. Figure 3. Figure 4. Figure 5. Figure 6. Figure 7. Figure 8. Figure 9. Figure 10. Figure 11. Figure 12. Figure 13. Figure 14. Figure 15. Figure 16. 4/24 Application high level block diagram. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 Batch Acquisition Mode use case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 Executing ISRs from RAM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 Executing ISRs from Flash memory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 Using events to wake up the CPU . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 MDK-ARM file placement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 MDK-ARM scatter file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 MDK-ARM Options menu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Update of EWARM linker . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 Update of EWARM startup file to handle an interrupt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Use case block diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 Use case state machine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 Startup and Configuration Menu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Wait MEMS movement while CPU is Sleep mode and Flash memory stopped . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Log example when configuration 4 is selected . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 Hardware environment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 DocID026482 Rev 1 AN4515 1 Application Overview Application Overview This section gives an overview of the application note use case, details how the user can implement the BAM and describes each low-power mode involved in the use case operation. 1.1 Hardware high level description This document first explains how to assess power consumption in different low-power modes (Standby, Sleep, Stop and Low-power run) and then highlights the significant power reduction achieved by using the BAM to transfer sensor (MEMS LSM303DLHC) data direction (UP or DOWN) to a master STM32F411xx microcontroller. The data sent by the sensor is received via the I2C interface and transferred by DMA to the RAM. After processing data, the DMA sends the data direction to the UART. It is then displayed via the USB virtual comport. Figure 1 shows a high-level block diagram of the application. Figure 1. Application high level block diagram )&',6&29(5< 6HQVRU 83 86 % &R 9LUW P3 XDO RUW ,& '2:1 'LVSOD\ 3& 18&/(2)5( 0DVWHU 06Y9 Note: The next version of this application note will include the X-Nucleo IKS01A1 as sensor instead of 32F401CDISCOVERY (STM32F401C-DISCO order code). DocID026482 Rev 1 5/24 23 Application Overview 1.2 AN4515 Low-power modes This section describes the different low-power modes used in the application. • Low-power run mode The CPU and some of the peripherals are running. To further reduce power consumption, unused GPIOs configured as analog pins and peripherals are disabled. • Sleep mode In this mode only the CPU is stopped and the peripherals kept running. To reduce power consumption the Flash memory can be stopped before entering Sleep mode. Peripherals can wake up the CPU when an interrupt occurs. • Stop mode The CPU is in DeepSleep mode. All peripherals except RTC are disabled. Exiting Stop mode is done by issuing an interrupt. • Standby mode In this mode the power is only maintained for the RTC registers. The device is woken by a rising edge on the WKUP pin that generates a system reset. Note: For more details about the low-power modes refer to STM32F411xx datasheets. 1.3 Batch Acquisition Mode (BAM) 1.3.1 Principle The Batch Acquisition Mode (BAM) optimizes power consumption for data batching. It allows exchanging batches of data through communication peripherals while the rest of the device (including the CPU) is in low-power mode: 1.3.2 • Only the needed DMA streams are enabled and running to transfer data from communication interfaces to internal RAM. • Routine execution from RAM allows switching off the Flash memory and stopping the Flash Interface clock. • MCU core is put in Sleep mode waiting for an interrupt/event to wake up. BAM use case Figure 2 shows one part of the application note use case block diagram. It describes the different peripherals involved in the BAM and mentions their power state (low-power or active). In fact, during data reception, only the DMA stream0, I2C1 and SRAM are active. The MCU core is in Sleep mode and the Flash memory is stopped until the DMA transfer is complete. 6/24 DocID026482 Rev 1 AN4515 Application Overview Figure 2. Batch Acquisition Mode use case 670)[( /60/'+& &257(; 0 .% )ODVK ,& $57 VDPSOHV $FFHOHURPHWHU '0$ .% 65$0 VWUHDP VWUHDP VWUHDP VWUHDP VWUHDP VWUHDP VWUHDP VWUHDP /RZSRZHUEORFNV $FWLYHEORFNV 06Y9 1.3.3 How to implement BAM When the BAM is enabled, the Flash memory is switched off by setting the FMSSR and FISSR bits in PWR_CR register. These bits cannot be set while executing the program from Flash memory. This can be done through a specific routine executed from RAM (see Figure 3, Figure 4 and Figure 5 for a description). Three methods can be used to implement the BAM. Each approach depends on user application: • Executing Interrupts from RAM • Executing Interrupts from Flash memory • Using events to wake up the CPU Executing interrupts from RAM This is the approach used in the application note use case (see Figure 3). The device is woken up from Sleep by an interrupt. The user application has therefore to store the required ISRs and the vector table in the RAM so that it is immediately executed from the RAM when the interrupt occurs. DocID026482 Rev 1 7/24 23 Application Overview AN4515 Figure 3. Executing ISRs from RAM 6WDUW H[HFXWLRQIURP5$0 6ZLWFK2IIWKH)ODVK 6ZLWFK2IIWKH)ODVK ,QWHUIDFH :), '0$WUDQVIHU FRPSOHWH LQWHUUXSW ([HFXWH,65URXWLQH 6ZLWFK2QWKH)ODVK,QWHUIDFH 6ZLWFK2QWKH)ODVK 'HOD\ wV 7HPSR dĞŵƉŽсϬ (QG H[HFXWLRQIURP5$0 06Y9 8/24 DocID026482 Rev 1 AN4515 Application Overview Executing Interrupts from Flash memory In this approach the Flash memory is stopped and all the interrupts must be disabled until the Flash memory is enabled again (see Figure 4). Figure 4. Executing ISRs from Flash memory ^ƚĂƌƚ ĞdžĞĐƵƚŝŽŶĨƌŽŵZD 'LVDEOHLQWHUUXSWV 6ZLWFK2IIWKH)ODVK 6ZLWFK2IIWKH)ODVK ,QWHUIDFH :), DƚƌĂŶƐĨĞƌ ĐŽŵƉůĞƚĞŝŶƚĞƌƌƵƉƚ 6ZLWFK2QWKH)ODVK /ŶƚĞƌĨĂĐĞ 6ZLWFK2QWKH)ODVK 'HOD\ wV 7HPSR dĞŵƉŽсϬ (QDEOHLQWHUUXSWV ([HFXWH,65URXWLQH ŶĚ ĞdžĞĐƵƚŝŽŶĨƌŽŵZD 06Y9 DocID026482 Rev 1 9/24 23 Application Overview AN4515 Using events to wakeup CPU The method uses events instead of interrupts to wake up the CPU from Sleep mode (see Figure 5). Figure 5. Using events to wake up the CPU 6WDUW H[HFXWLRQIURP5$0 6ZLWFK2IIWKH)ODVK 6ZLWFK2IIWKH)ODVK,QWHUIDFH :)( ǀĞŶƚсϭ 6ZLWFK2QWKH)ODVK,QWHUIDFH 6ZLWFK2QWKH)ODVK 'HOD\ 7HPSR dĞŵƉŽсϬ (QG H[HFXWLRQIURP5$0 06Y9 Summary of BAM implementation methods Table 2. Summary of methods Approach Executing ISRs from RAM Strength No latency in interrupt execution Executing ISRs from Flash memory Weakness FW little bit complex to implement Latency in interrupt execution Easy firmware implementation Using events to wake up the CPU 10/24 Interrupts are not executed since the Flash memory is stopped DocID026482 Rev 1 AN4515 1.3.4 Application Overview How to execute code from RAM using Keil® MDK-ARM™ toolchain This section gives an overview of the steps required to execute part of the application code from RAM using Keil MDK-ARM toolchain. Executing a source file from RAM Executing a source file from RAM means that all the functions declared in this file will be executed from RAM area. Follow the steps below to execute a file from RAM (see Figure 6): 1. Right click the file to place it in RAM and select Options. 2. Select the RAM area in the Memory Assignment menu. Figure 6. MDK-ARM file placement 06 9 Executing an interrupt from RAM The following steps are required to execute an interrupt handler from RAM: 1. Make a second vector table and save it in a new file (startup_stm32f411xe_ram.s) that will be saved in RAM. 2. Place the interrupt handler to be executed from RAM in a new file named stm32f4xx_it_ram.c. 3. Place the required files in the right RAM area in the scatter file (see Figure 7). DocID026482 Rev 1 11/24 23 Application Overview AN4515 Figure 7. MDK-ARM scatter file 4. Refer to the modified scatter file for the project options (see Figure 8). Figure 8. MDK-ARM Options menu 12/24 DocID026482 Rev 1 AN4515 1.3.5 Application Overview How to execute code from RAM using IAR-EWARM toolchain Executing code from RAM This operation requires a new RAM0 section to be defined in the linker file (.icf) (see Figure 9). The required steps are the following: 1. Define the address area for RAM0 by indicating the start and end addresses. 2. Tell the linker to copy at startup the section named ‘ram0’ from Flash memory to RAM0. 3. Indicate to the linker that ram0 code section should be placed in the RAM0 area. Figure 9. Update of EWARM linker 'HILQHVDGGUHVV ZKHUHWKHVHFRQG YHFWRUWDEOHZLOOEH ORFDWHG 'HILQHVDGGUHVV DUHDIRU5$0 PHPRU\ 7HOOVWKHOLQNHUWR FRS\WKHVHVHFWLRQV DWVWDUWXSWLPH 3ODFHVVHFWLRQUDPDW 5$0UHJLRQGHILQHG DERYH 06Y9 Executing a source file from RAM To execute a source file from RAM use the file Options window: 1. Select Options from the displayed menu. 2. Select C/C++ Compiler 3. Check override inherited settings from the displayed window. 4. Select the output tab and type the name of the section already defined in the linker file (.ram0 in this example) in the Code section name field. DocID026482 Rev 1 13/24 23 Application Overview AN4515 Executing an interrupt from RAM The steps required to execute an interrupt handler from RAM0 are the following: 1. Update the linker file (.icf) (see Figure 9). a) Define the address where the second vector table will be located: 0x2000 0000. b) Tell the linker to copy the section named .intvec_RAM0 at startup. 2. Update the startup file (see Figure 10) 3. Place the interrupt handlers to be executed in RAM0 in the new stm32F4xx_it_ram.c as described in Section : Executing a source file from RAM. 4. Remap the vector table to RAM0. To do this, modify the VTOR register in SystemInit function as following: SCB->VTOR = 0x2000 0000 | VECT_TAB_OFFSET Figure 10. Update of EWARM startup file to handle an interrupt 14/24 DocID026482 Rev 1 AN4515 2 Application note use case Application note use case This section describes the case developed in this application note through a block diagram and a state machine highlighting the different peripherals and the low-power modes that are used. Block diagram Figure 11 describes the different modules involved in the use case. Figure 11. Use case block diagram 670)[( /60/'+& &257(; 0 86%9LUWXDO&RP3RUW .% )ODVK $57 3&7HUPLQDO 'LVSOD\ 2.1 57& 3$ 7[ 8$57 3$ 5[ VDPSOHV $FFHOHURPHWHU ,& 3( ,17 .% 65$0 VWUHDP VWUHDP '0$ ,2V 18&/(2)5( 3$ 3$ 3$ 8VHUEXWWRQ 670)&',6&2 0VY9 DocID026482 Rev 1 15/24 23 Application note use case 2.2 AN4515 STM32F411xx used peripherals The application use case makes use of the below STM32F411xx peripherals: • Clocks Two clocks are used in this application: • – HSI: 16 MHz system clock source – LSE: 32.768 kHz low-speed external crystal which drives the RTC clock SysTick timer This timer is used for waiting loops or to generate timeouts (delays). • • GPIOs – PA0: used as user pushbutton and wakeup pin from Standby mode – PA3: set as a pin with interrupt on USART2_RX input to wakeup from Stop mode – PA4: set as an input pin with interrupt connected to the MEMS PE4 pin (INT1) on 32F401CDISCOVERY. This pin is used to wake up the CPU from Sleep mode. – PB8(I2C1_SCL) and PB9(I2C1_SDA) connected to MEMS PB6 and PB9 – When the microcontroller is in low-power mode, unused I/Os are placed in analog input mode to reduce power consumption. DMA1 DMA1 is used to transfer data while the CPU is in Sleep mode. • – Stream0: enabled for receiving data from I2C1 – Stream6: enabled for transmitting data to USART2 – Unused streams are disabled RTC The RTC is an independent timer/counter that provides a calendar with subseconds, seconds and minutes to generate timestamp events.It uses the LSE clock. • I2C1 The I2C1 interface receives data (11 samples) from the sensor at a speed up to 400 KHz. • USART2 The USART2 is used to transfer messages to USB virtual comport through the DMA. The USART2 is configured as follow: • – Word Length = 8 bits – Stop Bit = one Stop bit – Parity = without parity – Baud rate = 9600 bauds – Hardware flow control disabled (RTS and CTS signals) RAM A specific routine is executed from RAM when the Flash memory is switched off. 16/24 DocID026482 Rev 1 AN4515 2.3 Application note use case Functional description The principle of this use case is summarized in the state machine shown in Figure 12. Figure 12. Use case state machine 5HVHW 3$ 67'%< 581 3$ 6/((3 '0$7UDQVIHU 0(06/RRS &RPSOHWH '0$ 7UDQVIHU 2QJRLQJ 581 6/((3 '0$7UDQVIHU 2QJRLQJ '0$7UDQVIHU &RPSOHWH 6/((3 581 0(06(;7, 581 0(06(;7, 6723 581 8$57 5; (;7, 0(06(;7, 8$57 5; (;7, 581 6/((3 0(06(;7, /RZSRZHUPRGH 5XQPRGH %DWFK$FTXLVLWLRQ0RGH %$0 581 6/((3 '0$ 7UDQVIHU &RPSOHWH 6/((3 581 8$57 5; (;7, 8$57 5; (;7, '0$ 7UDQVIHU 2QJRLQJ 06Y9 The main steps of the application use case are the following: 1. The master and the sensor are powered on. By default the system is in STDBY state (Standby mode). 2. The user starts running the application by pushing the user button (PA0 on 32F401CDISCOVERY board).The CPU goes to SLEEP1 state while a DMA transfers startup message is displayed via USART2 and USB virtual comport. 3. When DMA transfers are complete, the CPU wakes up from SLEEP1 and enters STOP waiting for the user to read the configuration menu below (see Figure 13): 1: Flash active while CPU in sleep: Flash memory is running 2: Stop Flash while CPU in sleep: this configuration brings out the BAM feature. 3: Enable Time Stamp and Flash active while CPU in sleep: this option is used to track the different application state consumptions with using the period of each state displayed in timestamp log. 4: Enable Time Stamp and stop Flash while CPU in sleep: this option allows benefiting both from the second and third configurations. DocID026482 Rev 1 17/24 23 Application note use case AN4515 Figure 13. Startup and Configuration Menu 4. The system wakes up from Stop mode and enter SLEEP2 state waiting for the user to select the desired configuration. 5. Once the configuration is selected, an external interrupt on USART2_RX wakes up the CPU from Sleep mode. 6. The CPU enters Sleep mode again (SLEEP3 state) while a DMA transfers message is sent via USART2. 7. After a DMA transfer complete interrupt has been received, the CPU configures the MEMS and enters SLEEP4 state waiting for an accelerometer movement (UP or DOWN direction). The DMA sends the ### Move MEMS UP or DOWN ### message during Sleep mode. Figure 14. Wait MEMS movement while CPU is Sleep mode and Flash memory stopped 8. 18/24 After the MEMS has moved, the CPU wakes up from Sleep mode, configures the I2C interface and DMA to transfer samples coming from the MEMS. The DMA then starts DocID026482 Rev 1 AN4515 Application note use case sending data to the RAM while the Flash memory is stopped and the CPU goes back to Sleep mode (SLEEP5 state). 9. Once the DMA data transfer is complete, an interrupt wakes up the CPU to handle these data before it goes back to Sleep mode ((SLEEP6 state)). 10. While the CPU is in Sleep mode (SLEEP6 state) and the Flash memory is stopped, the DMA sends a complete log to the USART2 including MEMS direction and the timestamp (see Figure 15). Figure 15. Log example when configuration 4 is selected DocID026482 Rev 1 19/24 23 Application current consumption AN4515 3 Application current consumption 3.1 Hardware requirements Before running the application and measure the current consumption, connect your PC to the master and sensor as shown in Figure 16. Figure 16. Hardware environment 6HQVRU 7R PXOWLPHWHU 7R3& 0DVWHU 06Y9 The hardware required to run the application are the following: • Windows® PC • Two mini USB cables to power on the boards and to connect the Nucleo embedded STLINK for debugging and programming • Five connectors to link the 32F401CDISCOVERY pins with the corresponding Nucleo pins as described in Table 3. • A multimeter to measure current consumption. Table 3. Master and sensor board connection 20/24 NUCLEO-F411RE 32F401CDISCOVERY I2C SCL (PB8) I2C SCL (PB6) I2C SDA (PB9) I2C SDA (PB9) PA0 PA0 (USER button) PA4 PE4 (MEMS INT1 pin) GND GND DocID026482 Rev 1 AN4515 3.2 Application current consumption Software settings The measures below are taken using a code compiled with MDK-ARM toolchain V5.12 and with optimization Level3(-O3). 3.3 Measured current consumption This section compares the current consumptions obtained in the following conditions: • Flash memory stopped and CPU in Sleep mode • Flash memory active and the CPU in Sleep mode. Table 4 describes the average measures obtained for the MEMS loop part (SLEEP5, RUN7, SLEEP6 and RUN8) in the use case state machine. Table 4. Current consumption example Configuration Menu Active peripherals Current Consumption (uA) Flash active while CPU in sleep FLASH, RTC, USART2, DMA1(only stream0 and stream 6 enabled), I2C1 970 Stop Flash while CPU in sleep (BAM) RTC, USART2, DMA1(only stream0 and stream 6 enabled), I2C1 710 Table 4 shows a significant current consumption reduction of around 27 % obtained with the new STM32F411xx Stop Flash while CPU in Sleep feature (BAM). DocID026482 Rev 1 21/24 23 Conclusion 4 AN4515 Conclusion This application note complements the datasheets and reference manual by presenting a user guide on the new BAM implementation offered by STM32F411 line. A use case highlights the significant current consumption reduction obtained by using the BAM (Stop flash while CPU in sleep mode). It also allows assessing the different STM32F411xx low-power modes and, thanks to the timestamp log to, determining all state periods and calculating the application average consumption. 22/24 DocID026482 Rev 1 AN4515 5 Revision history Revision history Table 5. Document revision history Date Revision 19-Dec-2014 1 Changes Initial release. DocID026482 Rev 1 23/24 23 AN4515 IMPORTANT NOTICE – PLEASE READ CAREFULLY STMicroelectronics NV and its subsidiaries (“ST”) reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST’s terms and conditions of sale in place at the time of order acknowledgement. Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers’ products. No license, express or implied, to any intellectual property right is granted by ST herein. Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product. ST and the ST logo are trademarks of ST. All other product or service names are the property of their respective owners. Information in this document supersedes and replaces information previously supplied in any prior versions of this document. © 2014 STMicroelectronics – All rights reserved 24/24 DocID026482 Rev 1