Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/mdsetimage merge copies...
details: https://anonhg.NetBSD.org/src/rev/467e3a6c471b
branches: trunk
changeset: 347893:467e3a6c471b
user: christos <christos%NetBSD.org@localhost>
date: Wed Sep 21 16:25:41 2016 +0000
description:
merge copies...
diffstat:
usr.sbin/mdsetimage/Makefile | 4 +-
usr.sbin/mdsetimage/bin.h | 34 ++++
usr.sbin/mdsetimage/bin_bfd.c | 149 +++++++++++++++++
usr.sbin/mdsetimage/bin_nlist.c | 190 ++++++++++++++++++++++
usr.sbin/mdsetimage/exec_aout.c | 19 +-
usr.sbin/mdsetimage/exec_elf32.c | 14 +-
usr.sbin/mdsetimage/extern.h | 22 +-
usr.sbin/mdsetimage/mdsetimage.8 | 28 +++-
usr.sbin/mdsetimage/mdsetimage.c | 324 ++++++++++++++++++--------------------
9 files changed, 575 insertions(+), 209 deletions(-)
diffs (truncated from 1010 to 300 lines):
diff -r 665b58ce584f -r 467e3a6c471b usr.sbin/mdsetimage/Makefile
--- a/usr.sbin/mdsetimage/Makefile Wed Sep 21 14:50:48 2016 +0000
+++ b/usr.sbin/mdsetimage/Makefile Wed Sep 21 16:25:41 2016 +0000
@@ -1,10 +1,10 @@
-# $NetBSD: Makefile,v 1.16 2003/05/18 07:57:39 lukem Exp $
+# $NetBSD: Makefile,v 1.17 2016/09/21 16:25:41 christos Exp $
.include <bsd.own.mk>
PROG= mdsetimage
SRCS= mdsetimage.c exec_aout.c exec_ecoff.c exec_elf32.c exec_elf64.c \
- exec_coff.c
+ exec_coff.c bin_nlist.c
MAN= mdsetimage.8
.if ${MACHINE_ARCH} == "alpha"
diff -r 665b58ce584f -r 467e3a6c471b usr.sbin/mdsetimage/bin.h
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/usr.sbin/mdsetimage/bin.h Wed Sep 21 16:25:41 2016 +0000
@@ -0,0 +1,34 @@
+/* $NetBSD: bin.h,v 1.1 2016/09/21 16:25:41 christos Exp $ */
+
+/*-
+ * Copyright (c) 2016 The NetBSD Foundation, Inc.
+ * 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 NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``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 FOUNDATION OR CONTRIBUTORS
+ * 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.
+ */
+
+void *bin_open(int, const char *, const char *);
+int bin_find_md_root(void *, const char *, off_t, unsigned long,
+ const char *, const char *, size_t *, size_t *, uint32_t *, int);
+void bin_put_32(void *, off_t, char *);
+void bin_close(void *);
+const char **bin_supported_targets(void);
diff -r 665b58ce584f -r 467e3a6c471b usr.sbin/mdsetimage/bin_bfd.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/usr.sbin/mdsetimage/bin_bfd.c Wed Sep 21 16:25:41 2016 +0000
@@ -0,0 +1,149 @@
+/* $NetBSD: bin_bfd.c,v 1.1 2016/09/21 16:25:41 christos Exp $ */
+
+/*
+ * Copyright (c) 1996, 2002 Christopher G. Demetriou
+ * 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.
+ * 3. The name of the author may not be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * 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.
+ *
+ * <<Id: LICENSE_GC,v 1.1 2001/10/01 23:24:05 cgd Exp>>
+ */
+
+#if HAVE_NBTOOL_CONFIG_H
+#include "nbtool_config.h"
+#endif
+
+#include <sys/cdefs.h>
+__RCSID("$NetBSD: bin_bfd.c,v 1.1 2016/09/21 16:25:41 christos Exp $");
+
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+#include <err.h>
+#include <bfd.h>
+#include "bin.h"
+
+void *
+bin_open(int kfd, const char *kfile, const char *bfdname)
+{
+ bfd *abfd;
+ bfd_init();
+ if ((abfd = bfd_fdopenr(kfile, bfdname, kfd)) == NULL) {
+ bfd_perror("open");
+ exit(1);
+ }
+ if (!bfd_check_format(abfd, bfd_object)) {
+ bfd_perror("check format");
+ exit(1);
+ }
+ return abfd;
+}
+
+int
+bin_find_md_root(void *bin, const char *mappedkfile, off_t size,
+ unsigned long text_start,
+ const char *root_name, const char *size_name, size_t *md_root_offset,
+ size_t *md_root_size_offset, uint32_t *md_root_size, int verbose)
+{
+ bfd *abfd = bin;
+ long i;
+ long storage_needed;
+ long number_of_symbols;
+ asymbol **symbol_table = NULL;
+ struct symbols {
+ const char *name;
+ size_t offset;
+ } *s, symbols[3];
+
+ symbols[0].name = root_name;
+ symbols[1].name = size_name;
+ symbols[2].name = NULL;
+
+ storage_needed = bfd_get_symtab_upper_bound(abfd);
+ if (storage_needed <= 0) {
+ warnx("bfd storage needed error");
+ return 1;
+ }
+
+ symbol_table = malloc(storage_needed);
+ if (symbol_table == NULL) {
+ warn("symbol table");
+ return 1;
+ }
+
+ number_of_symbols = bfd_canonicalize_symtab(abfd, symbol_table);
+ if (number_of_symbols <= 0) {
+ warnx("can't canonicalize symbol table");
+ free(symbol_table);
+ return 1;
+ }
+
+ for (i = 0; i < number_of_symbols; i++) {
+ for (s = symbols; s->name != NULL; s++) {
+ const char *sym = symbol_table[i]->name;
+
+ /*
+ * match symbol prefix '_' or ''.
+ */
+ if (!strcmp(s->name, sym) ||
+ !strcmp(s->name + 1, sym)) {
+ s->offset =
+ (size_t)(symbol_table[i]->section->filepos
+ + symbol_table[i]->value);
+ }
+ }
+ }
+
+ free(symbol_table);
+
+ for (s = symbols; s->name != NULL; s++) {
+ if (s->offset == 0) {
+ warnx("missing offset for `%s'", s->name);
+ return 1;
+ }
+ }
+
+ *md_root_offset = symbols[0].offset;
+ *md_root_size_offset = symbols[1].offset;
+ *md_root_size = bfd_get_32(abfd, &mappedkfile[*md_root_size_offset]);
+
+ return 0;
+}
+
+void
+bin_put_32(void *bin, off_t size, char *buf)
+{
+ bfd_put_32((struct bfd *)bin, size, buf);
+}
+
+void
+bin_close(void *bin)
+{
+ bfd_close_all_done((struct bfd *)bin);
+}
+
+const char **
+bin_supported_targets(void)
+{
+ return bfd_target_list();
+}
diff -r 665b58ce584f -r 467e3a6c471b usr.sbin/mdsetimage/bin_nlist.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/usr.sbin/mdsetimage/bin_nlist.c Wed Sep 21 16:25:41 2016 +0000
@@ -0,0 +1,190 @@
+/* $NetBSD: bin_nlist.c,v 1.1 2016/09/21 16:25:41 christos Exp $ */
+
+/*
+ * Copyright (c) 1996, 2002 Christopher G. Demetriou
+ * 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.
+ * 3. The name of the author may not be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * 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.
+ *
+ * <<Id: LICENSE_GC,v 1.1 2001/10/01 23:24:05 cgd Exp>>
+ */
+#include <sys/cdefs.h>
+__RCSID("$NetBSD: bin_nlist.c,v 1.1 2016/09/21 16:25:41 christos Exp $");
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <nlist.h>
+#include <err.h>
+
+#include "bin.h"
+#include "extern.h"
+
+struct bininfo {
+ const char *fname;
+ int kfd;
+};
+
+#define X_MD_ROOT_IMAGE 0
+#define X_MD_ROOT_SIZE 1
+
+struct {
+ const char *name;
+ int (*check)(const char *, size_t);
+ int (*findoff)(const char *, size_t, u_long, size_t *, u_long);
+} exec_formats[] = {
+#ifdef NLIST_AOUT
+ { "a.out", check_aout, findoff_aout, },
+#endif
+#ifdef NLIST_ECOFF
+ { "ECOFF", check_ecoff, findoff_ecoff, },
+#endif
+#ifdef NLIST_ELF32
+ { "ELF32", check_elf32, findoff_elf32, },
+#endif
+#ifdef NLIST_ELF64
+ { "ELF64", check_elf64, findoff_elf64, },
+#endif
+#ifdef NLIST_COFF
+ { "COFF", check_coff, findoff_coff, },
+#endif
+};
+
+void *
+bin_open(int kfd, const char *kfile, const char *bfdname)
+{
+ struct bininfo *bin;
+
+ if ((bin = malloc(sizeof(*bin))) == NULL) {
+ warn("%s", kfile);
+ return NULL;
+ }
+ bin->kfd = kfd;
+ bin->fname = kfile;
+
+ return bin;
+}
+
+
+int
Home |
Main Index |
Thread Index |
Old Index