1a0509109SArd Biesheuvel/* SPDX-License-Identifier: GPL-2.0 */
2a0509109SArd Biesheuvel
3a0509109SArd Biesheuvel#include <linux/pe.h>
4a0509109SArd Biesheuvel
5a0509109SArd Biesheuvel#ifdef CONFIG_64BIT
6a0509109SArd Biesheuvel	.set		.Lextra_characteristics, 0x0
7a0509109SArd Biesheuvel	.set		.Lpe_opt_magic, PE_OPT_MAGIC_PE32PLUS
8a0509109SArd Biesheuvel#else
9a0509109SArd Biesheuvel	.set		.Lextra_characteristics, IMAGE_FILE_32BIT_MACHINE
10a0509109SArd Biesheuvel	.set		.Lpe_opt_magic, PE_OPT_MAGIC_PE32
11a0509109SArd Biesheuvel#endif
12a0509109SArd Biesheuvel
13a0509109SArd Biesheuvel	.section	".head", "a"
14a0509109SArd Biesheuvel	.globl		__efistub_efi_zboot_header
15a0509109SArd Biesheuvel__efistub_efi_zboot_header:
16a0509109SArd Biesheuvel.Ldoshdr:
17a0509109SArd Biesheuvel	.long		MZ_MAGIC
18a0509109SArd Biesheuvel	.ascii		"zimg"					// image type
19a0509109SArd Biesheuvel	.long		__efistub__gzdata_start - .Ldoshdr	// payload offset
201f1ba325SArd Biesheuvel	.long		__efistub__gzdata_size - 12		// payload size
21a0509109SArd Biesheuvel	.long		0, 0					// reserved
22a0509109SArd Biesheuvel	.asciz		COMP_TYPE				// compression type
23*29636a5cSArd Biesheuvel	.org		.Ldoshdr + 0x38
24*29636a5cSArd Biesheuvel	.long		LINUX_PE_MAGIC
25a0509109SArd Biesheuvel	.long		.Lpehdr - .Ldoshdr			// PE header offset
26a0509109SArd Biesheuvel
27a0509109SArd Biesheuvel.Lpehdr:
28a0509109SArd Biesheuvel	.long		PE_MAGIC
29a0509109SArd Biesheuvel	.short		MACHINE_TYPE
30a0509109SArd Biesheuvel	.short		.Lsection_count
31a0509109SArd Biesheuvel	.long		0
32a0509109SArd Biesheuvel	.long		0
33a0509109SArd Biesheuvel	.long		0
34a0509109SArd Biesheuvel	.short		.Lsection_table - .Loptional_header
35a0509109SArd Biesheuvel	.short		IMAGE_FILE_DEBUG_STRIPPED | \
36a0509109SArd Biesheuvel			IMAGE_FILE_EXECUTABLE_IMAGE | \
37a0509109SArd Biesheuvel			IMAGE_FILE_LINE_NUMS_STRIPPED |\
38a0509109SArd Biesheuvel			.Lextra_characteristics
39a0509109SArd Biesheuvel
40a0509109SArd Biesheuvel.Loptional_header:
41a0509109SArd Biesheuvel	.short		.Lpe_opt_magic
42a0509109SArd Biesheuvel	.byte		0, 0
43a0509109SArd Biesheuvel	.long		_etext - .Lefi_header_end
44a0509109SArd Biesheuvel	.long		__data_size
45a0509109SArd Biesheuvel	.long		0
46a0509109SArd Biesheuvel	.long		__efistub_efi_zboot_entry - .Ldoshdr
47a0509109SArd Biesheuvel	.long		.Lefi_header_end - .Ldoshdr
48a0509109SArd Biesheuvel
49a0509109SArd Biesheuvel#ifdef CONFIG_64BIT
50a0509109SArd Biesheuvel	.quad		0
51a0509109SArd Biesheuvel#else
52a0509109SArd Biesheuvel	.long		_etext - .Ldoshdr, 0x0
53a0509109SArd Biesheuvel#endif
54a0509109SArd Biesheuvel	.long		4096
55a0509109SArd Biesheuvel	.long		512
56a0509109SArd Biesheuvel	.short		0, 0
57a0509109SArd Biesheuvel	.short		LINUX_EFISTUB_MAJOR_VERSION	// MajorImageVersion
58a0509109SArd Biesheuvel	.short		LINUX_EFISTUB_MINOR_VERSION	// MinorImageVersion
59a0509109SArd Biesheuvel	.short		0, 0
60a0509109SArd Biesheuvel	.long		0
61a0509109SArd Biesheuvel	.long		_end - .Ldoshdr
62a0509109SArd Biesheuvel
63a0509109SArd Biesheuvel	.long		.Lefi_header_end - .Ldoshdr
64a0509109SArd Biesheuvel	.long		0
65a0509109SArd Biesheuvel	.short		IMAGE_SUBSYSTEM_EFI_APPLICATION
66a0509109SArd Biesheuvel	.short		0
67a0509109SArd Biesheuvel#ifdef CONFIG_64BIT
68a0509109SArd Biesheuvel	.quad		0, 0, 0, 0
69a0509109SArd Biesheuvel#else
70a0509109SArd Biesheuvel	.long		0, 0, 0, 0
71a0509109SArd Biesheuvel#endif
72a0509109SArd Biesheuvel	.long		0
73a0509109SArd Biesheuvel	.long		(.Lsection_table - .) / 8
74a0509109SArd Biesheuvel
75a0509109SArd Biesheuvel	.quad		0				// ExportTable
76a0509109SArd Biesheuvel	.quad		0				// ImportTable
77a0509109SArd Biesheuvel	.quad		0				// ResourceTable
78a0509109SArd Biesheuvel	.quad		0				// ExceptionTable
79a0509109SArd Biesheuvel	.quad		0				// CertificationTable
80a0509109SArd Biesheuvel	.quad		0				// BaseRelocationTable
81a0509109SArd Biesheuvel#ifdef CONFIG_DEBUG_EFI
82a0509109SArd Biesheuvel	.long		.Lefi_debug_table - .Ldoshdr	// DebugTable
83a0509109SArd Biesheuvel	.long		.Lefi_debug_table_size
84a0509109SArd Biesheuvel#endif
85a0509109SArd Biesheuvel
86a0509109SArd Biesheuvel.Lsection_table:
87a0509109SArd Biesheuvel	.ascii		".text\0\0\0"
88a0509109SArd Biesheuvel	.long		_etext - .Lefi_header_end
89a0509109SArd Biesheuvel	.long		.Lefi_header_end - .Ldoshdr
90a0509109SArd Biesheuvel	.long		_etext - .Lefi_header_end
91a0509109SArd Biesheuvel	.long		.Lefi_header_end - .Ldoshdr
92a0509109SArd Biesheuvel
93a0509109SArd Biesheuvel	.long		0, 0
94a0509109SArd Biesheuvel	.short		0, 0
95a0509109SArd Biesheuvel	.long		IMAGE_SCN_CNT_CODE | \
96a0509109SArd Biesheuvel			IMAGE_SCN_MEM_READ | \
97a0509109SArd Biesheuvel			IMAGE_SCN_MEM_EXECUTE
98a0509109SArd Biesheuvel
99a0509109SArd Biesheuvel	.ascii		".data\0\0\0"
100a0509109SArd Biesheuvel	.long		__data_size
101a0509109SArd Biesheuvel	.long		_etext - .Ldoshdr
102a0509109SArd Biesheuvel	.long		__data_rawsize
103a0509109SArd Biesheuvel	.long		_etext - .Ldoshdr
104a0509109SArd Biesheuvel
105a0509109SArd Biesheuvel	.long		0, 0
106a0509109SArd Biesheuvel	.short		0, 0
107a0509109SArd Biesheuvel	.long		IMAGE_SCN_CNT_INITIALIZED_DATA | \
108a0509109SArd Biesheuvel			IMAGE_SCN_MEM_READ | \
109a0509109SArd Biesheuvel			IMAGE_SCN_MEM_WRITE
110a0509109SArd Biesheuvel
111a0509109SArd Biesheuvel	.set		.Lsection_count, (. - .Lsection_table) / 40
112a0509109SArd Biesheuvel
113a0509109SArd Biesheuvel#ifdef CONFIG_DEBUG_EFI
114a0509109SArd Biesheuvel	.section	".rodata", "a"
115a0509109SArd Biesheuvel	.align		2
116a0509109SArd Biesheuvel.Lefi_debug_table:
117a0509109SArd Biesheuvel	// EFI_IMAGE_DEBUG_DIRECTORY_ENTRY
118a0509109SArd Biesheuvel	.long		0				// Characteristics
119a0509109SArd Biesheuvel	.long		0				// TimeDateStamp
120a0509109SArd Biesheuvel	.short		0				// MajorVersion
121a0509109SArd Biesheuvel	.short		0				// MinorVersion
122a0509109SArd Biesheuvel	.long		IMAGE_DEBUG_TYPE_CODEVIEW	// Type
123a0509109SArd Biesheuvel	.long		.Lefi_debug_entry_size		// SizeOfData
124a0509109SArd Biesheuvel	.long		0				// RVA
125a0509109SArd Biesheuvel	.long		.Lefi_debug_entry - .Ldoshdr	// FileOffset
126a0509109SArd Biesheuvel
127a0509109SArd Biesheuvel	.set		.Lefi_debug_table_size, . - .Lefi_debug_table
128a0509109SArd Biesheuvel	.previous
129a0509109SArd Biesheuvel
130a0509109SArd Biesheuvel.Lefi_debug_entry:
131a0509109SArd Biesheuvel	// EFI_IMAGE_DEBUG_CODEVIEW_NB10_ENTRY
132a0509109SArd Biesheuvel	.ascii		"NB10"				// Signature
133a0509109SArd Biesheuvel	.long		0				// Unknown
134a0509109SArd Biesheuvel	.long		0				// Unknown2
135a0509109SArd Biesheuvel	.long		0				// Unknown3
136a0509109SArd Biesheuvel
137a0509109SArd Biesheuvel	.asciz		ZBOOT_EFI_PATH
138a0509109SArd Biesheuvel
139a0509109SArd Biesheuvel	.set		.Lefi_debug_entry_size, . - .Lefi_debug_entry
140a0509109SArd Biesheuvel#endif
141a0509109SArd Biesheuvel
142a0509109SArd Biesheuvel	.p2align	12
143a0509109SArd Biesheuvel.Lefi_header_end:
144a0509109SArd Biesheuvel
145