crt0-efi-mips64el.S revision 1.1 1 1.1 jmcneill /* $NetBSD: crt0-efi-mips64el.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-mips64el.S - PE/COFF header for MIPS64 EFI applications
5 1.1 jmcneill *
6 1.1 jmcneill * Copright (C) 2014 Linaro Ltd. <ard.biesheuvel (at) linaro.org>
7 1.1 jmcneill * Copright (C) 2017 Heiher <r (at) hev.cc>
8 1.1 jmcneill *
9 1.1 jmcneill * Redistribution and use in source and binary forms, with or without
10 1.1 jmcneill * modification, are permitted provided that the following conditions
11 1.1 jmcneill * are met:
12 1.1 jmcneill * 1. Redistributions of source code must retain the above copyright
13 1.1 jmcneill * notice and this list of conditions, without modification.
14 1.1 jmcneill * 2. The name of the author may not be used to endorse or promote products
15 1.1 jmcneill * derived from this software without specific prior written permission.
16 1.1 jmcneill *
17 1.1 jmcneill * Alternatively, this software may be distributed under the terms of the
18 1.1 jmcneill * GNU General Public License as published by the Free Software Foundation;
19 1.1 jmcneill * either version 2 of the License, or (at your option) any later version.
20 1.1 jmcneill */
21 1.1 jmcneill
22 1.1 jmcneill .section .text.head
23 1.1 jmcneill
24 1.1 jmcneill /*
25 1.1 jmcneill * Magic "MZ" signature for PE/COFF
26 1.1 jmcneill */
27 1.1 jmcneill .globl ImageBase
28 1.1 jmcneill ImageBase:
29 1.1 jmcneill .ascii "MZ"
30 1.1 jmcneill .skip 58 // 'MZ' + pad + offset == 64
31 1.1 jmcneill .long pe_header - ImageBase // Offset to the PE header.
32 1.1 jmcneill pe_header:
33 1.1 jmcneill .ascii "PE"
34 1.1 jmcneill .short 0
35 1.1 jmcneill coff_header:
36 1.1 jmcneill .short 0x166 // MIPS little endian
37 1.1 jmcneill .short 2 // nr_sections
38 1.1 jmcneill .long 0 // TimeDateStamp
39 1.1 jmcneill .long 0 // PointerToSymbolTable
40 1.1 jmcneill .long 1 // NumberOfSymbols
41 1.1 jmcneill .short section_table - optional_header // SizeOfOptionalHeader
42 1.1 jmcneill .short 0x206 // Characteristics.
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 0x20b // 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
56 1.1 jmcneill extra_header_fields:
57 1.1 jmcneill .quad 0 // ImageBase
58 1.1 jmcneill .long 0x20 // SectionAlignment
59 1.1 jmcneill .long 0x8 // FileAlignment
60 1.1 jmcneill .short 0 // MajorOperatingSystemVersion
61 1.1 jmcneill .short 0 // MinorOperatingSystemVersion
62 1.1 jmcneill .short 0 // MajorImageVersion
63 1.1 jmcneill .short 0 // MinorImageVersion
64 1.1 jmcneill .short 0 // MajorSubsystemVersion
65 1.1 jmcneill .short 0 // MinorSubsystemVersion
66 1.1 jmcneill .long 0 // Win32VersionValue
67 1.1 jmcneill
68 1.1 jmcneill .long _edata - ImageBase // SizeOfImage
69 1.1 jmcneill
70 1.1 jmcneill // Everything before the kernel image is considered part of the header
71 1.1 jmcneill .long _start - ImageBase // SizeOfHeaders
72 1.1 jmcneill .long 0 // CheckSum
73 1.1 jmcneill .short EFI_SUBSYSTEM // Subsystem
74 1.1 jmcneill .short 0 // DllCharacteristics
75 1.1 jmcneill .quad 0 // SizeOfStackReserve
76 1.1 jmcneill .quad 0 // SizeOfStackCommit
77 1.1 jmcneill .quad 0 // SizeOfHeapReserve
78 1.1 jmcneill .quad 0 // SizeOfHeapCommit
79 1.1 jmcneill .long 0 // LoaderFlags
80 1.1 jmcneill .long 0x6 // NumberOfRvaAndSizes
81 1.1 jmcneill
82 1.1 jmcneill .quad 0 // ExportTable
83 1.1 jmcneill .quad 0 // ImportTable
84 1.1 jmcneill .quad 0 // ResourceTable
85 1.1 jmcneill .quad 0 // ExceptionTable
86 1.1 jmcneill .quad 0 // CertificationTable
87 1.1 jmcneill .quad 0 // BaseRelocationTable
88 1.1 jmcneill
89 1.1 jmcneill // Section table
90 1.1 jmcneill section_table:
91 1.1 jmcneill
92 1.1 jmcneill /*
93 1.1 jmcneill * The EFI application loader requires a relocation section
94 1.1 jmcneill * because EFI applications must be relocatable. This is a
95 1.1 jmcneill * dummy section as far as we are concerned.
96 1.1 jmcneill */
97 1.1 jmcneill .ascii ".reloc"
98 1.1 jmcneill .byte 0
99 1.1 jmcneill .byte 0 // end of 0 padding of section name
100 1.1 jmcneill .long 0
101 1.1 jmcneill .long 0
102 1.1 jmcneill .long 0 // SizeOfRawData
103 1.1 jmcneill .long 0 // PointerToRawData
104 1.1 jmcneill .long 0 // PointerToRelocations
105 1.1 jmcneill .long 0 // PointerToLineNumbers
106 1.1 jmcneill .short 0 // NumberOfRelocations
107 1.1 jmcneill .short 0 // NumberOfLineNumbers
108 1.1 jmcneill .long 0x42100040 // Characteristics (section flags)
109 1.1 jmcneill
110 1.1 jmcneill
111 1.1 jmcneill .ascii ".text"
112 1.1 jmcneill .byte 0
113 1.1 jmcneill .byte 0
114 1.1 jmcneill .byte 0 // end of 0 padding of section name
115 1.1 jmcneill .long _edata - _start // VirtualSize
116 1.1 jmcneill .long _start - ImageBase // VirtualAddress
117 1.1 jmcneill .long _edata - _start // SizeOfRawData
118 1.1 jmcneill .long _start - ImageBase // PointerToRawData
119 1.1 jmcneill
120 1.1 jmcneill .long 0 // PointerToRelocations (0 for executables)
121 1.1 jmcneill .long 0 // PointerToLineNumbers (0 for executables)
122 1.1 jmcneill .short 0 // NumberOfRelocations (0 for executables)
123 1.1 jmcneill .short 0 // NumberOfLineNumbers (0 for executables)
124 1.1 jmcneill .long 0xe0500020 // Characteristics (section flags)
125 1.1 jmcneill
126 1.1 jmcneill .set push
127 1.1 jmcneill .set noreorder
128 1.1 jmcneill .align 4
129 1.1 jmcneill
130 1.1 jmcneill .globl _start
131 1.1 jmcneill .ent _start
132 1.1 jmcneill .type _start, @function
133 1.1 jmcneill _start:
134 1.1 jmcneill daddiu $sp, -32
135 1.1 jmcneill sd $ra, ($sp)
136 1.1 jmcneill
137 1.1 jmcneill // Get pc & gp
138 1.1 jmcneill .align 3
139 1.1 jmcneill bal 1f
140 1.1 jmcneill sd $gp, 8($sp)
141 1.1 jmcneill _pc:
142 1.1 jmcneill .dword _gp
143 1.1 jmcneill .dword _DYNAMIC
144 1.1 jmcneill .dword _relocate
145 1.1 jmcneill 1:
146 1.1 jmcneill // pc in ra
147 1.1 jmcneill ld $gp, ($ra)
148 1.1 jmcneill dli $t0, _pc
149 1.1 jmcneill dsubu $gp, $t0
150 1.1 jmcneill daddu $gp, $ra
151 1.1 jmcneill
152 1.1 jmcneill sd $a0, 16($sp)
153 1.1 jmcneill sd $a1, 24($sp)
154 1.1 jmcneill
155 1.1 jmcneill // a2: ImageHandle
156 1.1 jmcneill move $a2, $a0
157 1.1 jmcneill // a3: SystemTable
158 1.1 jmcneill move $a3, $a1
159 1.1 jmcneill // a0: ImageBase
160 1.1 jmcneill dli $t1, ImageBase - _pc
161 1.1 jmcneill daddu $a0, $ra, $t1
162 1.1 jmcneill // a1: DynamicSection
163 1.1 jmcneill ld $t1, 8($ra)
164 1.1 jmcneill dsubu $t1, $t0
165 1.1 jmcneill daddu $a1, $ra, $t1
166 1.1 jmcneill // call _relocate
167 1.1 jmcneill ld $t1, 16($ra)
168 1.1 jmcneill dsubu $t1, $t0
169 1.1 jmcneill daddu $t9, $ra, $t1
170 1.1 jmcneill jalr $t9
171 1.1 jmcneill nop
172 1.1 jmcneill bnez $v0, 1b
173 1.1 jmcneill nop
174 1.1 jmcneill
175 1.1 jmcneill // a0: ImageHandle
176 1.1 jmcneill ld $a0, 16($sp)
177 1.1 jmcneill // call efi_main
178 1.1 jmcneill dla $t9, efi_main
179 1.1 jmcneill jalr $t9
180 1.1 jmcneill // a1: SystemTable
181 1.1 jmcneill ld $a1, 24($sp)
182 1.1 jmcneill
183 1.1 jmcneill 1:
184 1.1 jmcneill ld $gp, 8($sp)
185 1.1 jmcneill ld $ra, ($sp)
186 1.1 jmcneill jr $ra
187 1.1 jmcneill daddiu $sp, 32
188 1.1 jmcneill .end _start
189 1.1 jmcneill
190 1.1 jmcneill .set pop
191