crt0-efi-arm.S revision 1.1 1 1.1 jmcneill /* $NetBSD: crt0-efi-arm.S,v 1.1 2018/08/16 18:17:47 jmcneill Exp $ */
2 1.1 jmcneill
3 1.1 jmcneill /*
4 1.1 jmcneill * crt0-efi-arm.S - PE/COFF header for ARM EFI applications
5 1.1 jmcneill *
6 1.1 jmcneill * Copright (C) 2014 Linaro Ltd. <ard.biesheuvel (at) linaro.org>
7 1.1 jmcneill *
8 1.1 jmcneill * Redistribution and use in source and binary forms, with or without
9 1.1 jmcneill * modification, are permitted provided that the following conditions
10 1.1 jmcneill * are met:
11 1.1 jmcneill * 1. Redistributions of source code must retain the above copyright
12 1.1 jmcneill * notice and this list of conditions, without modification.
13 1.1 jmcneill * 2. The name of the author may not be used to endorse or promote products
14 1.1 jmcneill * derived from this software without specific prior written permission.
15 1.1 jmcneill *
16 1.1 jmcneill * Alternatively, this software may be distributed under the terms of the
17 1.1 jmcneill * GNU General Public License as published by the Free Software Foundation;
18 1.1 jmcneill * either version 2 of the License, or (at your option) any later version.
19 1.1 jmcneill */
20 1.1 jmcneill
21 1.1 jmcneill .section .text.head
22 1.1 jmcneill
23 1.1 jmcneill /*
24 1.1 jmcneill * Magic "MZ" signature for PE/COFF
25 1.1 jmcneill */
26 1.1 jmcneill .globl ImageBase
27 1.1 jmcneill ImageBase:
28 1.1 jmcneill .ascii "MZ"
29 1.1 jmcneill .skip 58 // 'MZ' + pad + offset == 64
30 1.1 jmcneill .long pe_header - ImageBase // Offset to the PE header.
31 1.1 jmcneill pe_header:
32 1.1 jmcneill .ascii "PE"
33 1.1 jmcneill .short 0
34 1.1 jmcneill coff_header:
35 1.1 jmcneill .short 0x1c2 // Mixed ARM/Thumb
36 1.1 jmcneill .short 2 // nr_sections
37 1.1 jmcneill .long 0 // TimeDateStamp
38 1.1 jmcneill .long 0 // PointerToSymbolTable
39 1.1 jmcneill .long 1 // NumberOfSymbols
40 1.1 jmcneill .short section_table - optional_header // SizeOfOptionalHeader
41 1.1 jmcneill .short 0x306 // Characteristics.
42 1.1 jmcneill // IMAGE_FILE_32BIT_MACHINE |
43 1.1 jmcneill // IMAGE_FILE_DEBUG_STRIPPED |
44 1.1 jmcneill // IMAGE_FILE_EXECUTABLE_IMAGE |
45 1.1 jmcneill // IMAGE_FILE_LINE_NUMS_STRIPPED
46 1.1 jmcneill optional_header:
47 1.1 jmcneill .short 0x10b // PE32+ format
48 1.1 jmcneill .byte 0x02 // MajorLinkerVersion
49 1.1 jmcneill .byte 0x14 // MinorLinkerVersion
50 1.1 jmcneill .long _edata - _start // SizeOfCode
51 1.1 jmcneill .long 0 // SizeOfInitializedData
52 1.1 jmcneill .long 0 // SizeOfUninitializedData
53 1.1 jmcneill .long _start - ImageBase // AddressOfEntryPoint
54 1.1 jmcneill .long _start - ImageBase // BaseOfCode
55 1.1 jmcneill .long 0 // BaseOfData
56 1.1 jmcneill
57 1.1 jmcneill extra_header_fields:
58 1.1 jmcneill .long 0 // ImageBase
59 1.1 jmcneill .long 0x20 // SectionAlignment
60 1.1 jmcneill .long 0x8 // FileAlignment
61 1.1 jmcneill .short 0 // MajorOperatingSystemVersion
62 1.1 jmcneill .short 0 // MinorOperatingSystemVersion
63 1.1 jmcneill .short 0 // MajorImageVersion
64 1.1 jmcneill .short 0 // MinorImageVersion
65 1.1 jmcneill .short 0 // MajorSubsystemVersion
66 1.1 jmcneill .short 0 // MinorSubsystemVersion
67 1.1 jmcneill .long 0 // Win32VersionValue
68 1.1 jmcneill
69 1.1 jmcneill .long _edata - ImageBase // SizeOfImage
70 1.1 jmcneill
71 1.1 jmcneill // Everything before the kernel image is considered part of the header
72 1.1 jmcneill .long _start - ImageBase // SizeOfHeaders
73 1.1 jmcneill .long 0 // CheckSum
74 1.1 jmcneill .short EFI_SUBSYSTEM // Subsystem
75 1.1 jmcneill .short 0 // DllCharacteristics
76 1.1 jmcneill .long 0 // SizeOfStackReserve
77 1.1 jmcneill .long 0 // SizeOfStackCommit
78 1.1 jmcneill .long 0 // SizeOfHeapReserve
79 1.1 jmcneill .long 0 // SizeOfHeapCommit
80 1.1 jmcneill .long 0 // LoaderFlags
81 1.1 jmcneill .long 0x6 // NumberOfRvaAndSizes
82 1.1 jmcneill
83 1.1 jmcneill .quad 0 // ExportTable
84 1.1 jmcneill .quad 0 // ImportTable
85 1.1 jmcneill .quad 0 // ResourceTable
86 1.1 jmcneill .quad 0 // ExceptionTable
87 1.1 jmcneill .quad 0 // CertificationTable
88 1.1 jmcneill .quad 0 // BaseRelocationTable
89 1.1 jmcneill
90 1.1 jmcneill // Section table
91 1.1 jmcneill section_table:
92 1.1 jmcneill
93 1.1 jmcneill /*
94 1.1 jmcneill * The EFI application loader requires a relocation section
95 1.1 jmcneill * because EFI applications must be relocatable. This is a
96 1.1 jmcneill * dummy section as far as we are concerned.
97 1.1 jmcneill */
98 1.1 jmcneill .ascii ".reloc"
99 1.1 jmcneill .byte 0
100 1.1 jmcneill .byte 0 // end of 0 padding of section name
101 1.1 jmcneill .long 0
102 1.1 jmcneill .long 0
103 1.1 jmcneill .long 0 // SizeOfRawData
104 1.1 jmcneill .long 0 // PointerToRawData
105 1.1 jmcneill .long 0 // PointerToRelocations
106 1.1 jmcneill .long 0 // PointerToLineNumbers
107 1.1 jmcneill .short 0 // NumberOfRelocations
108 1.1 jmcneill .short 0 // NumberOfLineNumbers
109 1.1 jmcneill .long 0x42100040 // Characteristics (section flags)
110 1.1 jmcneill
111 1.1 jmcneill
112 1.1 jmcneill .ascii ".text"
113 1.1 jmcneill .byte 0
114 1.1 jmcneill .byte 0
115 1.1 jmcneill .byte 0 // end of 0 padding of section name
116 1.1 jmcneill .long _edata - _start // VirtualSize
117 1.1 jmcneill .long _start - ImageBase // VirtualAddress
118 1.1 jmcneill .long _edata - _start // SizeOfRawData
119 1.1 jmcneill .long _start - ImageBase // PointerToRawData
120 1.1 jmcneill
121 1.1 jmcneill .long 0 // PointerToRelocations (0 for executables)
122 1.1 jmcneill .long 0 // PointerToLineNumbers (0 for executables)
123 1.1 jmcneill .short 0 // NumberOfRelocations (0 for executables)
124 1.1 jmcneill .short 0 // NumberOfLineNumbers (0 for executables)
125 1.1 jmcneill .long 0xe0500020 // Characteristics (section flags)
126 1.1 jmcneill
127 1.1 jmcneill _start:
128 1.1 jmcneill stmfd sp!, {r0-r2, lr}
129 1.1 jmcneill
130 1.1 jmcneill mov r2, r0
131 1.1 jmcneill mov r3, r1
132 1.1 jmcneill adr r1, .L_DYNAMIC
133 1.1 jmcneill ldr r0, [r1]
134 1.1 jmcneill add r1, r0, r1
135 1.1 jmcneill adr r0, ImageBase
136 1.1 jmcneill bl _relocate
137 1.1 jmcneill teq r0, #0
138 1.1 jmcneill bne 0f
139 1.1 jmcneill
140 1.1 jmcneill ldmfd sp, {r0-r1}
141 1.1 jmcneill bl efi_main
142 1.1 jmcneill
143 1.1 jmcneill 0: add sp, sp, #12
144 1.1 jmcneill ldr pc, [sp], #4
145 1.1 jmcneill
146 1.1 jmcneill .L_DYNAMIC:
147 1.1 jmcneill .word _DYNAMIC - .
148