1 // SPDX-License-Identifier: BSD-2-Clause 2 /* 3 * Copyright (c) 2020, Linaro Limited 4 * Copyright (c) 2014, STMicroelectronics International N.V. 5 */ 6 7 #include <initcall.h> 8 #include <trace.h> 9 #include <kernel/linker.h> 10 11 /* 12 * Note: this function is weak just to make it possible to exclude it from 13 * the unpaged area. 14 */ 15 void __weak call_initcalls(void) 16 { 17 const struct initcall *call = NULL; 18 TEE_Result ret = TEE_SUCCESS; 19 20 for (call = initcall_begin; call < initcall_end; call++) { 21 DMSG("level %d %s()", call->level, call->func_name); 22 ret = call->func(); 23 if (ret != TEE_SUCCESS) { 24 EMSG("Initcall __text_start + 0x%08" PRIxVA 25 " failed", (vaddr_t)call - VCORE_START_VA); 26 } 27 } 28 29 IMSG("Initialized"); 30 } 31 32 /* 33 * Note: this function is weak just to make it possible to exclude it from 34 * the unpaged area. 35 */ 36 void __weak call_finalcalls(void) 37 { 38 const struct initcall *call = NULL; 39 TEE_Result ret = TEE_SUCCESS; 40 41 for (call = finalcall_begin; call < finalcall_end; call++) { 42 DMSG("level %d %s()", call->level, call->func_name); 43 ret = call->func(); 44 if (ret != TEE_SUCCESS) { 45 EMSG("Finalcall __text_start + 0x%08" PRIxVA 46 " failed", (vaddr_t)call - VCORE_START_VA); 47 } 48 } 49 50 IMSG("Done"); 51 } 52