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