mirror of
				https://github.com/FreeRTOS/FreeRTOS-Kernel.git
				synced 2025-10-25 06:07:49 -04:00 
			
		
		
		
	Add STM32L Discovery board project as a starting point to adapt to an RTOS demo.
This commit is contained in:
		
							parent
							
								
									417c3d1054
								
							
						
					
					
						commit
						b89fd7c1e3
					
				
					 139 changed files with 71905 additions and 0 deletions
				
			
		|  | @ -0,0 +1,463 @@ | |||
| ;/******************** (C) COPYRIGHT 2012 STMicroelectronics ********************
 | ||||
| ;* File Name          : startup_stm32l1xx_md.s
 | ||||
| ;* Author             : MCD Application Team
 | ||||
| ;* Version            : V1.1.1
 | ||||
| ;* Date               : 09-March-2012
 | ||||
| ;* Description        : STM32L1xx Ultra Low Power Medium-density Devices vector 
 | ||||
| ;*                      table for EWARM toolchain.
 | ||||
| ;*                      This module performs:
 | ||||
| ;*                      - Set the initial SP
 | ||||
| ;*                      - Set the initial PC == __iar_program_start,
 | ||||
| ;*                      - Set the vector table entries with the exceptions ISR 
 | ||||
| ;*                        address.
 | ||||
| ;*                      After Reset the Cortex-M3 processor is in Thread mode,
 | ||||
| ;*                      priority is Privileged, and the Stack is set to Main.
 | ||||
| ;********************************************************************************
 | ||||
| ;* 
 | ||||
| ;* 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.
 | ||||
| ;* 
 | ||||
| ;*******************************************************************************/
 | ||||
| ;
 | ||||
| ;
 | ||||
| ; The modules in this file are included in the libraries, and may be replaced
 | ||||
| ; by any user-defined modules that define the PUBLIC symbol _program_start or
 | ||||
| ; a user defined start symbol.
 | ||||
| ; To override the cstartup defined in the library, simply add your modified
 | ||||
| ; version to the workbench project.
 | ||||
| ;
 | ||||
| ; The vector table is normally located at address 0.
 | ||||
| ; When debugging in RAM, it can be located in RAM, aligned to at least 2^6.
 | ||||
| ; The name "__vector_table" has special meaning for C-SPY:
 | ||||
| ; it is where the SP start value is found, and the NVIC vector
 | ||||
| ; table register (VTOR) is initialized to this address if != 0.
 | ||||
| ;
 | ||||
| ; Cortex-M version
 | ||||
| ;
 | ||||
| 
 | ||||
|         MODULE  ?cstartup | ||||
| 
 | ||||
|         ;; Forward declaration of sections.
 | ||||
|         SECTION CSTACK:DATA:NOROOT(3) | ||||
| 
 | ||||
|         SECTION .intvec:CODE:NOROOT(2) | ||||
| 
 | ||||
|         EXTERN  __iar_program_start | ||||
|         EXTERN  SystemInit         | ||||
|         PUBLIC  __vector_table | ||||
| 
 | ||||
|         DATA | ||||
| __vector_table | ||||
|         DCD     sfe(CSTACK) | ||||
|         DCD     Reset_Handler             ; Reset Handler
 | ||||
| 
 | ||||
|         DCD     NMI_Handler               ; NMI Handler
 | ||||
|         DCD     HardFault_Handler         ; Hard Fault Handler
 | ||||
|         DCD     MemManage_Handler         ; MPU Fault Handler
 | ||||
|         DCD     BusFault_Handler          ; Bus Fault Handler
 | ||||
|         DCD     UsageFault_Handler        ; Usage Fault Handler
 | ||||
|         DCD     0                         ; Reserved
 | ||||
|         DCD     0                         ; Reserved
 | ||||
|         DCD     0                         ; Reserved
 | ||||
|         DCD     0                         ; Reserved
 | ||||
|         DCD     SVC_Handler               ; SVCall Handler
 | ||||
|         DCD     DebugMon_Handler          ; Debug Monitor Handler
 | ||||
|         DCD     0                         ; Reserved
 | ||||
|         DCD     PendSV_Handler            ; PendSV Handler
 | ||||
