xref: /arm-trusted-firmware/plat/qemu/common/qemu_private.h (revision 91f16700b400a8c0651d24a598fc48ee2997a0d7)
1*91f16700Schasinglulu /*
2*91f16700Schasinglulu  * Copyright (c) 2015-2023, Arm Limited and Contributors. All rights reserved.
3*91f16700Schasinglulu  *
4*91f16700Schasinglulu  * SPDX-License-Identifier: BSD-3-Clause
5*91f16700Schasinglulu  */
6*91f16700Schasinglulu 
7*91f16700Schasinglulu #ifndef QEMU_PRIVATE_H
8*91f16700Schasinglulu #define QEMU_PRIVATE_H
9*91f16700Schasinglulu 
10*91f16700Schasinglulu #include <stdint.h>
11*91f16700Schasinglulu 
12*91f16700Schasinglulu #include <lib/xlat_tables/xlat_tables_v2.h>
13*91f16700Schasinglulu 
14*91f16700Schasinglulu void plat_qemu_io_setup(void);
15*91f16700Schasinglulu int qemu_io_register_sp_pkg(const char *name, const char *uuid,
16*91f16700Schasinglulu 			    uintptr_t load_addr);
17*91f16700Schasinglulu unsigned int plat_qemu_calc_core_pos(u_register_t mpidr);
18*91f16700Schasinglulu const mmap_region_t *plat_qemu_get_mmap(void);
19*91f16700Schasinglulu 
20*91f16700Schasinglulu void qemu_console_init(void);
21*91f16700Schasinglulu #ifdef PLAT_qemu_sbsa
22*91f16700Schasinglulu void sip_svc_init(void);
23*91f16700Schasinglulu #endif
24*91f16700Schasinglulu 
25*91f16700Schasinglulu void plat_qemu_gic_init(void);
26*91f16700Schasinglulu void qemu_pwr_gic_on_finish(void);
27*91f16700Schasinglulu void qemu_pwr_gic_off(void);
28*91f16700Schasinglulu 
29*91f16700Schasinglulu int qemu_set_tos_fw_info(uintptr_t config_base, uintptr_t log_addr,
30*91f16700Schasinglulu 			size_t log_size);
31*91f16700Schasinglulu 
32*91f16700Schasinglulu int qemu_set_nt_fw_info(
33*91f16700Schasinglulu /*
34*91f16700Schasinglulu  * Currently OP-TEE does not support reading DTBs from Secure memory
35*91f16700Schasinglulu  * and this option should be removed when feature is supported.
36*91f16700Schasinglulu  */
37*91f16700Schasinglulu #ifdef SPD_opteed
38*91f16700Schasinglulu 			uintptr_t log_addr,
39*91f16700Schasinglulu #endif
40*91f16700Schasinglulu 			size_t log_size,
41*91f16700Schasinglulu 			uintptr_t *ns_log_addr);
42*91f16700Schasinglulu 
43*91f16700Schasinglulu void qemu_bl2_sync_transfer_list(void);
44*91f16700Schasinglulu 
45*91f16700Schasinglulu #endif /* QEMU_PRIVATE_H */
46