master
1/*-
2 * SPDX-License-Identifier: BSD-3-Clause
3 *
4 * Copyright (c) 1995-1996 Søren Schmidt
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer
12 * in this position and unchanged.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
16 * 3. The name of the author may not be used to endorse or promote products
17 * derived from this software without specific prior written permission
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
20 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
21 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
22 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
23 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
24 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
28 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */
30
31#ifndef _SYS_IMGACT_ELF_H_
32#define _SYS_IMGACT_ELF_H_
33
34#include <machine/elf.h>
35
36#ifdef _KERNEL
37
38#define AUXARGS_ENTRY(pos, id, val) \
39 {(pos)->a_type = (id); (pos)->a_un.a_val = (val); (pos)++;}
40#if (defined(__LP64__) && __ELF_WORD_SIZE == 32)
41#define AUXARGS_ENTRY_PTR(pos, id, ptr) \
42 {(pos)->a_type = (id); (pos)->a_un.a_val = (uintptr_t)(ptr); (pos)++;}
43#else
44#define AUXARGS_ENTRY_PTR(pos, id, ptr) \
45 {(pos)->a_type = (id); (pos)->a_un.a_ptr = (ptr); (pos)++;}
46#endif
47
48struct image_params;
49struct thread;
50struct vnode;
51struct note_info_list;
52struct sbuf;
53
54/*
55 * Structure used to pass information from the loader to the
56 * stack fixup routine.
57 */
58typedef struct {
59 Elf_Ssize execfd;
60 Elf_Size phdr;
61 Elf_Size phent;
62 Elf_Size phnum;
63 Elf_Size pagesz;
64 Elf_Size base;
65 Elf_Size flags;
66 Elf_Size entry;
67 Elf_Word hdr_eflags; /* e_flags field from ehdr */
68} __ElfN(Auxargs);
69
70typedef struct {
71 Elf_Note hdr;
72 const char * vendor;
73 int flags;
74 bool (*trans_osrel)(const Elf_Note *, int32_t *);
75#define BN_CAN_FETCH_OSREL 0x0001 /* Deprecated. */
76#define BN_TRANSLATE_OSREL 0x0002 /* Use trans_osrel to fetch osrel */
77 /* after checking the image ABI specification, if needed. */
78} Elf_Brandnote;
79
80typedef struct {
81 int brand;
82 int machine;
83 const char *compat_3_brand; /* pre Binutils 2.10 method (FBSD 3) */
84 const char *interp_path;
85 struct sysentvec *sysvec;
86 const char *interp_newpath;
87 int flags;
88 Elf_Brandnote *brand_note;
89 bool (*header_supported)(struct image_params *,
90 int32_t *, uint32_t *);
91 /* High 8 bits of flags is private to the ABI */
92#define BI_CAN_EXEC_DYN 0x0001
93#define BI_BRAND_NOTE 0x0002 /* May have note.ABI-tag section. */
94#define BI_BRAND_NOTE_MANDATORY 0x0004 /* Must have note.ABI-tag section. */
95#define BI_BRAND_ONLY_STATIC 0x0008 /* Match only interp-less binaries. */
96} __ElfN(Brandinfo);
97
98__ElfType(Auxargs);
99__ElfType(Brandinfo);
100
101#define MAX_BRANDS 8
102#define FREEBSD_ABI_VENDOR "FreeBSD"
103#define GNU_ABI_VENDOR "GNU"
104
105typedef void (*outfunc_t)(void *, struct sbuf *, size_t *);
106
107/* Closure for __elfN(size_segments)(). */
108struct sseg_closure {
109 int count; /* Count of writable segments. */
110 size_t size; /* Total size of all writable segments. */
111};
112
113bool __elfN(brand_inuse)(Elf_Brandinfo *entry);
114int __elfN(insert_brand_entry)(Elf_Brandinfo *entry);
115int __elfN(remove_brand_entry)(Elf_Brandinfo *entry);
116int __elfN(freebsd_fixup)(uintptr_t *, struct image_params *);
117int __elfN(coredump)(struct thread *, struct vnode *, off_t, int);
118size_t __elfN(populate_note)(int, void *, void *, size_t, void **);
119int __elfN(freebsd_copyout_auxargs)(struct image_params *, uintptr_t);
120void __elfN(puthdr)(struct thread *, void *, size_t, int, size_t, int);
121void __elfN(prepare_notes)(struct thread *, struct note_info_list *,
122 size_t *);
123void __elfN(size_segments)(struct thread *, struct sseg_closure *, int);
124size_t __elfN(register_note)(struct thread *, struct note_info_list *,
125 int, outfunc_t, void *);
126bool __elfN(parse_notes)(struct image_params *, Elf_Note *, const char *,
127 const Elf_Phdr *, bool (*)(const Elf_Note *, void *, bool *),
128 void *);
129
130/* Machine specific function to dump per-thread information. */
131void __elfN(dump_thread)(struct thread *, void *, size_t *);
132
133extern int __elfN(fallback_brand);
134extern Elf_Brandnote __elfN(freebsd_brandnote);
135extern Elf_Brandnote __elfN(kfreebsd_brandnote);
136#endif /* _KERNEL */
137
138#endif /* !_SYS_IMGACT_ELF_H_ */