Merge remote-tracking branch 'origin/master'
[unleashed/lotheac.git] / usr / src / lib / libdtrace / common / io.d.in
blob4c337f3ae3325e9a86ece21889395a3a1682f4ad
1 /*
2 * CDDL HEADER START
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
19 * CDDL HEADER END
22 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
27 * Copyright (c) 2012, Joyent, Inc. All rights reserved.
30 #pragma D depends_on module unix
31 #pragma D depends_on provider io
33 inline int B_BUSY = @B_BUSY@;
34 #pragma D binding "1.0" B_BUSY
35 inline int B_DONE = @B_DONE@;
36 #pragma D binding "1.0" B_DONE
37 inline int B_ERROR = @B_ERROR@;
38 #pragma D binding "1.0" B_ERROR
39 inline int B_PAGEIO = @B_PAGEIO@;
40 #pragma D binding "1.0" B_PAGEIO
41 inline int B_PHYS = @B_PHYS@;
42 #pragma D binding "1.0" B_PHYS
43 inline int B_READ = @B_READ@;
44 #pragma D binding "1.0" B_READ
45 inline int B_WRITE = @B_WRITE@;
46 #pragma D binding "1.0" B_WRITE
47 inline int B_ASYNC = @B_ASYNC@;
48 #pragma D binding "1.0" B_ASYNC
50 typedef struct bufinfo {
51 int b_flags; /* buffer status */
52 size_t b_bcount; /* number of bytes */
53 caddr_t b_addr; /* buffer address */
54 uint64_t b_lblkno; /* block # on device */
55 uint64_t b_blkno; /* expanded block # on device */
56 size_t b_resid; /* # of bytes not transferred */
57 size_t b_bufsize; /* size of allocated buffer */
58 caddr_t b_iodone; /* I/O completion routine */
59 int b_error; /* expanded error field */
60 dev_t b_edev; /* extended device */
61 } bufinfo_t;
63 #pragma D binding "1.0" translator
64 translator bufinfo_t < struct buf *B > {
65 b_flags = B->b_flags;
66 b_addr = B->b_un.b_addr;
67 b_bcount = B->b_bcount;
68 b_lblkno = B->_b_blkno._f;
69 b_blkno = sizeof (long) == 8 ? B->_b_blkno._f : B->_b_blkno._p._l;
70 b_resid = B->b_resid;
71 b_bufsize = B->b_bufsize;
72 b_iodone = (caddr_t)B->b_iodone;
73 b_error = B->b_error;
74 b_edev = B->b_edev;
75 };
77 typedef struct devinfo {
78 int dev_major; /* major number */
79 int dev_minor; /* minor number */
80 int dev_instance; /* instance number */
81 string dev_name; /* name of device */
82 string dev_statname; /* name of device + instance/minor */
83 string dev_pathname; /* pathname of device */
84 } devinfo_t;
86 #pragma D binding "1.0" translator
87 translator devinfo_t < struct buf *B > {
88 dev_major = B->b_dip != NULL ? getmajor(B->b_edev) :
89 getmajor(B->b_file->v_vfsp->vfs_dev);
90 dev_minor = B->b_dip != NULL ? getminor(B->b_edev) :
91 getminor(B->b_file->v_vfsp->vfs_dev);
92 dev_instance = B->b_dip == NULL ?
93 getminor(B->b_file->v_vfsp->vfs_dev) :
94 ((struct dev_info *)B->b_dip)->devi_instance;
95 dev_name = B->b_dip == NULL ? "nfs" :
96 stringof(`devnamesp[getmajor(B->b_edev)].dn_name);
97 dev_statname = strjoin(B->b_dip == NULL ? "nfs" :
98 stringof(`devnamesp[getmajor(B->b_edev)].dn_name),
99 lltostr(B->b_dip == NULL ? getminor(B->b_file->v_vfsp->vfs_dev) :
100 ((struct dev_info *)B->b_dip)->devi_instance == 0 &&
101 ((struct dev_info *)B->b_dip)->devi_parent != NULL &&
102 ((struct dev_info *)B->b_dip)->devi_parent->devi_node_name ==
103 "pseudo" ? getminor(B->b_edev) :
104 ((struct dev_info *)B->b_dip)->devi_instance));
105 dev_pathname = B->b_dip == NULL ? "<nfs>" :
106 ddi_pathname(B->b_dip, getminor(B->b_edev));
109 typedef struct fileinfo {
110 string fi_name; /* name (basename of fi_pathname) */
111 string fi_dirname; /* directory (dirname of fi_pathname) */
112 string fi_pathname; /* full pathname */
113 offset_t fi_offset; /* offset within file */
114 string fi_fs; /* filesystem */
115 string fi_mount; /* mount point of file system */
116 int fi_oflags; /* open(2) flags for file descriptor */
117 } fileinfo_t;
119 #pragma D binding "1.0" translator
120 translator fileinfo_t < struct buf *B > {
121 fi_name = B->b_file == NULL ? "<none>" :
122 B->b_file->v_path == NULL ? "<unknown>" :
123 basename(cleanpath(B->b_file->v_path));
124 fi_dirname = B->b_file == NULL ? "<none>" :
125 B->b_file->v_path == NULL ? "<unknown>" :
126 dirname(cleanpath(B->b_file->v_path));
127 fi_pathname = B->b_file == NULL ? "<none>" :
128 B->b_file->v_path == NULL ? "<unknown>" :
129 cleanpath(B->b_file->v_path);
130 fi_offset = B->b_offset;
131 fi_fs = B->b_file == NULL ? "<none>" :
132 stringof(B->b_file->v_op->vnop_name);
133 fi_mount = B->b_file == NULL ? "<none>" :
134 B->b_file->v_vfsp->vfs_vnodecovered == NULL ? "/" :
135 B->b_file->v_vfsp->vfs_vnodecovered->v_path == NULL ? "<unknown>" :
136 cleanpath(B->b_file->v_vfsp->vfs_vnodecovered->v_path);
137 fi_oflags = 0;
141 * The following inline constants can be used to examine fi_oflags when using
142 * the fds[] array or a translated fileinfo_t. Note that the various open
143 * flags behave as a bit-field *except* for O_RDONLY, O_WRONLY, and O_RDWR.
144 * To test the open mode, you write code similar to that used with the fcntl(2)
145 * F_GET[X]FL command, such as: if ((fi_oflags & O_ACCMODE) == O_WRONLY).
147 inline int O_ACCMODE = @O_ACCMODE@;
148 #pragma D binding "1.1" O_ACCMODE
150 inline int O_RDONLY = @O_RDONLY@;
151 #pragma D binding "1.1" O_RDONLY
152 inline int O_WRONLY = @O_WRONLY@;
153 #pragma D binding "1.1" O_WRONLY
154 inline int O_RDWR = @O_RDWR@;
155 #pragma D binding "1.1" O_RDWR
156 inline int O_EXEC = @O_EXEC@;
157 inline int O_SEARCH = @O_SEARCH@;
159 inline int O_APPEND = @O_APPEND@;
160 #pragma D binding "1.1" O_APPEND
161 inline int O_CREAT = @O_CREAT@;
162 #pragma D binding "1.1" O_CREAT
163 inline int O_DSYNC = @O_DSYNC@;
164 #pragma D binding "1.1" O_DSYNC
165 inline int O_EXCL = @O_EXCL@;
166 #pragma D binding "1.1" O_EXCL
167 inline int O_NOCTTY = @O_NOCTTY@;
168 #pragma D binding "1.1" O_NOCTTY
169 inline int O_NONBLOCK = @O_NONBLOCK@;
170 #pragma D binding "1.1" O_NONBLOCK
171 inline int O_NDELAY = @O_NDELAY@;
172 #pragma D binding "1.1" O_NDELAY
173 inline int O_RSYNC = @O_RSYNC@;
174 #pragma D binding "1.1" O_RSYNC
175 inline int O_SYNC = @O_SYNC@;
176 #pragma D binding "1.1" O_SYNC
177 inline int O_TRUNC = @O_TRUNC@;
178 #pragma D binding "1.1" O_TRUNC
179 inline int O_XATTR = @O_XATTR@;
180 #pragma D binding "1.1" O_XATTR
181 inline int O_DIRECTORY = @O_DIRECTORY@;
183 #pragma D binding "1.1" translator
184 translator fileinfo_t < struct file *F > {
185 fi_name = F == NULL ? "<none>" :
186 F->f_vnode->v_path == NULL ? "<unknown>" :
187 basename(cleanpath(F->f_vnode->v_path));
188 fi_dirname = F == NULL ? "<none>" :
189 F->f_vnode->v_path == NULL ? "<unknown>" :
190 dirname(cleanpath(F->f_vnode->v_path));
191 fi_pathname = F == NULL ? "<none>" :
192 F->f_vnode->v_path == NULL ? "<unknown>" :
193 cleanpath(F->f_vnode->v_path);
194 fi_offset = F == NULL ? 0 : F->f_offset;
195 fi_fs = F == NULL ? "<none>" : stringof(F->f_vnode->v_op->vnop_name);
196 fi_mount = F == NULL ? "<none>" :
197 F->f_vnode->v_vfsp->vfs_vnodecovered == NULL ? "/" :
198 F->f_vnode->v_vfsp->vfs_vnodecovered->v_path == NULL ? "<unknown>" :
199 cleanpath(F->f_vnode->v_vfsp->vfs_vnodecovered->v_path);
200 /* This is OFLAGS() from fcntl.h, but we can't use that macro here. */
201 fi_oflags = F == NULL ? 0 : (F->f_flag & (O_EXEC|O_SEARCH) ? F->f_flag
202 : F->f_flag - 1);
205 inline fileinfo_t fds[int fd] = xlate <fileinfo_t> (getf(fd));
207 #pragma D attributes Stable/Stable/Common fds
208 #pragma D binding "1.1" fds
210 #pragma D binding "1.2" translator
211 translator fileinfo_t < struct vnode *V > {
212 fi_name = V->v_path == NULL ? "<unknown>" :
213 basename(cleanpath(V->v_path));
214 fi_dirname = V->v_path == NULL ? "<unknown>" :
215 dirname(cleanpath(V->v_path));
216 fi_pathname = V->v_path == NULL ? "<unknown>" : cleanpath(V->v_path);
217 fi_fs = stringof(V->v_op->vnop_name);
218 fi_mount = V->v_vfsp->vfs_vnodecovered == NULL ? "/" :
219 V->v_vfsp->vfs_vnodecovered->v_path == NULL ? "<unknown>" :
220 cleanpath(V->v_vfsp->vfs_vnodecovered->v_path);