Home | History | Annotate | Line # | Download | only in gnuefi
      1      1.1  jmcneill /*	$NetBSD: crt0-efi-mips64el.S,v 1.1.1.2 2021/09/30 18:50:09 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.1.2  jmcneill 	.long	0				// 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