|         DCD     SysTick_Handler           ; SysTick Handler
 | ||||
| 
 | ||||
|          ; External Interrupts
 | ||||
|         DCD     WWDG_IRQHandler           ; Window Watchdog
 | ||||
|         DCD     PVD_IRQHandler            ; PVD through EXTI Line detect
 | ||||
|         DCD     TAMPER_STAMP_IRQHandler   ; Tamper and Time Stamp
 | ||||
|         DCD     RTC_WKUP_IRQHandler       ; RTC Wakeup
 | ||||
|         DCD     FLASH_IRQHandler          ; FLASH
 | ||||
|         DCD     RCC_IRQHandler            ; RCC
 | ||||
|         DCD     EXTI0_IRQHandler          ; EXTI Line 0
 | ||||
|         DCD     EXTI1_IRQHandler          ; EXTI Line 1
 | ||||
|         DCD     EXTI2_IRQHandler          ; EXTI Line 2
 | ||||
|         DCD     EXTI3_IRQHandler          ; EXTI Line 3
 | ||||
|         DCD     EXTI4_IRQHandler          ; EXTI Line 4
 | ||||
|         DCD     DMA1_Channel1_IRQHandler  ; DMA1 Channel 1
 | ||||
|         DCD     DMA1_Channel2_IRQHandler  ; DMA1 Channel 2
 | ||||
|         DCD     DMA1_Channel3_IRQHandler  ; DMA1 Channel 3
 | ||||
|         DCD     DMA1_Channel4_IRQHandler  ; DMA1 Channel 4
 | ||||
|         DCD     DMA1_Channel5_IRQHandler  ; DMA1 Channel 5
 | ||||
|         DCD     DMA1_Channel6_IRQHandler  ; DMA1 Channel 6
 | ||||
|         DCD     DMA1_Channel7_IRQHandler  ; DMA1 Channel 7
 | ||||
|         DCD     ADC1_IRQHandler           ; ADC1
 | ||||
|         DCD     USB_HP_IRQHandler         ; USB High Priority
 | ||||
|         DCD     USB_LP_IRQHandler         ; USB Low  Priority
 | ||||
|         DCD     DAC_IRQHandler            ; DAC
 | ||||
|         DCD     COMP_IRQHandler           ; COMP through EXTI Line
 | ||||
|         DCD     EXTI9_5_IRQHandler        ; EXTI Line 9..5
 | ||||
|         DCD     LCD_IRQHandler            ; LCD
 | ||||
|         DCD     TIM9_IRQHandler           ; TIM9
 | ||||
|         DCD     TIM10_IRQHandler          ; TIM10
 | ||||
|         DCD     TIM11_IRQHandler          ; TIM11
 | ||||
|         DCD     TIM2_IRQHandler           ; TIM2
 | ||||
|         DCD     TIM3_IRQHandler           ; TIM3
 | ||||
|         DCD     TIM4_IRQHandler           ; TIM4
 | ||||
|         DCD     I2C1_EV_IRQHandler        ; I2C1 Event
 | ||||
|         DCD     I2C1_ER_IRQHandler        ; I2C1 Error
 | ||||
|         DCD     I2C2_EV_IRQHandler        ; I2C2 Event
 | ||||
|         DCD     I2C2_ER_IRQHandler        ; I2C2 Error
 | ||||
|         DCD     SPI1_IRQHandler           ; SPI1
 | ||||
|         DCD     SPI2_IRQHandler           ; SPI2
 | ||||
|         DCD     USART1_IRQHandler         ; USART1
 | ||||
|         DCD     USART2_IRQHandler         ; USART2
 | ||||
|         DCD     USART3_IRQHandler         ; USART3
 | ||||
|         DCD     EXTI15_10_IRQHandler      ; EXTI Line 15..10
 | ||||
|         DCD     RTC_Alarm_IRQHandler      ; RTC Alarm through EXTI Line
 | ||||
|         DCD     USB_FS_WKUP_IRQHandler    ; USB FS Wakeup from suspend
 | ||||
|         DCD     TIM6_IRQHandler           ; TIM6
 | ||||
|         DCD     TIM7_IRQHandler           ; TIM7
 | ||||
|          | ||||
| ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
 | ||||
