xref: /optee_os/core/kernel/initcall.c (revision e3172f9db6e5cc3092cd787795e255e39c8b80d8)
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