1*cf84ac9aSAndroid Build Coastguard Worker /*
2*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2015 Elvira Khabirova <[email protected]>
3*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2015-2016 Dmitry V. Levin <[email protected]>
4*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2015-2018 The strace developers.
5*cf84ac9aSAndroid Build Coastguard Worker * All rights reserved.
6*cf84ac9aSAndroid Build Coastguard Worker *
7*cf84ac9aSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without
8*cf84ac9aSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions
9*cf84ac9aSAndroid Build Coastguard Worker * are met:
10*cf84ac9aSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright
11*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer.
12*cf84ac9aSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright
13*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the
14*cf84ac9aSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution.
15*cf84ac9aSAndroid Build Coastguard Worker * 3. The name of the author may not be used to endorse or promote products
16*cf84ac9aSAndroid Build Coastguard Worker * derived from this software without specific prior written permission.
17*cf84ac9aSAndroid Build Coastguard Worker *
18*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19*cf84ac9aSAndroid Build Coastguard Worker * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20*cf84ac9aSAndroid Build Coastguard Worker * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21*cf84ac9aSAndroid Build Coastguard Worker * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22*cf84ac9aSAndroid Build Coastguard Worker * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23*cf84ac9aSAndroid Build Coastguard Worker * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24*cf84ac9aSAndroid Build Coastguard Worker * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25*cf84ac9aSAndroid Build Coastguard Worker * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26*cf84ac9aSAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*cf84ac9aSAndroid Build Coastguard Worker */
29*cf84ac9aSAndroid Build Coastguard Worker
30*cf84ac9aSAndroid Build Coastguard Worker #include "tests.h"
31*cf84ac9aSAndroid Build Coastguard Worker #include <errno.h>
32*cf84ac9aSAndroid Build Coastguard Worker #include <stdio.h>
33*cf84ac9aSAndroid Build Coastguard Worker #include <stdlib.h>
34*cf84ac9aSAndroid Build Coastguard Worker #include <sys/shm.h>
35*cf84ac9aSAndroid Build Coastguard Worker
36*cf84ac9aSAndroid Build Coastguard Worker #ifndef SHM_HUGE_SHIFT
37*cf84ac9aSAndroid Build Coastguard Worker # define SHM_HUGE_SHIFT 26
38*cf84ac9aSAndroid Build Coastguard Worker #endif
39*cf84ac9aSAndroid Build Coastguard Worker
40*cf84ac9aSAndroid Build Coastguard Worker #ifndef SHM_HUGE_MASK
41*cf84ac9aSAndroid Build Coastguard Worker # define SHM_HUGE_MASK 0x3f
42*cf84ac9aSAndroid Build Coastguard Worker #endif
43*cf84ac9aSAndroid Build Coastguard Worker
44*cf84ac9aSAndroid Build Coastguard Worker #ifndef SHM_STAT_ANY
45*cf84ac9aSAndroid Build Coastguard Worker # define SHM_STAT_ANY 15
46*cf84ac9aSAndroid Build Coastguard Worker #endif
47*cf84ac9aSAndroid Build Coastguard Worker
48*cf84ac9aSAndroid Build Coastguard Worker #include "xlat.h"
49*cf84ac9aSAndroid Build Coastguard Worker #include "xlat/shm_resource_flags.h"
50*cf84ac9aSAndroid Build Coastguard Worker
51*cf84ac9aSAndroid Build Coastguard Worker #if XLAT_RAW
52*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_flags "0x2ce1e00"
53*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_huge "21<<26"
54*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_private "0"
55*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_rmid "0"
56*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_set "0x1"
57*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_stat "0x2"
58*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_stat "0xd"
59*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_info "0xe"
60*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_stat_any "0xf"
61*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_64 "0x100"
62*cf84ac9aSAndroid Build Coastguard Worker # define str_bogus_cmd "0xdefaced2"
63*cf84ac9aSAndroid Build Coastguard Worker #elif XLAT_VERBOSE
64*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_flags \
65*cf84ac9aSAndroid Build Coastguard Worker "0x2ce1e00 /\\* IPC_CREAT\\|IPC_EXCL\\|SHM_HUGETLB\\|SHM_NORESERVE" \
66*cf84ac9aSAndroid Build Coastguard Worker "\\|0x2ce0000 \\*/"
67*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_huge "21<<26 /\\* SHM_HUGE_SHIFT \\*/"
68*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_private "0 /\\* IPC_PRIVATE \\*/"
69*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_rmid "0 /\\* IPC_RMID \\*/"
70*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_set "0x1 /\\* IPC_SET \\*/"
71*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_stat "0x2 /\\* IPC_STAT \\*/"
72*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_stat "0xd /\\* SHM_STAT \\*/"
73*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_info "0xe /\\* SHM_INFO \\*/"
74*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_stat_any "0xf /\\* SHM_STAT_ANY \\*/"
75*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_64 "0x100 /\\* IPC_64 \\*/"
76*cf84ac9aSAndroid Build Coastguard Worker # define str_bogus_cmd "0xdefaced2 /\\* SHM_\\?\\?\\? \\*/"
77*cf84ac9aSAndroid Build Coastguard Worker #else
78*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_flags \
79*cf84ac9aSAndroid Build Coastguard Worker "IPC_CREAT\\|IPC_EXCL\\|SHM_HUGETLB\\|SHM_NORESERVE\\|0x2ce0000"
80*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_huge "21<<SHM_HUGE_SHIFT"
81*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_private "IPC_PRIVATE"
82*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_rmid "IPC_RMID"
83*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_set "IPC_SET"
84*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_stat "IPC_STAT"
85*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_stat "SHM_STAT"
86*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_info "SHM_INFO"
87*cf84ac9aSAndroid Build Coastguard Worker # define str_shm_stat_any "SHM_STAT_ANY"
88*cf84ac9aSAndroid Build Coastguard Worker # define str_ipc_64 "IPC_64"
89*cf84ac9aSAndroid Build Coastguard Worker # define str_bogus_cmd "0xdefaced2 /\\* SHM_\\?\\?\\? \\*/"
90*cf84ac9aSAndroid Build Coastguard Worker #endif
91*cf84ac9aSAndroid Build Coastguard Worker
92*cf84ac9aSAndroid Build Coastguard Worker static int id = -1;
93*cf84ac9aSAndroid Build Coastguard Worker
94*cf84ac9aSAndroid Build Coastguard Worker static void
cleanup(void)95*cf84ac9aSAndroid Build Coastguard Worker cleanup(void)
96*cf84ac9aSAndroid Build Coastguard Worker {
97*cf84ac9aSAndroid Build Coastguard Worker shmctl(id, IPC_RMID, NULL);
98*cf84ac9aSAndroid Build Coastguard Worker printf("shmctl\\(%d, (%s\\|)?%s, NULL\\) = 0\n",
99*cf84ac9aSAndroid Build Coastguard Worker id, str_ipc_64, str_ipc_rmid);
100*cf84ac9aSAndroid Build Coastguard Worker id = -1;
101*cf84ac9aSAndroid Build Coastguard Worker }
102*cf84ac9aSAndroid Build Coastguard Worker
103*cf84ac9aSAndroid Build Coastguard Worker int
main(void)104*cf84ac9aSAndroid Build Coastguard Worker main(void)
105*cf84ac9aSAndroid Build Coastguard Worker {
106*cf84ac9aSAndroid Build Coastguard Worker static const key_t private_key =
107*cf84ac9aSAndroid Build Coastguard Worker (key_t) (0xffffffff00000000ULL | IPC_PRIVATE);
108*cf84ac9aSAndroid Build Coastguard Worker static const key_t bogus_key = (key_t) 0xeca86420fdb97531ULL;
109*cf84ac9aSAndroid Build Coastguard Worker static const int bogus_id = 0xdefaced1;
110*cf84ac9aSAndroid Build Coastguard Worker static const int bogus_cmd = 0xdefaced2;
111*cf84ac9aSAndroid Build Coastguard Worker static void * const bogus_addr = (void *) -1L;
112*cf84ac9aSAndroid Build Coastguard Worker static const size_t bogus_size =
113*cf84ac9aSAndroid Build Coastguard Worker /*
114*cf84ac9aSAndroid Build Coastguard Worker * musl sets size to SIZE_MAX if size argument is greater than
115*cf84ac9aSAndroid Build Coastguard Worker * PTRDIFF_MAX - musl/src/ipc/shmget.c
116*cf84ac9aSAndroid Build Coastguard Worker */
117*cf84ac9aSAndroid Build Coastguard Worker #ifdef __GLIBC__
118*cf84ac9aSAndroid Build Coastguard Worker (size_t) 0xdec0ded1dec0ded2ULL;
119*cf84ac9aSAndroid Build Coastguard Worker #else
120*cf84ac9aSAndroid Build Coastguard Worker (size_t) 0x1e55c0de5dec0dedULL;
121*cf84ac9aSAndroid Build Coastguard Worker #endif
122*cf84ac9aSAndroid Build Coastguard Worker static const unsigned int bogus_ipc_shm_flags =
123*cf84ac9aSAndroid Build Coastguard Worker IPC_CREAT | IPC_EXCL | SHM_HUGETLB | SHM_NORESERVE;
124*cf84ac9aSAndroid Build Coastguard Worker static const unsigned int huge_mask = SHM_HUGE_MASK << SHM_HUGE_SHIFT;
125*cf84ac9aSAndroid Build Coastguard Worker static const unsigned int huge_flags = 21 << SHM_HUGE_SHIFT;
126*cf84ac9aSAndroid Build Coastguard Worker int bogus_flags;
127*cf84ac9aSAndroid Build Coastguard Worker int rc;
128*cf84ac9aSAndroid Build Coastguard Worker struct shmid_ds ds;
129*cf84ac9aSAndroid Build Coastguard Worker
130*cf84ac9aSAndroid Build Coastguard Worker rc = shmget(bogus_key, bogus_size, 0);
131*cf84ac9aSAndroid Build Coastguard Worker printf("shmget\\(%#llx, %zu, 000\\) = %s\n",
132*cf84ac9aSAndroid Build Coastguard Worker zero_extend_signed_to_ull(bogus_key), bogus_size,
133*cf84ac9aSAndroid Build Coastguard Worker sprintrc_grep(rc));
134*cf84ac9aSAndroid Build Coastguard Worker
135*cf84ac9aSAndroid Build Coastguard Worker rc = shmget(bogus_key, bogus_size, huge_flags);
136*cf84ac9aSAndroid Build Coastguard Worker printf("shmget\\(%#llx, %zu, %s\\|%#03o\\) = %s\n",
137*cf84ac9aSAndroid Build Coastguard Worker zero_extend_signed_to_ull(bogus_key), bogus_size,
138*cf84ac9aSAndroid Build Coastguard Worker str_shm_huge, 0, sprintrc_grep(rc));
139*cf84ac9aSAndroid Build Coastguard Worker
140*cf84ac9aSAndroid Build Coastguard Worker bogus_flags = 0xface1e55 & ~(bogus_ipc_shm_flags | huge_mask);
141*cf84ac9aSAndroid Build Coastguard Worker rc = shmget(bogus_key, bogus_size, bogus_flags);
142*cf84ac9aSAndroid Build Coastguard Worker printf("shmget\\(%#llx, %zu, %#x\\|%#03o\\) = %s\n",
143*cf84ac9aSAndroid Build Coastguard Worker zero_extend_signed_to_ull(bogus_key), bogus_size,
144*cf84ac9aSAndroid Build Coastguard Worker bogus_flags & ~0777,
145*cf84ac9aSAndroid Build Coastguard Worker bogus_flags & 0777, sprintrc_grep(rc));
146*cf84ac9aSAndroid Build Coastguard Worker
147*cf84ac9aSAndroid Build Coastguard Worker bogus_flags |= bogus_ipc_shm_flags;
148*cf84ac9aSAndroid Build Coastguard Worker rc = shmget(bogus_key, bogus_size, bogus_flags);
149*cf84ac9aSAndroid Build Coastguard Worker printf("shmget\\(%#llx, %zu, %s\\|%#03o\\) = %s\n",
150*cf84ac9aSAndroid Build Coastguard Worker zero_extend_signed_to_ull(bogus_key), bogus_size,
151*cf84ac9aSAndroid Build Coastguard Worker str_ipc_flags,
152*cf84ac9aSAndroid Build Coastguard Worker bogus_flags & 0777, sprintrc_grep(rc));
153*cf84ac9aSAndroid Build Coastguard Worker
154*cf84ac9aSAndroid Build Coastguard Worker bogus_flags |= huge_flags;
155*cf84ac9aSAndroid Build Coastguard Worker rc = shmget(bogus_key, bogus_size, bogus_flags);
156*cf84ac9aSAndroid Build Coastguard Worker printf("shmget\\(%#llx, %zu, %s\\|%s\\|%#03o\\) = %s\n",
157*cf84ac9aSAndroid Build Coastguard Worker zero_extend_signed_to_ull(bogus_key), bogus_size,
158*cf84ac9aSAndroid Build Coastguard Worker str_ipc_flags, str_shm_huge,
159*cf84ac9aSAndroid Build Coastguard Worker bogus_flags & 0777, sprintrc_grep(rc));
160*cf84ac9aSAndroid Build Coastguard Worker
161*cf84ac9aSAndroid Build Coastguard Worker bogus_flags &= ~bogus_ipc_shm_flags;
162*cf84ac9aSAndroid Build Coastguard Worker rc = shmget(bogus_key, bogus_size, bogus_flags);
163*cf84ac9aSAndroid Build Coastguard Worker printf("shmget\\(%#llx, %zu, %#x\\|%s\\|%#03o\\) = %s\n",
164*cf84ac9aSAndroid Build Coastguard Worker zero_extend_signed_to_ull(bogus_key), bogus_size,
165*cf84ac9aSAndroid Build Coastguard Worker bogus_flags & ~(0777 | huge_mask),
166*cf84ac9aSAndroid Build Coastguard Worker str_shm_huge,
167*cf84ac9aSAndroid Build Coastguard Worker bogus_flags & 0777, sprintrc_grep(rc));
168*cf84ac9aSAndroid Build Coastguard Worker
169*cf84ac9aSAndroid Build Coastguard Worker id = shmget(private_key, 1, 0600);
170*cf84ac9aSAndroid Build Coastguard Worker if (id < 0)
171*cf84ac9aSAndroid Build Coastguard Worker perror_msg_and_skip("shmget");
172*cf84ac9aSAndroid Build Coastguard Worker printf("shmget\\(%s, 1, 0600\\) = %d\n", str_ipc_private, id);
173*cf84ac9aSAndroid Build Coastguard Worker atexit(cleanup);
174*cf84ac9aSAndroid Build Coastguard Worker
175*cf84ac9aSAndroid Build Coastguard Worker rc = shmctl(bogus_id, bogus_cmd, NULL);
176*cf84ac9aSAndroid Build Coastguard Worker printf("shmctl\\(%d, (%s\\|)?%s, NULL\\) = %s\n",
177*cf84ac9aSAndroid Build Coastguard Worker bogus_id, str_ipc_64, str_bogus_cmd, sprintrc_grep(rc));
178*cf84ac9aSAndroid Build Coastguard Worker
179*cf84ac9aSAndroid Build Coastguard Worker rc = shmctl(bogus_id, IPC_STAT, bogus_addr);
180*cf84ac9aSAndroid Build Coastguard Worker printf("shmctl\\(%d, (%s\\|)?%s, %p\\) = %s\n",
181*cf84ac9aSAndroid Build Coastguard Worker bogus_id, str_ipc_64, str_ipc_stat, bogus_addr,
182*cf84ac9aSAndroid Build Coastguard Worker sprintrc_grep(rc));
183*cf84ac9aSAndroid Build Coastguard Worker
184*cf84ac9aSAndroid Build Coastguard Worker if (shmctl(id, IPC_STAT, &ds))
185*cf84ac9aSAndroid Build Coastguard Worker perror_msg_and_skip("shmctl IPC_STAT");
186*cf84ac9aSAndroid Build Coastguard Worker printf("shmctl\\(%d, (%s\\|)?%s, \\{shm_perm=\\{uid=%u, gid=%u, "
187*cf84ac9aSAndroid Build Coastguard Worker "mode=%#o, key=%u, cuid=%u, cgid=%u\\}, shm_segsz=%u, shm_cpid=%u, "
188*cf84ac9aSAndroid Build Coastguard Worker "shm_lpid=%u, shm_nattch=%u, shm_atime=%u, shm_dtime=%u, "
189*cf84ac9aSAndroid Build Coastguard Worker "shm_ctime=%u\\}\\) = 0\n",
190*cf84ac9aSAndroid Build Coastguard Worker id, str_ipc_64, str_ipc_stat,
191*cf84ac9aSAndroid Build Coastguard Worker (unsigned) ds.shm_perm.uid, (unsigned) ds.shm_perm.gid,
192*cf84ac9aSAndroid Build Coastguard Worker (unsigned) ds.shm_perm.mode, (unsigned) ds.shm_perm.__key,
193*cf84ac9aSAndroid Build Coastguard Worker (unsigned) ds.shm_perm.cuid, (unsigned) ds.shm_perm.cgid,
194*cf84ac9aSAndroid Build Coastguard Worker (unsigned) ds.shm_segsz, (unsigned) ds.shm_cpid,
195*cf84ac9aSAndroid Build Coastguard Worker (unsigned) ds.shm_lpid, (unsigned) ds.shm_nattch,
196*cf84ac9aSAndroid Build Coastguard Worker (unsigned) ds.shm_atime, (unsigned) ds.shm_dtime,
197*cf84ac9aSAndroid Build Coastguard Worker (unsigned) ds. shm_ctime);
198*cf84ac9aSAndroid Build Coastguard Worker
199*cf84ac9aSAndroid Build Coastguard Worker if (shmctl(id, IPC_SET, &ds))
200*cf84ac9aSAndroid Build Coastguard Worker perror_msg_and_skip("shmctl IPC_SET");
201*cf84ac9aSAndroid Build Coastguard Worker printf("shmctl\\(%d, (%s\\|)?%s, \\{shm_perm=\\{uid=%u, gid=%u"
202*cf84ac9aSAndroid Build Coastguard Worker ", mode=%#o\\}, ...\\}\\) = 0\n",
203*cf84ac9aSAndroid Build Coastguard Worker id, str_ipc_64, str_ipc_set,
204*cf84ac9aSAndroid Build Coastguard Worker (unsigned) ds.shm_perm.uid, (unsigned) ds.shm_perm.gid,
205*cf84ac9aSAndroid Build Coastguard Worker (unsigned) ds.shm_perm.mode);
206*cf84ac9aSAndroid Build Coastguard Worker
207*cf84ac9aSAndroid Build Coastguard Worker rc = shmctl(0, SHM_INFO, &ds);
208*cf84ac9aSAndroid Build Coastguard Worker printf("shmctl\\(0, (%s\\|)?%s, %p\\) = %s\n",
209*cf84ac9aSAndroid Build Coastguard Worker str_ipc_64, str_shm_info, &ds, sprintrc_grep(rc));
210*cf84ac9aSAndroid Build Coastguard Worker
211*cf84ac9aSAndroid Build Coastguard Worker rc = shmctl(id, SHM_STAT, &ds);
212*cf84ac9aSAndroid Build Coastguard Worker printf("shmctl\\(%d, (%s\\|)?%s, %p\\) = %s\n",
213*cf84ac9aSAndroid Build Coastguard Worker id, str_ipc_64, str_shm_stat, &ds, sprintrc_grep(rc));
214*cf84ac9aSAndroid Build Coastguard Worker
215*cf84ac9aSAndroid Build Coastguard Worker rc = shmctl(id, SHM_STAT_ANY, &ds);
216*cf84ac9aSAndroid Build Coastguard Worker printf("shmctl\\(%d, (%s\\|)?%s, %p\\) = %s\n",
217*cf84ac9aSAndroid Build Coastguard Worker id, str_ipc_64, str_shm_stat_any, &ds, sprintrc_grep(rc));
218*cf84ac9aSAndroid Build Coastguard Worker
219*cf84ac9aSAndroid Build Coastguard Worker return 0;
220*cf84ac9aSAndroid Build Coastguard Worker }
221