xref: /aosp_15_r20/external/pigweed/targets/stm32f429i_disc1/boot.cc (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1*61c4878aSAndroid Build Coastguard Worker // Copyright 2020 The Pigweed Authors
2*61c4878aSAndroid Build Coastguard Worker //
3*61c4878aSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); you may not
4*61c4878aSAndroid Build Coastguard Worker // use this file except in compliance with the License. You may obtain a copy of
5*61c4878aSAndroid Build Coastguard Worker // the License at
6*61c4878aSAndroid Build Coastguard Worker //
7*61c4878aSAndroid Build Coastguard Worker //     https://www.apache.org/licenses/LICENSE-2.0
8*61c4878aSAndroid Build Coastguard Worker //
9*61c4878aSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*61c4878aSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11*61c4878aSAndroid Build Coastguard Worker // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12*61c4878aSAndroid Build Coastguard Worker // License for the specific language governing permissions and limitations under
13*61c4878aSAndroid Build Coastguard Worker // the License.
14*61c4878aSAndroid Build Coastguard Worker 
15*61c4878aSAndroid Build Coastguard Worker #include "pw_boot/boot.h"
16*61c4878aSAndroid Build Coastguard Worker 
17*61c4878aSAndroid Build Coastguard Worker #include "pw_boot_cortex_m/boot.h"
18*61c4878aSAndroid Build Coastguard Worker #include "pw_malloc/malloc.h"
19*61c4878aSAndroid Build Coastguard Worker #include "pw_preprocessor/compiler.h"
20*61c4878aSAndroid Build Coastguard Worker #include "pw_sys_io_baremetal_stm32f429/init.h"
21*61c4878aSAndroid Build Coastguard Worker 
22*61c4878aSAndroid Build Coastguard Worker // Note that constexpr is used inside of this function instead of using a static
23*61c4878aSAndroid Build Coastguard Worker // constexpr or declaring it outside of this function in an anonymous namespace,
24*61c4878aSAndroid Build Coastguard Worker // because constexpr makes it available for the compiler to evaluate during
25*61c4878aSAndroid Build Coastguard Worker // compile time but does NOT require it to be evaluated at compile time and we
26*61c4878aSAndroid Build Coastguard Worker // have to be incredibly careful that this does not end up in the .data section.
pw_boot_PreStaticMemoryInit()27*61c4878aSAndroid Build Coastguard Worker void pw_boot_PreStaticMemoryInit() {
28*61c4878aSAndroid Build Coastguard Worker // TODO: b/264897542 - Whether the FPU is enabled should be an Arm target trait.
29*61c4878aSAndroid Build Coastguard Worker #if defined(PW_ARMV7M_ENABLE_FPU) && PW_ARMV7M_ENABLE_FPU
30*61c4878aSAndroid Build Coastguard Worker   // Enable FPU if built using hardware FPU instructions.
31*61c4878aSAndroid Build Coastguard Worker   // CPCAR mask that enables FPU. (ARMv7-M Section B3.2.20)
32*61c4878aSAndroid Build Coastguard Worker   constexpr uint32_t kFpuEnableMask = (0xFu << 20);
33*61c4878aSAndroid Build Coastguard Worker 
34*61c4878aSAndroid Build Coastguard Worker   // Memory mapped register to enable FPU. (ARMv7-M Section B3.2.2, Table B3-4)
35*61c4878aSAndroid Build Coastguard Worker   volatile uint32_t& arm_v7m_cpacr =
36*61c4878aSAndroid Build Coastguard Worker       *reinterpret_cast<volatile uint32_t*>(0xE000ED88u);
37*61c4878aSAndroid Build Coastguard Worker   arm_v7m_cpacr = arm_v7m_cpacr | kFpuEnableMask;
38*61c4878aSAndroid Build Coastguard Worker 
39*61c4878aSAndroid Build Coastguard Worker   // Ensure the FPU configuration is committed and enabled before continuing and
40*61c4878aSAndroid Build Coastguard Worker   // potentially executing any FPU instructions, however rare that may be during
41*61c4878aSAndroid Build Coastguard Worker   // startup.
42*61c4878aSAndroid Build Coastguard Worker   asm volatile(
43*61c4878aSAndroid Build Coastguard Worker       " dsb \n"
44*61c4878aSAndroid Build Coastguard Worker       " isb \n"
45*61c4878aSAndroid Build Coastguard Worker       // clang-format off
46*61c4878aSAndroid Build Coastguard Worker       : /*output=*/
47*61c4878aSAndroid Build Coastguard Worker       : /*input=*/
48*61c4878aSAndroid Build Coastguard Worker       : /*clobbers=*/"memory"
49*61c4878aSAndroid Build Coastguard Worker       // clang-format on
50*61c4878aSAndroid Build Coastguard Worker   );
51*61c4878aSAndroid Build Coastguard Worker #endif  // PW_ARMV7M_ENABLE_FPU
52*61c4878aSAndroid Build Coastguard Worker }
53*61c4878aSAndroid Build Coastguard Worker 
pw_boot_PreStaticConstructorInit()54*61c4878aSAndroid Build Coastguard Worker void pw_boot_PreStaticConstructorInit() {
55*61c4878aSAndroid Build Coastguard Worker #if PW_MALLOC_ACTIVE
56*61c4878aSAndroid Build Coastguard Worker   pw_MallocInit(&pw_boot_heap_low_addr, &pw_boot_heap_high_addr);
57*61c4878aSAndroid Build Coastguard Worker #endif  // PW_MALLOC_ACTIVE
58*61c4878aSAndroid Build Coastguard Worker }
59*61c4878aSAndroid Build Coastguard Worker 
pw_boot_PreMainInit()60*61c4878aSAndroid Build Coastguard Worker void pw_boot_PreMainInit() { pw_sys_io_stm32f429_Init(); }
61*61c4878aSAndroid Build Coastguard Worker 
pw_boot_PostMain()62*61c4878aSAndroid Build Coastguard Worker PW_NO_RETURN void pw_boot_PostMain() {
63*61c4878aSAndroid Build Coastguard Worker   // In case main() returns, just sit here until the device is reset.
64*61c4878aSAndroid Build Coastguard Worker   while (true) {
65*61c4878aSAndroid Build Coastguard Worker   }
66*61c4878aSAndroid Build Coastguard Worker   PW_UNREACHABLE;
67*61c4878aSAndroid Build Coastguard Worker }
68