kernel - cleanup vfs_cache debugging
[dragonfly.git] / contrib / elftoolchain / libelf / elf_flag.c
blob73503214a9fe4f51ee8373839007bc7092ba0e35
1 /*-
2 * Copyright (c) 2006,2008-2009,2011 Joseph Koshy
3 * All rights reserved.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24 * SUCH DAMAGE.
27 #include <libelf.h>
29 #include "_libelf.h"
31 ELFTC_VCSID("$Id: elf_flag.c 3174 2015-03-27 17:13:41Z emaste $");
33 unsigned int
34 elf_flagarhdr(Elf_Arhdr *a, Elf_Cmd c, unsigned int flags)
36 unsigned int r;
38 if (a == NULL)
39 return (0);
41 if ((c != ELF_C_SET && c != ELF_C_CLR) ||
42 (flags & ~ELF_F_DIRTY) != 0) {
43 LIBELF_SET_ERROR(ARGUMENT, 0);
44 return (0);
47 if (c == ELF_C_SET)
48 r = a->ar_flags |= flags;
49 else
50 r = a->ar_flags &= ~flags;
52 return (r & LIBELF_F_API_MASK);
55 unsigned int
56 elf_flagdata(Elf_Data *d, Elf_Cmd c, unsigned int flags)
58 unsigned int r;
59 struct _Libelf_Data *ld;
61 if (d == NULL)
62 return (0);
64 if ((c != ELF_C_SET && c != ELF_C_CLR) ||
65 (flags & ~ELF_F_DIRTY) != 0) {
66 LIBELF_SET_ERROR(ARGUMENT, 0);
67 return (0);
70 ld = (struct _Libelf_Data *) d;
72 if (c == ELF_C_SET)
73 r = ld->d_flags |= flags;
74 else
75 r = ld->d_flags &= ~flags;
77 return (r & LIBELF_F_API_MASK);
80 unsigned int
81 elf_flagehdr(Elf *e, Elf_Cmd c, unsigned int flags)
83 int ec;
84 void *ehdr;
86 if (e == NULL)
87 return (0);
89 if ((c != ELF_C_SET && c != ELF_C_CLR) ||
90 (e->e_kind != ELF_K_ELF) || (flags & ~ELF_F_DIRTY) != 0 ||
91 ((ec = e->e_class) != ELFCLASS32 && ec != ELFCLASS64)) {
92 LIBELF_SET_ERROR(ARGUMENT, 0);
93 return (0);
96 if (ec == ELFCLASS32)
97 ehdr = e->e_u.e_elf.e_ehdr.e_ehdr32;
98 else
99 ehdr = e->e_u.e_elf.e_ehdr.e_ehdr64;
101 if (ehdr == NULL) {
102 LIBELF_SET_ERROR(SEQUENCE, 0);
103 return (0);
106 return (elf_flagelf(e, c, flags));
109 unsigned int
110 elf_flagelf(Elf *e, Elf_Cmd c, unsigned int flags)
112 unsigned int r;
114 if (e == NULL)
115 return (0);
117 if ((c != ELF_C_SET && c != ELF_C_CLR) ||
118 (e->e_kind != ELF_K_ELF) ||
119 (flags & ~(ELF_F_ARCHIVE | ELF_F_ARCHIVE_SYSV |
120 ELF_F_DIRTY | ELF_F_LAYOUT)) != 0) {
121 LIBELF_SET_ERROR(ARGUMENT, 0);
122 return (0);
125 if ((flags & ELF_F_ARCHIVE_SYSV) && (flags & ELF_F_ARCHIVE) == 0) {
126 LIBELF_SET_ERROR(ARGUMENT, 0);
127 return (0);
130 if ((flags & ELF_F_ARCHIVE) && e->e_cmd != ELF_C_WRITE) {
131 LIBELF_SET_ERROR(MODE, 0);
132 return (0);
135 if (c == ELF_C_SET)
136 r = e->e_flags |= flags;
137 else
138 r = e->e_flags &= ~flags;
139 return (r & LIBELF_F_API_MASK);
142 unsigned int
143 elf_flagphdr(Elf *e, Elf_Cmd c, unsigned int flags)
145 int ec;
146 void *phdr;
148 if (e == NULL)
149 return (0);
151 if ((c != ELF_C_SET && c != ELF_C_CLR) ||
152 (e->e_kind != ELF_K_ELF) || (flags & ~ELF_F_DIRTY) != 0 ||
153 ((ec = e->e_class) != ELFCLASS32 && ec != ELFCLASS64)) {
154 LIBELF_SET_ERROR(ARGUMENT, 0);
155 return (0);
158 if (ec == ELFCLASS32)
159 phdr = e->e_u.e_elf.e_phdr.e_phdr32;
160 else
161 phdr = e->e_u.e_elf.e_phdr.e_phdr64;
163 if (phdr == NULL) {
164 LIBELF_SET_ERROR(SEQUENCE, 0);
165 return (0);
168 return (elf_flagelf(e, c, flags));
171 unsigned int
172 elf_flagscn(Elf_Scn *s, Elf_Cmd c, unsigned int flags)
174 unsigned int r;
176 if (s == NULL)
177 return (0);
179 if ((c != ELF_C_SET && c != ELF_C_CLR) ||
180 (flags & ~ELF_F_DIRTY) != 0) {
181 LIBELF_SET_ERROR(ARGUMENT, 0);
182 return (0);
185 if (c == ELF_C_SET)
186 r = s->s_flags |= flags;
187 else
188 r = s->s_flags &= ~flags;
189 return (r & LIBELF_F_API_MASK);
192 unsigned int
193 elf_flagshdr(Elf_Scn *s, Elf_Cmd c, unsigned int flags)
195 return (elf_flagscn(s, c, flags));