

# AN3309 Application note

Clock configuration tool for STM32L microcontrollers

## Introduction

This application note presents the clock system configuration tool for the STM32L15xx microcontroller family.

This purpose of this tool is to help user configure the microcontroller clocks, taking into consideration the product parameters (power supply, product voltage range, the Flash access mode...).

The configuration tool is implemented in the "STM32L1xx\_Clock\_Configuration\_VX.Y.Z.xls" file which is supplied with this application note and can be downloaded from www.st.com.

It makes it easy to take care of all the following system aspects and interdependencies:

- Configure the system clock, HCLK source and output frequency.
- Configure the Core voltage range (V<sub>CORE</sub>).
- Configure the Flash latency (number of wait states depending on the HCLK frequency).
- Set the PCLK1, PCLK2 and TIMCLK (timer clocks) frequencies.
- Generate a ready-to-use system\_stm32l1xx.c file with all the above settings (STM32L15x CMSIS Cortex-M3 Device Peripheral Access Layer System Source File).
- *Note:* 1 The STM32L1xx\_Clock\_Configuration\_VX.Y.Z.xls is referred to as "Clock tool" throughout this document.
  - 2 Before using the Clock tool, it is essential to read the STM32L microcontroller reference manual (RM0038). This application note is not a substitute for the reference manual.

# Contents

| 1 | Glos | Glossary                                          |     |  |  |  |  |  |
|---|------|---------------------------------------------------|-----|--|--|--|--|--|
| 2 | Gett | ng started                                        | . 4 |  |  |  |  |  |
|   | 2.1  | Software requirements                             | . 4 |  |  |  |  |  |
|   | 2.2  | Hardware requirements                             | . 4 |  |  |  |  |  |
|   |      | 2.2.1 Introduction                                | . 4 |  |  |  |  |  |
|   |      | 2.2.2 Clock scheme for STM32L15x microcontrollers | . 5 |  |  |  |  |  |
| 3 | Tuto | ials                                              | . 8 |  |  |  |  |  |
|   | 3.1  | Wizard mode                                       |     |  |  |  |  |  |
|   | 3.2  | Expert mode                                       | 12  |  |  |  |  |  |
| 4 | Knov | Known limitations                                 |     |  |  |  |  |  |
| 5 | Con  | Conclusion                                        |     |  |  |  |  |  |
| 6 | Revi | Revision history                                  |     |  |  |  |  |  |



# 1 Glossary

#### Table 1.Definition of terms

| Term                           | Description               |  |
|--------------------------------|---------------------------|--|
| HCLK                           | AHB clock                 |  |
| PCLK1                          | APB1 clock                |  |
| PCLK2                          | APB2 clock                |  |
| TIMCLK                         | Timer clock               |  |
| USBCLK                         | USB clock                 |  |
| ADCCLK                         | ADC clock                 |  |
| F <sub>CPU</sub>               | Cortex-M3 clock           |  |
| V <sub>CORE</sub>              | Regulator output voltage  |  |
| V <sub>DD</sub>                | Power supply              |  |
| HSI                            | High speed internal clock |  |
| HSE                            | High speed external clock |  |
| MSI Multi-Speed internal clock |                           |  |



# 2 Getting started

This section describes the requirements and procedures needed to start using the Clock tool.

## 2.1 Software requirements

In order to use the Clock tool with Windows operating system, a recent version of Windows, such as Windows XP, Vista or Windows7 must be installed on the PC with at least 256 MB of RAM.

Before starting to use the Clock tool, make sure that Microsoft Office is installed on your machine and then follow these steps:

- Download the latest version of the **Clock tool** available from the ST website www.st.com.
- Enable macros and ActiveX controls:

Excel 1997-2003 version:

- a) Click Tools in the menu bar
- b) Click Macro
- c) Click Security
- d) Click Low (not recommended)

Note: If ActiveX controls are not enabled, a warning message is displayed asking you to enable ActiveX, in this case you should click "OK" to enable it.

#### Excel 2007 version:

- a) Click the Microsoft Office Button, and then click Excel options.
- b) Click Trust Center, click Trust center settings, and then click Macro settings.
- c) Click Enable all macros (not recommended, potentially dangerous code can run).
- d) Click Trust Center, click Trust center settings, and then click ActiveX settings.
- e) Click Enable all controls without restrictions and without prompting (not recommended; potentiality dangerous controls can run).
- f) Click **OK**.
- *Note:* For more information about how to enable macros and ActiveX controls please refer to the Microsoft Office website.

### 2.2 Hardware requirements

#### 2.2.1 Introduction

The Clock tool is designed to configure the system clocks and generate the *system\_stm32l1xx.c* file for STM32L15xx (Ultra low power medium-density) microcontrollers.



The system\_stm32l1xx.c file is provided as a template system clock configuration file which can be easily modified to select the corresponding system clock frequency, the  $V_{CORE}$  and also to configure the Flash latency.

#### 2.2.2 Clock scheme for STM32L15x microcontrollers

This section describes the system clock scheme, the voltage requirements (V<sub>DD</sub> and V<sub>CORE</sub>) versus the system clock frequency.

Four different clock sources can be used to drive the system clock (SYSCLK):

- HSI (16MHz) oscillator clock.
- HSE oscillator clock.
- PLL clock.
- MSI (65 KHz,131 KHz, 262 KHz, 524 KHz, 1 MHz, 2 MHz, 4 MHz) oscillator clock MSI Range 0 = 65.536 kHz.
  - MSI Range 1 = 131.072 kHz.
  - MSI Range 2 = 262.144 kHz.
  - MSI Range 3 = 524.288 kHz.
  - MSI Range 4 = 1048 kHz.
  - MSI Range 5 = 2097 kHz.
  - MSI Range 6 = 4194 kHz.







#### System clock source frequency versus V<sub>CORE</sub>

All the system clock sources depend on the  $V_{CORE}$  voltage range:

- **MSI**: this clock source can be used with all the  $V_{CORE}$  ranges (1.2 V, 1.5 V and 1.8 V (only when  $V_{DD} > 2$  V)).
- HSI: the HSI clock cannot be used when V<sub>CORE</sub> = 1.2 V (Range 3).
- HSE: the HSE clock frequency can range from 1 MHz (2 MHz when it is used as the PLL input clock) to 24 MHz using crystal oscillator (32 MHz using the external clock). The frequency must be chosen in accordance with the selected V<sub>CORE</sub> range. The maximum HSE frequency is:
  - 24 MHz when the  $V_{CORE}$  = 1.8 V (Range 1)
  - 16 MHz when the  $V_{CORE}$  = 1.5 V (Range 2)
  - 4 MHz when the  $V_{CORE}$  = 1.2 V (Range 3)
- PLL: the PLLVCO (defined by the PLL multiplication factor) also depends on the V<sub>CORE</sub> value since its maximum value is:
  - 96 MHz when V<sub>CORE</sub> = 1.8 V (Range 1)
  - 48 MHz when V<sub>CORE</sub> = 1.5 V (Range 2)
  - 24 MHz when V<sub>CORE</sub> = 1.2 V (Range 3)

When using PLL as system clock source the input clock frequency must be between 2 MHz and 24 MHz.

If the USB interface is used in the application, the PLLVCO must be programmed to output a 96 MHz frequency. This is required to provide a 48 MHz clock to the USB interface since the USBCLK is equal to PLLVCO divided by 2. For accuracy reasons, the USB peripheral must only be driven by the PLL configured with the HSE clock source.

Note: When V<sub>CORE</sub> Range 3 (V<sub>CORE</sub> = 1.2 V) is selected, the ADC peripheral can only operate at low speed sampling frequency (ADCCLK = 4 MHz, 250 ksps) and the ADC prescaler must be set to 4.



#### STM32L15xx performance versus V<sub>DD</sub> and V<sub>CORE</sub> range

The number of Flash memory wait states (latency) is defined according to the frequency of the CPU (Cortex-M3) and indirectly by the supply voltage of the device ( $V_{DD}$ ):

- If V<sub>CORE</sub> = 1.8 V (Range 1):
  - 0 Flash wait states are required when the CPU frequency is less than or equal to 16 MHz
  - 1 Flash wait state is required when the CPU frequency is greater than 16 MHz
- If V<sub>CORE</sub> = 1.5 V (Range 2)
  - 0 Flash wait states are required when the CPU frequency is less than or equal to 8MHz
  - 1 Flash wait state is required when the CPU frequency is greater than 8 MHz
- If V<sub>CORE</sub> = 1.2 V (Range 3)
  - O Flash wait states are required when the CPU frequency is less than or equal to 2 MHz
  - 1 Flash wait state is required when the CPU frequency is higher than 2 MHz

Refer to *Figure 2: STM32L15xx performance versus*  $V_{DD}$  *and*  $V_{CORE}$  *range on page 7* for a description of the STM32L15xx operating conditions versus the  $V_{CORE}$ .







## 3 Tutorials

This section describes step by step how to use the Clock tool to configure all the system clocks and generate the *system\_stm32l1xx.c* file.

Two modes are available: **Wizard** and **Expert**. The selection is made in the **Configuration mode** list box.

## 3.1 Wizard mode

This mode (default mode) guides you through a series of steps to obtain the desired clock system configuration quickly and easily.



#### Figure 3. Wizard mode user interface

Note: 1 The View button is used to activate or deactivate viewing the xls file in full screen mode.

- 2 The **Reset** button is used to set the system clock to the default configuration:
  - MSI (Range 5) as system clock source
  - $-V_{DD} = 3.3 V$
  - $V_{CORE} = 1.5 V$
  - Flash Latency (WS) = 0
  - HCLK = 2000 KHz
  - AHB, APB1 and APB2 prescalers are set to 1
  - HSE Clock value is 8 MHz





#### Step-by-step procedure:

 Enter the V<sub>DD</sub> power supply voltage range between 1.65 V and 3. V. Refer to *Figure 3: Wizard mode user interface*). If the V<sub>DD</sub> voltage is out of range, an error message will be displayed as shown in *Figure 4*.

#### Figure 4. V<sub>DD</sub> out of range



2. If the HSE is used in your application, set its frequency between:

- A minimum of 1 MHz or 2 MHz if is used as the PLL input clock
- A maximum of 24 MHz if a crystal oscillator is used.

If the frequency you entered is out of range, an error message is displayed, as shown in *Figure 5*. You then have to enter a valid frequency.

#### Figure 5. HSE value out of range

| HSE Free | juency 🔀                                   |
|----------|--------------------------------------------|
| (į)      | HSE value should be between 1MHz and 24MHz |
|          | ОК                                         |

- 3. Specify if a 48 MHz clock is needed for USB operation. If yes, this will add a constraint to the parameter setting in the PLL configuration. The USB can be used only when  $V_{CORE}$  is equal to 1.8 V and  $V_{DD}$  is equal to at least 2 V.
- Set the HCLK (AHB clock) frequency in KHz. The maximum frequency of HCLK depends on V<sub>CORE</sub> and also the Flash latency, and must be less than 32 MHz. In this Clock Tool, the following MSI values are used:
  - 65 KHz instead of 65536 Hz
  - 131 KHz instead of 131072 Hz
  - 262 KHz instead of 262144 Hz
  - 524 KHz instead of 524288 Hz
  - 1000 KHz instead of 1048 KHz
  - 2000 KHz instead of 2097 KHz
  - 4000 KHz instead of 4191 KHz

If the entered value is higher than 32 MHz an error message will be displayed as shown in *Figure 6*.







- 5. Select the APB1 prescaler settings from the list box to obtain the desired PCLK1 frequency. The timer clock (TIMCLK) frequencies are configured automatically depending on the APB1 prescaler settings.
- 6. Select the APB2 prescaler settings from the list box to obtain the desired PCLK2 frequency. The timer clock (TIMCLK) frequencies are configured automatically depending on the APB2 prescaler settings.
- 7. Click on the **RUN** button.
  - A message box is then displayed requesting you to select the V<sub>CORE</sub> value and the number of wait states (the selection list depends on the desired HCLK frequency)

Figure 7. Define the V<sub>CORE</sub> range and the number of Flash wait states



Note:

- When  $V_{CORE}$  Range 3 ( $V_{CORE} = 1.2 V$ ) is selected, the ADC can only operate at low speed sampling frequency (ADCCLK = 4 MHz, 250 ksps) and the ADC prescaler must be set to 4.
  - Check if the requirements you defined above can be achieved.

If yes, a message box is displayed, requesting you to select the clock source as shown in *Figure 8*. You can choose HSE, MSI, HSI or PLL (sourced by HSI or HSE).

#### Figure 8. Select the clock source

| Please select the system clock source 🔀 |
|-----------------------------------------|
| • MSI as system clock source            |
| C HSI as system clock source            |
| C HSE as system clock source            |
| C PLL[HSI] as system clock source       |
| C PLL[HSE] as system clock source       |
| ОК                                      |

Otherwise, a selection error message is displayed indicating if there is a conflicting requirement. You then have to change the requirements to resolve the conflict.







8. Finally, click on the **Generate** button to generate the *system\_stm32l1xx.c* file automatically.

The *system\_stm32l1xx.c* is generated in the same location as the Clock tool. You can display the file to verify the value of the system clock *SystemCoreClock* and also the value of AHB, APB1, APB2, the Flash access mode, V<sub>CORE</sub> and other parameters which are defined in the *SetSysClock* function.

The system\_stm32l1xx.c file must be added to the working project to be built.

If the file is not generated, an error message is displayed as shown in Figure 10.

Figure 10. File generation error

| Generat | te file 🛛 🔀                                                                                                                          |
|---------|--------------------------------------------------------------------------------------------------------------------------------------|
| 8       | The <:system_stm32l1xx.c:> system clock configuration file is not generated, Run the application first then try to generate the file |
|         | ОК                                                                                                                                   |



## 3.2 Expert mode

This mode provides more flexibility in the configuration but it is up to the user to ensure the configuration correctness.

Several steps should be followed *Figure 11: Expert mode user interface*:

#### Figure 11. Expert mode user interface



Note: 1 The View button is used to activate or deactivate viewing the xls file in full screen mode.

- 2 The **Reset** button is used to set the system clock to the default configuration:
  - MSI (Range 5) as system clock source
  - $V_{DD} = 3.3 V$
  - V<sub>CORE</sub> = 1.5 V
  - Flash Latency (WS) = 0
  - HCLK = 2000 KHz
  - AHB, APB1 and APB2 prescalers are set to 1
  - HSE Clock value is 8 MHz

#### Step-by-step procedure

- 1. Enter the V<sub>DD</sub> power supply voltage range between 1.65 V and 3.6 V. Refer to *Figure 11: Expert mode user interface*).
- 2. Set the V<sub>CORE</sub> to 1.2 V, 1.5 V or 1.8 V (depending on the V<sub>DD</sub> value).



# Note: When V<sub>DD</sub> < 2 V, Range 1 (V<sub>CORE</sub> = 1.8V) is not available. When V<sub>CORE</sub> = 1.2 V (Range 3), the ADC can only operate at low speed sampling frequency (ADCCLK = 4 MHz, 250 cusps) and the ADC prescaler should be set to 4. 3. Configure the Flash memory latency from the Flash wait state list box. 4. If the HSE is used in your application, set its frequency between:

- A minimum of 1 MHz or 2 MHz if it is used as the PLL input clock
  - A maximum of frequency which is determined by the V<sub>CORE</sub> range previously selected in step 2 above.

If the frequency you entered is out of range, the Clock Tool automatically restores the last correct HSE clock value.

- With V<sub>COBE</sub> = 1.2 V (Range 3) the maximum HSE frequency is 4 MHz
- With V<sub>CORE</sub> = 1.5 V (Range 2), the maximum HSE frequency is 16 MHz
- with V<sub>CORE</sub> = 1.8 V (Range 1), the maximum HSE frequency is 24 MHz
- Configure the System clock source (PLL, MSI, HSE or HSI). If you select PLL as System clock source you also have to select the source clock for the PLL (HSE or HSI). If the clock source selection is invalid (the HCLK frequency is too high) an error message is displayed as shown in *Figure 12*.

#### Figure 12. HCLK frequency too high

| HCKL frequency value out of range          |  |  |  |  |  |  |
|--------------------------------------------|--|--|--|--|--|--|
| scaler value or other system configuration |  |  |  |  |  |  |
|                                            |  |  |  |  |  |  |
|                                            |  |  |  |  |  |  |

6. Configure the AHB prescaler using the **AHB Prescaler** list box to obtain the desired HCLK frequency.

If the HCLK frequency is too high, an error message as shown in Figure 12.

- Select the APB1 prescaler settings from the list box to obtain the desired PCLK1 frequency. The timer clock (TIMCLK) frequencies are configured automatically depending on the APB1 prescaler settings.
- 8. Select the APB2 prescaler settings from the list box to obtain the desired PCLK2 frequency. The timer clock (TIMCLK) frequencies are configured automatically depending on the APB2 prescaler settings.
- 9. Finally, click on the **Generate** button to generate the *system\_stm32l1xx.c* file automatically.

The *system\_stm32l1xx.c* file is generated in the same location as the Clock tool. You can display the file to verify the value of the system clock "SystemCoreClock" and also the value of AHB, APB1, APB2, the Flash access mode, V<sub>CORE</sub>and other parameters which are defined in the "SetSysClock" function.

#### The system\_stm32l1xx.c file must be added to the working project to be built.



# 4 Known limitations

This sections describes the known limitations of the system clock configuration tool (Clock tool):

- This tool does not support configurations that use HSE external clock source.
- This tool does not support the fractional value of the HSE.



# 5 Conclusion

This application note provides a description of how to use the Clock tool for the STM32L1xx microcontroller devices. Using either one of the two configuration modes, this tool generates a source code file *system\_stm32l1xx.c* to configure the clock system of the STM32L.

Wizard mode is the first mode and provides a quick and easy way to configure the system clocks.

Expert mode is the second mode. It gives you more flexibility in setting up the system clock configuration while still respecting all the product constraints.



# 6 Revision history

#### Table 2.Document revision history

| Date        | Revision | Changes          |
|-------------|----------|------------------|
| 03-Jan-2011 | 1        | Initial release. |



#### Please Read Carefully:

Information in this document is provided solely in connection with ST products. STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, modifications or improvements, to this document, and the products and services described herein at any time, without notice.

All ST products are sold pursuant to ST's terms and conditions of sale.

Purchasers are solely responsible for the choice, selection and use of the ST products and services described herein, and ST assumes no liability whatsoever relating to the choice, selection or use of the ST products and services described herein.

No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted under this document. If any part of this document refers to any third party products or services it shall not be deemed a license grant by ST for the use of such third party products or services, or any intellectual property contained therein or considered as a warranty covering the use in any manner whatsoever of such third party products or services or any intellectual property contained therein.

UNLESS OTHERWISE SET FORTH IN ST'S TERMS AND CONDITIONS OF SALE ST DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY WITH RESPECT TO THE USE AND/OR SALE OF ST PRODUCTS INCLUDING WITHOUT LIMITATION IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE (AND THEIR EQUIVALENTS UNDER THE LAWS OF ANY JURISDICTION), OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT.

UNLESS EXPRESSLY APPROVED IN WRITING BY AN AUTHORIZED ST REPRESENTATIVE, ST PRODUCTS ARE NOT RECOMMENDED, AUTHORIZED OR WARRANTED FOR USE IN MILITARY, AIR CRAFT, SPACE, LIFE SAVING, OR LIFE SUSTAINING APPLICATIONS, NOR IN PRODUCTS OR SYSTEMS WHERE FAILURE OR MALFUNCTION MAY RESULT IN PERSONAL INJURY, DEATH, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE. ST PRODUCTS WHICH ARE NOT SPECIFIED AS "AUTOMOTIVE GRADE" MAY ONLY BE USED IN AUTOMOTIVE APPLICATIONS AT USER'S OWN RISK.

Resale of ST products with provisions different from the statements and/or technical features set forth in this document shall immediately void any warranty granted by ST for the ST product or service described herein and shall not create or extend in any manner whatsoever, any liability of ST.

ST and the ST logo are trademarks or registered trademarks of ST in various countries.

Information in this document supersedes and replaces all information previously supplied.

The ST logo is a registered trademark of STMicroelectronics. All other names are the property of their respective owners.

© 2011 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



Doc ID 18200 Rev 1