| ;;
 | ||||
| ;; Default interrupt handlers.
 | ||||
| ;;
 | ||||
|         THUMB | ||||
| 
 | ||||
|         PUBWEAK Reset_Handler | ||||
|         SECTION .text:CODE:REORDER(2) | ||||
| Reset_Handler | ||||
|         LDR     R0, =SystemInit | ||||
|         BLX     R0 | ||||
|         LDR     R0, =__iar_program_start | ||||
|         BX      R0 | ||||
|          | ||||
|         PUBWEAK NMI_Handler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| NMI_Handler | ||||
|         B NMI_Handler | ||||
|          | ||||
|          | ||||
|         PUBWEAK HardFault_Handler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| HardFault_Handler | ||||
|         B HardFault_Handler | ||||
|          | ||||
|          | ||||
|         PUBWEAK MemManage_Handler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| MemManage_Handler | ||||
|         B MemManage_Handler | ||||
|          | ||||
|                  | ||||
|         PUBWEAK BusFault_Handler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| BusFault_Handler | ||||
|         B BusFault_Handler | ||||
|          | ||||
|          | ||||
|         PUBWEAK UsageFault_Handler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| UsageFault_Handler | ||||
|         B UsageFault_Handler | ||||
|          | ||||
|          | ||||
|         PUBWEAK SVC_Handler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| SVC_Handler | ||||
|         B SVC_Handler | ||||
|          | ||||
|          | ||||
|         PUBWEAK DebugMon_Handler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| DebugMon_Handler | ||||
|         B DebugMon_Handler | ||||
|          | ||||
|          | ||||
|         PUBWEAK PendSV_Handler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| PendSV_Handler | ||||
|         B PendSV_Handler | ||||
|          | ||||
|          | ||||
|         PUBWEAK SysTick_Handler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| SysTick_Handler | ||||
|         B SysTick_Handler | ||||
|          | ||||
|          | ||||
|         PUBWEAK WWDG_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| WWDG_IRQHandler | ||||
|         B WWDG_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK PVD_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| PVD_IRQHandler | ||||
|         B PVD_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK TAMPER_STAMP_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| TAMPER_STAMP_IRQHandler | ||||
|         B TAMPER_STAMP_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK RTC_WKUP_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| RTC_WKUP_IRQHandler | ||||
|         B RTC_WKUP_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK FLASH_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| FLASH_IRQHandler | ||||
|         B FLASH_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK RCC_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| RCC_IRQHandler | ||||
|         B RCC_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK EXTI0_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| EXTI0_IRQHandler | ||||
|         B EXTI0_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK EXTI1_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| EXTI1_IRQHandler | ||||
|         B EXTI1_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK EXTI2_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| EXTI2_IRQHandler | ||||
|         B EXTI2_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK EXTI3_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| EXTI3_IRQHandler | ||||
|         B EXTI3_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK EXTI4_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| EXTI4_IRQHandler | ||||
|         B EXTI4_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK DMA1_Channel1_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| DMA1_Channel1_IRQHandler | ||||
|         B DMA1_Channel1_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK DMA1_Channel2_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| DMA1_Channel2_IRQHandler | ||||
|         B DMA1_Channel2_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK DMA1_Channel3_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| DMA1_Channel3_IRQHandler | ||||
|         B DMA1_Channel3_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK DMA1_Channel4_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| DMA1_Channel4_IRQHandler | ||||
|         B DMA1_Channel4_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK DMA1_Channel5_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| DMA1_Channel5_IRQHandler | ||||
|         B DMA1_Channel5_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK DMA1_Channel6_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| DMA1_Channel6_IRQHandler | ||||
|         B DMA1_Channel6_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK DMA1_Channel7_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| DMA1_Channel7_IRQHandler | ||||
|         B DMA1_Channel7_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK ADC1_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| ADC1_IRQHandler | ||||
|         B ADC1_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK USB_HP_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| USB_HP_IRQHandler | ||||
|         B USB_HP_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK USB_LP_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| USB_LP_IRQHandler | ||||
|         B USB_LP_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK DAC_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| DAC_IRQHandler | ||||
|         B DAC_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK COMP_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| COMP_IRQHandler | ||||
|         B COMP_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK EXTI9_5_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| EXTI9_5_IRQHandler | ||||
|         B EXTI9_5_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK LCD_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| LCD_IRQHandler | ||||
|         B LCD_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK TIM9_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| TIM9_IRQHandler | ||||
|         B TIM9_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK TIM10_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| TIM10_IRQHandler | ||||
|         B TIM10_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK TIM11_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| TIM11_IRQHandler | ||||
|         B TIM11_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK TIM2_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| TIM2_IRQHandler | ||||
|         B TIM2_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK TIM3_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| TIM3_IRQHandler | ||||
|         B TIM3_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK TIM4_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| TIM4_IRQHandler | ||||
|         B TIM4_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK I2C1_EV_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| I2C1_EV_IRQHandler | ||||
|         B I2C1_EV_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK I2C1_ER_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| I2C1_ER_IRQHandler | ||||
|         B I2C1_ER_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK I2C2_EV_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| I2C2_EV_IRQHandler | ||||
|         B I2C2_EV_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK I2C2_ER_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| I2C2_ER_IRQHandler | ||||
|         B I2C2_ER_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK SPI1_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| SPI1_IRQHandler | ||||
|         B SPI1_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK SPI2_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| SPI2_IRQHandler | ||||
|         B SPI2_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK USART1_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| USART1_IRQHandler | ||||
|         B USART1_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK USART2_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| USART2_IRQHandler | ||||
|         B USART2_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK USART3_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| USART3_IRQHandler | ||||
|         B USART3_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK EXTI15_10_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| EXTI15_10_IRQHandler | ||||
|         B EXTI15_10_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK RTC_Alarm_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| RTC_Alarm_IRQHandler | ||||
|         B RTC_Alarm_IRQHandler | ||||
|          | ||||
|          | ||||
|         PUBWEAK USB_FS_WKUP_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| USB_FS_WKUP_IRQHandler | ||||
|         B USB_FS_WKUP_IRQHandler | ||||
|          | ||||
| 
 | ||||
