STM8S/A Standard Peripherals Firmware Library: CSS (Clock security system) capability

STM8S/A

CSS (Clock security system) capability
  ******************** (C)COPYRIGHT 2014 STMicroelectronics *******************
  * @file    CLK/CLK_ClockSecuritySystem/readme.txt
  * @author  MCD Application Team
  * @version V2.2.0
  * @date    30-September-2014
  * @brief   This file contains the main function for Clock Security System example.
  ******************************************************************************
  *
  * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License");
  * You may not use this file except in compliance with the License.
  * You may obtain a copy of the License at:
  *
  *        http://www.st.com/software_license_agreement_liberty_v2
  *
  * Unless required by applicable law or agreed to in writing, software 
  * distributed under the License is distributed on an "AS IS" BASIS, 
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  * See the License for the specific language governing permissions and
  * limitations under the License.
  *
  ******************************************************************************
  
Example description

This example demonstrates the CSS (Clock Security System) capability. The MCU clock system is configured as follows:

  • HSI Prescaler = CLK_PRESCALER_HSIDIV8;
  • Switch Mode = CLK_SWITCHMODE_AUTO
  • New Clock = CLK_SOURCE_HSE;
  • Current Clock State = CLK_CURRENTCLOCKSTATE_DISABLE;
  • CSS = ENABLE
  • When detecting the change of clock from HSE to HSI/8 (auxilary), LEDs blinking frequency becomes slower.
Directory contents
Hardware and Software environment
  • This example runs on STM8S and STM8A High density, Medium density and Low density devices.
  • This example has been tested with STMicroelectronics STM8/128-EVAL evaluation board and can be easily tailored to any other development board.
  • STM8/128-EVAL Set-up
    • LD1..LD4
How to use it ?

In order to make the program work, you must do the following :

  • Copy all source files from this example folder to the template folder under Project
  • Open your preferred toolchain
  • Rebuild all files and load your image into target memory
  • Run the example
  • Observe the initial device frequency setting (HSE) on LED1, 2, 3, 4 of the Evaluation board (fast blinking frequency).
  • Disconnect the crystal. The system clock will then switch to HSI backup clock as the CSS is enabled.
  • The CPU is still processing operations but the frequency has changed to HSI/8 (CSS default clock): LED1, 2, 3, 4 are toggling at another frequency (Slower).
  • The clock switching can be monitored by putting a scope on PE0 (CCO pin).
Hint
  • Before using the HSE clock make sure that the "Flash_Wait_States" is set to 1.
    • with STVD (menu: Debug Instrument -> MCU configuration -> Options -> Flash_Wait_States: 1)
    • with RIDE (edit the "STM8_OB.asm" file to configure OPT7 & NOPT7 option bytes)
    • with EWSTM8 (menu: ST-LINK -> Option bytes ->Flash_Wait_States: 1)
Note:
  • High-Density STM8A devices are the STM8AF52xx STM8AF6269/8x/Ax, STM8AF51xx, and STM8AF6169/7x/8x/9x/Ax microcontrollers where the Flash memory density ranges between 32 to 128 Kbytes
  • Medium-Density STM8A devices are the STM8AF622x/4x, STM8AF6266/68, STM8AF612x/4x, and STM8AF6166/68 microcontrollers where the Flash memory density ranges between 8 to 32 Kbytes
  • High-Density STM8S devices are the STM8S207xx, STM8S007 and STM8S208xx microcontrollers where the Flash memory density ranges between 32 to 128 Kbytes.
  • Medium-Density STM8S devices are the STM8S105x and STM8S005 microcontrollers where the Flash memory density ranges between 16 to 32-Kbytes.
  • Low-Density STM8S devices are the STM8S103xx, STM8S003 and STM8S903xx microcontrollers where the Flash density is 8 Kbytes.

© COPYRIGHT STMicroelectronics

STM8 Standard Peripherals Library: Footer

 

 

 

      For complete documentation on STM8 8-bit Microcontrollers platform visit www.st.com