compat_util.c revision 1.46.18.2 1 /* $NetBSD: compat_util.c,v 1.46.18.2 2018/03/30 23:57:59 pgoyette Exp $ */
2
3 /*-
4 * Copyright (c) 1994 The NetBSD Foundation, Inc.
5 * All rights reserved.
6 *
7 * This code is derived from software contributed to The NetBSD Foundation
8 * by Christos Zoulas and Frank van der Linden.
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
30 */
31
32 /*
33 * Copyright (c) 2008, 2009 Matthew R. Green
34 * All rights reserved.
35 *
36 * Redistribution and use in source and binary forms, with or without
37 * modification, are permitted provided that the following conditions
38 * are met:
39 * 1. Redistributions of source code must retain the above copyright
40 * notice, this list of conditions and the following disclaimer.
41 * 2. Redistributions in binary form must reproduce the above copyright
42 * notice, this list of conditions and the following disclaimer in the
43 * documentation and/or other materials provided with the distribution.
44 * 3. The name of the author may not be used to endorse or promote products
45 * derived from this software without specific prior written permission.
46 *
47 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
48 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
49 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
50 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
51 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
52 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
53 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
54 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
55 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
56 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
57 * SUCH DAMAGE.
58 */
59
60 #include <sys/cdefs.h>
61 __KERNEL_RCSID(0, "$NetBSD: compat_util.c,v 1.46.18.2 2018/03/30 23:57:59 pgoyette Exp $");
62
63 #include <sys/param.h>
64 #include <sys/systm.h>
65 #include <sys/namei.h>
66 #include <sys/proc.h>
67 #include <sys/file.h>
68 #include <sys/stat.h>
69 #include <sys/filedesc.h>
70 #include <sys/exec.h>
71 #include <sys/ioctl.h>
72 #include <sys/kernel.h>
73 #include <sys/vnode.h>
74 #include <sys/syslog.h>
75 #include <sys/mount.h>
76 #include <sys/module.h>
77
78 #include <compat/common/compat_util.h>
79
80 /*
81 * Translate one set of flags to another, based on the entries in
82 * the given table. If 'leftover' is specified, it is filled in
83 * with any flags which could not be translated.
84 */
85 unsigned long
86 emul_flags_translate(const struct emul_flags_xtab *tab,
87 unsigned long in, unsigned long *leftover)
88 {
89 unsigned long out;
90
91 for (out = 0; tab->omask != 0; tab++) {
92 if ((in & tab->omask) == tab->oval) {
93 in &= ~tab->omask;
94 out |= tab->nval;
95 }
96 }
97 if (leftover != NULL)
98 *leftover = in;
99 return (out);
100 }
101
102 void
103 compat_offseterr(struct vnode *vp, const char *msg)
104 {
105 struct mount *mp;
106
107 mp = vp->v_mount;
108
109 log(LOG_ERR, "%s: dir offset too large on fs %s (mounted from %s)\n",
110 msg, mp->mnt_stat.f_mntonname, mp->mnt_stat.f_mntfromname);
111 uprintf("%s: dir offset too large for emulated program\n", msg);
112 }
113
114 /*
115 * Look for native NetBSD compatibility libraries, usually interp-ABI.
116 * It returns 0 if it changed the interpreter, otherwise it returns
117 * the error from namei(). Callers should not try any more processing
118 * if this returns 0, and probably should just ignore the return value.
119 */
120 int
121 compat_elf_check_interp(struct exec_package *epp,
122 char *interp,
123 const char *interp_suffix)
124 {
125 int error = 0;
126
127 /*
128 * Don't look for something else, if someone has already found and
129 * setup the ep_interp already.
130 */
131 if (interp && epp->ep_interp == NULL) {
132 /*
133 * If the path is exactly "/usr/libexec/ld.elf_so", first
134 * try to see if "/usr/libexec/ld.elf_so-<abi>" exists
135 * and if so, use that instead.
136 */
137 if (strcmp(interp, "/usr/libexec/ld.elf_so") == 0 ||
138 strcmp(interp, "/libexec/ld.elf_so") == 0) {
139 struct vnode *vp;
140 char *path;
141
142 path = PNBUF_GET();
143 snprintf(path, MAXPATHLEN, "%s-%s", interp, interp_suffix);
144 error = namei_simple_kernel(path,
145 NSM_FOLLOW_NOEMULROOT, &vp);
146 /*
147 * If that worked, replace interpreter in case we
148 * actually need to load it.
149 */
150 if (error == 0) {
151 epp->ep_interp = vp;
152 snprintf(interp, MAXPATHLEN, "%s", path);
153 }
154 PNBUF_PUT(path);
155 }
156 }
157 return error;
158 }
159
160 #ifdef _MODULE
161
162 MODULE(MODULE_CLASS_MISC, compat_util, NULL);
163
164 int
165 compat_util_modcmd(modcmd_t cmd, void *arg)
166 {
167
168 switch (cmd) {
169 case MODULE_CMD_INIT:
170 case MODULE_CMD_FINI:
171 return 0;
172 default:
173 return ENOTTY;
174 }
175 }
176 #endif /* _MODULE */
177