a lot more will need to be added as we go on.. This was pulled from heltec's PingPong example, but all licenses are free.. Also, the files were cleaned up, that is CRs removed, and trailing white space removed from lines...mbed-sx1276
@@ -0,0 +1,266 @@ | |||||
/**************************************************************************//** | |||||
* @file cmsis_compiler.h | |||||
* @brief CMSIS compiler generic header file | |||||
* @version V5.0.4 | |||||
* @date 10. January 2018 | |||||
******************************************************************************/ | |||||
/* | |||||
* Copyright (c) 2009-2018 Arm Limited. All rights reserved. | |||||
* | |||||
* SPDX-License-Identifier: Apache-2.0 | |||||
* | |||||
* Licensed under the Apache License, Version 2.0 (the License); you may | |||||
* not use this file except in compliance with the License. | |||||
* You may obtain a copy of the License at | |||||
* | |||||
* www.apache.org/licenses/LICENSE-2.0 | |||||
* | |||||
* 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. | |||||
*/ | |||||
#ifndef __CMSIS_COMPILER_H | |||||
#define __CMSIS_COMPILER_H | |||||
#include <stdint.h> | |||||
/* | |||||
* Arm Compiler 4/5 | |||||
*/ | |||||
#if defined ( __CC_ARM ) | |||||
#include "cmsis_armcc.h" | |||||
/* | |||||
* Arm Compiler 6 (armclang) | |||||
*/ | |||||
#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) | |||||
#include "cmsis_armclang.h" | |||||
/* | |||||
* GNU Compiler | |||||
*/ | |||||
#elif defined ( __GNUC__ ) | |||||
#include "cmsis_gcc.h" | |||||
/* | |||||
* IAR Compiler | |||||
*/ | |||||
#elif defined ( __ICCARM__ ) | |||||
#include <cmsis_iccarm.h> | |||||
/* | |||||
* TI Arm Compiler | |||||
*/ | |||||
#elif defined ( __TI_ARM__ ) | |||||
#include <cmsis_ccs.h> | |||||
#ifndef __ASM | |||||
#define __ASM __asm | |||||
#endif | |||||
#ifndef __INLINE | |||||
#define __INLINE inline | |||||
#endif | |||||
#ifndef __STATIC_INLINE | |||||
#define __STATIC_INLINE static inline | |||||
#endif | |||||
#ifndef __STATIC_FORCEINLINE | |||||
#define __STATIC_FORCEINLINE __STATIC_INLINE | |||||
#endif | |||||
#ifndef __NO_RETURN | |||||
#define __NO_RETURN __attribute__((noreturn)) | |||||
#endif | |||||
#ifndef __USED | |||||
#define __USED __attribute__((used)) | |||||
#endif | |||||
#ifndef __WEAK | |||||
#define __WEAK __attribute__((weak)) | |||||
#endif | |||||
#ifndef __PACKED | |||||
#define __PACKED __attribute__((packed)) | |||||
#endif | |||||
#ifndef __PACKED_STRUCT | |||||
#define __PACKED_STRUCT struct __attribute__((packed)) | |||||
#endif | |||||
#ifndef __PACKED_UNION | |||||
#define __PACKED_UNION union __attribute__((packed)) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT32 /* deprecated */ | |||||
struct __attribute__((packed)) T_UINT32 { uint32_t v; }; | |||||
#define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT16_WRITE | |||||
__PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; | |||||
#define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void*)(addr))->v) = (val)) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT16_READ | |||||
__PACKED_STRUCT T_UINT16_READ { uint16_t v; }; | |||||
#define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT32_WRITE | |||||
__PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; | |||||
#define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT32_READ | |||||
__PACKED_STRUCT T_UINT32_READ { uint32_t v; }; | |||||
#define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) | |||||
#endif | |||||
#ifndef __ALIGNED | |||||
#define __ALIGNED(x) __attribute__((aligned(x))) | |||||
#endif | |||||
#ifndef __RESTRICT | |||||
#warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. | |||||
#define __RESTRICT | |||||
#endif | |||||
/* | |||||
* TASKING Compiler | |||||
*/ | |||||
#elif defined ( __TASKING__ ) | |||||
/* | |||||
* The CMSIS functions have been implemented as intrinsics in the compiler. | |||||
* Please use "carm -?i" to get an up to date list of all intrinsics, | |||||
* Including the CMSIS ones. | |||||
*/ | |||||
#ifndef __ASM | |||||
#define __ASM __asm | |||||
#endif | |||||
#ifndef __INLINE | |||||
#define __INLINE inline | |||||
#endif | |||||
#ifndef __STATIC_INLINE | |||||
#define __STATIC_INLINE static inline | |||||
#endif | |||||
#ifndef __STATIC_FORCEINLINE | |||||
#define __STATIC_FORCEINLINE __STATIC_INLINE | |||||
#endif | |||||
#ifndef __NO_RETURN | |||||
#define __NO_RETURN __attribute__((noreturn)) | |||||
#endif | |||||
#ifndef __USED | |||||
#define __USED __attribute__((used)) | |||||
#endif | |||||
#ifndef __WEAK | |||||
#define __WEAK __attribute__((weak)) | |||||
#endif | |||||
#ifndef __PACKED | |||||
#define __PACKED __packed__ | |||||
#endif | |||||
#ifndef __PACKED_STRUCT | |||||
#define __PACKED_STRUCT struct __packed__ | |||||
#endif | |||||
#ifndef __PACKED_UNION | |||||
#define __PACKED_UNION union __packed__ | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT32 /* deprecated */ | |||||
struct __packed__ T_UINT32 { uint32_t v; }; | |||||
#define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT16_WRITE | |||||
__PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; | |||||
#define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT16_READ | |||||
__PACKED_STRUCT T_UINT16_READ { uint16_t v; }; | |||||
#define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT32_WRITE | |||||
__PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; | |||||
#define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT32_READ | |||||
__PACKED_STRUCT T_UINT32_READ { uint32_t v; }; | |||||
#define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) | |||||
#endif | |||||
#ifndef __ALIGNED | |||||
#define __ALIGNED(x) __align(x) | |||||
#endif | |||||
#ifndef __RESTRICT | |||||
#warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. | |||||
#define __RESTRICT | |||||
#endif | |||||
/* | |||||
* COSMIC Compiler | |||||
*/ | |||||
#elif defined ( __CSMC__ ) | |||||
#include <cmsis_csm.h> | |||||
#ifndef __ASM | |||||
#define __ASM _asm | |||||
#endif | |||||
#ifndef __INLINE | |||||
#define __INLINE inline | |||||
#endif | |||||
#ifndef __STATIC_INLINE | |||||
#define __STATIC_INLINE static inline | |||||
#endif | |||||
#ifndef __STATIC_FORCEINLINE | |||||
#define __STATIC_FORCEINLINE __STATIC_INLINE | |||||
#endif | |||||
#ifndef __NO_RETURN | |||||
// NO RETURN is automatically detected hence no warning here | |||||
#define __NO_RETURN | |||||
#endif | |||||
#ifndef __USED | |||||
#warning No compiler specific solution for __USED. __USED is ignored. | |||||
#define __USED | |||||
#endif | |||||
#ifndef __WEAK | |||||
#define __WEAK __weak | |||||
#endif | |||||
#ifndef __PACKED | |||||
#define __PACKED @packed | |||||
#endif | |||||
#ifndef __PACKED_STRUCT | |||||
#define __PACKED_STRUCT @packed struct | |||||
#endif | |||||
#ifndef __PACKED_UNION | |||||
#define __PACKED_UNION @packed union | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT32 /* deprecated */ | |||||
@packed struct T_UINT32 { uint32_t v; }; | |||||
#define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT16_WRITE | |||||
__PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; | |||||
#define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT16_READ | |||||
__PACKED_STRUCT T_UINT16_READ { uint16_t v; }; | |||||
#define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT32_WRITE | |||||
__PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; | |||||
#define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) | |||||
#endif | |||||
#ifndef __UNALIGNED_UINT32_READ | |||||
__PACKED_STRUCT T_UINT32_READ { uint32_t v; }; | |||||
#define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) | |||||
#endif | |||||
#ifndef __ALIGNED | |||||
#warning No compiler specific solution for __ALIGNED. __ALIGNED is ignored. | |||||
#define __ALIGNED(x) | |||||
#endif | |||||
#ifndef __RESTRICT | |||||
#warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. | |||||
#define __RESTRICT | |||||
#endif | |||||
#else | |||||
#error Unknown compiler. | |||||
#endif | |||||
#endif /* __CMSIS_COMPILER_H */ | |||||
@@ -0,0 +1,39 @@ | |||||
/**************************************************************************//** | |||||
* @file cmsis_version.h | |||||
* @brief CMSIS Core(M) Version definitions | |||||
* @version V5.0.2 | |||||
* @date 19. April 2017 | |||||
******************************************************************************/ | |||||
/* | |||||
* Copyright (c) 2009-2017 ARM Limited. All rights reserved. | |||||
* | |||||
* SPDX-License-Identifier: Apache-2.0 | |||||
* | |||||
* Licensed under the Apache License, Version 2.0 (the License); you may | |||||
* not use this file except in compliance with the License. | |||||
* You may obtain a copy of the License at | |||||
* | |||||
* www.apache.org/licenses/LICENSE-2.0 | |||||
* | |||||
* 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. | |||||
*/ | |||||
#if defined ( __ICCARM__ ) | |||||
#pragma system_include /* treat file as system include file for MISRA check */ | |||||
#elif defined (__clang__) | |||||
#pragma clang system_header /* treat file as system include file */ | |||||
#endif | |||||
#ifndef __CMSIS_VERSION_H | |||||
#define __CMSIS_VERSION_H | |||||
/* CMSIS Version definitions */ | |||||
#define __CM_CMSIS_VERSION_MAIN ( 5U) /*!< [31:16] CMSIS Core(M) main version */ | |||||
#define __CM_CMSIS_VERSION_SUB ( 1U) /*!< [15:0] CMSIS Core(M) sub version */ | |||||
#define __CM_CMSIS_VERSION ((__CM_CMSIS_VERSION_MAIN << 16U) | \ | |||||
__CM_CMSIS_VERSION_SUB ) /*!< CMSIS Core(M) version number */ | |||||
#endif |
@@ -0,0 +1,200 @@ | |||||
/* | |||||
****************************************************************************** | |||||
** | |||||
** File : LinkerScript.ld | |||||
** | |||||
** Author : Auto-generated by STM32CubeIDE | |||||
** | |||||
** Abstract : Linker script for STM32L151CCUx Device from stm32l1 series | |||||
** 256Kbytes FLASH | |||||
** 32Kbytes RAM | |||||
** | |||||
** Set heap size, stack size and stack location according | |||||
** to application requirements. | |||||
** | |||||
** Set memory bank area and size if external memory is used. | |||||
** | |||||
** Target : STMicroelectronics STM32 | |||||
** | |||||
** Distribution: The file is distributed as is without any warranty | |||||
** of any kind. | |||||
** | |||||
***************************************************************************** | |||||
** @attention | |||||
** | |||||
** <h2><center>© COPYRIGHT(c) 2020 STMicroelectronics</center></h2> | |||||
** | |||||
** Redistribution and use in source and binary forms, with or without modification, | |||||
** are permitted provided that the following conditions are met: | |||||
** 1. Redistributions of source code must retain the above copyright notice, | |||||
** this list of conditions and the following disclaimer. | |||||
** 2. Redistributions in binary form must reproduce the above copyright notice, | |||||
** this list of conditions and the following disclaimer in the documentation | |||||
** and/or other materials provided with the distribution. | |||||
** 3. Neither the name of STMicroelectronics nor the names of its contributors | |||||
** may be used to endorse or promote products derived from this software | |||||
** without specific prior written permission. | |||||
** | |||||
** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | |||||
** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |||||
** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||||
** DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | |||||
** FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |||||
** DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | |||||
** SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | |||||
** CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||||
** OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | |||||
** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |||||
** | |||||
***************************************************************************** | |||||
*/ | |||||
/* Entry Point */ | |||||
ENTRY(Reset_Handler) | |||||
/* Highest address of the user mode stack */ | |||||
_estack = ORIGIN(RAM) + LENGTH(RAM); /* end of "RAM" Ram type memory */ | |||||
_Min_Heap_Size = 0x200 ; /* required amount of heap */ | |||||
_Min_Stack_Size = 0x400 ; /* required amount of stack */ | |||||
/* Memories definition */ | |||||
MEMORY | |||||
{ | |||||
RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K | |||||
FLASH (rx) : ORIGIN = 0x8000000, LENGTH = 256K | |||||
} | |||||
/* Sections */ | |||||
SECTIONS | |||||
{ | |||||
/* The startup code into "FLASH" Rom type memory */ | |||||
.isr_vector : | |||||
{ | |||||
. = ALIGN(4); | |||||
KEEP(*(.isr_vector)) /* Startup code */ | |||||
. = ALIGN(4); | |||||
} >FLASH | |||||
/* The program code and other data into "FLASH" Rom type memory */ | |||||
.text : | |||||
{ | |||||
. = ALIGN(4); | |||||
*(.text) /* .text sections (code) */ | |||||
*(.text*) /* .text* sections (code) */ | |||||
*(.glue_7) /* glue arm to thumb code */ | |||||
*(.glue_7t) /* glue thumb to arm code */ | |||||
*(.eh_frame) | |||||
KEEP (*(.init)) | |||||
KEEP (*(.fini)) | |||||
. = ALIGN(4); | |||||
_etext = .; /* define a global symbols at end of code */ | |||||
} >FLASH | |||||
/* Constant data into "FLASH" Rom type memory */ | |||||
.rodata : | |||||
{ | |||||
. = ALIGN(4); | |||||
*(.rodata) /* .rodata sections (constants, strings, etc.) */ | |||||
*(.rodata*) /* .rodata* sections (constants, strings, etc.) */ | |||||
. = ALIGN(4); | |||||
} >FLASH | |||||
.ARM.extab : { | |||||
. = ALIGN(4); | |||||
*(.ARM.extab* .gnu.linkonce.armextab.*) | |||||
. = ALIGN(4); | |||||
} >FLASH | |||||
.ARM : { | |||||
. = ALIGN(4); | |||||
__exidx_start = .; | |||||
*(.ARM.exidx*) | |||||
__exidx_end = .; | |||||
. = ALIGN(4); | |||||
} >FLASH | |||||
.preinit_array : | |||||
{ | |||||
. = ALIGN(4); | |||||
PROVIDE_HIDDEN (__preinit_array_start = .); | |||||
KEEP (*(.preinit_array*)) | |||||
PROVIDE_HIDDEN (__preinit_array_end = .); | |||||
. = ALIGN(4); | |||||
} >FLASH | |||||
.init_array : | |||||
{ | |||||
. = ALIGN(4); | |||||
PROVIDE_HIDDEN (__init_array_start = .); | |||||
KEEP (*(SORT(.init_array.*))) | |||||
KEEP (*(.init_array*)) | |||||
PROVIDE_HIDDEN (__init_array_end = .); | |||||
. = ALIGN(4); | |||||
} >FLASH | |||||
.fini_array : | |||||
{ | |||||
. = ALIGN(4); | |||||
PROVIDE_HIDDEN (__fini_array_start = .); | |||||
KEEP (*(SORT(.fini_array.*))) | |||||
KEEP (*(.fini_array*)) | |||||
PROVIDE_HIDDEN (__fini_array_end = .); | |||||
. = ALIGN(4); | |||||
} >FLASH | |||||
/* Used by the startup to initialize data */ | |||||
_sidata = LOADADDR(.data); | |||||
/* Initialized data sections into "RAM" Ram type memory */ | |||||
.data : | |||||
{ | |||||
. = ALIGN(4); | |||||
_sdata = .; /* create a global symbol at data start */ | |||||
*(.data) /* .data sections */ | |||||
*(.data*) /* .data* sections */ | |||||
. = ALIGN(4); | |||||
_edata = .; /* define a global symbol at data end */ | |||||
} >RAM AT> FLASH | |||||
/* Uninitialized data section into "RAM" Ram type memory */ | |||||
. = ALIGN(4); | |||||
.bss : | |||||
{ | |||||
/* This is used by the startup in order to initialize the .bss section */ | |||||
_sbss = .; /* define a global symbol at bss start */ | |||||
__bss_start__ = _sbss; | |||||
*(.bss) | |||||
*(.bss*) | |||||
*(COMMON) | |||||
. = ALIGN(4); | |||||
_ebss = .; /* define a global symbol at bss end */ | |||||
__bss_end__ = _ebss; | |||||
} >RAM | |||||
/* User_heap_stack section, used to check that there is enough "RAM" Ram type memory left */ | |||||
._user_heap_stack : | |||||
{ | |||||
. = ALIGN(8); | |||||
PROVIDE ( end = . ); | |||||
PROVIDE ( _end = . ); | |||||
. = . + _Min_Heap_Size; | |||||
. = . + _Min_Stack_Size; | |||||
. = ALIGN(8); | |||||
} >RAM | |||||
/* Remove information from the compiler libraries */ | |||||
/DISCARD/ : | |||||
{ | |||||
libc.a ( * ) | |||||
libm.a ( * ) | |||||
libgcc.a ( * ) | |||||
} | |||||
.ARM.attributes 0 : { *(.ARM.attributes) } | |||||
} |
@@ -0,0 +1,400 @@ | |||||
/** | |||||
****************************************************************************** | |||||
* @file startup_stm32l151xc.s | |||||
* @author MCD Application Team | |||||
* @brief STM32L151XC Devices vector table for GCC toolchain. | |||||
* This module performs: | |||||
* - Set the initial SP | |||||
* - Set the initial PC == Reset_Handler, | |||||
* - Set the vector table entries with the exceptions ISR address | |||||
* - Configure the clock system | |||||
* - Branches to main in the C library (which eventually | |||||
* calls main()). | |||||
* After Reset the Cortex-M3 processor is in Thread mode, | |||||
* priority is Privileged, and the Stack is set to Main. | |||||
****************************************************************************** | |||||
* | |||||
* @attention | |||||
* | |||||
* Copyright (c) 2017 STMicroelectronics. All rights reserved. | |||||
* | |||||
* This software component is licensed by ST under BSD 3-Clause license, | |||||
* the "License"; You may not use this file except in compliance with the | |||||
* License. You may obtain a copy of the License at: | |||||
* opensource.org/licenses/BSD-3-Clause | |||||
* | |||||
****************************************************************************** | |||||
*/ | |||||
.syntax unified | |||||
.cpu cortex-m3 | |||||
.fpu softvfp | |||||
.thumb | |||||
.global g_pfnVectors | |||||
.global Default_Handler | |||||
/* start address for the initialization values of the .data section. | |||||
defined in linker script */ | |||||
.word _sidata | |||||
/* start address for the .data section. defined in linker script */ | |||||
.word _sdata | |||||
/* end address for the .data section. defined in linker script */ | |||||
.word _edata | |||||
/* start address for the .bss section. defined in linker script */ | |||||
.word _sbss | |||||
/* end address for the .bss section. defined in linker script */ | |||||
.word _ebss | |||||
.equ BootRAM, 0xF108F85F | |||||
/** | |||||
* @brief This is the code that gets called when the processor first | |||||
* starts execution following a reset event. Only the absolutely | |||||
* necessary set is performed, after which the application | |||||
* supplied main() routine is called. | |||||
* @param None | |||||
* @retval : None | |||||
*/ | |||||
.section .text.Reset_Handler | |||||
.weak Reset_Handler | |||||
.type Reset_Handler, %function | |||||
Reset_Handler: | |||||
/* Copy the data segment initializers from flash to SRAM */ | |||||
movs r1, #0 | |||||
b LoopCopyDataInit | |||||
CopyDataInit: | |||||
ldr r3, =_sidata | |||||
ldr r3, [r3, r1] | |||||
str r3, [r0, r1] | |||||
adds r1, r1, #4 | |||||
LoopCopyDataInit: | |||||
ldr r0, =_sdata | |||||
ldr r3, =_edata | |||||
adds r2, r0, r1 | |||||
cmp r2, r3 | |||||
bcc CopyDataInit | |||||
ldr r2, =_sbss | |||||
b LoopFillZerobss | |||||
/* Zero fill the bss segment. */ | |||||
FillZerobss: | |||||
movs r3, #0 | |||||
str r3, [r2], #4 | |||||
LoopFillZerobss: | |||||
ldr r3, = _ebss | |||||
cmp r2, r3 | |||||
bcc FillZerobss | |||||
/* Call the clock system intitialization function.*/ | |||||
bl SystemInit | |||||
/* Call static constructors */ | |||||
bl __libc_init_array | |||||
/* Call the application's entry point.*/ | |||||
bl main | |||||
bx lr | |||||
.size Reset_Handler, .-Reset_Handler | |||||
/** | |||||
* @brief This is the code that gets called when the processor receives an | |||||
* unexpected interrupt. This simply enters an infinite loop, preserving | |||||
* the system state for examination by a debugger. | |||||
* | |||||
* @param None | |||||
* @retval : None | |||||
*/ | |||||
.section .text.Default_Handler,"ax",%progbits | |||||
Default_Handler: | |||||
Infinite_Loop: | |||||
b Infinite_Loop | |||||
.size Default_Handler, .-Default_Handler | |||||
/****************************************************************************** | |||||
* | |||||
* The minimal vector table for a Cortex M3. Note that the proper constructs | |||||
* must be placed on this to ensure that it ends up at physical address | |||||
* 0x0000.0000. | |||||
* | |||||
******************************************************************************/ | |||||
.section .isr_vector,"a",%progbits | |||||
.type g_pfnVectors, %object | |||||
.size g_pfnVectors, .-g_pfnVectors | |||||
g_pfnVectors: | |||||
.word _estack | |||||
.word Reset_Handler | |||||
.word NMI_Handler | |||||
.word HardFault_Handler | |||||
.word MemManage_Handler | |||||
.word BusFault_Handler | |||||
.word UsageFault_Handler | |||||
.word 0 | |||||
.word 0 | |||||
.word 0 | |||||
.word 0 | |||||
.word SVC_Handler | |||||
.word DebugMon_Handler | |||||
.word 0 | |||||
.word PendSV_Handler | |||||
.word SysTick_Handler | |||||
.word WWDG_IRQHandler | |||||
.word PVD_IRQHandler | |||||
.word TAMPER_STAMP_IRQHandler | |||||
.word RTC_WKUP_IRQHandler | |||||
.word FLASH_IRQHandler | |||||
.word RCC_IRQHandler | |||||
.word EXTI0_IRQHandler | |||||
.word EXTI1_IRQHandler | |||||
.word EXTI2_IRQHandler | |||||
.word EXTI3_IRQHandler | |||||
.word EXTI4_IRQHandler | |||||
.word DMA1_Channel1_IRQHandler | |||||
.word DMA1_Channel2_IRQHandler | |||||
.word DMA1_Channel3_IRQHandler | |||||
.word DMA1_Channel4_IRQHandler | |||||
.word DMA1_Channel5_IRQHandler | |||||
.word DMA1_Channel6_IRQHandler | |||||
.word DMA1_Channel7_IRQHandler | |||||
.word ADC1_IRQHandler | |||||
.word USB_HP_IRQHandler | |||||
.word USB_LP_IRQHandler | |||||
.word DAC_IRQHandler | |||||
.word COMP_IRQHandler | |||||
.word EXTI9_5_IRQHandler | |||||
.word 0 | |||||
.word TIM9_IRQHandler | |||||
.word TIM10_IRQHandler | |||||
.word TIM11_IRQHandler | |||||
.word TIM2_IRQHandler | |||||
.word TIM3_IRQHandler | |||||
.word TIM4_IRQHandler | |||||
.word I2C1_EV_IRQHandler | |||||
.word I2C1_ER_IRQHandler | |||||
.word I2C2_EV_IRQHandler | |||||
.word I2C2_ER_IRQHandler | |||||
.word SPI1_IRQHandler | |||||
.word SPI2_IRQHandler | |||||
.word USART1_IRQHandler | |||||
.word USART2_IRQHandler | |||||
.word USART3_IRQHandler | |||||
.word EXTI15_10_IRQHandler | |||||
.word RTC_Alarm_IRQHandler | |||||
.word USB_FS_WKUP_IRQHandler | |||||
.word TIM6_IRQHandler | |||||
.word TIM7_IRQHandler | |||||
.word 0 | |||||
.word TIM5_IRQHandler | |||||
.word SPI3_IRQHandler | |||||
.word 0 | |||||
.word 0 | |||||
.word DMA2_Channel1_IRQHandler | |||||
.word DMA2_Channel2_IRQHandler | |||||
.word DMA2_Channel3_IRQHandler | |||||
.word DMA2_Channel4_IRQHandler | |||||
.word DMA2_Channel5_IRQHandler | |||||
.word 0 | |||||
.word COMP_ACQ_IRQHandler | |||||
.word 0 | |||||
.word 0 | |||||
.word 0 | |||||
.word 0 | |||||
.word 0 | |||||
.word BootRAM /* @0x108. This is for boot in RAM mode for | |||||
STM32L151XC devices. */ | |||||
/******************************************************************************* | |||||
* | |||||
* Provide weak aliases for each Exception handler to the Default_Handler. | |||||
* As they are weak aliases, any function with the same name will override | |||||
* this definition. | |||||
* | |||||
*******************************************************************************/ | |||||
.weak NMI_Handler | |||||
.thumb_set NMI_Handler,Default_Handler | |||||
.weak HardFault_Handler | |||||
.thumb_set HardFault_Handler,Default_Handler | |||||
.weak MemManage_Handler | |||||
.thumb_set MemManage_Handler,Default_Handler | |||||
.weak BusFault_Handler | |||||
.thumb_set BusFault_Handler,Default_Handler | |||||
.weak UsageFault_Handler | |||||
.thumb_set UsageFault_Handler,Default_Handler | |||||
.weak SVC_Handler | |||||
.thumb_set SVC_Handler,Default_Handler | |||||
.weak DebugMon_Handler | |||||
.thumb_set DebugMon_Handler,Default_Handler | |||||
.weak PendSV_Handler | |||||
.thumb_set PendSV_Handler,Default_Handler | |||||
.weak SysTick_Handler | |||||
.thumb_set SysTick_Handler,Default_Handler | |||||
.weak WWDG_IRQHandler | |||||
.thumb_set WWDG_IRQHandler,Default_Handler | |||||
.weak PVD_IRQHandler | |||||
.thumb_set PVD_IRQHandler,Default_Handler | |||||
.weak TAMPER_STAMP_IRQHandler | |||||
.thumb_set TAMPER_STAMP_IRQHandler,Default_Handler | |||||
.weak RTC_WKUP_IRQHandler | |||||
.thumb_set RTC_WKUP_IRQHandler,Default_Handler | |||||
.weak FLASH_IRQHandler | |||||
.thumb_set FLASH_IRQHandler,Default_Handler | |||||
.weak RCC_IRQHandler | |||||
.thumb_set RCC_IRQHandler,Default_Handler | |||||
.weak EXTI0_IRQHandler | |||||
.thumb_set EXTI0_IRQHandler,Default_Handler | |||||
.weak EXTI1_IRQHandler | |||||
.thumb_set EXTI1_IRQHandler,Default_Handler | |||||
.weak EXTI2_IRQHandler | |||||
.thumb_set EXTI2_IRQHandler,Default_Handler | |||||
.weak EXTI3_IRQHandler | |||||
.thumb_set EXTI3_IRQHandler,Default_Handler | |||||
.weak EXTI4_IRQHandler | |||||
.thumb_set EXTI4_IRQHandler,Default_Handler | |||||
.weak DMA1_Channel1_IRQHandler | |||||
.thumb_set DMA1_Channel1_IRQHandler,Default_Handler | |||||
.weak DMA1_Channel2_IRQHandler | |||||
.thumb_set DMA1_Channel2_IRQHandler,Default_Handler | |||||
.weak DMA1_Channel3_IRQHandler | |||||
.thumb_set DMA1_Channel3_IRQHandler,Default_Handler | |||||
.weak DMA1_Channel4_IRQHandler | |||||
.thumb_set DMA1_Channel4_IRQHandler,Default_Handler | |||||
.weak DMA1_Channel5_IRQHandler | |||||
.thumb_set DMA1_Channel5_IRQHandler,Default_Handler | |||||
.weak DMA1_Channel6_IRQHandler | |||||
.thumb_set DMA1_Channel6_IRQHandler,Default_Handler | |||||
.weak DMA1_Channel7_IRQHandler | |||||
.thumb_set DMA1_Channel7_IRQHandler,Default_Handler | |||||
.weak ADC1_IRQHandler | |||||
.thumb_set ADC1_IRQHandler,Default_Handler | |||||
.weak USB_HP_IRQHandler | |||||
.thumb_set USB_HP_IRQHandler,Default_Handler | |||||
.weak USB_LP_IRQHandler | |||||
.thumb_set USB_LP_IRQHandler,Default_Handler | |||||
.weak DAC_IRQHandler | |||||
.thumb_set DAC_IRQHandler,Default_Handler | |||||
.weak COMP_IRQHandler | |||||
.thumb_set COMP_IRQHandler,Default_Handler | |||||
.weak EXTI9_5_IRQHandler | |||||
.thumb_set EXTI9_5_IRQHandler,Default_Handler | |||||
.weak TIM9_IRQHandler | |||||
.thumb_set TIM9_IRQHandler,Default_Handler | |||||
.weak TIM10_IRQHandler | |||||
.thumb_set TIM10_IRQHandler,Default_Handler | |||||
.weak TIM11_IRQHandler | |||||
.thumb_set TIM11_IRQHandler,Default_Handler | |||||
.weak TIM2_IRQHandler | |||||
.thumb_set TIM2_IRQHandler,Default_Handler | |||||
.weak TIM3_IRQHandler | |||||
.thumb_set TIM3_IRQHandler,Default_Handler | |||||
.weak TIM4_IRQHandler | |||||
.thumb_set TIM4_IRQHandler,Default_Handler | |||||
.weak I2C1_EV_IRQHandler | |||||
.thumb_set I2C1_EV_IRQHandler,Default_Handler | |||||
.weak I2C1_ER_IRQHandler | |||||
.thumb_set I2C1_ER_IRQHandler,Default_Handler | |||||
.weak I2C2_EV_IRQHandler | |||||
.thumb_set I2C2_EV_IRQHandler,Default_Handler | |||||
.weak I2C2_ER_IRQHandler | |||||
.thumb_set I2C2_ER_IRQHandler,Default_Handler | |||||
.weak SPI1_IRQHandler | |||||
.thumb_set SPI1_IRQHandler,Default_Handler | |||||
.weak SPI2_IRQHandler | |||||
.thumb_set SPI2_IRQHandler,Default_Handler | |||||
.weak USART1_IRQHandler | |||||
.thumb_set USART1_IRQHandler,Default_Handler | |||||
.weak USART2_IRQHandler | |||||
.thumb_set USART2_IRQHandler,Default_Handler | |||||
.weak USART3_IRQHandler | |||||
.thumb_set USART3_IRQHandler,Default_Handler | |||||
.weak EXTI15_10_IRQHandler | |||||
.thumb_set EXTI15_10_IRQHandler,Default_Handler | |||||
.weak RTC_Alarm_IRQHandler | |||||
.thumb_set RTC_Alarm_IRQHandler,Default_Handler | |||||
.weak USB_FS_WKUP_IRQHandler | |||||
.thumb_set USB_FS_WKUP_IRQHandler,Default_Handler | |||||
.weak TIM6_IRQHandler | |||||
.thumb_set TIM6_IRQHandler,Default_Handler | |||||
.weak TIM7_IRQHandler | |||||
.thumb_set TIM7_IRQHandler,Default_Handler | |||||
.weak TIM5_IRQHandler | |||||
.thumb_set TIM5_IRQHandler,Default_Handler | |||||
.weak SPI3_IRQHandler | |||||
.thumb_set SPI3_IRQHandler,Default_Handler | |||||
.weak DMA2_Channel1_IRQHandler | |||||
.thumb_set DMA2_Channel1_IRQHandler,Default_Handler | |||||
.weak DMA2_Channel2_IRQHandler | |||||
.thumb_set DMA2_Channel2_IRQHandler,Default_Handler | |||||
.weak DMA2_Channel3_IRQHandler | |||||
.thumb_set DMA2_Channel3_IRQHandler,Default_Handler | |||||
.weak DMA2_Channel4_IRQHandler | |||||
.thumb_set DMA2_Channel4_IRQHandler,Default_Handler | |||||
.weak DMA2_Channel5_IRQHandler | |||||
.thumb_set DMA2_Channel5_IRQHandler,Default_Handler | |||||
.weak COMP_ACQ_IRQHandler | |||||
.thumb_set COMP_ACQ_IRQHandler,Default_Handler | |||||
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | |||||
@@ -0,0 +1,246 @@ | |||||
/** | |||||
****************************************************************************** | |||||
* @file stm32l1xx.h | |||||
* @author MCD Application Team | |||||
* @brief CMSIS STM32L1xx Device Peripheral Access Layer Header File. | |||||
* | |||||
* The file is the unique include file that the application programmer | |||||
* is using in the C source code, usually in main.c. This file contains: | |||||
* - Configuration section that allows to select: | |||||
* - The STM32L1xx device used in the target application | |||||
* - To use or not the peripheral’s drivers in application code(i.e. | |||||
* code will be based on direct access to peripheral’s registers | |||||
* rather than drivers API), this option is controlled by | |||||
* "#define USE_HAL_DRIVER" | |||||
* | |||||
****************************************************************************** | |||||
* @attention | |||||
* | |||||
* <h2><center>© Copyright (c) 2017 STMicroelectronics. | |||||
* All rights reserved.</center></h2> | |||||
* | |||||
* This software component is licensed by ST under BSD 3-Clause license, | |||||
* the "License"; You may not use this file except in compliance with the | |||||
* License. You may obtain a copy of the License at: | |||||
* opensource.org/licenses/BSD-3-Clause | |||||
* | |||||
****************************************************************************** | |||||
*/ | |||||
/** @addtogroup CMSIS | |||||
* @{ | |||||
*/ | |||||
/** @addtogroup stm32l1xx | |||||
* @{ | |||||
*/ | |||||
#ifndef __STM32L1XX_H | |||||
#define __STM32L1XX_H | |||||
#ifdef __cplusplus | |||||
extern "C" { | |||||
#endif /* __cplusplus */ | |||||
/** @addtogroup Library_configuration_section | |||||
* @{ | |||||
*/ | |||||
/** | |||||
* @brief STM32 Family | |||||
*/ | |||||
#if !defined (STM32L1) | |||||
#define STM32L1 | |||||
#endif /* STM32L1 */ | |||||
/* Uncomment the line below according to the target STM32L device used in your | |||||
application | |||||
*/ | |||||
#if !defined (STM32L100xB) && !defined (STM32L100xBA) && !defined (STM32L100xC) && \ | |||||
!defined (STM32L151xB) && !defined (STM32L151xBA) && !defined (STM32L151xC) && !defined (STM32L151xCA) && !defined (STM32L151xD) && !defined (STM32L151xDX) && !defined (STM32L151xE) && \ | |||||
!defined (STM32L152xB) && !defined (STM32L152xBA) && !defined (STM32L152xC) && !defined (STM32L152xCA) && !defined (STM32L152xD) && !defined (STM32L152xDX) && !defined (STM32L152xE) && \ | |||||
!defined (STM32L162xC) && !defined (STM32L162xCA) && !defined (STM32L162xD) && !defined (STM32L162xDX) && !defined (STM32L162xE) | |||||
/* #define STM32L100xB */ /*!< STM32L100C6, STM32L100R and STM32L100RB Devices */ | |||||
/* #define STM32L100xBA */ /*!< STM32L100C6-A, STM32L100R8-A and STM32L100RB-A Devices */ | |||||
/* #define STM32L100xC */ /*!< STM32L100RC Devices */ | |||||
/* #define STM32L151xB */ /*!< STM32L151C6, STM32L151R6, STM32L151C8, STM32L151R8, STM32L151V8, STM32L151CB, STM32L151RB and STM32L151VB */ | |||||
/* #define STM32L151xBA */ /*!< STM32L151C6-A, STM32L151R6-A, STM32L151C8-A, STM32L151R8-A, STM32L151V8-A, STM32L151CB-A, STM32L151RB-A and STM32L151VB-A */ | |||||
/* #define STM32L151xC */ /*!< STM32L151CC, STM32L151UC, STM32L151RC and STM32L151VC */ | |||||
/* #define STM32L151xCA */ /*!< STM32L151RC-A, STM32L151VC-A, STM32L151QC and STM32L151ZC */ | |||||
/* #define STM32L151xD */ /*!< STM32L151QD, STM32L151RD, STM32L151VD & STM32L151ZD */ | |||||
/* #define STM32L151xDX */ /*!< STM32L151VD-X Devices */ | |||||
/* #define STM32L151xE */ /*!< STM32L151QE, STM32L151RE, STM32L151VE and STM32L151ZE */ | |||||
/* #define STM32L152xB */ /*!< STM32L152C6, STM32L152R6, STM32L152C8, STM32L152R8, STM32L152V8, STM32L152CB, STM32L152RB and STM32L152VB */ | |||||
/* #define STM32L152xBA */ /*!< STM32L152C6-A, STM32L152R6-A, STM32L152C8-A, STM32L152R8-A, STM32L152V8-A, STM32L152CB-A, STM32L152RB-A and STM32L152VB-A */ | |||||
/* #define STM32L152xC */ /*!< STM32L152CC, STM32L152UC, STM32L152RC and STM32L152VC */ | |||||
/* #define STM32L152xCA */ /*!< STM32L152RC-A, STM32L152VC-A, STM32L152QC and STM32L152ZC */ | |||||
/* #define STM32L152xD */ /*!< STM32L152QD, STM32L152RD, STM32L152VD and STM32L152ZD */ | |||||
/* #define STM32L152xDX */ /*!< STM32L152VD-X Devices */ | |||||
/* #define STM32L152xE */ /*!< STM32L152QE, STM32L152RE, STM32L152VE and STM32L152ZE */ | |||||
/* #define STM32L162xC */ /*!< STM32L162RC and STM32L162VC */ | |||||
/* #define STM32L162xCA */ /*!< STM32L162RC-A, STM32L162VC-A, STM32L162QC and STM32L162ZC */ | |||||
/* #define STM32L162xD */ /*!< STM32L162QD, STM32L162RD, STM32L162VD and STM32L162ZD */ | |||||
/* #define STM32L162xDX */ /*!< STM32L162VD-X Devices */ | |||||
/* #define STM32L162xE */ /*!< STM32L162RE, STM32L162VE and STM32L162ZE */ | |||||
#endif | |||||
/* Tip: To avoid modifying this file each time you need to switch between these | |||||
devices, you can define the device in your toolchain compiler preprocessor. | |||||
*/ | |||||
#if !defined (USE_HAL_DRIVER) | |||||
/** | |||||
* @brief Comment the line below if you will not use the peripherals drivers. | |||||
In this case, these drivers will not be included and the application code will | |||||
be based on direct access to peripherals registers | |||||
*/ | |||||
/*#define USE_HAL_DRIVER */ | |||||
#endif /* USE_HAL_DRIVER */ | |||||
/** | |||||
* @brief CMSIS Device version number | |||||
*/ | |||||
#define __STM32L1xx_CMSIS_VERSION_MAIN (0x02) /*!< [31:24] main version */ | |||||
#define __STM32L1xx_CMSIS_VERSION_SUB1 (0x03) /*!< [23:16] sub1 version */ | |||||
#define __STM32L1xx_CMSIS_VERSION_SUB2 (0x00) /*!< [15:8] sub2 version */ | |||||
#define __STM32L1xx_CMSIS_VERSION_RC (0x00) /*!< [7:0] release candidate */ | |||||
#define __STM32L1xx_CMSIS_VERSION ((__STM32L1xx_CMSIS_VERSION_MAIN << 24)\ | |||||
|(__STM32L1xx_CMSIS_VERSION_SUB1 << 16)\ | |||||
|(__STM32L1xx_CMSIS_VERSION_SUB2 << 8 )\ | |||||
|(__STM32L1xx_CMSIS_VERSION_RC)) | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup Device_Included | |||||
* @{ | |||||
*/ | |||||
#if defined(STM32L100xB) | |||||
#include "stm32l100xb.h" | |||||
#elif defined(STM32L100xBA) | |||||
#include "stm32l100xba.h" | |||||
#elif defined(STM32L100xC) | |||||
#include "stm32l100xc.h" | |||||
#elif defined(STM32L151xB) | |||||
#include "stm32l151xb.h" | |||||
#elif defined(STM32L151xBA) | |||||
#include "stm32l151xba.h" | |||||
#elif defined(STM32L151xC) | |||||
#include "stm32l151xc.h" | |||||
#elif defined(STM32L151xCA) | |||||
#include "stm32l151xca.h" | |||||
#elif defined(STM32L151xD) | |||||
#include "stm32l151xd.h" | |||||
#elif defined(STM32L151xDX) | |||||
#include "stm32l151xdx.h" | |||||
#elif defined(STM32L151xE) | |||||
#include "stm32l151xe.h" | |||||
#elif defined(STM32L152xB) | |||||
#include "stm32l152xb.h" | |||||
#elif defined(STM32L152xBA) | |||||
#include "stm32l152xba.h" | |||||
#elif defined(STM32L152xC) | |||||
#include "stm32l152xc.h" | |||||
#elif defined(STM32L152xCA) | |||||
#include "stm32l152xca.h" | |||||
#elif defined(STM32L152xD) | |||||
#include "stm32l152xd.h" | |||||
#elif defined(STM32L152xDX) | |||||
#include "stm32l152xdx.h" | |||||
#elif defined(STM32L152xE) | |||||
#include "stm32l152xe.h" | |||||
#elif defined(STM32L162xC) | |||||
#include "stm32l162xc.h" | |||||
#elif defined(STM32L162xCA) | |||||
#include "stm32l162xca.h" | |||||
#elif defined(STM32L162xD) | |||||
#include "stm32l162xd.h" | |||||
#elif defined(STM32L162xDX) | |||||
#include "stm32l162xdx.h" | |||||
#elif defined(STM32L162xE) | |||||
#include "stm32l162xe.h" | |||||
#else | |||||
#error "Please select first the target STM32L1xx device used in your application (in stm32l1xx.h file)" | |||||
#endif | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup Exported_types | |||||
* @{ | |||||
*/ | |||||
typedef enum | |||||
{ | |||||
RESET = 0, | |||||
SET = !RESET | |||||
} FlagStatus, ITStatus; | |||||
typedef enum | |||||
{ | |||||
DISABLE = 0, | |||||
ENABLE = !DISABLE | |||||
} FunctionalState; | |||||
#define IS_FUNCTIONAL_STATE(STATE) (((STATE) == DISABLE) || ((STATE) == ENABLE)) | |||||
typedef enum | |||||
{ | |||||
SUCCESS = 0, | |||||
ERROR = !SUCCESS | |||||
} ErrorStatus; | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup Exported_macros | |||||
* @{ | |||||
*/ | |||||
#define SET_BIT(REG, BIT) ((REG) |= (BIT)) | |||||
#define CLEAR_BIT(REG, BIT) ((REG) &= ~(BIT)) | |||||
#define READ_BIT(REG, BIT) ((REG) & (BIT)) | |||||
#define CLEAR_REG(REG) ((REG) = (0x0)) | |||||
#define WRITE_REG(REG, VAL) ((REG) = (VAL)) | |||||
#define READ_REG(REG) ((REG)) | |||||
#define MODIFY_REG(REG, CLEARMASK, SETMASK) WRITE_REG((REG), (((READ_REG(REG)) & (~(CLEARMASK))) | (SETMASK))) | |||||
#define POSITION_VAL(VAL) (__CLZ(__RBIT(VAL))) | |||||
/** | |||||
* @} | |||||
*/ | |||||
#if defined (USE_HAL_DRIVER) | |||||
#include "stm32l1xx_hal.h" | |||||
#endif /* USE_HAL_DRIVER */ | |||||
#ifdef __cplusplus | |||||
} | |||||
#endif /* __cplusplus */ | |||||
#endif /* __STM32L1xx_H */ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ |
@@ -0,0 +1,426 @@ | |||||
/** | |||||
****************************************************************************** | |||||
* @file system_stm32l1xx.c | |||||
* @author MCD Application Team | |||||
* @brief CMSIS Cortex-M3 Device Peripheral Access Layer System Source File. | |||||
* | |||||
* This file provides two functions and one global variable to be called from | |||||
* user application: | |||||
* - SystemInit(): This function is called at startup just after reset and | |||||
* before branch to main program. This call is made inside | |||||
* the "startup_stm32l1xx.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. | |||||
* | |||||
****************************************************************************** | |||||
* @attention | |||||
* | |||||
* <h2><center>© Copyright (c) 2017 STMicroelectronics. | |||||
* All rights reserved.</center></h2> | |||||
* | |||||
* This software component is licensed by ST under BSD 3-Clause license, | |||||
* the "License"; You may not use this file except in compliance with the | |||||
* License. You may obtain a copy of the License at: | |||||
* opensource.org/licenses/BSD-3-Clause | |||||
* | |||||
****************************************************************************** | |||||
*/ | |||||
/** @addtogroup CMSIS | |||||
* @{ | |||||
*/ | |||||
/** @addtogroup stm32l1xx_system | |||||
* @{ | |||||
*/ | |||||
/** @addtogroup STM32L1xx_System_Private_Includes | |||||
* @{ | |||||
*/ | |||||
#include "stm32l1xx.h" | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup STM32L1xx_System_Private_TypesDefinitions | |||||
* @{ | |||||
*/ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup STM32L1xx_System_Private_Defines | |||||
* @{ | |||||
*/ | |||||
#if !defined (HSE_VALUE) | |||||
#define HSE_VALUE ((uint32_t)8000000U) /*!< Default value of the External oscillator in Hz. | |||||
This value can be provided and adapted by the user application. */ | |||||
#endif /* HSE_VALUE */ | |||||
#if !defined (HSI_VALUE) | |||||
#define HSI_VALUE ((uint32_t)8000000U) /*!< Default value of the Internal oscillator in Hz. | |||||
This value can be provided and adapted by the user application. */ | |||||
#endif /* HSI_VALUE */ | |||||
/*!< Uncomment the following line if you need to use external SRAM mounted | |||||
on STM32L152D_EVAL board as data memory */ | |||||
/* #define DATA_IN_ExtSRAM */ | |||||
/*!< Uncomment the following line if you need to relocate your vector Table in | |||||
Internal SRAM. */ | |||||
/* #define VECT_TAB_SRAM */ | |||||
#define VECT_TAB_OFFSET 0x00U /*!< Vector Table base offset field. | |||||
This value must be a multiple of 0x200. */ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup STM32L1xx_System_Private_Macros | |||||
* @{ | |||||
*/ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup STM32L1xx_System_Private_Variables | |||||
* @{ | |||||
*/ | |||||
/* This variable is updated in three ways: | |||||
1) by calling CMSIS function SystemCoreClockUpdate() | |||||
2) by calling HAL API function HAL_RCC_GetHCLKFreq() | |||||
3) each time HAL_RCC_ClockConfig() is called to configure the system clock frequency | |||||
Note: If you use this function to configure the system clock; then there | |||||
is no need to call the 2 first functions listed above, since SystemCoreClock | |||||
variable is updated automatically. | |||||
*/ | |||||
uint32_t SystemCoreClock = 2097000U; | |||||
const uint8_t PLLMulTable[9] = {3U, 4U, 6U, 8U, 12U, 16U, 24U, 32U, 48U}; | |||||
const uint8_t AHBPrescTable[16] = {0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 1U, 2U, 3U, 4U, 6U, 7U, 8U, 9U}; | |||||
const uint8_t APBPrescTable[8] = {0U, 0U, 0U, 0U, 1U, 2U, 3U, 4U}; | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup STM32L1xx_System_Private_FunctionPrototypes | |||||
* @{ | |||||
*/ | |||||
#if defined (STM32L151xD) || defined (STM32L152xD) || defined (STM32L162xD) | |||||
#ifdef DATA_IN_ExtSRAM | |||||
static void SystemInit_ExtMemCtl(void); | |||||
#endif /* DATA_IN_ExtSRAM */ | |||||
#endif /* STM32L151xD || STM32L152xD || STM32L162xD */ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @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; | |||||
#ifdef DATA_IN_ExtSRAM | |||||
SystemInit_ExtMemCtl(); | |||||
#endif /* DATA_IN_ExtSRAM */ | |||||
#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 | |||||
* The SystemCoreClock variable contains the core clock (HCLK), it can | |||||
* be used by the user application to setup the SysTick timer or configure | |||||
* other parameters. | |||||
* | |||||
* @note Each time the core clock (HCLK) changes, this function must be called | |||||
* to update SystemCoreClock variable value. Otherwise, any configuration | |||||
* based on this variable will be incorrect. | |||||
* | |||||
* @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; | |||||
} | |||||
#if defined (STM32L151xD) || defined (STM32L152xD) || defined (STM32L162xD) | |||||
#ifdef DATA_IN_ExtSRAM | |||||
/** | |||||
* @brief Setup the external memory controller. | |||||
* Called in SystemInit() function before jump to main. | |||||
* This function configures the external SRAM mounted on STM32L152D_EVAL board | |||||
* This SRAM will be used as program data memory (including heap and stack). | |||||
* @param None | |||||
* @retval None | |||||
*/ | |||||
void SystemInit_ExtMemCtl(void) | |||||
{ | |||||
__IO uint32_t tmpreg = 0; | |||||
/* Flash 1 wait state */ | |||||
FLASH->ACR |= FLASH_ACR_LATENCY; | |||||
/* Power enable */ | |||||
RCC->APB1ENR |= RCC_APB1ENR_PWREN; | |||||
/* Delay after an RCC peripheral clock enabling */ | |||||
tmpreg = READ_BIT(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) | |||||
{ | |||||
} | |||||
/*-- GPIOs Configuration -----------------------------------------------------*/ | |||||
/* | |||||
+-------------------+--------------------+------------------+------------------+ | |||||
+ SRAM pins assignment + | |||||
+-------------------+--------------------+------------------+------------------+ | |||||
| PD0 <-> FSMC_D2 | PE0 <-> FSMC_NBL0 | PF0 <-> FSMC_A0 | PG0 <-> FSMC_A10 | | |||||
| PD1 <-> FSMC_D3 | PE1 <-> FSMC_NBL1 | PF1 <-> FSMC_A1 | PG1 <-> FSMC_A11 | | |||||
| PD4 <-> FSMC_NOE | PE7 <-> FSMC_D4 | PF2 <-> FSMC_A2 | PG2 <-> FSMC_A12 | | |||||
| PD5 <-> FSMC_NWE | PE8 <-> FSMC_D5 | PF3 <-> FSMC_A3 | PG3 <-> FSMC_A13 | | |||||
| PD8 <-> FSMC_D13 | PE9 <-> FSMC_D6 | PF4 <-> FSMC_A4 | PG4 <-> FSMC_A14 | | |||||
| PD9 <-> FSMC_D14 | PE10 <-> FSMC_D7 | PF5 <-> FSMC_A5 | PG5 <-> FSMC_A15 | | |||||
| PD10 <-> FSMC_D15 | PE11 <-> FSMC_D8 | PF12 <-> FSMC_A6 | PG10<-> FSMC_NE2 | | |||||
| PD11 <-> FSMC_A16 | PE12 <-> FSMC_D9 | PF13 <-> FSMC_A7 |------------------+ | |||||
| PD12 <-> FSMC_A17 | PE13 <-> FSMC_D10 | PF14 <-> FSMC_A8 | | |||||
| PD13 <-> FSMC_A18 | PE14 <-> FSMC_D11 | PF15 <-> FSMC_A9 | | |||||
| PD14 <-> FSMC_D0 | PE15 <-> FSMC_D12 |------------------+ | |||||
| PD15 <-> FSMC_D1 |--------------------+ | |||||
+-------------------+ | |||||
*/ | |||||
/* Enable GPIOD, GPIOE, GPIOF and GPIOG interface clock */ | |||||
RCC->AHBENR = 0x000080D8; | |||||
/* Delay after an RCC peripheral clock enabling */ | |||||
tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIODEN); | |||||
/* Connect PDx pins to FSMC Alternate function */ | |||||
GPIOD->AFR[0] = 0x00CC00CC; | |||||
GPIOD->AFR[1] = 0xCCCCCCCC; | |||||
/* Configure PDx pins in Alternate function mode */ | |||||
GPIOD->MODER = 0xAAAA0A0A; | |||||
/* Configure PDx pins speed to 40 MHz */ | |||||
GPIOD->OSPEEDR = 0xFFFF0F0F; | |||||
/* Configure PDx pins Output type to push-pull */ | |||||
GPIOD->OTYPER = 0x00000000; | |||||
/* No pull-up, pull-down for PDx pins */ | |||||
GPIOD->PUPDR = 0x00000000; | |||||
/* Connect PEx pins to FSMC Alternate function */ | |||||
GPIOE->AFR[0] = 0xC00000CC; | |||||
GPIOE->AFR[1] = 0xCCCCCCCC; | |||||
/* Configure PEx pins in Alternate function mode */ | |||||
GPIOE->MODER = 0xAAAA800A; | |||||
/* Configure PEx pins speed to 40 MHz */ | |||||
GPIOE->OSPEEDR = 0xFFFFC00F; | |||||
/* Configure PEx pins Output type to push-pull */ | |||||
GPIOE->OTYPER = 0x00000000; | |||||
/* No pull-up, pull-down for PEx pins */ | |||||
GPIOE->PUPDR = 0x00000000; | |||||
/* Connect PFx pins to FSMC Alternate function */ | |||||
GPIOF->AFR[0] = 0x00CCCCCC; | |||||
GPIOF->AFR[1] = 0xCCCC0000; | |||||
/* Configure PFx pins in Alternate function mode */ | |||||
GPIOF->MODER = 0xAA000AAA; | |||||
/* Configure PFx pins speed to 40 MHz */ | |||||
GPIOF->OSPEEDR = 0xFF000FFF; | |||||
/* Configure PFx pins Output type to push-pull */ | |||||
GPIOF->OTYPER = 0x00000000; | |||||
/* No pull-up, pull-down for PFx pins */ | |||||
GPIOF->PUPDR = 0x00000000; | |||||
/* Connect PGx pins to FSMC Alternate function */ | |||||
GPIOG->AFR[0] = 0x00CCCCCC; | |||||
GPIOG->AFR[1] = 0x00000C00; | |||||
/* Configure PGx pins in Alternate function mode */ | |||||
GPIOG->MODER = 0x00200AAA; | |||||
/* Configure PGx pins speed to 40 MHz */ | |||||
GPIOG->OSPEEDR = 0x00300FFF; | |||||
/* Configure PGx pins Output type to push-pull */ | |||||
GPIOG->OTYPER = 0x00000000; | |||||
/* No pull-up, pull-down for PGx pins */ | |||||
GPIOG->PUPDR = 0x00000000; | |||||
/*-- FSMC Configuration ------------------------------------------------------*/ | |||||
/* Enable the FSMC interface clock */ | |||||
RCC->AHBENR = 0x400080D8; | |||||
/* Delay after an RCC peripheral clock enabling */ | |||||
tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_FSMCEN); | |||||
(void)(tmpreg); | |||||
/* Configure and enable Bank1_SRAM3 */ | |||||
FSMC_Bank1->BTCR[4] = 0x00001011; | |||||
FSMC_Bank1->BTCR[5] = 0x00000300; | |||||
FSMC_Bank1E->BWTR[4] = 0x0FFFFFFF; | |||||
/* | |||||
Bank1_SRAM3 is configured as follow: | |||||
p.FSMC_AddressSetupTime = 0; | |||||
p.FSMC_AddressHoldTime = 0; | |||||
p.FSMC_DataSetupTime = 3; | |||||
p.FSMC_BusTurnAroundDuration = 0; | |||||
p.FSMC_CLKDivision = 0; | |||||
p.FSMC_DataLatency = 0; | |||||
p.FSMC_AccessMode = FSMC_AccessMode_A; | |||||
FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM3; | |||||
FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable; | |||||
FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM; | |||||
FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b; | |||||
FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable; | |||||
FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable; | |||||
FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low; | |||||
FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable; | |||||
FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState; | |||||
FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable; | |||||
FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable; | |||||
FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable; | |||||
FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable; | |||||
FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &p; | |||||
FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &p; | |||||
FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure); | |||||
FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM3, ENABLE); | |||||
*/ | |||||
} | |||||
#endif /* DATA_IN_ExtSRAM */ | |||||
#endif /* STM32L151xD || STM32L152xD || STM32L162xD */ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ |
@@ -0,0 +1,108 @@ | |||||
/** | |||||
****************************************************************************** | |||||
* @file system_stm32l1xx.h | |||||
* @author MCD Application Team | |||||
* @brief CMSIS Cortex-M3 Device System Source File for STM32L1xx devices. | |||||
****************************************************************************** | |||||
* @attention | |||||
* | |||||
* <h2><center>© Copyright (c) 2017 STMicroelectronics. | |||||
* All rights reserved.</center></h2> | |||||
* | |||||
* This software component is licensed by ST under BSD 3-Clause license, | |||||
* the "License"; You may not use this file except in compliance with the | |||||
* License. You may obtain a copy of the License at: | |||||
* opensource.org/licenses/BSD-3-Clause | |||||
* | |||||
****************************************************************************** | |||||
*/ | |||||
/** @addtogroup CMSIS | |||||
* @{ | |||||
*/ | |||||
/** @addtogroup stm32l1xx_system | |||||
* @{ | |||||
*/ | |||||
/** | |||||
* @brief Define to prevent recursive inclusion | |||||
*/ | |||||
#ifndef __SYSTEM_STM32L1XX_H | |||||
#define __SYSTEM_STM32L1XX_H | |||||
#ifdef __cplusplus | |||||
extern "C" { | |||||
#endif | |||||
/** @addtogroup STM32L1xx_System_Includes | |||||
* @{ | |||||
*/ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup STM32L1xx_System_Exported_types | |||||
* @{ | |||||
*/ | |||||
/* This variable is updated in three ways: | |||||
1) by calling CMSIS function SystemCoreClockUpdate() | |||||
2) by calling HAL API function HAL_RCC_GetSysClockFreq() | |||||
3) each time HAL_RCC_ClockConfig() is called to configure the system clock frequency | |||||
Note: If you use this function to configure the system clock; then there | |||||
is no need to call the 2 first functions listed above, since SystemCoreClock | |||||
variable is updated automatically. | |||||
*/ | |||||
extern uint32_t SystemCoreClock; /*!< System Clock Frequency (Core Clock) */ | |||||
/* | |||||
*/ | |||||
extern const uint8_t AHBPrescTable[16]; /*!< AHB prescalers table values */ | |||||
extern const uint8_t APBPrescTable[8]; /*!< APB prescalers table values */ | |||||
extern const uint8_t PLLMulTable[9]; /*!< PLL multipiers table values */ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup STM32L1xx_System_Exported_Constants | |||||
* @{ | |||||
*/ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup STM32L1xx_System_Exported_Macros | |||||
* @{ | |||||
*/ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** @addtogroup STM32L1xx_System_Exported_Functions | |||||
* @{ | |||||
*/ | |||||
extern void SystemInit(void); | |||||
extern void SystemCoreClockUpdate(void); | |||||
/** | |||||
* @} | |||||
*/ | |||||
#ifdef __cplusplus | |||||
} | |||||
#endif | |||||
#endif /*__SYSTEM_STM32L1XX_H */ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/** | |||||
* @} | |||||
*/ | |||||
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ |
@@ -0,0 +1,270 @@ | |||||
/****************************************************************************** | |||||
* @file mpu_armv7.h | |||||
* @brief CMSIS MPU API for Armv7-M MPU | |||||
* @version V5.0.4 | |||||
* @date 10. January 2018 | |||||
******************************************************************************/ | |||||
/* | |||||
* Copyright (c) 2017-2018 Arm Limited. All rights reserved. | |||||
* | |||||
* SPDX-License-Identifier: Apache-2.0 | |||||
* | |||||
* Licensed under the Apache License, Version 2.0 (the License); you may | |||||
* not use this file except in compliance with the License. | |||||
* You may obtain a copy of the License at | |||||
* | |||||
* www.apache.org/licenses/LICENSE-2.0 | |||||
* | |||||
* 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. | |||||
*/ | |||||
#if defined ( __ICCARM__ ) | |||||
#pragma system_include /* treat file as system include file for MISRA check */ | |||||
#elif defined (__clang__) | |||||
#pragma clang system_header /* treat file as system include file */ | |||||
#endif | |||||
#ifndef ARM_MPU_ARMV7_H | |||||
#define ARM_MPU_ARMV7_H | |||||
#define ARM_MPU_REGION_SIZE_32B ((uint8_t)0x04U) ///!< MPU Region Size 32 Bytes | |||||
#define ARM_MPU_REGION_SIZE_64B ((uint8_t)0x05U) ///!< MPU Region Size 64 Bytes | |||||
#define ARM_MPU_REGION_SIZE_128B ((uint8_t)0x06U) ///!< MPU Region Size 128 Bytes | |||||
#define ARM_MPU_REGION_SIZE_256B ((uint8_t)0x07U) ///!< MPU Region Size 256 Bytes | |||||
#define ARM_MPU_REGION_SIZE_512B ((uint8_t)0x08U) ///!< MPU Region Size 512 Bytes | |||||
#define ARM_MPU_REGION_SIZE_1KB ((uint8_t)0x09U) ///!< MPU Region Size 1 KByte | |||||
#define ARM_MPU_REGION_SIZE_2KB ((uint8_t)0x0AU) ///!< MPU Region Size 2 KBytes | |||||
#define ARM_MPU_REGION_SIZE_4KB ((uint8_t)0x0BU) ///!< MPU Region Size 4 KBytes | |||||
#define ARM_MPU_REGION_SIZE_8KB ((uint8_t)0x0CU) ///!< MPU Region Size 8 KBytes | |||||
#define ARM_MPU_REGION_SIZE_16KB ((uint8_t)0x0DU) ///!< MPU Region Size 16 KBytes | |||||
#define ARM_MPU_REGION_SIZE_32KB ((uint8_t)0x0EU) ///!< MPU Region Size 32 KBytes | |||||
#define ARM_MPU_REGION_SIZE_64KB ((uint8_t)0x0FU) ///!< MPU Region Size 64 KBytes | |||||
#define ARM_MPU_REGION_SIZE_128KB ((uint8_t)0x10U) ///!< MPU Region Size 128 KBytes | |||||
#define ARM_MPU_REGION_SIZE_256KB ((uint8_t)0x11U) ///!< MPU Region Size 256 KBytes | |||||
#define ARM_MPU_REGION_SIZE_512KB ((uint8_t)0x12U) ///!< MPU Region Size 512 KBytes | |||||
#define ARM_MPU_REGION_SIZE_1MB ((uint8_t)0x13U) ///!< MPU Region Size 1 MByte | |||||
#define ARM_MPU_REGION_SIZE_2MB ((uint8_t)0x14U) ///!< MPU Region Size 2 MBytes | |||||
#define ARM_MPU_REGION_SIZE_4MB ((uint8_t)0x15U) ///!< MPU Region Size 4 MBytes | |||||
#define ARM_MPU_REGION_SIZE_8MB ((uint8_t)0x16U) ///!< MPU Region Size 8 MBytes | |||||
#define ARM_MPU_REGION_SIZE_16MB ((uint8_t)0x17U) ///!< MPU Region Size 16 MBytes | |||||
#define ARM_MPU_REGION_SIZE_32MB ((uint8_t)0x18U) ///!< MPU Region Size 32 MBytes | |||||
#define ARM_MPU_REGION_SIZE_64MB ((uint8_t)0x19U) ///!< MPU Region Size 64 MBytes | |||||
#define ARM_MPU_REGION_SIZE_128MB ((uint8_t)0x1AU) ///!< MPU Region Size 128 MBytes | |||||
#define ARM_MPU_REGION_SIZE_256MB ((uint8_t)0x1BU) ///!< MPU Region Size 256 MBytes | |||||
#define ARM_MPU_REGION_SIZE_512MB ((uint8_t)0x1CU) ///!< MPU Region Size 512 MBytes | |||||
#define ARM_MPU_REGION_SIZE_1GB ((uint8_t)0x1DU) ///!< MPU Region Size 1 GByte | |||||
#define ARM_MPU_REGION_SIZE_2GB ((uint8_t)0x1EU) ///!< MPU Region Size 2 GBytes | |||||
#define ARM_MPU_REGION_SIZE_4GB ((uint8_t)0x1FU) ///!< MPU Region Size 4 GBytes | |||||
#define ARM_MPU_AP_NONE 0U ///!< MPU Access Permission no access | |||||
#define ARM_MPU_AP_PRIV 1U ///!< MPU Access Permission privileged access only | |||||
#define ARM_MPU_AP_URO 2U ///!< MPU Access Permission unprivileged access read-only | |||||
#define ARM_MPU_AP_FULL 3U ///!< MPU Access Permission full access | |||||
#define ARM_MPU_AP_PRO 5U ///!< MPU Access Permission privileged access read-only | |||||
#define ARM_MPU_AP_RO 6U ///!< MPU Access Permission read-only access | |||||
/** MPU Region Base Address Register Value | |||||
* | |||||
* \param Region The region to be configured, number 0 to 15. | |||||
* \param BaseAddress The base address for the region. | |||||
*/ | |||||
#define ARM_MPU_RBAR(Region, BaseAddress) \ | |||||
(((BaseAddress) & MPU_RBAR_ADDR_Msk) | \ | |||||
((Region) & MPU_RBAR_REGION_Msk) | \ | |||||
(MPU_RBAR_VALID_Msk)) | |||||
/** | |||||
* MPU Memory Access Attributes | |||||
* | |||||
* \param TypeExtField Type extension field, allows you to configure memory access type, for example strongly ordered, peripheral. | |||||
* \param IsShareable Region is shareable between multiple bus masters. | |||||
* \param IsCacheable Region is cacheable, i.e. its value may be kept in cache. | |||||
* \param IsBufferable Region is bufferable, i.e. using write-back caching. Cacheable but non-bufferable regions use write-through policy. | |||||
*/ | |||||
#define ARM_MPU_ACCESS_(TypeExtField, IsShareable, IsCacheable, IsBufferable) \ | |||||
((((TypeExtField ) << MPU_RASR_TEX_Pos) & MPU_RASR_TEX_Msk) | \ | |||||
(((IsShareable ) << MPU_RASR_S_Pos) & MPU_RASR_S_Msk) | \ | |||||
(((IsCacheable ) << MPU_RASR_C_Pos) & MPU_RASR_C_Msk) | \ | |||||
(((IsBufferable ) << MPU_RASR_B_Pos) & MPU_RASR_B_Msk)) | |||||
/** | |||||
* MPU Region Attribute and Size Register Value | |||||
* | |||||
* \param DisableExec Instruction access disable bit, 1= disable instruction fetches. | |||||
* \param AccessPermission Data access permissions, allows you to configure read/write access for User and Privileged mode. | |||||
* \param AccessAttributes Memory access attribution, see \ref ARM_MPU_ACCESS_. | |||||
* \param SubRegionDisable Sub-region disable field. | |||||
* \param Size Region size of the region to be configured, for example 4K, 8K. | |||||
*/ | |||||
#define ARM_MPU_RASR_EX(DisableExec, AccessPermission, AccessAttributes, SubRegionDisable, Size) \ | |||||
((((DisableExec ) << MPU_RASR_XN_Pos) & MPU_RASR_XN_Msk) | \ | |||||
(((AccessPermission) << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk) | \ | |||||
(((AccessAttributes) ) & (MPU_RASR_TEX_Msk | MPU_RASR_S_Msk | MPU_RASR_C_Msk | MPU_RASR_B_Msk))) | |||||
/** | |||||
* MPU Region Attribute and Size Register Value | |||||
* | |||||
* \param DisableExec Instruction access disable bit, 1= disable instruction fetches. | |||||
* \param AccessPermission Data access permissions, allows you to configure read/write access for User and Privileged mode. | |||||
* \param TypeExtField Type extension field, allows you to configure memory access type, for example strongly ordered, peripheral. | |||||
* \param IsShareable Region is shareable between multiple bus masters. | |||||
* \param IsCacheable Region is cacheable, i.e. its value may be kept in cache. | |||||
* \param IsBufferable Region is bufferable, i.e. using write-back caching. Cacheable but non-bufferable regions use write-through policy. | |||||
* \param SubRegionDisable Sub-region disable field. | |||||
* \param Size Region size of the region to be configured, for example 4K, 8K. | |||||
*/ | |||||
#define ARM_MPU_RASR(DisableExec, AccessPermission, TypeExtField, IsShareable, IsCacheable, IsBufferable, SubRegionDisable, Size) \ | |||||
ARM_MPU_RASR_EX(DisableExec, AccessPermission, ARM_MPU_ACCESS_(TypeExtField, IsShareable, IsCacheable, IsBufferable), SubRegionDisable, Size) | |||||
/** | |||||
* MPU Memory Access Attribute for strongly ordered memory. | |||||
* - TEX: 000b | |||||
* - Shareable | |||||
* - Non-cacheable | |||||
* - Non-bufferable | |||||
*/ | |||||
#define ARM_MPU_ACCESS_ORDERED ARM_MPU_ACCESS_(0U, 1U, 0U, 0U) | |||||
/** | |||||
* MPU Memory Access Attribute for device memory. | |||||
* - TEX: 000b (if non-shareable) or 010b (if shareable) | |||||
* - Shareable or non-shareable | |||||
* - Non-cacheable | |||||
* - Bufferable (if shareable) or non-bufferable (if non-shareable) | |||||
* | |||||
* \param IsShareable Configures the device memory as shareable or non-shareable. | |||||
*/ | |||||
#define ARM_MPU_ACCESS_DEVICE(IsShareable) ((IsShareable) ? ARM_MPU_ACCESS_(0U, 1U, 0U, 1U) : ARM_MPU_ACCESS_(2U, 0U, 0U, 0U)) | |||||
/** | |||||
* MPU Memory Access Attribute for normal memory. | |||||
* - TEX: 1BBb (reflecting outer cacheability rules) | |||||
* - Shareable or non-shareable | |||||
* - Cacheable or non-cacheable (reflecting inner cacheability rules) | |||||
* - Bufferable or non-bufferable (reflecting inner cacheability rules) | |||||
* | |||||
* \param OuterCp Configures the outer cache policy. | |||||
* \param InnerCp Configures the inner cache policy. | |||||
* \param IsShareable Configures the memory as shareable or non-shareable. | |||||
*/ | |||||
#define ARM_MPU_ACCESS_NORMAL(OuterCp, InnerCp, IsShareable) ARM_MPU_ACCESS_((4U | (OuterCp)), IsShareable, ((InnerCp) & 2U), ((InnerCp) & 1U)) | |||||
/** | |||||
* MPU Memory Access Attribute non-cacheable policy. | |||||
*/ | |||||
#define ARM_MPU_CACHEP_NOCACHE 0U | |||||
/** | |||||
* MPU Memory Access Attribute write-back, write and read allocate policy. | |||||
*/ | |||||
#define ARM_MPU_CACHEP_WB_WRA 1U | |||||
/** | |||||
* MPU Memory Access Attribute write-through, no write allocate policy. | |||||
*/ | |||||
#define ARM_MPU_CACHEP_WT_NWA 2U | |||||
/** | |||||
* MPU Memory Access Attribute write-back, no write allocate policy. | |||||
*/ | |||||
#define ARM_MPU_CACHEP_WB_NWA 3U | |||||
/** | |||||
* Struct for a single MPU Region | |||||
*/ | |||||
typedef struct { | |||||
uint32_t RBAR; //!< The region base address register value (RBAR) | |||||
uint32_t RASR; //!< The region attribute and size register value (RASR) \ref MPU_RASR | |||||
} ARM_MPU_Region_t; | |||||
/** Enable the MPU. | |||||
* \param MPU_Control Default access permissions for unconfigured regions. | |||||
*/ | |||||
__STATIC_INLINE void ARM_MPU_Enable(uint32_t MPU_Control) | |||||
{ | |||||
__DSB(); | |||||
__ISB(); | |||||
MPU->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk; | |||||
#ifdef SCB_SHCSR_MEMFAULTENA_Msk | |||||
SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk; | |||||
#endif | |||||
} | |||||
/** Disable the MPU. | |||||
*/ | |||||
__STATIC_INLINE void ARM_MPU_Disable(void) | |||||
{ | |||||
__DSB(); | |||||
__ISB(); | |||||
#ifdef SCB_SHCSR_MEMFAULTENA_Msk | |||||
SCB->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk; | |||||
#endif | |||||
MPU->CTRL &= ~MPU_CTRL_ENABLE_Msk; | |||||
} | |||||
/** Clear and disable the given MPU region. | |||||
* \param rnr Region number to be cleared. | |||||
*/ | |||||
__STATIC_INLINE void ARM_MPU_ClrRegion(uint32_t rnr) | |||||
{ | |||||
MPU->RNR = rnr; | |||||
MPU->RASR = 0U; | |||||
} | |||||
/** Configure an MPU region. | |||||
* \param rbar Value for RBAR register. | |||||
* \param rsar Value for RSAR register. | |||||
*/ | |||||
__STATIC_INLINE void ARM_MPU_SetRegion(uint32_t rbar, uint32_t rasr) | |||||
{ | |||||
MPU->RBAR = rbar; | |||||
MPU->RASR = rasr; | |||||
} | |||||
/** Configure the given MPU region. | |||||
* \param rnr Region number to be configured. | |||||
* \param rbar Value for RBAR register. | |||||
* \param rsar Value for RSAR register. | |||||
*/ | |||||
__STATIC_INLINE void ARM_MPU_SetRegionEx(uint32_t rnr, uint32_t rbar, uint32_t rasr) | |||||
{ | |||||
MPU->RNR = rnr; | |||||
MPU->RBAR = rbar; | |||||
MPU->RASR = rasr; | |||||
} | |||||
/** Memcopy with strictly ordered memory access, e.g. for register targets. | |||||
* \param dst Destination data is copied to. | |||||
* \param src Source data is copied from. | |||||
* \param len Amount of data words to be copied. | |||||
*/ | |||||
__STATIC_INLINE void orderedCpy(volatile uint32_t* dst, const uint32_t* __RESTRICT src, uint32_t len) | |||||
{ | |||||
uint32_t i; | |||||
for (i = 0U; i < len; ++i) | |||||
{ | |||||
dst[i] = src[i]; | |||||
} | |||||
} | |||||
/** Load the given number of MPU regions from a table. | |||||
* \param table Pointer to the MPU configuration table. | |||||
* \param cnt Amount of regions to be configured. | |||||
*/ | |||||
__STATIC_INLINE void ARM_MPU_Load(ARM_MPU_Region_t const* table, uint32_t cnt) | |||||
{ | |||||
const uint32_t rowWordSize = sizeof(ARM_MPU_Region_t)/4U; | |||||
while (cnt > MPU_TYPE_RALIASES) { | |||||
orderedCpy(&(MPU->RBAR), &(table->RBAR), MPU_TYPE_RALIASES*rowWordSize); | |||||
table += MPU_TYPE_RALIASES; | |||||
cnt -= MPU_TYPE_RALIASES; | |||||
} | |||||
orderedCpy(&(MPU->RBAR), &(table->RBAR), cnt*rowWordSize); | |||||
} | |||||
#endif |