sysv_ipc.c revision 1.12 1 1.12 mycroft /* $NetBSD: sysv_ipc.c,v 1.12 1997/05/08 17:16:15 mycroft Exp $ */
2 1.7 cgd
3 1.1 cgd /*
4 1.10 mycroft * Copyright (c) 1995 Charles M. Hannum. All rights reserved.
5 1.1 cgd *
6 1.1 cgd * Redistribution and use in source and binary forms, with or without
7 1.1 cgd * modification, are permitted provided that the following conditions
8 1.1 cgd * are met:
9 1.1 cgd * 1. Redistributions of source code must retain the above copyright
10 1.1 cgd * notice, this list of conditions and the following disclaimer.
11 1.6 hpeyerl * 2. Redistributions in binary form must reproduce the above copyright
12 1.6 hpeyerl * notice, this list of conditions and the following disclaimer in the
13 1.6 hpeyerl * documentation and/or other materials provided with the distribution.
14 1.6 hpeyerl * 3. All advertising materials mentioning features or use of this software
15 1.6 hpeyerl * must display the following acknowledgement:
16 1.10 mycroft * This product includes software developed by Charles M. Hannum.
17 1.10 mycroft * 4. The name of the author may not be used to endorse or promote products
18 1.6 hpeyerl * derived from this software without specific prior written permission.
19 1.1 cgd *
20 1.4 hpeyerl * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
21 1.4 hpeyerl * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
22 1.4 hpeyerl * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
23 1.4 hpeyerl * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
24 1.4 hpeyerl * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25 1.4 hpeyerl * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 1.4 hpeyerl * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 1.4 hpeyerl * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 1.4 hpeyerl * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
29 1.4 hpeyerl * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 1.1 cgd */
31 1.1 cgd
32 1.2 mycroft #include <sys/param.h>
33 1.2 mycroft #include <sys/kernel.h>
34 1.2 mycroft #include <sys/proc.h>
35 1.2 mycroft #include <sys/ipc.h>
36 1.4 hpeyerl #include <sys/systm.h>
37 1.10 mycroft #include <sys/mount.h>
38 1.10 mycroft #include <sys/vnode.h>
39 1.12 mycroft #include <sys/stat.h>
40 1.1 cgd
41 1.1 cgd /*
42 1.4 hpeyerl * Check for ipc permission
43 1.1 cgd */
44 1.1 cgd
45 1.4 hpeyerl int
46 1.5 mycroft ipcperm(cred, perm, mode)
47 1.5 mycroft struct ucred *cred;
48 1.4 hpeyerl struct ipc_perm *perm;
49 1.1 cgd int mode;
50 1.1 cgd {
51 1.12 mycroft mode_t mask;
52 1.12 mycroft
53 1.12 mycroft if (cred->cr_uid == 0)
54 1.12 mycroft return (0);
55 1.1 cgd
56 1.9 mycroft if (mode == IPC_M) {
57 1.12 mycroft if (cred->cr_uid == perm->uid ||
58 1.9 mycroft cred->cr_uid == perm->cuid)
59 1.9 mycroft return (0);
60 1.9 mycroft return (EPERM);
61 1.1 cgd }
62 1.4 hpeyerl
63 1.12 mycroft mask = 0;
64 1.12 mycroft
65 1.12 mycroft if (cred->cr_uid == perm->uid ||
66 1.12 mycroft cred->cr_uid == perm->cuid) {
67 1.12 mycroft if (mode & IPC_R)
68 1.12 mycroft mask |= S_IRUSR;
69 1.12 mycroft if (mode & IPC_W)
70 1.12 mycroft mask |= S_IWUSR;
71 1.12 mycroft return ((perm->mode & mask) == mask ? 0 : EACCES);
72 1.12 mycroft }
73 1.12 mycroft
74 1.12 mycroft if (cred->cr_gid == perm->gid || groupmember(perm->gid, cred) ||
75 1.12 mycroft cred->cr_gid == perm->cgid || groupmember(perm->cgid, cred)) {
76 1.12 mycroft if (mode & IPC_R)
77 1.12 mycroft mask |= S_IRGRP;
78 1.12 mycroft if (mode & IPC_W)
79 1.12 mycroft mask |= S_IWGRP;
80 1.12 mycroft return ((perm->mode & mask) == mask ? 0 : EACCES);
81 1.12 mycroft }
82 1.12 mycroft
83 1.12 mycroft if (mode & IPC_R)
84 1.12 mycroft mask |= S_IROTH;
85 1.12 mycroft if (mode & IPC_W)
86 1.12 mycroft mask |= S_IWOTH;
87 1.12 mycroft return ((perm->mode & mask) == mask ? 0 : EACCES);
88 1.1 cgd }
89