2 * This file is part of Cleanflight and Betaflight.
4 * Cleanflight and Betaflight are free software. You can redistribute
5 * this software and/or modify this software under the terms of the
6 * GNU General Public License as published by the Free Software
7 * Foundation, either version 3 of the License, or (at your option)
10 * Cleanflight and Betaflight are distributed in the hope that they
11 * will be useful, but WITHOUT ANY WARRANTY; without even the implied
12 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13 * See the GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this software.
18 * If not, see <http://www.gnu.org/licenses/>.
28 #include "drivers/accgyro/accgyro_mpu.h"
29 #include "drivers/exti.h"
30 #include "drivers/nvic.h"
31 #include "drivers/system.h"
32 #include "drivers/persistent.h"
34 #include "stm32f7xx_ll_cortex.h"
37 #define AIRCR_VECTKEY_MASK ((uint32_t)0x05FA0000)
39 #define DEFAULT_STACK_POINTER ((uint32_t *) 0x1FF00000)
40 #define SYSTEM_MEMORY_RESET_VECTOR ((uint32_t *) 0x1FF00004)
42 void SystemClock_Config(void);
44 void systemReset(void)
50 void systemResetToBootloader(bootloaderRequestType_e requestType
)
52 switch (requestType
) {
53 case BOOTLOADER_REQUEST_ROM
:
55 persistentObjectWrite(PERSISTENT_OBJECT_RESET_REASON
, RESET_BOOTLOADER_REQUEST_ROM
);
64 bool isMPUSoftReset(void)
66 if (cachedRccCsrValue
& RCC_CSR_SFTRSTF
)
72 static void checkForBootLoaderRequest(void)
74 uint32_t bootloaderRequest
= persistentObjectRead(PERSISTENT_OBJECT_RESET_REASON
);
76 if (bootloaderRequest
!= RESET_BOOTLOADER_REQUEST_ROM
) {
79 persistentObjectWrite(PERSISTENT_OBJECT_RESET_REASON
, RESET_BOOTLOADER_POST
);
81 __SYSCFG_CLK_ENABLE();
82 SYSCFG
->MEMRMP
|= SYSCFG_MEM_BOOT_ADD0
;
84 __set_MSP(*DEFAULT_STACK_POINTER
);
86 ((void (*)(void))*SYSTEM_MEMORY_RESET_VECTOR
)();
93 checkForBootLoaderRequest();
95 // Mark ITCM-RAM as read-only
96 LL_MPU_ConfigRegion(LL_MPU_REGION_NUMBER0
, 0, RAMITCM_BASE
, LL_MPU_REGION_SIZE_16KB
| LL_MPU_REGION_PRIV_RO_URO
);
97 LL_MPU_Enable(LL_MPU_CTRL_PRIVILEGED_DEFAULT
);
99 //SystemClock_Config();
101 // Configure NVIC preempt/priority groups
102 HAL_NVIC_SetPriorityGrouping(NVIC_PRIORITY_GROUPING
);
104 // cache RCC->CSR value to use it in isMPUSoftReset() and others
105 cachedRccCsrValue
= RCC
->CSR
;
107 /* Accounts for OP Bootloader, set the Vector Table base address as specified in .ld file */
108 //extern void *isr_vector_table_base;
109 //NVIC_SetVectorTable((uint32_t)&isr_vector_table_base, 0x0);
110 //__HAL_RCC_USB_OTG_FS_CLK_DISABLE;
114 // Init cycle counter
118 //SysTick_Config(SystemCoreClock / 1000);
119 HAL_SYSTICK_Config(HAL_RCC_GetHCLKFreq()/1000);
121 HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK
);