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]
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 */
63 #
pragma D binding
"1.0" translator
64 translator bufinfo_t
< struct buf
*B
> {
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
;
71 b_bufsize
= B
->b_bufsize
;
72 b_iodone
= (caddr_t
)B
->b_iodone
;
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 */
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 */
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
);
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_LARGEFILE
= @O_LARGEFILE@
;
168 #
pragma D binding
"1.1" O_LARGEFILE
169 inline
int O_NOCTTY
= @O_NOCTTY@
;
170 #
pragma D binding
"1.1" O_NOCTTY
171 inline
int O_NONBLOCK
= @O_NONBLOCK@
;
172 #
pragma D binding
"1.1" O_NONBLOCK
173 inline
int O_NDELAY
= @O_NDELAY@
;
174 #
pragma D binding
"1.1" O_NDELAY
175 inline
int O_RSYNC
= @O_RSYNC@
;
176 #
pragma D binding
"1.1" O_RSYNC
177 inline
int O_SYNC
= @O_SYNC@
;
178 #
pragma D binding
"1.1" O_SYNC
179 inline
int O_TRUNC
= @O_TRUNC@
;
180 #
pragma D binding
"1.1" O_TRUNC
181 inline
int O_XATTR
= @O_XATTR@
;
182 #
pragma D binding
"1.1" O_XATTR
183 inline
int O_DIRECTORY
= @O_DIRECTORY@
;
185 #
pragma D binding
"1.1" translator
186 translator fileinfo_t
< struct file
*F
> {
187 fi_name
= F
== NULL ?
"<none>" :
188 F
->f_vnode
->v_path
== NULL ?
"<unknown>" :
189 basename(cleanpath(F
->f_vnode
->v_path
));
190 fi_dirname
= F
== NULL ?
"<none>" :
191 F
->f_vnode
->v_path
== NULL ?
"<unknown>" :
192 dirname(cleanpath(F
->f_vnode
->v_path
));
193 fi_pathname
= F
== NULL ?
"<none>" :
194 F
->f_vnode
->v_path
== NULL ?
"<unknown>" :
195 cleanpath(F
->f_vnode
->v_path
);
196 fi_offset
= F
== NULL ?
0 : F
->f_offset
;
197 fi_fs
= F
== NULL ?
"<none>" : stringof(F
->f_vnode
->v_op
->vnop_name
);
198 fi_mount
= F
== NULL ?
"<none>" :
199 F
->f_vnode
->v_vfsp
->vfs_vnodecovered
== NULL ?
"/" :
200 F
->f_vnode
->v_vfsp
->vfs_vnodecovered
->v_path
== NULL ?
"<unknown>" :
201 cleanpath(F
->f_vnode
->v_vfsp
->vfs_vnodecovered
->v_path
);
202 /* This is OFLAGS() from fcntl.h, but we can't use that macro here. */
203 fi_oflags
= F
== NULL ?
0 : (F
->f_flag
& (O_EXEC|O_SEARCH
) ? F
->f_flag
207 inline fileinfo_t fds
[int fd
] = xlate
<fileinfo_t
> (getf(fd
));
209 #
pragma D attributes Stable
/Stable
/Common fds
210 #
pragma D binding
"1.1" fds
212 #
pragma D binding
"1.2" translator
213 translator fileinfo_t
< struct vnode
*V
> {
214 fi_name
= V
->v_path
== NULL ?
"<unknown>" :
215 basename(cleanpath(V
->v_path
));
216 fi_dirname
= V
->v_path
== NULL ?
"<unknown>" :
217 dirname(cleanpath(V
->v_path
));
218 fi_pathname
= V
->v_path
== NULL ?
"<unknown>" : cleanpath(V
->v_path
);
219 fi_fs
= stringof(V
->v_op
->vnop_name
);
220 fi_mount
= V
->v_vfsp
->vfs_vnodecovered
== NULL ?
"/" :
221 V
->v_vfsp
->vfs_vnodecovered
->v_path
== NULL ?
"<unknown>" :
222 cleanpath(V
->v_vfsp
->vfs_vnodecovered
->v_path
);