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 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