1*a1e26a70SApple OSS Distributions /* 2*a1e26a70SApple OSS Distributions * Copyright (c) 2007 Apple, Inc. All rights reserved. 3*a1e26a70SApple OSS Distributions * 4*a1e26a70SApple OSS Distributions * @APPLE_LICENSE_HEADER_START@ 5*a1e26a70SApple OSS Distributions * 6*a1e26a70SApple OSS Distributions * The contents of this file constitute Original Code as defined in and 7*a1e26a70SApple OSS Distributions * are subject to the Apple Public Source License Version 1.1 (the 8*a1e26a70SApple OSS Distributions * "License"). You may not use this file except in compliance with the 9*a1e26a70SApple OSS Distributions * License. Please obtain a copy of the License at 10*a1e26a70SApple OSS Distributions * http://www.apple.com/publicsource and read it before using this file. 11*a1e26a70SApple OSS Distributions * 12*a1e26a70SApple OSS Distributions * This Original Code and all software distributed under the License are 13*a1e26a70SApple OSS Distributions * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER 14*a1e26a70SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 15*a1e26a70SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 16*a1e26a70SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the 17*a1e26a70SApple OSS Distributions * License for the specific language governing rights and limitations 18*a1e26a70SApple OSS Distributions * under the License. 19*a1e26a70SApple OSS Distributions * 20*a1e26a70SApple OSS Distributions * @APPLE_LICENSE_HEADER_END@ 21*a1e26a70SApple OSS Distributions */ 22*a1e26a70SApple OSS Distributions 23*a1e26a70SApple OSS Distributions #pragma D depends_on library darwin.d 24*a1e26a70SApple OSS Distributions #pragma D depends_on module mach_kernel 25*a1e26a70SApple OSS Distributions #pragma D depends_on provider io 26*a1e26a70SApple OSS Distributions 27*a1e26a70SApple OSS Distributions inline int B_WRITE = 0x0000; 28*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_WRITE 29*a1e26a70SApple OSS Distributions inline int B_READ = 0x0001; 30*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_READ 31*a1e26a70SApple OSS Distributions inline int B_ASYNC = 0x0002; 32*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_ASYNC 33*a1e26a70SApple OSS Distributions inline int B_NOCACHE = 0x0004; 34*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_NOCACHE 35*a1e26a70SApple OSS Distributions inline int B_DELWRI = 0x0008; 36*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_DELWRI 37*a1e26a70SApple OSS Distributions inline int B_LOCKED = 0x0010; 38*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_LOCKED 39*a1e26a70SApple OSS Distributions inline int B_PHYS = 0x0020; 40*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_PHYS 41*a1e26a70SApple OSS Distributions inline int B_CLUSTER = 0x0040; 42*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_CLUSTER 43*a1e26a70SApple OSS Distributions inline int B_PAGEIO = 0x0080; 44*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_PAGEIO 45*a1e26a70SApple OSS Distributions inline int B_META = 0x0100; 46*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_META 47*a1e26a70SApple OSS Distributions inline int B_RAW = 0x0200; 48*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_RAW 49*a1e26a70SApple OSS Distributions inline int B_FUA = 0x0400; 50*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_FUA 51*a1e26a70SApple OSS Distributions inline int B_PASSIVE = 0x0800; 52*a1e26a70SApple OSS Distributions #pragma D binding "1.0" B_PASSIVE 53*a1e26a70SApple OSS Distributions 54*a1e26a70SApple OSS Distributions typedef struct bufinfo { 55*a1e26a70SApple OSS Distributions int b_flags; /* buffer status */ 56*a1e26a70SApple OSS Distributions size_t b_bcount; /* number of bytes */ 57*a1e26a70SApple OSS Distributions caddr_t b_addr; /* buffer address */ 58*a1e26a70SApple OSS Distributions uint64_t b_lblkno; /* block # on device */ 59*a1e26a70SApple OSS Distributions uint64_t b_blkno; /* expanded block # on device */ 60*a1e26a70SApple OSS Distributions size_t b_resid; /* # of bytes not transferred */ 61*a1e26a70SApple OSS Distributions size_t b_bufsize; /* size of allocated buffer */ 62*a1e26a70SApple OSS Distributions caddr_t b_iodone; /* I/O completion routine */ 63*a1e26a70SApple OSS Distributions int b_error; /* expanded error field */ 64*a1e26a70SApple OSS Distributions dev_t b_edev; /* extended device */ 65*a1e26a70SApple OSS Distributions } bufinfo_t; 66*a1e26a70SApple OSS Distributions 67*a1e26a70SApple OSS Distributions #pragma D binding "1.0" translator 68*a1e26a70SApple OSS Distributions translator bufinfo_t < struct buf *B > { 69*a1e26a70SApple OSS Distributions b_flags = B->b_flags; 70*a1e26a70SApple OSS Distributions b_addr = (caddr_t)B->b_datap; 71*a1e26a70SApple OSS Distributions b_bcount = B->b_bcount; 72*a1e26a70SApple OSS Distributions b_lblkno = B->b_lblkno; 73*a1e26a70SApple OSS Distributions b_blkno = B->b_blkno; 74*a1e26a70SApple OSS Distributions b_resid = B->b_resid; 75*a1e26a70SApple OSS Distributions b_bufsize = B->b_bufsize; 76*a1e26a70SApple OSS Distributions b_iodone = (caddr_t)B->b_iodone; 77*a1e26a70SApple OSS Distributions b_error = B->b_error; 78*a1e26a70SApple OSS Distributions b_edev = B->b_dev; 79*a1e26a70SApple OSS Distributions }; 80*a1e26a70SApple OSS Distributions 81*a1e26a70SApple OSS Distributions typedef struct devinfo { 82*a1e26a70SApple OSS Distributions int dev_major; /* major number */ 83*a1e26a70SApple OSS Distributions int dev_minor; /* minor number */ 84*a1e26a70SApple OSS Distributions int dev_instance; /* instance number */ 85*a1e26a70SApple OSS Distributions string dev_name; /* name of device */ 86*a1e26a70SApple OSS Distributions string dev_statname; /* name of device + instance/minor */ 87*a1e26a70SApple OSS Distributions string dev_pathname; /* pathname of device */ 88*a1e26a70SApple OSS Distributions } devinfo_t; 89*a1e26a70SApple OSS Distributions 90*a1e26a70SApple OSS Distributions #pragma D binding "1.0" translator 91*a1e26a70SApple OSS Distributions translator devinfo_t < struct buf *B > { 92*a1e26a70SApple OSS Distributions dev_major = getmajor(B->b_dev); 93*a1e26a70SApple OSS Distributions dev_minor = getminor(B->b_dev); 94*a1e26a70SApple OSS Distributions dev_instance = getminor(B->b_dev); 95*a1e26a70SApple OSS Distributions dev_name = "??"; /* XXX */ 96*a1e26a70SApple OSS Distributions dev_statname = "??"; /* XXX */ 97*a1e26a70SApple OSS Distributions dev_pathname = "??"; /* XXX */ 98*a1e26a70SApple OSS Distributions }; 99*a1e26a70SApple OSS Distributions 100*a1e26a70SApple OSS Distributions typedef off_t offset_t; 101*a1e26a70SApple OSS Distributions 102*a1e26a70SApple OSS Distributions typedef struct fileinfo { 103*a1e26a70SApple OSS Distributions string fi_name; /* name (basename of fi_pathname) */ 104*a1e26a70SApple OSS Distributions string fi_dirname; /* directory (dirname of fi_pathname) */ 105*a1e26a70SApple OSS Distributions string fi_pathname; /* full pathname */ 106*a1e26a70SApple OSS Distributions offset_t fi_offset; /* offset within file */ 107*a1e26a70SApple OSS Distributions string fi_fs; /* filesystem */ 108*a1e26a70SApple OSS Distributions string fi_mount; /* mount point of file system */ 109*a1e26a70SApple OSS Distributions int fi_oflags; /* open(2) flags for file descriptor */ 110*a1e26a70SApple OSS Distributions } fileinfo_t; 111*a1e26a70SApple OSS Distributions 112*a1e26a70SApple OSS Distributions #pragma D binding "1.0" translator 113*a1e26a70SApple OSS Distributions translator fileinfo_t < struct buf *B > { 114*a1e26a70SApple OSS Distributions fi_name = B->b_vp->v_name == NULL ? "<unknown (NULL v_name)>" : B->b_vp->v_name; 115*a1e26a70SApple OSS Distributions 116*a1e26a70SApple OSS Distributions fi_dirname = B->b_vp->v_parent == NULL ? "<unknown (NULL v_parent)>" : 117*a1e26a70SApple OSS Distributions (B->b_vp->v_parent->v_name == NULL ? "<unknown (NULL v_name)>" : B->b_vp->v_parent->v_name); 118*a1e26a70SApple OSS Distributions 119*a1e26a70SApple OSS Distributions fi_pathname = strjoin("??/", 120*a1e26a70SApple OSS Distributions strjoin(B->b_vp->v_parent == NULL ? "<unknown (NULL v_parent)>" : 121*a1e26a70SApple OSS Distributions (B->b_vp->v_parent->v_name == NULL ? "<unknown (NULL v_name)>" : B->b_vp->v_parent->v_name), 122*a1e26a70SApple OSS Distributions strjoin("/", 123*a1e26a70SApple OSS Distributions B->b_vp->v_name == NULL ? "<unknown (NULL v_name)>" : B->b_vp->v_name))); 124*a1e26a70SApple OSS Distributions 125*a1e26a70SApple OSS Distributions fi_offset = B->b_upl == NULL ? -1 : ((upl_t)B->b_upl)->u_offset; 126*a1e26a70SApple OSS Distributions 127*a1e26a70SApple OSS Distributions fi_fs = B->b_vp->v_mount->mnt_vtable->vfc_name; 128*a1e26a70SApple OSS Distributions 129*a1e26a70SApple OSS Distributions fi_mount = B->b_vp->v_mount->mnt_vnodecovered == NULL ? "/" : B->b_vp->v_mount->mnt_vnodecovered->v_name; 130*a1e26a70SApple OSS Distributions 131*a1e26a70SApple OSS Distributions fi_oflags = 0; 132*a1e26a70SApple OSS Distributions }; 133*a1e26a70SApple OSS Distributions 134*a1e26a70SApple OSS Distributions /* 135*a1e26a70SApple OSS Distributions * The following inline constants can be used to examine fi_oflags when using 136*a1e26a70SApple OSS Distributions * the fds[] array or a translated fileglob *. Note that the various open 137*a1e26a70SApple OSS Distributions * flags behave as a bit-field *except* for O_RDONLY, O_WRONLY, and O_RDWR. 138*a1e26a70SApple OSS Distributions * To test the open mode, you write code similar to that used with the fcntl(2) 139*a1e26a70SApple OSS Distributions * F_GET[X]FL command, such as: if ((fi_oflags & O_ACCMODE) == O_WRONLY). 140*a1e26a70SApple OSS Distributions */ 141*a1e26a70SApple OSS Distributions inline int O_ACCMODE = 0x0003; 142*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_ACCMODE 143*a1e26a70SApple OSS Distributions 144*a1e26a70SApple OSS Distributions inline int O_RDONLY = 0x0000; 145*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_RDONLY 146*a1e26a70SApple OSS Distributions inline int O_WRONLY = 0x0001; 147*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_WRONLY 148*a1e26a70SApple OSS Distributions inline int O_RDWR = 0x0002; 149*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_RDWR 150*a1e26a70SApple OSS Distributions 151*a1e26a70SApple OSS Distributions inline int O_NONBLOCK = 0x0004; 152*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_NONBLOCK 153*a1e26a70SApple OSS Distributions inline int O_APPEND = 0x0008; 154*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_APPEND 155*a1e26a70SApple OSS Distributions inline int O_SHLOCK = 0x0010; 156*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_SHLOCK 157*a1e26a70SApple OSS Distributions inline int O_EXLOCK = 0x0020; 158*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_EXLOCK 159*a1e26a70SApple OSS Distributions inline int O_ASYNC = 0x0040; 160*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_ASYNC 161*a1e26a70SApple OSS Distributions inline int O_SYNC = 0x0080; 162*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_SYNC 163*a1e26a70SApple OSS Distributions inline int O_NOFOLLOW = 0x0100; 164*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_NOFOLLOW 165*a1e26a70SApple OSS Distributions inline int O_CREAT = 0x0200; 166*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_CREAT 167*a1e26a70SApple OSS Distributions inline int O_TRUNC = 0x0400; 168*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_TRUNC 169*a1e26a70SApple OSS Distributions inline int O_EXCL = 0x0800; 170*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_EXCL 171*a1e26a70SApple OSS Distributions inline int O_RESOLVE_BENEATH = 0x1000; 172*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_RESOLVE_BENEATH 173*a1e26a70SApple OSS Distributions inline int O_EVTONLY = 0x8000; 174*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_EVTONLY 175*a1e26a70SApple OSS Distributions inline int O_NOCTTY = 0x20000; 176*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_NOCTTY 177*a1e26a70SApple OSS Distributions inline int O_DIRECTORY = 0x100000; 178*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_DIRECTORY 179*a1e26a70SApple OSS Distributions inline int O_SYMLINK = 0x200000; 180*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_SYMLINK 181*a1e26a70SApple OSS Distributions inline int O_NOFOLLOW_ANY = 0x20000000; 182*a1e26a70SApple OSS Distributions #pragma D binding "1.1" O_NOFOLLOW_ANY 183*a1e26a70SApple OSS Distributions 184*a1e26a70SApple OSS Distributions /* From bsd/sys/file_internal.h */ 185*a1e26a70SApple OSS Distributions inline int DTYPE_VNODE = 1; 186*a1e26a70SApple OSS Distributions #pragma D binding "1.1" DTYPE_VNODE 187*a1e26a70SApple OSS Distributions inline int DTYPE_SOCKET = 2; 188*a1e26a70SApple OSS Distributions #pragma D binding "1.1" DTYPE_SOCKET 189*a1e26a70SApple OSS Distributions inline int DTYPE_PSXSHM = 3; 190*a1e26a70SApple OSS Distributions #pragma D binding "1.1" DTYPE_PSXSHM 191*a1e26a70SApple OSS Distributions inline int DTYPE_PSXSEM = 4; 192*a1e26a70SApple OSS Distributions #pragma D binding "1.1" DTYPE_PSXSEM 193*a1e26a70SApple OSS Distributions inline int DTYPE_KQUEUE = 5; 194*a1e26a70SApple OSS Distributions #pragma D binding "1.1" DTYPE_KQUEUE 195*a1e26a70SApple OSS Distributions inline int DTYPE_PIPE = 6; 196*a1e26a70SApple OSS Distributions #pragma D binding "1.1" DTYPE_PIPE 197*a1e26a70SApple OSS Distributions inline int DTYPE_FSEVENTS = 7; 198*a1e26a70SApple OSS Distributions #pragma D binding "1.1" DTYPE_FSEVENTS 199*a1e26a70SApple OSS Distributions 200*a1e26a70SApple OSS Distributions #pragma D binding "1.1" translator 201*a1e26a70SApple OSS Distributions translator fileinfo_t < struct fileglob *F > { 202*a1e26a70SApple OSS Distributions fi_name = (F == NULL) ? "<none>" : 203*a1e26a70SApple OSS Distributions F->fg_ops->fo_type == DTYPE_VNODE ? 204*a1e26a70SApple OSS Distributions ((struct vnode *)F->fg_data)->v_name == NULL ? "<unknown (NULL v_name)>" : ((struct vnode *)F->fg_data)->v_name : 205*a1e26a70SApple OSS Distributions F->fg_ops->fo_type == DTYPE_SOCKET ? "<socket>" : 206*a1e26a70SApple OSS Distributions F->fg_ops->fo_type == DTYPE_PSXSHM ? "<shared memory>" : 207*a1e26a70SApple OSS Distributions F->fg_ops->fo_type == DTYPE_PSXSEM ? "<semaphore>" : 208*a1e26a70SApple OSS Distributions F->fg_ops->fo_type == DTYPE_KQUEUE ? "<kqueue>" : 209*a1e26a70SApple OSS Distributions F->fg_ops->fo_type == DTYPE_PIPE ? "<pipe>" : 210*a1e26a70SApple OSS Distributions F->fg_ops->fo_type == DTYPE_FSEVENTS ? "<fsevents>" : "<unknown (BAD fo_type)>"; 211*a1e26a70SApple OSS Distributions 212*a1e26a70SApple OSS Distributions fi_dirname = (F == NULL) ? "<none>" : 213*a1e26a70SApple OSS Distributions F->fg_ops->fo_type != DTYPE_VNODE ? "<unknown (not a vnode)>" : 214*a1e26a70SApple OSS Distributions ((struct vnode *)F->fg_data)->v_parent == NULL ? "<unknown (NULL v_parent)>" : 215*a1e26a70SApple OSS Distributions (((struct vnode *)F->fg_data)->v_parent->v_name == NULL ? "<unknown (NULL v_name)>" : 216*a1e26a70SApple OSS Distributions ((struct vnode *)F->fg_data)->v_parent->v_name); 217*a1e26a70SApple OSS Distributions 218*a1e26a70SApple OSS Distributions fi_pathname = (F == NULL) ? "<none>" : 219*a1e26a70SApple OSS Distributions F->fg_ops->fo_type != DTYPE_VNODE ? "<unknown (not a vnode)>" : 220*a1e26a70SApple OSS Distributions strjoin("??/", 221*a1e26a70SApple OSS Distributions strjoin(((struct vnode *)F->fg_data)->v_parent == NULL ? "<unknown (NULL v_parent)>" : 222*a1e26a70SApple OSS Distributions (((struct vnode *)F->fg_data)->v_parent->v_name == NULL ? "<unknown (NULL v_name)>" : 223*a1e26a70SApple OSS Distributions ((struct vnode *)F->fg_data)->v_parent->v_name), 224*a1e26a70SApple OSS Distributions strjoin("/", 225*a1e26a70SApple OSS Distributions ((struct vnode *)F->fg_data)->v_name == NULL ? "<unknown (NULL v_name)>" : 226*a1e26a70SApple OSS Distributions ((struct vnode *)F->fg_data)->v_name))); 227*a1e26a70SApple OSS Distributions 228*a1e26a70SApple OSS Distributions fi_offset = (F == NULL) ? 0 : 229*a1e26a70SApple OSS Distributions F->fg_offset; 230*a1e26a70SApple OSS Distributions 231*a1e26a70SApple OSS Distributions fi_fs = (F == NULL) ? "<none>" : 232*a1e26a70SApple OSS Distributions F->fg_ops->fo_type != DTYPE_VNODE ? "<unknown (not a vnode)>" : 233*a1e26a70SApple OSS Distributions ((struct vnode *)F->fg_data)->v_mount->mnt_vtable->vfc_name; 234*a1e26a70SApple OSS Distributions 235*a1e26a70SApple OSS Distributions fi_mount = (F == NULL) ? "<none>" : 236*a1e26a70SApple OSS Distributions F->fg_ops->fo_type != DTYPE_VNODE ? "<unknown (not a vnode)>" : 237*a1e26a70SApple OSS Distributions ((struct vnode *)F->fg_data)->v_mount->mnt_vnodecovered == NULL ? "/" : 238*a1e26a70SApple OSS Distributions ((struct vnode *)F->fg_data)->v_mount->mnt_vnodecovered->v_name; 239*a1e26a70SApple OSS Distributions 240*a1e26a70SApple OSS Distributions fi_oflags = (F == NULL) ? 0 : 241*a1e26a70SApple OSS Distributions F->fg_flag - 1; /* Subtract one to map FREAD/FWRITE bitfield to O_RD/WR open() flags. */ 242*a1e26a70SApple OSS Distributions }; 243*a1e26a70SApple OSS Distributions 244*a1e26a70SApple OSS Distributions inline fileinfo_t fds[int fd] = xlate <fileinfo_t> ( 245*a1e26a70SApple OSS Distributions (fd >= 0 && fd < curproc->p_fd.fd_afterlast) ? 246*a1e26a70SApple OSS Distributions (struct fileglob *)(curproc->p_fd.fd_ofiles[fd]->fp_glob) : 247*a1e26a70SApple OSS Distributions (struct fileglob *)NULL); 248*a1e26a70SApple OSS Distributions 249*a1e26a70SApple OSS Distributions #pragma D attributes Stable/Stable/Common fds 250*a1e26a70SApple OSS Distributions #pragma D binding "1.1" fds 251*a1e26a70SApple OSS Distributions 252*a1e26a70SApple OSS Distributions #pragma D binding "1.2" translator 253*a1e26a70SApple OSS Distributions translator fileinfo_t < struct vnode *V > { 254*a1e26a70SApple OSS Distributions fi_name = V->v_name == NULL ? "<unknown (NULL v_name)>" : V->v_name; 255*a1e26a70SApple OSS Distributions 256*a1e26a70SApple OSS Distributions fi_dirname = V->v_parent == NULL ? "<unknown (NULL v_parent)>" : 257*a1e26a70SApple OSS Distributions (V->v_parent->v_name == NULL ? "<unknown (NULL v_name)>" : V->v_parent->v_name); 258*a1e26a70SApple OSS Distributions 259*a1e26a70SApple OSS Distributions fi_pathname = strjoin("??/", 260*a1e26a70SApple OSS Distributions strjoin(V->v_parent == NULL ? "<unknown (NULL v_parent)>" : 261*a1e26a70SApple OSS Distributions (V->v_parent->v_name == NULL ? "<unknown (NULL v_name)>" : V->v_parent->v_name), 262*a1e26a70SApple OSS Distributions strjoin("/", 263*a1e26a70SApple OSS Distributions V->v_name == NULL ? "<unknown (NULL v_name)>" : V->v_name))); 264*a1e26a70SApple OSS Distributions 265*a1e26a70SApple OSS Distributions fi_fs = V->v_mount->mnt_vtable->vfc_name; 266*a1e26a70SApple OSS Distributions 267*a1e26a70SApple OSS Distributions fi_mount = V->v_mount->mnt_vnodecovered == NULL ? "/" : V->v_mount->mnt_vnodecovered->v_name; 268*a1e26a70SApple OSS Distributions }; 269*a1e26a70SApple OSS Distributions 270