diff options
Diffstat (limited to 'sys/arch/sparc64')
-rw-r--r-- | sys/arch/sparc64/stand/ofwboot/Makefile | 10 | ||||
-rw-r--r-- | sys/arch/sparc64/stand/ofwboot/boot.c | 17 | ||||
-rw-r--r-- | sys/arch/sparc64/stand/ofwboot/elf64_exec.c | 18 |
3 files changed, 17 insertions, 28 deletions
diff --git a/sys/arch/sparc64/stand/ofwboot/Makefile b/sys/arch/sparc64/stand/ofwboot/Makefile index 249994e1d9b..16212eee795 100644 --- a/sys/arch/sparc64/stand/ofwboot/Makefile +++ b/sys/arch/sparc64/stand/ofwboot/Makefile @@ -1,4 +1,4 @@ -# $OpenBSD: Makefile,v 1.15 2010/08/21 17:22:42 jsing Exp $ +# $OpenBSD: Makefile,v 1.16 2010/08/25 12:53:38 jsing Exp $ # $NetBSD: Makefile,v 1.2 2001/03/04 14:50:05 mrg Exp $ CURDIR= ${.CURDIR} @@ -14,7 +14,8 @@ PROG?= ofwboot NOMAN= ja, man! .PATH: ${S}/arch/sparc64/sparc64 -SRCS= srt0.s Locore.c boot.c ofdev.c alloc.c net.c netif_of.c vers.c +SRCS= srt0.s Locore.c alloc.c boot.c elf64_exec.c net.c netif_of.c \ + ofdev.c vers.c .PATH: ${S}/lib/libkern/arch/sparc64 ${S}/lib/libkern SRCS+= strlcpy.c strcmp.c strlcat.c strlen.c @@ -45,9 +46,7 @@ CPPFLAGS+= -DRELOC=0x${RELOC} # # XXXXX FIXME # -CPPFLAGS+= -DSPARC_BOOT_ELF CPPFLAGS+= -DSPARC_BOOT_UFS -CPPFLAGS+= -DSPARC_BOOT_NFS #CPPFLAGS+= -DSPARC_BOOT_HSFS .if !make(libdep) && !make(sadep) && !make(salibdir) && !make(obj) @@ -64,7 +63,4 @@ NORMAL_S= ${CC} ${AFLAGS} ${CPPFLAGS} -c $< srt0.o: srt0.s ${NORMAL_S} -# Explicit dependency for this. -boot.o: boot.c elf64_exec.c - .include <bsd.prog.mk> diff --git a/sys/arch/sparc64/stand/ofwboot/boot.c b/sys/arch/sparc64/stand/ofwboot/boot.c index 957becf48a6..eae7ac736a8 100644 --- a/sys/arch/sparc64/stand/ofwboot/boot.c +++ b/sys/arch/sparc64/stand/ofwboot/boot.c @@ -1,4 +1,4 @@ -/* $OpenBSD: boot.c,v 1.17 2010/08/21 17:22:42 jsing Exp $ */ +/* $OpenBSD: boot.c,v 1.18 2010/08/25 12:53:38 jsing Exp $ */ /* $NetBSD: boot.c,v 1.3 2001/05/31 08:55:19 mrg Exp $ */ /* * Copyright (c) 1997, 1999 Eduardo E. Horvath. All rights reserved. @@ -82,10 +82,7 @@ char bootfile[128]; int boothowto; int debug; - -#ifdef SPARC_BOOT_ELF int elf64_exec(int, Elf64_Ehdr *, u_int64_t *, void **, void **); -#endif #if 0 static void @@ -213,9 +210,7 @@ int loadfile(int fd, char *args) { union { -#ifdef SPARC_BOOT_ELF Elf64_Ehdr elf64; -#endif } hdr; int rval; u_int64_t entry = 0; @@ -240,13 +235,11 @@ loadfile(int fd, char *args) } /* Determine file type, load kernel. */ -#ifdef SPARC_BOOT_ELF if (bcmp(hdr.elf64.e_ident, ELFMAG, SELFMAG) == 0 && hdr.elf64.e_ident[EI_CLASS] == ELFCLASS64) { + printf("Booting %s\n", opened_name); rval = elf64_exec(fd, &hdr.elf64, &entry, &ssym, &esym); - } else -#endif - { + } else { rval = 1; printf("unknown executable format\n"); } @@ -266,10 +259,6 @@ loadfile(int fd, char *args) return (rval); } -#ifdef SPARC_BOOT_ELF -#include "elf64_exec.c" -#endif /* SPARC_BOOT_ELF */ - int main() { diff --git a/sys/arch/sparc64/stand/ofwboot/elf64_exec.c b/sys/arch/sparc64/stand/ofwboot/elf64_exec.c index ba25baaeea4..56ba5a27c2f 100644 --- a/sys/arch/sparc64/stand/ofwboot/elf64_exec.c +++ b/sys/arch/sparc64/stand/ofwboot/elf64_exec.c @@ -1,4 +1,4 @@ -/* $OpenBSD: elf64_exec.c,v 1.1 2010/08/21 17:22:42 jsing Exp $ */ +/* $OpenBSD: elf64_exec.c,v 1.2 2010/08/25 12:53:38 jsing Exp $ */ /* $NetBSD: elfXX_exec.c,v 1.2 2001/08/15 20:08:15 eeh Exp $ */ /* @@ -49,6 +49,13 @@ #define ELF_ALIGN(x) (((x) + 7) & (~7)) +#include <lib/libsa/stand.h> + +#include <sys/param.h> +#include <sys/exec_elf.h> + +#include "openfirm.h" + int elf64_exec(int fd, Elf_Ehdr *elf, u_int64_t *entryp, void **ssymp, void **esymp){ Elf_Shdr *shp; @@ -63,11 +70,6 @@ elf64_exec(int fd, Elf_Ehdr *elf, u_int64_t *entryp, void **ssymp, void **esymp) * Don't display load address for ELF; it's encoded in * each section. */ -#ifdef DEBUG - printf("elf%d_exec: ", ELFSIZE); -#endif - printf("Booting %s\n", opened_name); - for (i = 0; i < elf->e_phnum; i++) { Elf_Phdr phdr; size = lseek(fd, (size_t)(elf->e_phoff + sizeof(phdr) * i), @@ -84,6 +86,7 @@ elf64_exec(int fd, Elf_Ehdr *elf, u_int64_t *entryp, void **ssymp, void **esymp) printf("%s%lu@0x%lx", first ? "" : "+", (u_long)phdr.p_filesz, (u_long)phdr.p_vaddr); (void)lseek(fd, (size_t)phdr.p_offset, SEEK_SET); + /* * If the segment's VA is aligned on a 4MB boundary, align its * request 4MB aligned physical memory. Otherwise use default @@ -107,7 +110,8 @@ elf64_exec(int fd, Elf_Ehdr *elf, u_int64_t *entryp, void **ssymp, void **esymp) /* Zero BSS. */ if (phdr.p_filesz < phdr.p_memsz) { - printf("+%lu@0x%lx", (u_long)phdr.p_memsz - phdr.p_filesz, + printf("+%lu@0x%lx", + (u_long)phdr.p_memsz - phdr.p_filesz, (u_long)(phdr.p_vaddr + phdr.p_filesz)); bzero((void *)(long)phdr.p_vaddr + phdr.p_filesz, (size_t)phdr.p_memsz - phdr.p_filesz); |