root / lab4 / .minix-src / include / sys / shm.h @ 14
History | View | Annotate | Download (7.82 KB)
1 | 13 | up20180614 | /* $NetBSD: shm.h,v 1.49 2015/05/13 01:16:15 pgoyette Exp $ */
|
---|---|---|---|
2 | |||
3 | /*-
|
||
4 | * Copyright (c) 1999 The NetBSD Foundation, Inc.
|
||
5 | * All rights reserved.
|
||
6 | *
|
||
7 | * This code is derived from software contributed to The NetBSD Foundation
|
||
8 | * by Jason R. Thorpe of the Numerical Aerospace Simulation Facility,
|
||
9 | * NASA Ames Research Center.
|
||
10 | *
|
||
11 | * Redistribution and use in source and binary forms, with or without
|
||
12 | * modification, are permitted provided that the following conditions
|
||
13 | * are met:
|
||
14 | * 1. Redistributions of source code must retain the above copyright
|
||
15 | * notice, this list of conditions and the following disclaimer.
|
||
16 | * 2. Redistributions in binary form must reproduce the above copyright
|
||
17 | * notice, this list of conditions and the following disclaimer in the
|
||
18 | * documentation and/or other materials provided with the distribution.
|
||
19 | *
|
||
20 | * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
||
21 | * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
||
22 | * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||
23 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
||
24 | * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||
25 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||
26 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||
27 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||
28 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||
29 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||
30 | * POSSIBILITY OF SUCH DAMAGE.
|
||
31 | */
|
||
32 | |||
33 | /*
|
||
34 | * Copyright (c) 1994 Adam Glass
|
||
35 | * All rights reserved.
|
||
36 | *
|
||
37 | * Redistribution and use in source and binary forms, with or without
|
||
38 | * modification, are permitted provided that the following conditions
|
||
39 | * are met:
|
||
40 | * 1. Redistributions of source code must retain the above copyright
|
||
41 | * notice, this list of conditions and the following disclaimer.
|
||
42 | * 2. Redistributions in binary form must reproduce the above copyright
|
||
43 | * notice, this list of conditions and the following disclaimer in the
|
||
44 | * documentation and/or other materials provided with the distribution.
|
||
45 | * 3. All advertising materials mentioning features or use of this software
|
||
46 | * must display the following acknowledgement:
|
||
47 | * This product includes software developed by Adam Glass.
|
||
48 | * 4. The name of the author may not be used to endorse or promote products
|
||
49 | * derived from this software without specific prior written permission
|
||
50 | *
|
||
51 | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
||
52 | * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||
53 | * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||
54 | * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||
55 | * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||
56 | * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||
57 | * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||
58 | * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||
59 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
||
60 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
61 | */
|
||
62 | |||
63 | /*
|
||
64 | * As defined+described in "X/Open System Interfaces and Headers"
|
||
65 | * Issue 4, p. XXX
|
||
66 | */
|
||
67 | |||
68 | #ifndef _SYS_SHM_H_
|
||
69 | #define _SYS_SHM_H_
|
||
70 | |||
71 | #include <sys/cdefs.h> |
||
72 | #include <sys/featuretest.h> |
||
73 | |||
74 | #include <sys/ipc.h> |
||
75 | |||
76 | #define SHM_RDONLY 010000 /* Attach read-only (else read-write) */ |
||
77 | #define SHM_RND 020000 /* Round attach address to SHMLBA */ |
||
78 | #ifdef _KERNEL
|
||
79 | #define _SHM_RMLINGER 040000 /* Attach even if segment removed */ |
||
80 | #endif
|
||
81 | |||
82 | /* Segment low boundry address multiple */
|
||
83 | #if defined(_KERNEL) || defined(_STANDALONE) || defined(_MODULE)
|
||
84 | #define SHMLBA PAGE_SIZE
|
||
85 | #else
|
||
86 | /*
|
||
87 | * SHMLBA uses libc's internal __sysconf() to retrieve the machine's
|
||
88 | * page size. The value of _SC_PAGESIZE is 28 -- we hard code it so we do not
|
||
89 | * need to include unistd.h
|
||
90 | */
|
||
91 | __BEGIN_DECLS |
||
92 | long __sysconf(int); |
||
93 | __END_DECLS |
||
94 | #define SHMLBA (__sysconf(28)) |
||
95 | #endif
|
||
96 | |||
97 | typedef unsigned int shmatt_t; |
||
98 | |||
99 | struct shmid_ds {
|
||
100 | struct ipc_perm shm_perm; /* operation permission structure */ |
||
101 | size_t shm_segsz; /* size of segment in bytes */
|
||
102 | pid_t shm_lpid; /* process ID of last shm operation */
|
||
103 | pid_t shm_cpid; /* process ID of creator */
|
||
104 | shmatt_t shm_nattch; /* number of current attaches */
|
||
105 | time_t shm_atime; /* time of last shmat() */
|
||
106 | time_t shm_dtime; /* time of last shmdt() */
|
||
107 | time_t shm_ctime; /* time of last change by shmctl() */
|
||
108 | |||
109 | /*
|
||
110 | * These members are private and used only in the internal
|
||
111 | * implementation of this interface.
|
||
112 | */
|
||
113 | void *_shm_internal;
|
||
114 | }; |
||
115 | |||
116 | #if defined(_NETBSD_SOURCE)
|
||
117 | /*
|
||
118 | * Some systems (e.g. HP-UX) take these as the second (cmd) arg to shmctl().
|
||
119 | */
|
||
120 | #define SHM_LOCK 3 /* Lock segment in memory. */ |
||
121 | #define SHM_UNLOCK 4 /* Unlock a segment locked by SHM_LOCK. */ |
||
122 | #endif /* _NETBSD_SOURCE */ |
||
123 | |||
124 | #if defined(_NETBSD_SOURCE)
|
||
125 | /*
|
||
126 | * Permission definitions used in shmflag arguments to shmat(2) and shmget(2).
|
||
127 | * Provided for source compatibility only; do not use in new code!
|
||
128 | */
|
||
129 | #define SHM_R IPC_R /* S_IRUSR, R for owner */ |
||
130 | #define SHM_W IPC_W /* S_IWUSR, W for owner */ |
||
131 | |||
132 | /*
|
||
133 | * System 5 style catch-all structure for shared memory constants that
|
||
134 | * might be of interest to user programs. Do we really want/need this?
|
||
135 | */
|
||
136 | struct shminfo {
|
||
137 | uint64_t shmmax; /* max shared memory segment size (bytes) */
|
||
138 | uint32_t shmmin; /* min shared memory segment size (bytes) */
|
||
139 | uint32_t shmmni; /* max number of shared memory identifiers */
|
||
140 | uint32_t shmseg; /* max shared memory segments per process */
|
||
141 | uint32_t shmall; /* max amount of shared memory (pages) */
|
||
142 | }; |
||
143 | |||
144 | /* Warning: 64-bit structure padding is needed here */
|
||
145 | struct shmid_ds_sysctl {
|
||
146 | struct ipc_perm_sysctl shm_perm;
|
||
147 | uint64_t shm_segsz; |
||
148 | pid_t shm_lpid; |
||
149 | pid_t shm_cpid; |
||
150 | time_t shm_atime; |
||
151 | time_t shm_dtime; |
||
152 | time_t shm_ctime; |
||
153 | uint32_t shm_nattch; |
||
154 | }; |
||
155 | struct shm_sysctl_info {
|
||
156 | struct shminfo shminfo;
|
||
157 | struct shmid_ds_sysctl shmids[1]; |
||
158 | }; |
||
159 | #endif /* _NETBSD_SOURCE */ |
||
160 | |||
161 | #ifdef _KERNEL
|
||
162 | extern struct shminfo shminfo; |
||
163 | extern struct shmid_ds *shmsegs; |
||
164 | extern int shm_nused; |
||
165 | |||
166 | #define SHMSEG_FREE 0x0200 |
||
167 | #define SHMSEG_REMOVED 0x0400 |
||
168 | #define SHMSEG_ALLOCATED 0x0800 |
||
169 | #define SHMSEG_WANTED 0x1000 |
||
170 | #define SHMSEG_RMLINGER 0x2000 |
||
171 | #define SHMSEG_WIRED 0x4000 |
||
172 | |||
173 | struct vmspace;
|
||
174 | |||
175 | void shminit(void); |
||
176 | int shmfini(void); |
||
177 | void shmfork(struct vmspace *, struct vmspace *); |
||
178 | void shmexit(struct vmspace *); |
||
179 | int shmctl1(struct lwp *, int, int, struct shmid_ds *); |
||
180 | |||
181 | #define SYSCTL_FILL_SHM(src, dst) do { \ |
||
182 | SYSCTL_FILL_PERM((src).shm_perm, (dst).shm_perm); \ |
||
183 | (dst).shm_segsz = (src).shm_segsz; \ |
||
184 | (dst).shm_lpid = (src).shm_lpid; \ |
||
185 | (dst).shm_cpid = (src).shm_cpid; \ |
||
186 | (dst).shm_atime = (src).shm_atime; \ |
||
187 | (dst).shm_dtime = (src).shm_dtime; \ |
||
188 | (dst).shm_ctime = (src).shm_ctime; \ |
||
189 | (dst).shm_nattch = (src).shm_nattch; \ |
||
190 | } while (/*CONSTCOND*/ 0) |
||
191 | |||
192 | #else /* !_KERNEL */ |
||
193 | |||
194 | __BEGIN_DECLS |
||
195 | void *shmat(int, const void *, int); |
||
196 | int shmctl(int, int, struct shmid_ds *) __RENAME(__shmctl50); |
||
197 | int shmdt(const void *); |
||
198 | int shmget(key_t, size_t, int); |
||
199 | __END_DECLS |
||
200 | |||
201 | #endif /* !_KERNEL */ |
||
202 | |||
203 | #if defined(__minix)
|
||
204 | /* ipcs ctl commands */
|
||
205 | #define SHM_STAT 13 |
||
206 | #define SHM_INFO 14 |
||
207 | |||
208 | struct shm_info
|
||
209 | { |
||
210 | int used_ids;
|
||
211 | unsigned long int shm_tot; /* total allocated shm */ |
||
212 | unsigned long int shm_rss; /* total resident shm */ |
||
213 | unsigned long int shm_swp; /* total swapped shm */ |
||
214 | unsigned long int swap_attempts; |
||
215 | unsigned long int swap_successes; |
||
216 | }; |
||
217 | |||
218 | #define SHMMNI 1024 |
||
219 | #define SHMSEG 32 /* max shared segs per process */ |
||
220 | |||
221 | /* Public shm_perm.mode flags, synchronized with NetBSD kernel values above */
|
||
222 | #define SHM_DEST 0x0400 /* destroy on last detach (SHMSEG_REMOVED) */ |
||
223 | #define SHM_LOCKED 0x4000 /* pages will not be swapped (SHMSEG_WIRED) */ |
||
224 | |||
225 | #endif /* defined(__minix) */ |
||
226 | |||
227 | #endif /* !_SYS_SHM_H_ */ |