xref: /linux/arch/arm64/include/asm/hyp_image.h (revision fa21472a316af8ad7af3114049db89678444c7ed)
1ab25464bSDavid Brazdil /* SPDX-License-Identifier: GPL-2.0 */
2ab25464bSDavid Brazdil /*
3ab25464bSDavid Brazdil  * Copyright (C) 2020 Google LLC.
4ab25464bSDavid Brazdil  * Written by David Brazdil <dbrazdil@google.com>
5ab25464bSDavid Brazdil  */
6ab25464bSDavid Brazdil 
7ab25464bSDavid Brazdil #ifndef __ARM64_HYP_IMAGE_H__
8ab25464bSDavid Brazdil #define __ARM64_HYP_IMAGE_H__
9ab25464bSDavid Brazdil 
10f7a4825dSDavid Brazdil #define __HYP_CONCAT(a, b)	a ## b
11f7a4825dSDavid Brazdil #define HYP_CONCAT(a, b)	__HYP_CONCAT(a, b)
12f7a4825dSDavid Brazdil 
13*fa21472aSQuentin Perret #ifndef __KVM_NVHE_HYPERVISOR__
14ce492a16SDavid Brazdil /*
15ce492a16SDavid Brazdil  * KVM nVHE code has its own symbol namespace prefixed with __kvm_nvhe_,
16ce492a16SDavid Brazdil  * to separate it from the kernel proper.
17ce492a16SDavid Brazdil  */
18ce492a16SDavid Brazdil #define kvm_nvhe_sym(sym)	__kvm_nvhe_##sym
19*fa21472aSQuentin Perret #else
20*fa21472aSQuentin Perret #define kvm_nvhe_sym(sym)	sym
21*fa21472aSQuentin Perret #endif
22ce492a16SDavid Brazdil 
23ab25464bSDavid Brazdil #ifdef LINKER_SCRIPT
24ab25464bSDavid Brazdil 
25ab25464bSDavid Brazdil /*
26ab25464bSDavid Brazdil  * KVM nVHE ELF section names are prefixed with .hyp, to separate them
27ab25464bSDavid Brazdil  * from the kernel proper.
28ab25464bSDavid Brazdil  */
29ab25464bSDavid Brazdil #define HYP_SECTION_NAME(NAME)	.hyp##NAME
30ab25464bSDavid Brazdil 
31f7a4825dSDavid Brazdil /* Symbol defined at the beginning of each hyp section. */
32f7a4825dSDavid Brazdil #define HYP_SECTION_SYMBOL_NAME(NAME) \
33f7a4825dSDavid Brazdil 	HYP_CONCAT(__hyp_section_, HYP_SECTION_NAME(NAME))
34f7a4825dSDavid Brazdil 
35f7a4825dSDavid Brazdil /*
36f7a4825dSDavid Brazdil  * Helper to generate linker script statements starting a hyp section.
37f7a4825dSDavid Brazdil  *
38f7a4825dSDavid Brazdil  * A symbol with a well-known name is defined at the first byte. This
39f7a4825dSDavid Brazdil  * is used as a base for hyp relocations (see gen-hyprel.c). It must
40f7a4825dSDavid Brazdil  * be defined inside the section so the linker of `vmlinux` cannot
41f7a4825dSDavid Brazdil  * separate it from the section data.
42f7a4825dSDavid Brazdil  */
43f7a4825dSDavid Brazdil #define BEGIN_HYP_SECTION(NAME)				\
44f7a4825dSDavid Brazdil 	HYP_SECTION_NAME(NAME) : {			\
45f7a4825dSDavid Brazdil 		HYP_SECTION_SYMBOL_NAME(NAME) = .;
46f7a4825dSDavid Brazdil 
47f7a4825dSDavid Brazdil /* Helper to generate linker script statements ending a hyp section. */
48f7a4825dSDavid Brazdil #define END_HYP_SECTION					\
49f7a4825dSDavid Brazdil 	}
50f7a4825dSDavid Brazdil 
51ab25464bSDavid Brazdil /* Defines an ELF hyp section from input section @NAME and its subsections. */
52ab25464bSDavid Brazdil #define HYP_SECTION(NAME)			\
53f7a4825dSDavid Brazdil 	BEGIN_HYP_SECTION(NAME)			\
54f7a4825dSDavid Brazdil 		*(NAME NAME##.*)		\
55f7a4825dSDavid Brazdil 	END_HYP_SECTION
56ab25464bSDavid Brazdil 
57ce492a16SDavid Brazdil /*
58ce492a16SDavid Brazdil  * Defines a linker script alias of a kernel-proper symbol referenced by
59ce492a16SDavid Brazdil  * KVM nVHE hyp code.
60ce492a16SDavid Brazdil  */
61ce492a16SDavid Brazdil #define KVM_NVHE_ALIAS(sym)	kvm_nvhe_sym(sym) = sym;
62ce492a16SDavid Brazdil 
637b4a7b5eSWill Deacon /* Defines a linker script alias for KVM nVHE hyp symbols */
647b4a7b5eSWill Deacon #define KVM_NVHE_ALIAS_HYP(first, sec)	kvm_nvhe_sym(first) = kvm_nvhe_sym(sec);
657b4a7b5eSWill Deacon 
66ab25464bSDavid Brazdil #endif /* LINKER_SCRIPT */
67ab25464bSDavid Brazdil 
68ab25464bSDavid Brazdil #endif /* __ARM64_HYP_IMAGE_H__ */
69