|         PUBWEAK TIM6_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| TIM6_IRQHandler | ||||
|         B TIM6_IRQHandler | ||||
|          | ||||
| 
 | ||||
|         PUBWEAK TIM7_IRQHandler | ||||
|         SECTION .text:CODE:REORDER(1) | ||||
| TIM7_IRQHandler | ||||
|         B TIM7_IRQHandler                 | ||||
| 
 | ||||
|         END | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -0,0 +1,367 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    system_stm32l1xx.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.0.3 | ||||
|   * @date    May-2013 | ||||
|   * @brief   CMSIS Cortex-M3 Device Peripheral Access Layer System Source File. | ||||
|   *          This file contains the system clock configuration for STM32L1xx Ultra | ||||
|   *          Low Medium-density devices, and is generated by the clock configuration | ||||
|   *          tool "STM32L1xx_Clock_Configuration_V1.0.0.xls". | ||||
|   *              | ||||
|   * 1.  This file provides two functions and one global variable to be called from  | ||||
|   *     user application: | ||||
|   *      - SystemInit(): Setups the system clock (System clock source, PLL Multiplier | ||||
|   *                      and Divider factors, AHB/APBx prescalers and Flash settings), | ||||
|   *                      depending on the configuration made in the clock xls tool.  | ||||
|   *                      This function is called at startup just after reset and  | ||||
|   *                      before branch to main program. This call is made inside | ||||
|   *                      the "startup_stm32l1xx_md.s" file. | ||||
|   *                         | ||||
|   *      - SystemCoreClock variable: Contains the core clock (HCLK), it can be used | ||||
|   *                                  by the user application to setup the SysTick  | ||||
|   *                                  timer or configure other parameters. | ||||
|   *                                      | ||||
|   *      - SystemCoreClockUpdate(): Updates the variable SystemCoreClock and must | ||||
|   *                                 be called whenever the core clock is changed | ||||
|   *                                 during program execution.    | ||||
|   *       | ||||
|   * 2. After each device reset the MSI (2.1 MHz Range) is used as system clock source. | ||||
|   *    Then SystemInit() function is called, in "startup_stm32l1xx_md.s" file, to | ||||
|   *    configure the system clock before to branch to main program.     | ||||
|   *     | ||||
|   * 3. If the system clock source selected by user fails to startup, the SystemInit() | ||||
|   *    function will do nothing and MSI still used as system clock source. User can  | ||||
|   *    add some code to deal with this issue inside the SetSysClock() function.        | ||||
|   *  | ||||
|   * 4. The default value of HSE crystal is set to 8MHz, refer to "HSE_VALUE" define | ||||
|   *    in "stm32l1xx.h" file. When HSE is used as system clock source, directly or | ||||
|   *    through PLL, and you are using different crystal you have to adapt the HSE | ||||
|   *    value to your own configuration. | ||||
|   *  | ||||
|   * 5. This file configures the system clock as follows:   | ||||
|   *============================================================================= | ||||
|   *                         System Clock Configuration | ||||
|   *============================================================================= | ||||
|   *        System clock source          | HSI | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        SYSCLK                       | 16000000 Hz | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        HCLK                         | 16000000 Hz | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        AHB Prescaler                | 1 | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        APB1 Prescaler               | 1 | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        APB2 Prescaler               | 1 | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        HSE Frequency                | 8000000 Hz | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        PLL DIV                      | Not Used | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        PLL MUL                      | Not Used | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        VDD                          | 3.3 V | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        Vcore                        | 1.8 V (Range 1) | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        Flash Latency                | 0 WS | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *        Require 48MHz for USB clock  | Disabled | ||||
|   *-----------------------------------------------------------------------------  | ||||
|   *============================================================================= | ||||
|   ******************************************************************************  | ||||
|   * @attention | ||||
|   * | ||||
|   * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS | ||||
|   * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE | ||||
|   * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY | ||||
|   * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING | ||||
|   * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE | ||||
|   * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS. | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2010 STMicroelectronics</center></h2> | ||||
|   ******************************************************************************   | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup CMSIS
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup stm32l1xx_system
 | ||||
