1 1.4 skrll /* $NetBSD: loadfile_machdep.h,v 1.4 2023/10/06 11:45:37 skrll Exp $ */ 2 1.1 cherry 3 1.1 cherry /*- 4 1.1 cherry * Copyright (c) 1998 The NetBSD Foundation, Inc. 5 1.1 cherry * All rights reserved. 6 1.1 cherry * 7 1.1 cherry * This code is derived from software contributed to The NetBSD Foundation 8 1.1 cherry * by Christos Zoulas and Ross Harvey. 9 1.1 cherry * 10 1.1 cherry * Redistribution and use in source and binary forms, with or without 11 1.1 cherry * modification, are permitted provided that the following conditions 12 1.1 cherry * are met: 13 1.1 cherry * 1. Redistributions of source code must retain the above copyright 14 1.1 cherry * notice, this list of conditions and the following disclaimer. 15 1.1 cherry * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 cherry * notice, this list of conditions and the following disclaimer in the 17 1.1 cherry * documentation and/or other materials provided with the distribution. 18 1.1 cherry * 19 1.1 cherry * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.1 cherry * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.1 cherry * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.1 cherry * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.1 cherry * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.1 cherry * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.1 cherry * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.1 cherry * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.1 cherry * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.1 cherry * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.1 cherry * POSSIBILITY OF SUCH DAMAGE. 30 1.1 cherry */ 31 1.1 cherry 32 1.1 cherry #define BOOT_ELF64 33 1.1 cherry 34 1.1 cherry #define LOAD_KERNEL (LOAD_ALL & ~LOAD_TEXTA) 35 1.1 cherry #define COUNT_KERNEL (COUNT_ALL & ~COUNT_TEXTA) 36 1.1 cherry 37 1.1 cherry #ifndef MD_LOADSEG 38 1.1 cherry /* XXX: Multiple unwind sections are ignored, and the last one found returned... Fixme! */ 39 1.1 cherry extern vaddr_t ia64_unwindtab; 40 1.1 cherry extern vsize_t ia64_unwindtablen; 41 1.1 cherry #define MD_LOADSEG(phdr) ((phdr)->p_type == PT_IA_64_UNWIND ? ia64_unwindtab = (phdr)->p_vaddr, ia64_unwindtablen = (phdr)->p_filesz, 1 : 0) 42 1.1 cherry #endif 43 1.1 cherry 44 1.1 cherry #ifdef _STANDALONE 45 1.1 cherry 46 1.1 cherry /* XXX: cherry: This whole thing is glue between the NetBSD pread/vpbcopy etc. etc 47 1.4 skrll * and the FreeBSD kern_pread/bzero etc. etc. Needs to be cleaned up 48 1.1 cherry * after discussion. 49 1.1 cherry */ 50 1.1 cherry 51 1.1 cherry #include "bootstrap.h" 52 1.1 cherry 53 1.1 cherry #define LOADADDR(a) ((a) + offset) 54 1.1 cherry #define ALIGNENTRY(a) Error! alpha supports ECOFF and ELF only! /* Fixme: for ia64 */ 55 1.1 cherry #define READ(f, b, c) pread((f), LOADADDR(b), (c)) 56 1.1 cherry #define BCOPY(s, d, c) vpbcopy((s), LOADADDR(d), (c)) 57 1.1 cherry #define BZERO(d, c) pbzero(LOADADDR(d), (c)) 58 1.3 joerg #define WARN(a) do { \ 59 1.3 joerg (void)printf a; \ 60 1.3 joerg if (errno) \ 61 1.3 joerg (void)printf(": %s\n", \ 62 1.3 joerg strerror(errno)); \ 63 1.3 joerg else \ 64 1.3 joerg (void)printf("\n"); \ 65 1.3 joerg } while(/* CONSTCOND */0) 66 1.1 cherry #define PROGRESS(a) (void) printf a 67 1.1 cherry #define ALLOC(a) alloc(a) 68 1.1 cherry #define DEALLOC(a, b) dealloc(a, b) 69 1.1 cherry #define OKMAGIC(a) Error! ia64 supports ELF only! 70 1.1 cherry 71 1.1 cherry 72 1.1 cherry /* XXX: defines below glues NetBSD conventions with bootstrap.h. */ 73 1.1 cherry 74 1.1 cherry #define vpbcopy archsw.arch_copyin 75 1.1 cherry #define pbzero kern_bzero 76 1.1 cherry #define pread archsw.arch_readin 77 1.1 cherry 78 1.1 cherry #else 79 1.1 cherry 80 1.1 cherry #define LOADADDR(a) (((u_long)(a)) + offset) 81 1.1 cherry #define ALIGNENTRY(a) ((u_long)(a)) 82 1.1 cherry #define READ(f, b, c) read((f), (void *)LOADADDR(b), (c)) 83 1.1 cherry #define BCOPY(s, d, c) memcpy((void *)LOADADDR(d), (void *)(s), (c)) 84 1.1 cherry #define BZERO(d, c) memset((void *)LOADADDR(d), 0, (c)) 85 1.1 cherry #define WARN(a) warn a 86 1.1 cherry #define PROGRESS(a) /* nothing */ 87 1.1 cherry #define ALLOC(a) malloc(a) 88 1.1 cherry #define DEALLOC(a, b) free(a) 89 1.1 cherry #define OKMAGIC(a) ((a) == OMAGIC) 90 1.1 cherry 91 1.1 cherry ssize_t vread(int, u_long, u_long *, size_t); 92 1.1 cherry void vcopy(u_long, u_long, u_long *, size_t); 93 1.1 cherry void vzero(u_long, u_long *, size_t); 94 1.1 cherry 95 1.1 cherry #endif 96