summaryrefslogtreecommitdiff
path: root/usr.sbin
diff options
context:
space:
mode:
authorTheo de Raadt <deraadt@cvs.openbsd.org>2013-10-13 20:17:52 +0000
committerTheo de Raadt <deraadt@cvs.openbsd.org>2013-10-13 20:17:52 +0000
commitc38194a066a56fb77ef5bcaa5855a3c427a40ed4 (patch)
tree00855a67ac3c3372244d56502dcb6b958efa6f16 /usr.sbin
parent6a09b5c1ff12704920703c51c529ac25fb0f07f5 (diff)
remote bits for a.out and ecoff
ok guenther
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/config/Makefile3
-rw-r--r--usr.sbin/config/exec.c131
-rw-r--r--usr.sbin/config/exec_ecoff.c147
3 files changed, 6 insertions, 275 deletions
diff --git a/usr.sbin/config/Makefile b/usr.sbin/config/Makefile
index cc69f9218cb..8ef06f4c8f6 100644
--- a/usr.sbin/config/Makefile
+++ b/usr.sbin/config/Makefile
@@ -1,4 +1,4 @@
-# $OpenBSD: Makefile,v 1.15 2013/07/05 21:29:51 miod Exp $
+# $OpenBSD: Makefile,v 1.16 2013/10/13 20:17:51 deraadt Exp $
.include <bsd.own.mk>
@@ -6,7 +6,6 @@ PROG= config
SRCS= files.c gram.y hash.c main.c mkheaders.c mkioconf.c mkmakefile.c \
mkswap.c pack.c scan.l sem.c util.c \
ukc.c misc.c ukcutil.c cmd.c exec.c
-CFLAGS+=-DELF_SUPPORT
SRCS+= exec_elf.c
CFLAGS+=-I${.CURDIR} -I.
diff --git a/usr.sbin/config/exec.c b/usr.sbin/config/exec.c
index e1a70257cbf..f388543c3fa 100644
--- a/usr.sbin/config/exec.c
+++ b/usr.sbin/config/exec.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: exec.c,v 1.9 2011/10/02 22:20:49 edd Exp $ */
+/* $OpenBSD: exec.c,v 1.10 2013/10/13 20:17:51 deraadt Exp $ */
/*
* Copyright (c) 1999 Mats O Jansson. All rights reserved.
@@ -31,153 +31,32 @@
#include <fcntl.h>
#include <stdio.h>
-#ifdef AOUT_SUPPORT
-int aout_check(char *);
-void aout_loadkernel(char *);
-void aout_savekernel(char *);
-caddr_t aout_adjust(caddr_t);
-caddr_t aout_readjust(caddr_t);
-#endif
-
-#ifdef ECOFF_SUPPORT
-int ecoff_check(char *);
-void ecoff_loadkernel(char *);
-void ecoff_savekernel(char *);
-caddr_t ecoff_adjust(caddr_t);
-caddr_t ecoff_readjust(caddr_t);
-#endif
-
-#ifdef ELF_SUPPORT
int elf_check(char *);
void elf_loadkernel(char *);
void elf_savekernel(char *);
caddr_t elf_adjust(caddr_t);
caddr_t elf_readjust(caddr_t);
-#endif
-
-#define DO_AOUT 0
-#define DO_ECOFF 1
-#define DO_ELF 2
-
-int current_exec = -1;
caddr_t
adjust(caddr_t x)
{
- switch (current_exec) {
-#ifdef AOUT_SUPPORT
- case DO_AOUT:
- return(aout_adjust(x));
- break;
-#endif
-#ifdef ECOFF_SUPPORT
- case DO_ECOFF:
- return(ecoff_adjust(x));
- break;
-#endif
-#ifdef ELF_SUPPORT
- case DO_ELF:
- return(elf_adjust(x));
- break;
-#endif
- default:
- errx(1, "no supported exec type");
- }
+ return(elf_adjust(x));
}
caddr_t
readjust(caddr_t x)
{
- switch (current_exec) {
-#ifdef AOUT_SUPPORT
- case DO_AOUT:
- return(aout_readjust(x));
- break;
-#endif
-#ifdef ECOFF_SUPPORT
- case DO_ECOFF:
- return(ecoff_readjust(x));
- break;
-#endif
-#ifdef ELF_SUPPORT
- case DO_ELF:
- return(elf_readjust(x));
- break;
-#endif
- default:
- errx(1, "no supported exec type");
- }
+ return(elf_readjust(x));
}
void
loadkernel(char *file)
{
- struct stat st;
-
- if (stat(file, &st) == -1)
- err(1, "cannot stat '%s'", file);
-
- current_exec = -1;
-
-#ifdef AOUT_SUPPORT
- if (aout_check(file)) {
- current_exec = DO_AOUT;
- }
-#endif
-
-#ifdef ECOFF_SUPPORT
- if (ecoff_check(file)) {
- current_exec = DO_ECOFF;
- }
-#endif
-
-#ifdef ELF_SUPPORT
- if (elf_check(file)) {
- current_exec = DO_ELF;
- }
-#endif
-
- switch (current_exec) {
-#ifdef AOUT_SUPPORT
- case DO_AOUT:
- aout_loadkernel(file);
- break;
-#endif
-#ifdef ECOFF_SUPPORT
- case DO_ECOFF:
- ecoff_loadkernel(file);
- break;
-#endif
-#ifdef ELF_SUPPORT
- case DO_ELF:
- elf_loadkernel(file);
- break;
-#endif
- default:
- errx(1, "no supported exec type");
- }
+ elf_loadkernel(file);
}
void
savekernel(char *outfile)
{
- switch (current_exec) {
-#ifdef AOUT_SUPPORT
- case DO_AOUT:
- aout_savekernel(outfile);
- break;
-#endif
-#ifdef ECOFF_SUPPORT
- case DO_ECOFF:
- ecoff_savekernel(outfile);
- break;
-#endif
-#ifdef ELF_SUPPORT
- case DO_ELF:
- elf_savekernel(outfile);
- break;
-#endif
- default:
- errx(1, "no supported exec type");
- }
+ elf_savekernel(outfile);
}
diff --git a/usr.sbin/config/exec_ecoff.c b/usr.sbin/config/exec_ecoff.c
deleted file mode 100644
index 72456c78b49..00000000000
--- a/usr.sbin/config/exec_ecoff.c
+++ /dev/null
@@ -1,147 +0,0 @@
-/* $OpenBSD: exec_ecoff.c,v 1.11 2011/10/02 22:20:49 edd Exp $ */
-
-/*
- * Copyright (c) 1999 Mats O Jansson. All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-#include <sys/types.h>
-#include <sys/exec.h>
-#include <sys/exec_ecoff.h>
-
-#include <err.h>
-#include <errno.h>
-#include <fcntl.h>
-#include <nlist.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <unistd.h>
-
-#include "config.h"
-#include "ukc.h"
-
-caddr_t ecoff_p, ecoff_r, ecoff_b;
-int ecoff_psz = 0, ecoff_rsz = 0, ecoff_bsz = 0;
-struct ecoff_exechdr ecoff_ex;
-
-caddr_t
-ecoff_adjust(caddr_t x)
-{
- unsigned long y;
-
- y = (unsigned long)x - nl[P_KERNEL_TEXT].n_value + (unsigned long)ecoff_p;
-
- return((caddr_t)y);
-}
-
-caddr_t
-ecoff_readjust(caddr_t x)
-{
- unsigned long y;
-
- y = (unsigned long)x - (unsigned long)ecoff_p + nl[P_KERNEL_TEXT].n_value;
-
- return((caddr_t)y);
-}
-
-int
-ecoff_check(char *file)
-{
- int fd, ret = 1;
-
- if ((fd = open(file, O_RDONLY | O_EXLOCK, 0)) < 0)
- return (0);
-
- if (read(fd,(char *)&ecoff_ex, sizeof(ecoff_ex)) != sizeof(ecoff_ex))
- ret = 0;
-
- if (ret) {
- if (ECOFF_BADMAG(&ecoff_ex))
- ret = 0;
- }
-
- close(fd);
- return (ret);
-}
-
-void
-ecoff_loadkernel(char *file)
-{
- int fd;
- off_t beg, cur, end;
-
- if ((fd = open(file, O_RDONLY | O_EXLOCK, 0)) < 0)
- err(1, "%s", file);
-
- if (read(fd, (char *)&ecoff_ex, sizeof(ecoff_ex)) != sizeof(ecoff_ex))
- errx(1, "can't read ecoff header");
-
- if (ECOFF_BADMAG(&ecoff_ex))
- errx(1, "bad ecoff magic");
-
- ecoff_psz = ecoff_ex.a.tsize + ecoff_ex.a.dsize;
- beg = lseek(fd, ECOFF_TXTOFF(&ecoff_ex), SEEK_SET);
-
- ecoff_bsz = (int)beg;
- ecoff_b = emalloc(ecoff_bsz);
-
- ecoff_p = emalloc(ecoff_psz);
-
- if (read(fd, ecoff_p, ecoff_psz) != ecoff_psz)
- errx(1, "can't read ecoff text and data");
-
- cur = lseek(fd, (off_t)0, SEEK_CUR);
- end = lseek(fd, (off_t)0, SEEK_END);
- (void)lseek(fd, (off_t)0, SEEK_SET);
- if (read(fd, ecoff_b, ecoff_bsz) != ecoff_bsz)
- errx(1, "can't read begining of file %s", file);
- (void)lseek(fd, cur, SEEK_SET);
-
- ecoff_rsz = (int)(end - cur);
-
- ecoff_r = emalloc(ecoff_rsz);
-
- if (read(fd, ecoff_r, ecoff_rsz) != ecoff_rsz)
- errx(1, "can't read rest of file %s", file);
-
- close(fd);
-}
-
-void
-ecoff_savekernel(char *outfile)
-{
- int fd;
-
- if ((fd = open(outfile, O_WRONLY | O_CREAT | O_TRUNC, 0755)) < 0)
- err(1, "%s", outfile);
-
- if (write(fd, ecoff_b, ecoff_bsz) != ecoff_bsz)
- errx(1, "can't write beginning of file %s",outfile);
-
- if (write(fd, ecoff_p, ecoff_psz) != ecoff_psz)
- errx(1, "can't write ecoff text and data");
-
- if (write(fd, ecoff_r, ecoff_rsz) != ecoff_rsz)
- errx(1, "can't write rest of file %s", outfile);
-
- close(fd);
-}