1*9d12795fSRobert Mustacchi /*
2*9d12795fSRobert Mustacchi  * This file and its contents are supplied under the terms of the
3*9d12795fSRobert Mustacchi  * Common Development and Distribution License ("CDDL"), version 1.0.
4*9d12795fSRobert Mustacchi  * You may only use this file in accordance with the terms of version
5*9d12795fSRobert Mustacchi  * 1.0 of the CDDL.
6*9d12795fSRobert Mustacchi  *
7*9d12795fSRobert Mustacchi  * A full copy of the text of the CDDL should have accompanied this
8*9d12795fSRobert Mustacchi  * source.  A copy of the CDDL is also available via the Internet at
9*9d12795fSRobert Mustacchi  * http://www.illumos.org/license/CDDL.
10*9d12795fSRobert Mustacchi  */
11*9d12795fSRobert Mustacchi 
12*9d12795fSRobert Mustacchi /*
13*9d12795fSRobert Mustacchi  * Copyright (c) 2015, Joyent, Inc.
14*9d12795fSRobert Mustacchi  */
15*9d12795fSRobert Mustacchi 
16*9d12795fSRobert Mustacchi /*
17*9d12795fSRobert Mustacchi  * Verify that using MC_INHERIT_ZERO works just fine when applied to a subset of
18*9d12795fSRobert Mustacchi  * a region, meaning that we should have created a struct vpage for that region.
19*9d12795fSRobert Mustacchi  */
20*9d12795fSRobert Mustacchi 
21*9d12795fSRobert Mustacchi #include <sys/types.h>
22*9d12795fSRobert Mustacchi #include <unistd.h>
23*9d12795fSRobert Mustacchi #include <assert.h>
24*9d12795fSRobert Mustacchi #include <sys/mman.h>
25*9d12795fSRobert Mustacchi #include <string.h>
26*9d12795fSRobert Mustacchi #include <errno.h>
27*9d12795fSRobert Mustacchi #include <stdlib.h>
28*9d12795fSRobert Mustacchi #include <wait.h>
29*9d12795fSRobert Mustacchi 
30*9d12795fSRobert Mustacchi int
main(void)31*9d12795fSRobert Mustacchi main(void)
32*9d12795fSRobert Mustacchi {
33*9d12795fSRobert Mustacchi 	void *buf;
34*9d12795fSRobert Mustacchi 	pid_t child;
35*9d12795fSRobert Mustacchi 	int ret, i;
36*9d12795fSRobert Mustacchi 	siginfo_t info;
37*9d12795fSRobert Mustacchi 	uint8_t *ubuf;
38*9d12795fSRobert Mustacchi 	size_t pgsz = sysconf(_SC_PAGESIZE);
39*9d12795fSRobert Mustacchi 	size_t mapsz = 10 * pgsz;
40*9d12795fSRobert Mustacchi 	size_t clrsz = 5 * pgsz;
41*9d12795fSRobert Mustacchi 	size_t clroff = 2 * pgsz;
42*9d12795fSRobert Mustacchi 
43*9d12795fSRobert Mustacchi 	buf = mmap(NULL, mapsz, PROT_READ | PROT_WRITE,
44*9d12795fSRobert Mustacchi 	    MAP_PRIVATE | MAP_ANON, -1, 0);
45*9d12795fSRobert Mustacchi 	assert(buf != MAP_FAILED);
46*9d12795fSRobert Mustacchi 	memset(buf, 'a', mapsz);
47*9d12795fSRobert Mustacchi 
48*9d12795fSRobert Mustacchi 	ret = memcntl(buf + clroff, clrsz, MC_INHERIT_ZERO, 0, 0, 0);
49*9d12795fSRobert Mustacchi 	assert(ret == 0);
50*9d12795fSRobert Mustacchi 
51*9d12795fSRobert Mustacchi 	child = fork();
52*9d12795fSRobert Mustacchi 	if (child == 0) {
53*9d12795fSRobert Mustacchi 		ubuf = buf;
54*9d12795fSRobert Mustacchi 		for (i = 0; i < clroff; i++)
55*9d12795fSRobert Mustacchi 			assert(ubuf[i] == 'a');
56*9d12795fSRobert Mustacchi 		for (i = clroff; i < clrsz + clroff; i++)
57*9d12795fSRobert Mustacchi 			assert(ubuf[i] == 0);
58*9d12795fSRobert Mustacchi 		for (i = clrsz + clroff; i < mapsz; i++)
59*9d12795fSRobert Mustacchi 			assert(ubuf[i] == 'a');
60*9d12795fSRobert Mustacchi 		exit(0);
61*9d12795fSRobert Mustacchi 	}
62*9d12795fSRobert Mustacchi 	assert(child != -1);
63*9d12795fSRobert Mustacchi 
64*9d12795fSRobert Mustacchi 	do {
65*9d12795fSRobert Mustacchi 		ret = waitid(P_PID, child, &info, WEXITED);
66*9d12795fSRobert Mustacchi 	} while (ret == -1 && errno == EINTR);
67*9d12795fSRobert Mustacchi 	assert(ret == 0);
68*9d12795fSRobert Mustacchi 	assert(info.si_pid == child);
69*9d12795fSRobert Mustacchi 	assert(info.si_status == 0);
70*9d12795fSRobert Mustacchi 
71*9d12795fSRobert Mustacchi 	for (i = 0, ubuf = buf; i < mapsz; i++)
72*9d12795fSRobert Mustacchi 		assert(ubuf[i] == 'a');
73*9d12795fSRobert Mustacchi 
74*9d12795fSRobert Mustacchi 	return (0);
75*9d12795fSRobert Mustacchi }
76