1 /**************************************************************************//**
2  * @file     system_ARMCM7.c
3  * @brief    CMSIS Device System Source File for
4  *           ARMCM7 Device
5  * @version  V1.0.1
6  * @date     15. November 2019
7  ******************************************************************************/
8 /*
9  * Copyright (c) 2009-2019 Arm Limited. All rights reserved.
10  *
11  * SPDX-License-Identifier: Apache-2.0
12  *
13  * Licensed under the Apache License, Version 2.0 (the License); you may
14  * not use this file except in compliance with the License.
15  * You may obtain a copy of the License at
16  *
17  * www.apache.org/licenses/LICENSE-2.0
18  *
19  * Unless required by applicable law or agreed to in writing, software
20  * distributed under the License is distributed on an AS IS BASIS, WITHOUT
21  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
22  * See the License for the specific language governing permissions and
23  * limitations under the License.
24  */
25 
26 #if defined (ARMCM7)
27   #include "ARMCM7.h"
28 #elif defined (ARMCM7_SP)
29   #include "ARMCM7_SP.h"
30 #elif defined (ARMCM7_DP)
31   #include "ARMCM7_DP.h"
32 #else
33   #error device not specified!
34 #endif
35 
36 /*----------------------------------------------------------------------------
37   Define clocks
38  *----------------------------------------------------------------------------*/
39 #define  XTAL            (50000000UL)     /* Oscillator frequency */
40 
41 #define  SYSTEM_CLOCK    (XTAL / 2U)
42 
43 /*----------------------------------------------------------------------------
44   Exception / Interrupt Vector table
45  *----------------------------------------------------------------------------*/
46 extern const VECTOR_TABLE_Type __VECTOR_TABLE[240];
47 
48 
49 /*----------------------------------------------------------------------------
50   System Core Clock Variable
51  *----------------------------------------------------------------------------*/
52 uint32_t SystemCoreClock = SYSTEM_CLOCK;  /* System Core Clock Frequency */
53 
54 
55 /*----------------------------------------------------------------------------
56   System Core Clock update function
57  *----------------------------------------------------------------------------*/
SystemCoreClockUpdate(void)58 void SystemCoreClockUpdate (void)
59 {
60   SystemCoreClock = SYSTEM_CLOCK;
61 }
62 
63 /*----------------------------------------------------------------------------
64   System initialization function
65  *----------------------------------------------------------------------------*/
SystemInit(void)66 void SystemInit (void)
67 {
68 
69 #if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U)
70   SCB->VTOR = (uint32_t) &(__VECTOR_TABLE[0]);
71 #endif
72 
73 #if defined (__FPU_USED) && (__FPU_USED == 1U)
74   SCB->CPACR |= ((3U << 10U*2U) |           /* enable CP10 Full Access */
75                  (3U << 11U*2U)  );         /* enable CP11 Full Access */
76 #endif
77 
78 #ifdef UNALIGNED_SUPPORT_DISABLE
79   SCB->CCR |= SCB_CCR_UNALIGN_TRP_Msk;
80 #endif
81 
82   SystemCoreClock = SYSTEM_CLOCK;
83 }
84