|   * @{ | ||||
|   */   | ||||
|    | ||||
| /** @addtogroup STM32L1xx_System_Private_Includes
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_System_Private_TypesDefinitions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_System_Private_Defines
 | ||||
|   * @{ | ||||
|   */ | ||||
| /*!< Uncomment the following line if you need to relocate your vector Table in
 | ||||
|      Internal SRAM. */  | ||||
| /* #define VECT_TAB_SRAM */ | ||||
| #define VECT_TAB_OFFSET  0x0 /*!< Vector Table base offset field.  | ||||
|                                   This value must be a multiple of 0x200. */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_System_Private_Macros
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_System_Private_Variables
 | ||||
|   * @{ | ||||
|   */ | ||||
| uint32_t SystemCoreClock    = 16000000; | ||||
| __I uint8_t PLLMulTable[9] = {3, 4, 6, 8, 12, 16, 24, 32, 48}; | ||||
| __I uint8_t AHBPrescTable[16] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9}; | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_System_Private_FunctionPrototypes
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| static void SetSysClock(void); | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_System_Private_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Setup the microcontroller system. | ||||
|   *         Initialize the Embedded Flash Interface, the PLL and update the  | ||||
|   *         SystemCoreClock variable. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void SystemInit (void) | ||||
| { | ||||
|   /*!< Set MSION bit */ | ||||
|   RCC->CR |= (uint32_t)0x00000100; | ||||
| 
 | ||||
|   /*!< Reset SW[1:0], HPRE[3:0], PPRE1[2:0], PPRE2[2:0], MCOSEL[2:0] and MCOPRE[2:0] bits */ | ||||
|   RCC->CFGR &= (uint32_t)0x88FFC00C; | ||||
|    | ||||
|   /*!< Reset HSION, HSEON, CSSON and PLLON bits */ | ||||
|   RCC->CR &= (uint32_t)0xEEFEFFFE; | ||||
| 
 | ||||
|   /*!< Reset HSEBYP bit */ | ||||
|   RCC->CR &= (uint32_t)0xFFFBFFFF; | ||||
| 
 | ||||
|   /*!< Reset PLLSRC, PLLMUL[3:0] and PLLDIV[1:0] bits */ | ||||
|   RCC->CFGR &= (uint32_t)0xFF02FFFF; | ||||
| 
 | ||||
|   /*!< Disable all interrupts */ | ||||
|   RCC->CIR = 0x00000000; | ||||
|      | ||||
|   /* Configure the System clock frequency, AHB/APBx prescalers and Flash settings */ | ||||
|   SetSysClock(); | ||||
| 
 | ||||
| #ifdef VECT_TAB_SRAM | ||||
|   SCB->VTOR = SRAM_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal SRAM. */ | ||||
| #else | ||||
|   SCB->VTOR = FLASH_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal FLASH. */ | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Update SystemCoreClock according to Clock Register Values | ||||
|   * @note   - The system frequency computed by this function is not the real  | ||||
|   *           frequency in the chip. It is calculated based on the predefined  | ||||
|   *           constant and the selected clock source: | ||||
|   *              | ||||
|   *           - If SYSCLK source is MSI, SystemCoreClock will contain the MSI  | ||||
|   *             value as defined by the MSI range. | ||||
|   *                                    | ||||
|   *           - If SYSCLK source is HSI, SystemCoreClock will contain the HSI_VALUE(*) | ||||
|   *                                               | ||||
|   *           - If SYSCLK source is HSE, SystemCoreClock will contain the HSE_VALUE(**) | ||||
|   *                           | ||||
|   *           - If SYSCLK source is PLL, SystemCoreClock will contain the HSE_VALUE(**)  | ||||
|   *             or HSI_VALUE(*) multiplied/divided by the PLL factors. | ||||
|   *          | ||||
|   *         (*) HSI_VALUE is a constant defined in stm32l1xx.h file (default value | ||||
|   *             16 MHz) but the real value may vary depending on the variations | ||||
|   *             in voltage and temperature.    | ||||
|   *     | ||||
|   *         (**) HSE_VALUE is a constant defined in stm32l1xx.h file (default value | ||||
|   *              8 MHz), user has to ensure that HSE_VALUE is same as the real | ||||
|   *              frequency of the crystal used. Otherwise, this function may | ||||
|   *              have wrong result. | ||||
|   *                 | ||||
|   *         - The result of this function could be not correct when using fractional | ||||
|   *           value for HSE crystal.   | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void SystemCoreClockUpdate (void) | ||||
| { | ||||
|   uint32_t tmp = 0, pllmul = 0, plldiv = 0, pllsource = 0, msirange = 0; | ||||
| 
 | ||||
|   /* Get SYSCLK source -------------------------------------------------------*/ | ||||
|   tmp = RCC->CFGR & RCC_CFGR_SWS; | ||||
|    | ||||
|   switch (tmp) | ||||
|   { | ||||
|     case 0x00:  /* MSI used as system clock */ | ||||
|       msirange = (RCC->ICSCR & RCC_ICSCR_MSIRANGE) >> 13; | ||||
|       SystemCoreClock = (32768 * (1 << (msirange + 1))); | ||||
|       break; | ||||
|     case 0x04:  /* HSI used as system clock */ | ||||
|       SystemCoreClock = HSI_VALUE; | ||||
|       break; | ||||
|     case 0x08:  /* HSE used as system clock */ | ||||
|       SystemCoreClock = HSE_VALUE; | ||||
|       break; | ||||
|     case 0x0C:  /* PLL used as system clock */ | ||||
|       /* Get PLL clock source and multiplication factor ----------------------*/ | ||||
|       pllmul = RCC->CFGR & RCC_CFGR_PLLMUL; | ||||
|       plldiv = RCC->CFGR & RCC_CFGR_PLLDIV; | ||||
|       pllmul = PLLMulTable[(pllmul >> 18)]; | ||||
|       plldiv = (plldiv >> 22) + 1; | ||||
|        | ||||
|       pllsource = RCC->CFGR & RCC_CFGR_PLLSRC; | ||||
| 
 | ||||
|       if (pllsource == 0x00) | ||||
|       { | ||||
|         /* HSI oscillator clock selected as PLL clock entry */ | ||||
|         SystemCoreClock = (((HSI_VALUE) * pllmul) / plldiv); | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|         /* HSE selected as PLL clock entry */ | ||||
|         SystemCoreClock = (((HSE_VALUE) * pllmul) / plldiv); | ||||
|       } | ||||
|       break; | ||||
|     default: /* MSI used as system clock */ | ||||
|       msirange = (RCC->ICSCR & RCC_ICSCR_MSIRANGE) >> 13; | ||||
|       SystemCoreClock = (32768 * (1 << (msirange + 1))); | ||||
|       break; | ||||
|   } | ||||
|   /* Compute HCLK clock frequency --------------------------------------------*/ | ||||
|   /* Get HCLK prescaler */ | ||||
|   tmp = AHBPrescTable[((RCC->CFGR & RCC_CFGR_HPRE) >> 4)]; | ||||
|   /* HCLK clock frequency */ | ||||
|   SystemCoreClock >>= tmp; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configures the System clock frequency, AHB/APBx prescalers and Flash  | ||||
|   *         settings. | ||||
|   * @note   This function should be called only once the RCC clock configuration   | ||||
|   *         is reset to the default reset state (done in SystemInit() function).              | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| static void SetSysClock(void) | ||||
| { | ||||
|   __IO uint32_t StartUpCounter = 0, HSIStatus = 0; | ||||
|    | ||||
|   /* SYSCLK, HCLK, PCLK2 and PCLK1 configuration ---------------------------*/ | ||||
|   /* Enable HSI */ | ||||
|   RCC->CR |= ((uint32_t)RCC_CR_HSION); | ||||
|   | ||||
|   /* Wait till HSI is ready and if Time out is reached exit */ | ||||
|   do | ||||
|   { | ||||
|     HSIStatus = RCC->CR & RCC_CR_HSIRDY; | ||||
|   } while((HSIStatus == 0) && (StartUpCounter != HSI_STARTUP_TIMEOUT)); | ||||
| 
 | ||||
|   if ((RCC->CR & RCC_CR_HSIRDY) != RESET) | ||||
|   { | ||||
|     HSIStatus = (uint32_t)0x01; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     HSIStatus = (uint32_t)0x00; | ||||
|   } | ||||
|      | ||||
|   if (HSIStatus == (uint32_t)0x01) | ||||
|   { | ||||
|     /* Flash 0 wait state */ | ||||
|     FLASH->ACR &= ~FLASH_ACR_LATENCY; | ||||
|      | ||||
|     /* Disable Prefetch Buffer */ | ||||
|     FLASH->ACR &= ~FLASH_ACR_PRFTEN; | ||||
| 
 | ||||
|     /* Disable 64-bit access */ | ||||
|     FLASH->ACR &= ~FLASH_ACR_ACC64; | ||||
|      | ||||
| 
 | ||||
|     /* Power enable */ | ||||
|     RCC->APB1ENR |= RCC_APB1ENR_PWREN; | ||||
|    | ||||
|     /* Select the Voltage Range 1 (1.8 V) */ | ||||
|     PWR->CR = PWR_CR_VOS_0; | ||||
|    | ||||
|    | ||||
|     /* Wait Until the Voltage Regulator is ready */ | ||||
|     while((PWR->CSR & PWR_CSR_VOSF) != RESET) | ||||
|     { | ||||
|     } | ||||
|        | ||||
|     /* HCLK = SYSCLK /1*/ | ||||
|     RCC->CFGR |= (uint32_t)RCC_CFGR_HPRE_DIV1; | ||||
|     /* PCLK2 = HCLK /1*/ | ||||
|     RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE2_DIV1; | ||||
|      | ||||
|     /* PCLK1 = HCLK /1*/ | ||||
|     RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE1_DIV1; | ||||
|      | ||||
|     /* Select HSI as system clock source */ | ||||
|     RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_SW)); | ||||
|     RCC->CFGR |= (uint32_t)RCC_CFGR_SW_HSI; | ||||
| 
 | ||||
|     /* Wait till HSI is used as system clock source */ | ||||
|     while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS) != (uint32_t)RCC_CFGR_SWS_HSI) | ||||
|     { | ||||
|     } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* If HSI fails to start-up, the application will have wrong clock
 | ||||
|        configuration. User can add here some code to deal with this error */ | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /******************* (C) COPYRIGHT 2010 STMicroelectronics *****END OF FILE****/ | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue