xref: /freebsd/stand/efi/loader/arch/arm/exec.c (revision 7c43148a)
1ca987d46SWarner Losh /*-
2ca987d46SWarner Losh  * Copyright (c) 2001 Benno Rice <benno@FreeBSD.org>
3ca987d46SWarner Losh  * Copyright (c) 2007 Semihalf, Rafal Jaworowski <raj@semihalf.com>
4ca987d46SWarner Losh  * All rights reserved.
5ca987d46SWarner Losh  *
6ca987d46SWarner Losh  * Redistribution and use in source and binary forms, with or without
7ca987d46SWarner Losh  * modification, are permitted provided that the following conditions
8ca987d46SWarner Losh  * are met:
9ca987d46SWarner Losh  * 1. Redistributions of source code must retain the above copyright
10ca987d46SWarner Losh  *    notice, this list of conditions and the following disclaimer.
11ca987d46SWarner Losh  * 2. Redistributions in binary form must reproduce the above copyright
12ca987d46SWarner Losh  *    notice, this list of conditions and the following disclaimer in the
13ca987d46SWarner Losh  *    documentation and/or other materials provided with the distribution.
14ca987d46SWarner Losh  *
15ca987d46SWarner Losh  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16ca987d46SWarner Losh  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17ca987d46SWarner Losh  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18ca987d46SWarner Losh  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19ca987d46SWarner Losh  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20ca987d46SWarner Losh  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21ca987d46SWarner Losh  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22ca987d46SWarner Losh  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23ca987d46SWarner Losh  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24ca987d46SWarner Losh  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25ca987d46SWarner Losh  * SUCH DAMAGE.
26ca987d46SWarner Losh  */
27ca987d46SWarner Losh 
28ca987d46SWarner Losh #include <sys/param.h>
29ca987d46SWarner Losh #include <sys/linker.h>
30ca987d46SWarner Losh 
31ca987d46SWarner Losh #include <machine/md_var.h>
32ca987d46SWarner Losh #include <machine/metadata.h>
33ca987d46SWarner Losh #include <machine/elf.h>
34ca987d46SWarner Losh 
35ca987d46SWarner Losh #include <stand.h>
36ca987d46SWarner Losh 
37ca987d46SWarner Losh #include <efi.h>
38ca987d46SWarner Losh #include <efilib.h>
39ca987d46SWarner Losh 
40ca987d46SWarner Losh #include "bootstrap.h"
41ca987d46SWarner Losh #include "loader_efi.h"
42ca987d46SWarner Losh 
43ed87efbeSRoger Pau Monné extern int bi_load(char *, vm_offset_t *, vm_offset_t *, bool);
44ca987d46SWarner Losh 
45ca987d46SWarner Losh static int
__elfN(arm_load)4656e53cb8SWarner Losh __elfN(arm_load)(char *filename, uint64_t dest,
47ca987d46SWarner Losh     struct preloaded_file **result)
48ca987d46SWarner Losh {
49ca987d46SWarner Losh 	int r;
50ca987d46SWarner Losh 
51ca987d46SWarner Losh 	r = __elfN(loadfile)(filename, dest, result);
52ca987d46SWarner Losh 	if (r != 0)
53ca987d46SWarner Losh 		return (r);
54ca987d46SWarner Losh 
55ca987d46SWarner Losh 	return (0);
56ca987d46SWarner Losh }
57ca987d46SWarner Losh 
58ca987d46SWarner Losh static int
__elfN(arm_exec)59ca987d46SWarner Losh __elfN(arm_exec)(struct preloaded_file *fp)
60ca987d46SWarner Losh {
61ca987d46SWarner Losh 	struct file_metadata *fmp;
62ca987d46SWarner Losh 	vm_offset_t modulep, kernend;
63ca987d46SWarner Losh 	Elf_Ehdr *e;
64ca987d46SWarner Losh 	int error;
65ca987d46SWarner Losh 	void (*entry)(void *);
66ca987d46SWarner Losh 
67ca987d46SWarner Losh 	if ((fmp = file_findmetadata(fp, MODINFOMD_ELFHDR)) == NULL)
68ca987d46SWarner Losh 		return (EFTYPE);
69ca987d46SWarner Losh 
70ca987d46SWarner Losh 	e = (Elf_Ehdr *)&fmp->md_data;
71ca987d46SWarner Losh 
72ca987d46SWarner Losh 	efi_time_fini();
73ea7796a9SRebecca Cran 
74ea7796a9SRebecca Cran 	entry = efi_translate(e->e_entry);
75ea7796a9SRebecca Cran 
764f8212c8SJessica Clarke 	printf("Kernel entry at %p...\n", entry);
77ea7796a9SRebecca Cran 	printf("Kernel args: %s\n", fp->f_args);
78ea7796a9SRebecca Cran 
79ed87efbeSRoger Pau Monné 	if ((error = bi_load(fp->f_args, &modulep, &kernend, true)) != 0) {
80ca987d46SWarner Losh 		efi_time_init();
81ca987d46SWarner Losh 		return (error);
82ca987d46SWarner Losh 	}
83ca987d46SWarner Losh 
84ea7796a9SRebecca Cran 	/* At this point we've called ExitBootServices, so we can't call
85ea7796a9SRebecca Cran 	 * printf or any other function that uses Boot Services */
86ca987d46SWarner Losh 
87ca987d46SWarner Losh 	dev_cleanup();
88ca987d46SWarner Losh 
89ca987d46SWarner Losh 	(*entry)((void *)modulep);
90ca987d46SWarner Losh 	panic("exec returned");
91ca987d46SWarner Losh }
92ca987d46SWarner Losh 
93ca987d46SWarner Losh static struct file_format arm_elf = {
94ca987d46SWarner Losh 	__elfN(arm_load),
95ca987d46SWarner Losh 	__elfN(arm_exec)
96ca987d46SWarner Losh };
97ca987d46SWarner Losh 
98ca987d46SWarner Losh struct file_format *file_formats[] = {
99ca987d46SWarner Losh 	&arm_elf,
100ca987d46SWarner Losh 	NULL
101ca987d46SWarner Losh };
102ca987d46SWarner Losh 
103