1*43a90889SApple OSS Distributions /* 2*43a90889SApple OSS Distributions * Copyright (c) 2004-2005, 2011 Apple Computer, Inc. All rights reserved. 3*43a90889SApple OSS Distributions * 4*43a90889SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 5*43a90889SApple OSS Distributions * 6*43a90889SApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code 7*43a90889SApple OSS Distributions * as defined in and that are subject to the Apple Public Source License 8*43a90889SApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in 9*43a90889SApple OSS Distributions * compliance with the License. The rights granted to you under the License 10*43a90889SApple OSS Distributions * may not be used to create, or enable the creation or redistribution of, 11*43a90889SApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to 12*43a90889SApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any 13*43a90889SApple OSS Distributions * terms of an Apple operating system software license agreement. 14*43a90889SApple OSS Distributions * 15*43a90889SApple OSS Distributions * Please obtain a copy of the License at 16*43a90889SApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file. 17*43a90889SApple OSS Distributions * 18*43a90889SApple OSS Distributions * The Original Code and all software distributed under the License are 19*43a90889SApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 20*43a90889SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 21*43a90889SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 22*43a90889SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 23*43a90889SApple OSS Distributions * Please see the License for the specific language governing rights and 24*43a90889SApple OSS Distributions * limitations under the License. 25*43a90889SApple OSS Distributions * 26*43a90889SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 27*43a90889SApple OSS Distributions */ 28*43a90889SApple OSS Distributions /* 29*43a90889SApple OSS Distributions * Copyright (c) 1993, David Greenman 30*43a90889SApple OSS Distributions * All rights reserved. 31*43a90889SApple OSS Distributions * 32*43a90889SApple OSS Distributions * Redistribution and use in source and binary forms, with or without 33*43a90889SApple OSS Distributions * modification, are permitted provided that the following conditions 34*43a90889SApple OSS Distributions * are met: 35*43a90889SApple OSS Distributions * 1. Redistributions of source code must retain the above copyright 36*43a90889SApple OSS Distributions * notice, this list of conditions and the following disclaimer. 37*43a90889SApple OSS Distributions * 2. Redistributions in binary form must reproduce the above copyright 38*43a90889SApple OSS Distributions * notice, this list of conditions and the following disclaimer in the 39*43a90889SApple OSS Distributions * documentation and/or other materials provided with the distribution. 40*43a90889SApple OSS Distributions * 3. All advertising materials mentioning features or use of this software 41*43a90889SApple OSS Distributions * must display the following acknowledgement: 42*43a90889SApple OSS Distributions * This product includes software developed by the University of 43*43a90889SApple OSS Distributions * California, Berkeley and its contributors. 44*43a90889SApple OSS Distributions * 4. Neither the name of the University nor the names of its contributors 45*43a90889SApple OSS Distributions * may be used to endorse or promote products derived from this software 46*43a90889SApple OSS Distributions * without specific prior written permission. 47*43a90889SApple OSS Distributions * 48*43a90889SApple OSS Distributions * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 49*43a90889SApple OSS Distributions * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 50*43a90889SApple OSS Distributions * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 51*43a90889SApple OSS Distributions * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 52*43a90889SApple OSS Distributions * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 53*43a90889SApple OSS Distributions * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 54*43a90889SApple OSS Distributions * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 55*43a90889SApple OSS Distributions * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 56*43a90889SApple OSS Distributions * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 57*43a90889SApple OSS Distributions * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 58*43a90889SApple OSS Distributions * SUCH DAMAGE. 59*43a90889SApple OSS Distributions */ 60*43a90889SApple OSS Distributions /* 61*43a90889SApple OSS Distributions * NOTICE: This file was modified by SPARTA, Inc. in 2005 to introduce 62*43a90889SApple OSS Distributions * support for mandatory and extensible security protections. This notice 63*43a90889SApple OSS Distributions * is included in support of clause 2.2 (b) of the Apple Public License, 64*43a90889SApple OSS Distributions * Version 2.0. 65*43a90889SApple OSS Distributions */ 66*43a90889SApple OSS Distributions #ifndef _SYS_IMGACT_H_ 67*43a90889SApple OSS Distributions #define _SYS_IMGACT_H_ 68*43a90889SApple OSS Distributions 69*43a90889SApple OSS Distributions #define IMG_SHSIZE 512 /* largest shell interpreter, in bytes */ 70*43a90889SApple OSS Distributions 71*43a90889SApple OSS Distributions struct label; 72*43a90889SApple OSS Distributions struct proc; 73*43a90889SApple OSS Distributions struct nameidata; 74*43a90889SApple OSS Distributions 75*43a90889SApple OSS Distributions struct image_params { 76*43a90889SApple OSS Distributions user_addr_t ip_user_fname; /* argument */ 77*43a90889SApple OSS Distributions user_addr_t ip_user_argv; /* argument */ 78*43a90889SApple OSS Distributions user_addr_t ip_user_envv; /* argument */ 79*43a90889SApple OSS Distributions int ip_seg; /* segment for arguments */ 80*43a90889SApple OSS Distributions struct vnode *ip_vp; /* file */ 81*43a90889SApple OSS Distributions struct vnode_attr *ip_vattr; /* run file attributes */ 82*43a90889SApple OSS Distributions struct vnode_attr *ip_origvattr; /* invocation file attributes */ 83*43a90889SApple OSS Distributions cpu_type_t ip_origcputype; /* cputype of invocation file */ 84*43a90889SApple OSS Distributions cpu_subtype_t ip_origcpusubtype; /* subtype of invocation file */ 85*43a90889SApple OSS Distributions char *ip_vdata; /* file data (up to one page) */ 86*43a90889SApple OSS Distributions int ip_flags; /* image flags */ 87*43a90889SApple OSS Distributions int ip_argc; /* argument count */ 88*43a90889SApple OSS Distributions int ip_envc; /* environment count */ 89*43a90889SApple OSS Distributions int ip_applec; /* apple vector count */ 90*43a90889SApple OSS Distributions 91*43a90889SApple OSS Distributions char *ip_startargv; /* argument vector beginning */ 92*43a90889SApple OSS Distributions char *ip_endargv; /* end of argv/start of envv */ 93*43a90889SApple OSS Distributions char *ip_endenvv; /* end of envv/start of applev */ 94*43a90889SApple OSS Distributions 95*43a90889SApple OSS Distributions char *ip_strings; /* base address for strings */ 96*43a90889SApple OSS Distributions char *ip_strendp; /* current end pointer */ 97*43a90889SApple OSS Distributions 98*43a90889SApple OSS Distributions char *ip_subsystem_root_path; /* filepath for the subsystem root */ 99*43a90889SApple OSS Distributions 100*43a90889SApple OSS Distributions int ip_argspace; /* remaining space of NCARGS limit (argv+envv) */ 101*43a90889SApple OSS Distributions int ip_strspace; /* remaining total string space */ 102*43a90889SApple OSS Distributions 103*43a90889SApple OSS Distributions user_size_t ip_arch_offset; /* subfile offset in ip_vp */ 104*43a90889SApple OSS Distributions user_size_t ip_arch_size; /* subfile length in ip_vp */ 105*43a90889SApple OSS Distributions char ip_interp_buffer[IMG_SHSIZE]; /* interpreter buffer space */ 106*43a90889SApple OSS Distributions int ip_interp_sugid_fd; /* fd for sugid script */ 107*43a90889SApple OSS Distributions 108*43a90889SApple OSS Distributions /* Next two fields are for support of architecture translation... */ 109*43a90889SApple OSS Distributions struct vfs_context *ip_vfs_context; /* VFS context */ 110*43a90889SApple OSS Distributions struct nameidata *ip_ndp; /* current nameidata */ 111*43a90889SApple OSS Distributions thread_t ip_new_thread; /* thread for spawn */ 112*43a90889SApple OSS Distributions 113*43a90889SApple OSS Distributions struct label *ip_execlabelp; /* label of the executable */ 114*43a90889SApple OSS Distributions struct label *ip_scriptlabelp; /* label of the script */ 115*43a90889SApple OSS Distributions struct vnode *ip_scriptvp; /* script */ 116*43a90889SApple OSS Distributions unsigned int ip_csflags; /* code signing flags */ 117*43a90889SApple OSS Distributions int ip_mac_return; /* return code from mac policy checks */ 118*43a90889SApple OSS Distributions void *ip_px_sa; /* posix_spawn attrs */ 119*43a90889SApple OSS Distributions void *ip_px_sfa; /* posix_spawn file actions */ 120*43a90889SApple OSS Distributions void *ip_px_spa; /* posix_spawn port actions */ 121*43a90889SApple OSS Distributions vm_map_t ip_free_map; /* map to free once iocount is dropped on vnode */ 122*43a90889SApple OSS Distributions struct ip_px_smpx_s { 123*43a90889SApple OSS Distributions void *array; 124*43a90889SApple OSS Distributions void *data; 125*43a90889SApple OSS Distributions uint64_t datalen; 126*43a90889SApple OSS Distributions } ip_px_smpx; /* MAC-specific spawn attrs. */ 127*43a90889SApple OSS Distributions void *ip_px_persona; /* persona args */ 128*43a90889SApple OSS Distributions void *ip_px_pcred_info; /* posix cred args */ 129*43a90889SApple OSS Distributions void *ip_cs_error; /* codesigning error reason */ 130*43a90889SApple OSS Distributions char *ip_inherited_shared_region_id; /* inherited shared region id for ptr auth */ 131*43a90889SApple OSS Distributions 132*43a90889SApple OSS Distributions uint64_t ip_dyld_fsid; 133*43a90889SApple OSS Distributions uint64_t ip_dyld_fsobjid; 134*43a90889SApple OSS Distributions uint64_t ip_inherited_jop_pid; 135*43a90889SApple OSS Distributions unsigned int ip_simulator_binary; /* simulator binary flags */ 136*43a90889SApple OSS Distributions }; 137*43a90889SApple OSS Distributions 138*43a90889SApple OSS Distributions /* 139*43a90889SApple OSS Distributions * Image flags 140*43a90889SApple OSS Distributions */ 141*43a90889SApple OSS Distributions #define IMGPF_NONE 0x00000000 /* No flags */ 142*43a90889SApple OSS Distributions #define IMGPF_INTERPRET 0x00000001 /* Interpreter invoked */ 143*43a90889SApple OSS Distributions #define IMGPF_RESERVED 0x00000002 144*43a90889SApple OSS Distributions #define IMGPF_WAS_64BIT_ADDR 0x00000004 /* exec from a 64Bit address space */ 145*43a90889SApple OSS Distributions #define IMGPF_IS_64BIT_ADDR 0x00000008 /* exec to a 64Bit address space */ 146*43a90889SApple OSS Distributions #define IMGPF_SPAWN 0x00000010 /* spawn (without setexec) */ 147*43a90889SApple OSS Distributions #define IMGPF_DISABLE_ASLR 0x00000020 /* disable ASLR */ 148*43a90889SApple OSS Distributions #define IMGPF_ALLOW_DATA_EXEC 0x00000040 /* forcibly disallow data execution */ 149*43a90889SApple OSS Distributions #if XNU_TARGET_OS_OSX 150*43a90889SApple OSS Distributions #define IMGPF_3P_PLUGINS 0x00000080 /* this platform binary might load third party plugins */ 151*43a90889SApple OSS Distributions #endif /* XNU_TARGET_OS_OSX */ 152*43a90889SApple OSS Distributions #define IMGPF_EXEC 0x00000100 /* exec */ 153*43a90889SApple OSS Distributions #define IMGPF_HIGH_BITS_ASLR 0x00000200 /* randomize high bits of ASLR slide */ 154*43a90889SApple OSS Distributions #define IMGPF_IS_64BIT_DATA 0x00000400 /* exec to a 64Bit register state */ 155*43a90889SApple OSS Distributions #define IMGPF_DRIVER 0x00000800 /* exec of a driver binary (no LC_MAIN) */ 156*43a90889SApple OSS Distributions #define IMGPF_RESLIDE 0x00001000 /* reslide the shared cache */ 157*43a90889SApple OSS Distributions #define IMGPF_PLUGIN_HOST_DISABLE_A_KEYS 0x00002000 /* process hosts plugins, disable ptr auth A keys */ 158*43a90889SApple OSS Distributions #define IMGPF_HW_TPRO 0x00004000 /* HW support for read-only/read-write trusted paths */ 159*43a90889SApple OSS Distributions #define IMGPF_HARDENED_HEAP 0x00008000 /* enable hardened-heap for the process */ 160*43a90889SApple OSS Distributions #define IMGPF_ROSETTA 0x10000000 /* load rosetta runtime */ 161*43a90889SApple OSS Distributions #define IMGPF_ALT_ROSETTA 0x20000000 /* load alternative rosetta runtime */ 162*43a90889SApple OSS Distributions #define IMGPF_NOJOP 0x80000000 163*43a90889SApple OSS Distributions 164*43a90889SApple OSS Distributions /* 165*43a90889SApple OSS Distributions * Simulator binary flags 166*43a90889SApple OSS Distributions */ 167*43a90889SApple OSS Distributions #define IMGPF_SB_DEFAULT 0 /* Default value, did not check if it is a simulator binary */ 168*43a90889SApple OSS Distributions #define IMGPF_SB_TRUE 1 /* Binary is a simulator binary */ 169*43a90889SApple OSS Distributions #define IMGPF_SB_FALSE 2 /* Binary is not a simulator binary */ 170*43a90889SApple OSS Distributions 171*43a90889SApple OSS Distributions 172*43a90889SApple OSS Distributions #endif /* !_SYS_IMGACT */ 173