1*94d3b452SApple OSS Distributions /* 2*94d3b452SApple OSS Distributions * Coyright (c) 2005-2013 Apple Inc. All rights reserved. 3*94d3b452SApple OSS Distributions * 4*94d3b452SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 5*94d3b452SApple OSS Distributions * 6*94d3b452SApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code 7*94d3b452SApple OSS Distributions * as defined in and that are subject to the Apple Public Source License 8*94d3b452SApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in 9*94d3b452SApple OSS Distributions * compliance with the License. The rights granted to you under the License 10*94d3b452SApple OSS Distributions * may not be used to create, or enable the creation or redistribution of, 11*94d3b452SApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to 12*94d3b452SApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any 13*94d3b452SApple OSS Distributions * terms of an Apple operating system software license agreement. 14*94d3b452SApple OSS Distributions * 15*94d3b452SApple OSS Distributions * Please obtain a copy of the License at 16*94d3b452SApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file. 17*94d3b452SApple OSS Distributions * 18*94d3b452SApple OSS Distributions * The Original Code and all software distributed under the License are 19*94d3b452SApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 20*94d3b452SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 21*94d3b452SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 22*94d3b452SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 23*94d3b452SApple OSS Distributions * Please see the License for the specific language governing rights and 24*94d3b452SApple OSS Distributions * limitations under the License. 25*94d3b452SApple OSS Distributions * 26*94d3b452SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 27*94d3b452SApple OSS Distributions */ 28*94d3b452SApple OSS Distributions 29*94d3b452SApple OSS Distributions #ifndef __MUNGE_H__ 30*94d3b452SApple OSS Distributions #define __MUNGE_H__ 31*94d3b452SApple OSS Distributions 32*94d3b452SApple OSS Distributions /* 33*94d3b452SApple OSS Distributions * Syscall argument mungers. 34*94d3b452SApple OSS Distributions * 35*94d3b452SApple OSS Distributions * The data to be munged has been explicitly copied in to the argument 36*94d3b452SApple OSS Distributions * area, and will be munged in place in the uu_arg[] array. These 37*94d3b452SApple OSS Distributions * mungers are for 32-bit app's syscalls, since 64-bit args are copied 38*94d3b452SApple OSS Distributions * from the save area to the uu_args in the order the 39*94d3b452SApple OSS Distributions * syscall ABI calls for. 40*94d3b452SApple OSS Distributions * 41*94d3b452SApple OSS Distributions * The issue is that the incoming args are 32-bit, but we must expand 42*94d3b452SApple OSS Distributions * them in place into 64-bit args, as if they were from a 64-bit process. 43*94d3b452SApple OSS Distributions * 44*94d3b452SApple OSS Distributions * There are several functions in this file with the following prototype 45*94d3b452SApple OSS Distributions * 46*94d3b452SApple OSS Distributions * void munge_XXXX(void *uu_args); 47*94d3b452SApple OSS Distributions * 48*94d3b452SApple OSS Distributions * The name of the function encodes the number and type of the parameters, 49*94d3b452SApple OSS Distributions * as follows: 50*94d3b452SApple OSS Distributions * 51*94d3b452SApple OSS Distributions * w = a 32-bit value such as an int or a 32-bit ptr, that does not 52*94d3b452SApple OSS Distributions * require sign extension. These are handled by zeroing a word 53*94d3b452SApple OSS Distributions * of output, and copying a word from input to output. 54*94d3b452SApple OSS Distributions * 55*94d3b452SApple OSS Distributions * s = a 32-bit value such as a long, which must be sign-extended to 56*94d3b452SApple OSS Distributions * a 64-bit long-long in the uu_args. These are handled by 57*94d3b452SApple OSS Distributions * loading a word of input and sign extending it to a double, 58*94d3b452SApple OSS Distributions * and storing two words of output. 59*94d3b452SApple OSS Distributions * 60*94d3b452SApple OSS Distributions * l = a 64-bit long-long. These are handled by copying two words 61*94d3b452SApple OSS Distributions * of input to the output. 62*94d3b452SApple OSS Distributions * 63*94d3b452SApple OSS Distributions * For example, "munge_wls" takes a word, a long-long, and a word. This 64*94d3b452SApple OSS Distributions * takes four words in the uu_arg[] area: the first word is in one, the 65*94d3b452SApple OSS Distributions * long-long takes two, and the final word is in the fourth. We store six 66*94d3b452SApple OSS Distributions * words: the low word is left in place, followed by a 0, followed by the 67*94d3b452SApple OSS Distributions * two words of the long-long, followed by the low word and the sign extended 68*94d3b452SApple OSS Distributions * high word of the preceeding low word. 69*94d3b452SApple OSS Distributions * 70*94d3b452SApple OSS Distributions * Because this is an in-place modification, we actually start at the end 71*94d3b452SApple OSS Distributions * of uu_arg[] and work our way back to the beginning of the array. 72*94d3b452SApple OSS Distributions */ 73*94d3b452SApple OSS Distributions 74*94d3b452SApple OSS Distributions #if __arm__ && (__BIGGEST_ALIGNMENT__ > 4) 75*94d3b452SApple OSS Distributions int munge_w(const void *regs, void *args); 76*94d3b452SApple OSS Distributions int munge_ww(const void *regs, void *args); 77*94d3b452SApple OSS Distributions int munge_www(const void *regs, void *args); 78*94d3b452SApple OSS Distributions int munge_wwww(const void *regs, void *args); 79*94d3b452SApple OSS Distributions int munge_wwwww(const void *regs, void *args); 80*94d3b452SApple OSS Distributions int munge_wwwwww(const void *regs, void *args); 81*94d3b452SApple OSS Distributions int munge_wwwwwww(const void *regs, void *args); 82*94d3b452SApple OSS Distributions int munge_wwwwwwww(const void *regs, void *args); 83*94d3b452SApple OSS Distributions int munge_wl(const void *regs, void *args); 84*94d3b452SApple OSS Distributions int munge_wwl(const void *regs, void *args); 85*94d3b452SApple OSS Distributions int munge_wwlw(const void *regs, void *args); 86*94d3b452SApple OSS Distributions int munge_wwlll(const void *regs, void *args); 87*94d3b452SApple OSS Distributions int munge_wwlllll(const void *regs, void *args); 88*94d3b452SApple OSS Distributions int munge_wwllww(const void *regs, void *args); 89*94d3b452SApple OSS Distributions int munge_wlw(const void *regs, void *args); 90*94d3b452SApple OSS Distributions int munge_wlww(const void *regs, void *args); 91*94d3b452SApple OSS Distributions int munge_wlwwwl(const void *regs, void *args); 92*94d3b452SApple OSS Distributions int munge_wlwwwll(const void *regs, void *args); 93*94d3b452SApple OSS Distributions int munge_wlwwwllw(const void *regs, void *args); 94*94d3b452SApple OSS Distributions int munge_wlwwlwlw(const void *regs, void *args); 95*94d3b452SApple OSS Distributions int munge_wll(const void *regs, void *args); 96*94d3b452SApple OSS Distributions int munge_wllww(const void *regs, void *args); 97*94d3b452SApple OSS Distributions int munge_wlll(const void *regs, void *args); 98*94d3b452SApple OSS Distributions int munge_wlllww(const void *regs, void *args); 99*94d3b452SApple OSS Distributions int munge_wllll(const void *regs, void *args); 100*94d3b452SApple OSS Distributions int munge_wllwwll(const void *regs, void *args); 101*94d3b452SApple OSS Distributions int munge_wwwlw(const void *regs, void *args); 102*94d3b452SApple OSS Distributions int munge_wwwlww(const void *regs, void *args); 103*94d3b452SApple OSS Distributions int munge_wwwlwww(const void *regs, void *args); 104*94d3b452SApple OSS Distributions int munge_wwwl(const void *regs, void *args); 105*94d3b452SApple OSS Distributions int munge_wwwwlw(const void *regs, void *args); 106*94d3b452SApple OSS Distributions int munge_wwwwllww(const void *regs, void *args); 107*94d3b452SApple OSS Distributions int munge_wwwwl(const void *regs, void *args); 108*94d3b452SApple OSS Distributions int munge_wwwwwl(const void *regs, void *args); 109*94d3b452SApple OSS Distributions int munge_wwwwwlww(const void *regs, void *args); 110*94d3b452SApple OSS Distributions int munge_wwwwwllw(const void *regs, void *args); 111*94d3b452SApple OSS Distributions int munge_wwwwwlll(const void *regs, void *args); 112*94d3b452SApple OSS Distributions int munge_wwwwwwl(const void *regs, void *args); 113*94d3b452SApple OSS Distributions int munge_wwwwwwlw(const void *regs, void *args); 114*94d3b452SApple OSS Distributions int munge_wwwwwwll(const void *regs, void *args); 115*94d3b452SApple OSS Distributions int munge_wsw(const void *regs, void *args); 116*94d3b452SApple OSS Distributions int munge_wws(const void *regs, void *args); 117*94d3b452SApple OSS Distributions int munge_wwws(const void *regs, void *args); 118*94d3b452SApple OSS Distributions int munge_wwwsw(const void *regs, void *args); 119*94d3b452SApple OSS Distributions int munge_llllllll(const void *regs, void *args); 120*94d3b452SApple OSS Distributions int munge_llllll(const void *regs, void *args); 121*94d3b452SApple OSS Distributions int munge_l(const void *regs, void *args); 122*94d3b452SApple OSS Distributions int munge_ll(const void *regs, void *args); 123*94d3b452SApple OSS Distributions int munge_lll(const void *regs, void *args); 124*94d3b452SApple OSS Distributions int munge_lw(const void *regs, void *args); 125*94d3b452SApple OSS Distributions int munge_lwww(const void *regs, void *args); 126*94d3b452SApple OSS Distributions int munge_lwwwwwww(const void *regs, void *args); 127*94d3b452SApple OSS Distributions int munge_wwlww(const void *regs, void *args); 128*94d3b452SApple OSS Distributions int munge_wwlwww(const void *regs, void *args); 129*94d3b452SApple OSS Distributions int munge_wwlwwwl(const void *regs, void *args); 130*94d3b452SApple OSS Distributions #else 131*94d3b452SApple OSS Distributions void munge_w(void *args); 132*94d3b452SApple OSS Distributions void munge_ww(void *args); 133*94d3b452SApple OSS Distributions void munge_www(void *args); 134*94d3b452SApple OSS Distributions void munge_wwww(void *args); 135*94d3b452SApple OSS Distributions void munge_wwwww(void *args); 136*94d3b452SApple OSS Distributions void munge_wwwwww(void *args); 137*94d3b452SApple OSS Distributions void munge_wwwwwww(void *args); 138*94d3b452SApple OSS Distributions void munge_wwwwwwww(void *args); 139*94d3b452SApple OSS Distributions void munge_wl(void *args); 140*94d3b452SApple OSS Distributions void munge_wwl(void *args); 141*94d3b452SApple OSS Distributions void munge_wwlw(void *args); 142*94d3b452SApple OSS Distributions void munge_wwlll(void *args); 143*94d3b452SApple OSS Distributions void munge_wwlllll(void *args); 144*94d3b452SApple OSS Distributions void munge_wwllww(void *args); 145*94d3b452SApple OSS Distributions void munge_wlw(void *args); 146*94d3b452SApple OSS Distributions void munge_wlww(void *args); 147*94d3b452SApple OSS Distributions void munge_wlwwwl(void *args); 148*94d3b452SApple OSS Distributions void munge_wlwwwll(void *args); 149*94d3b452SApple OSS Distributions void munge_wlwwwllw(void *args); 150*94d3b452SApple OSS Distributions void munge_wlwwlwlw(void *args); 151*94d3b452SApple OSS Distributions void munge_wll(void *args); 152*94d3b452SApple OSS Distributions void munge_wllww(void *args); 153*94d3b452SApple OSS Distributions void munge_wlll(void *args); 154*94d3b452SApple OSS Distributions void munge_wlllww(void *args); 155*94d3b452SApple OSS Distributions void munge_wllll(void *args); 156*94d3b452SApple OSS Distributions void munge_wllwwll(void *args); 157*94d3b452SApple OSS Distributions void munge_wwwlw(void *args); 158*94d3b452SApple OSS Distributions void munge_wwwlww(void *args); 159*94d3b452SApple OSS Distributions void munge_wwwlwww(void *args); 160*94d3b452SApple OSS Distributions void munge_wwwl(void *args); 161*94d3b452SApple OSS Distributions void munge_wwwwlw(void *args); 162*94d3b452SApple OSS Distributions void munge_wwwwllww(void *args); 163*94d3b452SApple OSS Distributions void munge_wwwwl(void *args); 164*94d3b452SApple OSS Distributions void munge_wwwwwl(void *args); 165*94d3b452SApple OSS Distributions void munge_wwwwwlww(void *args); 166*94d3b452SApple OSS Distributions void munge_wwwwwllw(void *args); 167*94d3b452SApple OSS Distributions void munge_wwwwwlll(void *args); 168*94d3b452SApple OSS Distributions void munge_wwwwwwl(void *args); 169*94d3b452SApple OSS Distributions void munge_wwwwwwlw(void *args); 170*94d3b452SApple OSS Distributions void munge_wwwwwwll(void *args); 171*94d3b452SApple OSS Distributions void munge_wsw(void *args); 172*94d3b452SApple OSS Distributions void munge_wws(void *args); 173*94d3b452SApple OSS Distributions void munge_wwws(void *args); 174*94d3b452SApple OSS Distributions void munge_wwwsw(void *args); 175*94d3b452SApple OSS Distributions void munge_llllllll(void *args); 176*94d3b452SApple OSS Distributions void munge_llllll(void *args); 177*94d3b452SApple OSS Distributions void munge_llll(void *args); 178*94d3b452SApple OSS Distributions void munge_l(void *args); 179*94d3b452SApple OSS Distributions void munge_ll(void *args); 180*94d3b452SApple OSS Distributions void munge_lll(void *args); 181*94d3b452SApple OSS Distributions void munge_lw(void *args); 182*94d3b452SApple OSS Distributions void munge_lwww(void *args); 183*94d3b452SApple OSS Distributions void munge_lwwwwwww(void *args); 184*94d3b452SApple OSS Distributions void munge_wwlww(void *args); 185*94d3b452SApple OSS Distributions void munge_wwlwww(void *args); 186*94d3b452SApple OSS Distributions void munge_wwlwwwl(void *args); 187*94d3b452SApple OSS Distributions #endif /* __arm__ && (__BIGGEST_ALIGNMENT__ > 4) */ 188*94d3b452SApple OSS Distributions #endif /* __MUNGE_H__ */ 189