xref: /titanic_44/usr/src/cmd/fs.d/cachefs/cfsd/cfsd_kmod.c (revision 908f1e1388f616898b4e515d343c0414f2a6472e)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright 2004 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  */
26 
27 #pragma ident	"%Z%%M%	%I%	%E% SMI"
28 
29 /*
30  * Source file for the cfsd_kmod class.
31  */
32 
33 #include <stdio.h>
34 #include <stdlib.h>
35 #include <stddef.h>
36 #include <string.h>
37 #include <errno.h>
38 #include <unistd.h>
39 #include <fcntl.h>
40 #include <sys/param.h>
41 #include <sys/types.h>
42 #include <sys/fcntl.h>
43 #include <sys/cred.h>
44 #include <sys/vnode.h>
45 #include <sys/vfs.h>
46 #include <sys/fs/cachefs_fs.h>
47 #include <sys/fs/cachefs_dlog.h>
48 #include <sys/fs/cachefs_ioctl.h>
49 #include <mdbug/mdbug.h>
50 #include "cfsd.h"
51 #include "cfsd_kmod.h"
52 
53 /*
54  * copy_cred (copy dl_cred_t followed by a list of gid_t)
55  */
56 
57 static void
58 copy_cred(dl_cred_t *dst, const dl_cred_t *src)
59 {
60 	int n = src->cr_ngroups;
61 
62 	if (n > NGROUPS_MAX_DEFAULT)
63 		n = NGROUPS_MAX_DEFAULT;
64 
65 	(void) memcpy(dst, src, sizeof (*dst) + (n - 1) * sizeof (gid_t));
66 	dst->cr_ngroups = n;
67 }
68 
69 /*
70  * ------------------------------------------------------------
71  *			cfsd_kmod_create
72  *
73  * Description:
74  * Arguments:
75  * Returns:
76  * Preconditions:
77  */
78 
79 cfsd_kmod_object_t *
80 cfsd_kmod_create(void)
81 {
82 	cfsd_kmod_object_t *kmod_object_p;
83 
84 	dbug_enter("cfsd_kmod_create");
85 	kmod_object_p = cfsd_calloc(sizeof (cfsd_kmod_object_t));
86 
87 	kmod_object_p->i_fd = -1;
88 
89 	dbug_leave("cfsd_kmod_create");
90 	return (kmod_object_p);
91 }
92 
93 /*
94  * ------------------------------------------------------------
95  *			cfsd_kmod_destory
96  *
97  * Description:
98  * Arguments:
99  * Returns:
100  * Preconditions:
101  */
102 
103 
104 void
105 cfsd_kmod_destroy(cfsd_kmod_object_t *kmod_object_p)
106 {
107 	dbug_enter("cfsd_kmod_destroy");
108 	dbug_precond(kmod_object_p);
109 
110 	/* clean up old stuff */
111 	kmod_shutdown(kmod_object_p);
112 
113 	cfsd_free(kmod_object_p);
114 	dbug_leave("cfsd_kmod_destroy");
115 }
116 
117 /*
118  * ------------------------------------------------------------
119  *			kmod_setup
120  *
121  * Description:
122  * Arguments:
123  *	path
124  * Returns:
125  *	Returns ...
126  * Preconditions:
127  *	precond(path)
128  */
129 int
130 kmod_setup(cfsd_kmod_object_t *kmod_object_p, const char *path)
131 {
132 	int xx;
133 	int error;
134 
135 	dbug_enter("kmod_setup");
136 	dbug_precond(kmod_object_p);
137 	dbug_precond(path);
138 
139 	/* clean up old stuff */
140 	kmod_shutdown(kmod_object_p);
141 
142 	/* try to open the file */
143 	dbug_assert(kmod_object_p->i_fd == -1);
144 	kmod_object_p->i_fd = open(path, O_RDONLY);
145 
146 	/* return result */
147 	if (kmod_object_p->i_fd == -1) {
148 		xx = errno;
149 		dbug_print(("err", "open of %s failed %d", path, xx));
150 	} else {
151 		xx = 0;
152 		strlcpy(kmod_object_p->i_path, path,
153 		    sizeof (kmod_object_p->i_path));
154 		dbug_print(("info", "opened %s on fd %d", path,
155 		    kmod_object_p->i_fd));
156 
157 		/* tell the cachefs kmod we are here */
158 		xx = kmod_doioctl(kmod_object_p, CFSDCMD_DAEMONID,
159 		    NULL, 0, NULL, 0);
160 		if (xx) {
161 			error = errno;
162 			dbug_print(("ioctl", "daemonid error %d", error));
163 		}
164 	}
165 
166 	dbug_leave("kmod_setup");
167 	return (xx);
168 }
169 
170 /*
171  *			kmod_shutdown
172  *
173  * Description:
174  * Arguments:
175  * Returns:
176  * Preconditions:
177  */
178 void
179 kmod_shutdown(cfsd_kmod_object_t *kmod_object_p)
180 {
181 	dbug_enter("kmod_shutdown");
182 	dbug_precond(kmod_object_p);
183 
184 	/* close down the old fd if necessary */
185 	if (kmod_object_p->i_fd >= 0) {
186 		if (close(kmod_object_p->i_fd))
187 			dbug_print(("err", "cannot close kmod fd, %d", errno));
188 	}
189 	kmod_object_p->i_fd = -1;
190 	dbug_leave("kmod_shutdown");
191 }
192 
193 /*
194  * ------------------------------------------------------------
195  *			kmod_xwait
196  *
197  * Description:
198  * Arguments:
199  * Returns:
200  *	Returns ...
201  * Preconditions:
202  */
203 int
204 kmod_xwait(cfsd_kmod_object_t *kmod_object_p)
205 {
206 	int xx;
207 	int error = 0;
208 
209 	dbug_enter("kmod_xwait");
210 	dbug_precond(kmod_object_p);
211 
212 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_XWAIT, NULL, 0, NULL, 0);
213 	if (xx)
214 		error = errno;
215 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
216 	dbug_leave("kmod_xwait");
217 	return (error);
218 }
219 
220 /*
221  * ------------------------------------------------------------
222  *			kmod_stateget
223  *
224  * Description:
225  * Arguments:
226  * Returns:
227  *	Returns ...
228  * Preconditions:
229  */
230 int
231 kmod_stateget(cfsd_kmod_object_t *kmod_object_p)
232 {
233 	int state;
234 	int xx;
235 
236 	dbug_enter("kmod_stateget");
237 	dbug_precond(kmod_object_p);
238 
239 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_STATEGET, NULL, 0, &state,
240 	    sizeof (state));
241 	dbug_print(("ioctl", "returns %d, state %d", xx, state));
242 	if (xx == -1) {
243 		/* XXX do what? */
244 		dbug_assert(0);
245 	}
246 	dbug_leave("kmod_stateget");
247 	return (state);
248 }
249 
250 /*
251  * ------------------------------------------------------------
252  *			kmod_stateset
253  *
254  * Description:
255  * Arguments:
256  *	state
257  * Returns:
258  *	Returns ...
259  * Preconditions:
260  */
261 int
262 kmod_stateset(cfsd_kmod_object_t *kmod_object_p, int state)
263 {
264 	int xx;
265 	int error = 0;
266 
267 	dbug_enter("kmod_stateset");
268 	dbug_precond(kmod_object_p);
269 
270 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_STATESET, &state,
271 	    sizeof (state), NULL, 0);
272 	if (xx)
273 		error = errno;
274 	dbug_print(("ioctl", "returns %d, state set to %d", xx, state));
275 	dbug_leave("kmod_stateset");
276 	return (error);
277 }
278 
279 /*
280  * ------------------------------------------------------------
281  *			kmod_exists
282  *
283  * Description:
284  * Arguments:
285  *	cidp
286  * Returns:
287  *	Returns ...
288  * Preconditions:
289  *	precond(cidp)
290  */
291 int
292 kmod_exists(cfsd_kmod_object_t *kmod_object_p, cfs_cid_t *cidp)
293 {
294 	int xx;
295 	int error = 0;
296 
297 	dbug_enter("kmod_exists");
298 	dbug_precond(kmod_object_p);
299 	dbug_precond(cidp);
300 
301 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_EXISTS, cidp,
302 	    sizeof (cfs_cid_t), NULL, 0);
303 	if (xx)
304 		error = errno;
305 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
306 	dbug_print(("ioctl", "   cid %08x", cidp->cid_fileno));
307 	dbug_leave("kmod_exists");
308 	return (error);
309 }
310 
311 /*
312  * ------------------------------------------------------------
313  *			kmod_lostfound
314  *
315  * Description:
316  * Arguments:
317  *	cidp
318  * Returns:
319  *	Returns ...
320  * Preconditions:
321  *	precond(cidp)
322  */
323 int
324 kmod_lostfound(cfsd_kmod_object_t *kmod_object_p, cfs_cid_t *cidp,
325 	const char *namep, char *newnamep)
326 {
327 	cachefsio_lostfound_arg_t info;
328 	cachefsio_lostfound_return_t ret;
329 	int error = 0;
330 	int xx;
331 
332 	dbug_enter("kmod_lostfound");
333 	dbug_precond(kmod_object_p);
334 	dbug_precond(cidp);
335 	dbug_precond(namep);
336 	dbug_precond(newnamep);
337 	dbug_precond(strlen(namep) < (size_t)MAXNAMELEN);
338 
339 	info.lf_cid = *cidp;
340 	strlcpy(info.lf_name, namep, sizeof (info.lf_name));
341 
342 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_LOSTFOUND, &info,
343 	    sizeof (info), &ret, sizeof (ret));
344 	if (xx)
345 		error = errno;
346 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
347 	dbug_print(("ioctl", "   cid %08x", cidp->cid_fileno));
348 	dbug_print(("ioctl", "   suggested name '%s'", namep));
349 	if (xx == 0) {
350 		dbug_print(("ioctl", "   new name '%s'", ret.lf_name));
351 		dbug_assert(strlen(ret.lf_name) < (size_t)MAXNAMELEN);
352 		if (newnamep)
353 			strlcpy(newnamep, ret.lf_name, MAXNAMELEN);
354 	}
355 	dbug_leave("kmod_lostfound");
356 	return (error);
357 }
358 
359 #if 0
360 /*
361  * ------------------------------------------------------------
362  *			kmod_lostfoundall
363  *
364  * Description:
365  * Arguments:
366  * Returns:
367  *	Returns ...
368  * Preconditions:
369  */
370 int
371 kmod_lostfoundall(cfsd_kmod_object_t *kmod_object_p)
372 {
373 	int error = 0;
374 	int xx = -1;
375 
376 	dbug_enter("kmod_lostfoundall");
377 	dbug_precond(kmod_object_p);
378 
379 	/* xx = ioctl(kmod_object_p->i_fd, CACHEFSIO_LOSTFOUNDALL, 0); */
380 	if (xx)
381 		error = errno;
382 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
383 	dbug_leave("kmod_lostfoundall");
384 	return (error);
385 }
386 /*
387  *			kmod_rofs
388  *
389  * Description:
390  * Arguments:
391  * Returns:
392  *	Returns ...
393  * Preconditions:
394  */
395 int
396 kmod_rofs(cfsd_kmod_object_t *kmod_object_p)
397 {
398 	int error = 0;
399 	int xx = -1;
400 
401 	dbug_enter("kmod_rofs");
402 	dbug_precond(kmod_object_p);
403 
404 	/* xx = ioctl(kmod_object_p->i_fd, CACHEFSIO_ROFS, 0); */
405 	if (xx)
406 		error = errno;
407 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
408 	dbug_leave("kmod_rofs");
409 	return (error);
410 }
411 #endif
412 
413 /*
414  *			kmod_rootfid
415  *
416  * Description:
417  *	Fills in fidp with the fid of the root of the file system.
418  * Arguments:
419  *	fidp
420  * Returns:
421  *	Returns 0 for success, errno value for an error
422  * Preconditions:
423  *	precond(fidp)
424  */
425 int
426 kmod_rootfid(cfsd_kmod_object_t *kmod_object_p, cfs_fid_t *fidp)
427 {
428 	int error = 0;
429 	int xx;
430 
431 	dbug_enter("kmod_rootfid");
432 	dbug_precond(kmod_object_p);
433 	dbug_precond(fidp);
434 
435 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_ROOTFID, NULL, 0, fidp,
436 	    sizeof (*fidp));
437 	if (xx)
438 		error = errno;
439 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
440 	dbug_leave("kmod_rootfid");
441 	return (error);
442 }
443 
444 
445 /*
446  *			kmod_getstats
447  *
448  * Description:
449  * Arguments:
450  *	gsp
451  * Returns:
452  *	Returns ...
453  * Preconditions:
454  *	precond(gsp)
455  */
456 int
457 kmod_getstats(cfsd_kmod_object_t *kmod_object_p, cachefsio_getstats_t *gsp)
458 {
459 	int error = 0;
460 	int xx;
461 
462 	dbug_enter("kmod_getstats");
463 	dbug_precond(kmod_object_p);
464 
465 	dbug_precond(gsp);
466 
467 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_GETSTATS, NULL, 0, gsp,
468 	    sizeof (*gsp));
469 	if (xx)
470 		error = errno;
471 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
472 	dbug_print(("ioctl", "total blocks %d", gsp->gs_total));
473 	dbug_print(("ioctl", "gc blocks %d", gsp->gs_gc));
474 	dbug_print(("ioctl", "active blocks %d", gsp->gs_active));
475 	dbug_print(("ioctl", "packed blocks %d", gsp->gs_packed));
476 	dbug_print(("ioctl", "free blocks %d", gsp->gs_free));
477 	dbug_print(("ioctl", "gctime %x", gsp->gs_gctime));
478 	dbug_leave("kmod_getstats");
479 	return (error);
480 }
481 
482 /*
483  * ------------------------------------------------------------
484  *			kmod_getinfo
485  *
486  * Description:
487  * Arguments:
488  *	filep
489  * Returns:
490  *	Returns ...
491  * Preconditions:
492  *	precond(filep)
493  *	precond(infop)
494  */
495 int
496 kmod_getinfo(cfsd_kmod_object_t *kmod_object_p, cfs_cid_t *filep,
497 	cachefsio_getinfo_t *infop)
498 {
499 	int error = 0;
500 	int xx;
501 
502 	dbug_enter("kmod_getinfo");
503 	dbug_precond(kmod_object_p);
504 
505 	dbug_precond(filep);
506 	dbug_precond(infop);
507 
508 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_GETINFO, filep,
509 	    sizeof (*filep), infop, sizeof (*infop));
510 	if (xx)
511 		error = errno;
512 
513 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
514 	dbug_print(("ioctl", "   file cid %08x", filep->cid_fileno));
515 	if (xx == 0) {
516 		dbug_print(("ioctl", "   modified %d  seq %d",
517 		    infop->gi_modified, infop->gi_seq));
518 		dbug_print(("ioctl", "   name \"%s\"", infop->gi_name));
519 		dbug_print(("ioctl", "   parent cid %08x",
520 		    infop->gi_pcid.cid_fileno));
521 		infop->gi_attr.va_mask = AT_ALL;
522 		kmod_print_attr(&infop->gi_attr);
523 	}
524 	dbug_leave("kmod_getinfo");
525 	return (error);
526 }
527 
528 /*
529  * ------------------------------------------------------------
530  *			kmod_cidtofid
531  *
532  * Description:
533  * Arguments:
534  *	cidp
535  *	fidp
536  * Returns:
537  *	Returns ...
538  * Preconditions:
539  *	precond(cidp)
540  *	precond(fidp)
541  */
542 int
543 kmod_cidtofid(cfsd_kmod_object_t *kmod_object_p, cfs_cid_t *cidp,
544 		cfs_fid_t *fidp)
545 {
546 	int error = 0;
547 	int xx;
548 
549 	dbug_enter("kmod_cidtofid");
550 	dbug_precond(kmod_object_p);
551 
552 	dbug_precond(cidp);
553 	dbug_precond(fidp);
554 
555 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_CIDTOFID, cidp, sizeof (*cidp),
556 	    fidp, sizeof (*fidp));
557 	if (xx)
558 		error = errno;
559 
560 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
561 	dbug_print(("ioctl", "   cid %08x", cidp->cid_fileno));
562 	if (xx == 0) {
563 		kmod_format_fid(kmod_object_p, fidp);
564 		dbug_print(("ioctl", "   fid \"%s\"", kmod_object_p->i_fidbuf));
565 	}
566 	dbug_leave("kmod_cidtofid");
567 	return (error);
568 }
569 
570 /*
571  * ------------------------------------------------------------
572  *			kmod_getattrfid
573  *
574  * Description:
575  * Arguments:
576  *	fidp
577  *	credp
578  *	vattrp
579  * Returns:
580  *	Returns ...
581  * Preconditions:
582  *	precond(fidp)
583  *	precond(credp)
584  *	precond(vattrp)
585  */
586 int
587 kmod_getattrfid(cfsd_kmod_object_t *kmod_object_p, cfs_fid_t *fidp,
588 	dl_cred_t *credp, vattr_t *vattrp)
589 {
590 	int error = 0;
591 	int xx;
592 	cachefsio_getattrfid_t info;
593 
594 	dbug_enter("kmod_getattrfid");
595 	dbug_precond(kmod_object_p);
596 
597 	dbug_precond(fidp);
598 	dbug_precond(credp);
599 	dbug_precond(vattrp);
600 
601 	info.cg_backfid = *fidp;
602 
603 	copy_cred(&info.cg_cred, credp);
604 
605 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_GETATTRFID, &info,
606 	    sizeof (info), vattrp, sizeof (*vattrp));
607 	if (xx)
608 		error = errno;
609 
610 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
611 	kmod_format_fid(kmod_object_p, fidp);
612 	dbug_print(("ioctl", "   fid \"%s\"", kmod_object_p->i_fidbuf));
613 	kmod_print_cred(credp);
614 	if (xx == 0) {
615 		vattrp->va_mask = AT_ALL;
616 		kmod_print_attr(vattrp);
617 	}
618 	dbug_leave("kmod_getattrfid");
619 	return (error);
620 }
621 
622 /*
623  * ------------------------------------------------------------
624  *			kmod_getattrname
625  *
626  * Description:
627  * Arguments:
628  *	dirp
629  *	name
630  *	credp
631  *	vattrp
632  *	filep
633  * Returns:
634  *	Returns ...
635  * Preconditions:
636  *	precond(dirp)
637  *	precond(name)
638  *	precond(credp)
639  */
640 int
641 kmod_getattrname(cfsd_kmod_object_t *kmod_object_p, cfs_fid_t *dirp,
642 	const char *name, dl_cred_t *credp, vattr_t *vattrp, cfs_fid_t *filep)
643 {
644 	cachefsio_getattrname_arg_t info;
645 	cachefsio_getattrname_return_t ret;
646 	int error = 0;
647 	int xx;
648 
649 	dbug_enter("kmod_getattrname");
650 	dbug_precond(kmod_object_p);
651 
652 	dbug_precond(dirp);
653 	dbug_precond(name);
654 	dbug_precond(credp);
655 
656 	info.cg_dir = *dirp;
657 	dbug_assert(strlen(name) < (size_t)MAXNAMELEN);
658 	strlcpy(info.cg_name, name, sizeof (info.cg_name));
659 	copy_cred(&info.cg_cred, credp);
660 
661 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_GETATTRNAME, &info,
662 	    sizeof (info), &ret, sizeof (ret));
663 	if (xx)
664 		error = errno;
665 
666 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
667 	kmod_format_fid(kmod_object_p, dirp);
668 	dbug_print(("ioctl", "   dir fid \"%s\"", kmod_object_p->i_fidbuf));
669 	dbug_print(("ioctl", "   name '%s'", info.cg_name));
670 	kmod_print_cred(credp);
671 	if (xx == 0) {
672 		ret.cg_attr.va_mask = AT_ALL;
673 		kmod_print_attr(&ret.cg_attr);
674 		kmod_format_fid(kmod_object_p, &ret.cg_fid);
675 		dbug_print(("ioctl", "   file fid \"%s\"",
676 		    kmod_object_p->i_fidbuf));
677 		if (vattrp)
678 			*vattrp = ret.cg_attr;
679 		if (filep)
680 			*filep = ret.cg_fid;
681 	}
682 	dbug_leave("kmod_getattrname");
683 	return (error);
684 }
685 
686 /*
687  * ------------------------------------------------------------
688  *			kmod_create
689  *
690  * Description:
691  * Arguments:
692  *	dirp
693  *	namep
694  *	vattrp
695  *	exclusive
696  *	mode
697  *	credp
698  *	newfidp
699  *	mtimep
700  *	ctimep
701  * Returns:
702  *	Returns ...
703  * Preconditions:
704  *	precond(dirp)
705  *	precond(namep)
706  *	precond(vattrp)
707  *	precond(credp)
708  */
709 int
710 kmod_create(cfsd_kmod_object_t *kmod_object_p,
711 	cfs_fid_t *dirp,
712 	const char *namep,
713 	const cfs_cid_t *cidp,
714 	vattr_t *vattrp,
715 	int exclusive,
716 	int mode,
717 	dl_cred_t *credp,
718 	cfs_fid_t *newfidp,
719 	cfs_timestruc_t *ctimep,
720 	cfs_timestruc_t *mtimep)
721 {
722 	cachefsio_create_arg_t info;
723 	cachefsio_create_return_t ret;
724 	int error = 0;
725 	int xx;
726 
727 	dbug_enter("kmod_create");
728 	dbug_precond(kmod_object_p);
729 
730 	dbug_precond(dirp);
731 	dbug_precond(namep);
732 	dbug_precond(vattrp);
733 	dbug_precond(credp);
734 
735 	info.cr_backfid = *dirp;
736 	dbug_assert(strlen(namep) < (size_t)MAXNAMELEN);
737 	strlcpy(info.cr_name, namep, sizeof (info.cr_name));
738 	if (cidp) {
739 		info.cr_cid = *cidp;
740 	} else {
741 		info.cr_cid.cid_fileno = 0;
742 		info.cr_cid.cid_flags = 0;
743 	}
744 	info.cr_va = *vattrp;
745 	info.cr_exclusive = exclusive;
746 	info.cr_mode = mode;
747 	copy_cred(&info.cr_cred, credp);
748 
749 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_CREATE, &info, sizeof (info),
750 	    &ret, sizeof (ret));
751 	if (xx)
752 		error = errno;
753 
754 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
755 	kmod_format_fid(kmod_object_p, dirp);
756 	dbug_print(("ioctl", "   dir fid \"%s\"", kmod_object_p->i_fidbuf));
757 	dbug_print(("ioctl", "   name '%s', exclusive %d, mode 0%o",
758 	    namep, exclusive, mode));
759 	kmod_print_attr(vattrp);
760 	kmod_print_cred(credp);
761 	if (xx == 0) {
762 		if (newfidp)
763 			*newfidp = ret.cr_newfid;
764 		if (ctimep)
765 			*ctimep = ret.cr_ctime;
766 		if (mtimep)
767 			*mtimep = ret.cr_mtime;
768 		kmod_format_fid(kmod_object_p, &ret.cr_newfid);
769 		dbug_print(("ioctl", "   created file fid \"%s\"",
770 		    kmod_object_p->i_fidbuf));
771 		dbug_print(("ioctl", "   ctime %x %x",
772 		    ret.cr_ctime.tv_sec, ret.cr_ctime.tv_nsec));
773 		dbug_print(("ioctl", "   mtime %x %x",
774 		    ret.cr_mtime.tv_sec, ret.cr_mtime.tv_nsec));
775 	}
776 	dbug_leave("kmod_create");
777 	return (error);
778 }
779 
780 /*
781  * ------------------------------------------------------------
782  *			kmod_pushback
783  *
784  * Description:
785  * Arguments:
786  *	filep
787  *	fidp
788  *	credp
789  * Returns:
790  *	Returns ...
791  * Preconditions:
792  *	precond(filep)
793  *	precond(fidp)
794  *	precond(credp)
795  */
796 int
797 kmod_pushback(cfsd_kmod_object_t *kmod_object_p,
798 	cfs_cid_t *filep,
799 	cfs_fid_t *fidp,
800 	dl_cred_t *credp,
801 	cfs_timestruc_t *ctimep,
802 	cfs_timestruc_t *mtimep,
803 	int update)
804 {
805 	cachefsio_pushback_arg_t info;
806 	cachefsio_pushback_return_t ret;
807 	int error = 0;
808 	int xx;
809 
810 	dbug_enter("kmod_pushback");
811 	dbug_precond(kmod_object_p);
812 
813 	dbug_precond(filep);
814 	dbug_precond(fidp);
815 	dbug_precond(credp);
816 
817 	/* note: update is no longer used */
818 
819 	info.pb_cid = *filep;
820 	info.pb_fid = *fidp;
821 	copy_cred(&info.pb_cred, credp);
822 
823 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_PUSHBACK, &info, sizeof (info),
824 	    &ret, sizeof (ret));
825 	if (xx)
826 		error = errno;
827 
828 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
829 	dbug_print(("ioctl", "   cid %08x", filep->cid_fileno));
830 	kmod_format_fid(kmod_object_p, fidp);
831 	dbug_print(("ioctl", "   fid \"%s\"", kmod_object_p->i_fidbuf));
832 	kmod_print_cred(credp);
833 	if (xx == 0) {
834 		if (ctimep)
835 			*ctimep = ret.pb_ctime;
836 		if (mtimep)
837 			*mtimep = ret.pb_mtime;
838 		dbug_print(("ioctl", "   ctime %x %x",
839 		    ret.pb_ctime.tv_sec, ret.pb_ctime.tv_nsec));
840 		dbug_print(("ioctl", "   mtime %x %x",
841 		    ret.pb_mtime.tv_sec, ret.pb_mtime.tv_nsec));
842 	}
843 	dbug_leave("kmod_pushback");
844 	return (error);
845 }
846 
847 
848 /*
849  * ------------------------------------------------------------
850  *			kmod_rename
851  *
852  * Description:
853  * Arguments:
854  *	olddir
855  *	oldname
856  *	newdir
857  *	newname
858  *	credp
859  * Returns:
860  *	Returns ...
861  * Preconditions:
862  *	precond(olddir)
863  *	precond(oldname)
864  *	precond(newdir)
865  *	precond(newname)
866  *	precond(credp)
867  */
868 int
869 kmod_rename(cfsd_kmod_object_t *kmod_object_p,
870 	cfs_fid_t *olddir,
871 	const char *oldname,
872 	cfs_fid_t *newdir,
873 	const char *newname,
874 	const cfs_cid_t *cidp,
875 	dl_cred_t *credp,
876 	cfs_timestruc_t *ctimep,
877 	cfs_timestruc_t *delctimep,
878 	const cfs_cid_t *delcidp)
879 {
880 	cachefsio_rename_arg_t info;
881 	cachefsio_rename_return_t ret;
882 	int error = 0;
883 	int xx;
884 
885 	dbug_enter("kmod_rename");
886 	dbug_precond(kmod_object_p);
887 
888 	dbug_precond(olddir);
889 	dbug_precond(oldname);
890 	dbug_precond(newdir);
891 	dbug_precond(newname);
892 	dbug_precond(credp);
893 	dbug_precond(ctimep);
894 
895 	info.rn_olddir = *olddir;
896 	dbug_assert(strlen(oldname) < (size_t)MAXNAMELEN);
897 	strlcpy(info.rn_oldname, oldname, sizeof (info.rn_oldname));
898 	info.rn_newdir = *newdir;
899 	dbug_assert(strlen(newname) < (size_t)MAXNAMELEN);
900 	strlcpy(info.rn_newname, newname, sizeof (info.rn_newname));
901 	info.rn_cid = *cidp;
902 	copy_cred(&info.rn_cred, credp);
903 	info.rn_del_getctime = delctimep ? 1 : 0;
904 	info.rn_del_cid = *delcidp;
905 
906 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_RENAME, &info, sizeof (info),
907 	    &ret, sizeof (ret));
908 	if (xx)
909 		error = errno;
910 
911 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
912 	kmod_format_fid(kmod_object_p, olddir);
913 	dbug_print(("ioctl", "   old dir fid \"%s\"", kmod_object_p->i_fidbuf));
914 	kmod_format_fid(kmod_object_p, newdir);
915 	dbug_print(("ioctl", "   new dir fid \"%s\"", kmod_object_p->i_fidbuf));
916 	dbug_print(("ioctl", "   old name '%s'  new name '%s'",
917 	    oldname, newname));
918 	kmod_print_cred(credp);
919 	if (xx == 0) {
920 		*ctimep = ret.rn_ctime;
921 		dbug_print(("ioctl", "   ctime %x %x",
922 		    ctimep->tv_sec, ctimep->tv_nsec));
923 		if (delctimep) {
924 			*delctimep = ret.rn_del_ctime;
925 			dbug_print(("ioctl", "   del ctime %x %x",
926 			    delctimep->tv_sec, delctimep->tv_nsec));
927 		}
928 	}
929 	dbug_leave("kmod_rename");
930 	return (error);
931 }
932 
933 /*
934  * ------------------------------------------------------------
935  *			kmod_setattr
936  *
937  * Description:
938  * Arguments:
939  *	fidp
940  *	vattrp
941  *	flags
942  *	credp
943  * Returns:
944  *	Returns ...
945  * Preconditions:
946  *	precond(fidp)
947  *	precond(vattrp)
948  *	precond(credp)
949  */
950 int
951 kmod_setattr(cfsd_kmod_object_t *kmod_object_p,
952 	cfs_fid_t *fidp,
953 	const cfs_cid_t *cidp,
954 	vattr_t *vattrp,
955 	int flags,
956 	dl_cred_t *credp,
957 	cfs_timestruc_t *ctimep,
958 	cfs_timestruc_t *mtimep)
959 {
960 	cachefsio_setattr_arg_t info;
961 	cachefsio_setattr_return_t ret;
962 	int error = 0;
963 	int xx;
964 
965 	dbug_enter("kmod_setattr");
966 	dbug_precond(kmod_object_p);
967 
968 	dbug_precond(fidp);
969 	dbug_precond(cidp);
970 	dbug_precond(vattrp);
971 	dbug_precond(credp);
972 	dbug_precond(ctimep);
973 	dbug_precond(mtimep);
974 
975 	info.sa_backfid = *fidp;
976 	info.sa_cid = *cidp;
977 	info.sa_vattr = *vattrp;
978 	info.sa_flags = flags;
979 	copy_cred(&info.sa_cred, credp);
980 
981 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_SETATTR, &info, sizeof (info),
982 	    &ret, sizeof (ret));
983 	if (xx)
984 		error = errno;
985 
986 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
987 	dbug_print(("ioctl", "   flags 0x%x", flags));
988 	kmod_format_fid(kmod_object_p, fidp);
989 	dbug_print(("ioctl", "   fid \"%s\"", kmod_object_p->i_fidbuf));
990 	kmod_print_attr(vattrp);
991 	kmod_print_cred(credp);
992 	if (xx == 0) {
993 		*ctimep = ret.sa_ctime;
994 		*mtimep = ret.sa_mtime;
995 		dbug_print(("ioctl", "   ctime %x %x", ctimep->tv_sec,
996 		    ctimep->tv_nsec));
997 		dbug_print(("ioctl", "   mtime %x %x", mtimep->tv_sec,
998 		    mtimep->tv_nsec));
999 	}
1000 	dbug_leave("kmod_setattr");
1001 	return (error);
1002 }
1003 
1004 /*
1005  * ------------------------------------------------------------
1006  *			kmod_setsecattr
1007  *
1008  * Description:
1009  * Arguments:
1010  *	fidp
1011  *	aclcnt
1012  *	dfaclcnt
1013  *	acl
1014  *	flags
1015  *	credp
1016  * Returns:
1017  *	Returns ...
1018  * Preconditions:
1019  *	precond(fidp)
1020  *	precond(acl)
1021  *	precond(credp)
1022  *	precond(aclcnt + dfaclcnt <= MAX_ACL_ENTRIES)
1023  */
1024 int
1025 kmod_setsecattr(cfsd_kmod_object_t *kmod_object_p,
1026 	cfs_fid_t *fidp,
1027 	const cfs_cid_t *cidp,
1028 	ulong_t mask,
1029 	int aclcnt,
1030 	int dfaclcnt,
1031 	const aclent_t *acl,
1032 	dl_cred_t *credp,
1033 	cfs_timestruc_t *ctimep,
1034 	cfs_timestruc_t *mtimep)
1035 {
1036 	cachefsio_setsecattr_arg_t info;
1037 	cachefsio_setsecattr_return_t ret;
1038 	int error = 0;
1039 	int xx;
1040 
1041 	dbug_enter("kmod_setsecattr");
1042 	dbug_precond(kmod_object_p);
1043 
1044 	dbug_precond(fidp);
1045 	dbug_precond(cidp);
1046 	dbug_precond(acl);
1047 	dbug_precond(credp);
1048 	dbug_precond(ctimep);
1049 	dbug_precond(mtimep);
1050 	dbug_precond(aclcnt + dfaclcnt <= MAX_ACL_ENTRIES);
1051 
1052 	info.sc_backfid = *fidp;
1053 	info.sc_cid = *cidp;
1054 	info.sc_mask = mask;
1055 	info.sc_aclcnt = aclcnt;
1056 	info.sc_dfaclcnt = dfaclcnt;
1057 	memcpy(&info.sc_acl, acl, (aclcnt + dfaclcnt) * sizeof (aclent_t));
1058 	copy_cred(&info.sc_cred, credp);
1059 
1060 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_SETSECATTR, &info,
1061 	    sizeof (info), &ret, sizeof (ret));
1062 	if (xx)
1063 		error = errno;
1064 
1065 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
1066 	kmod_format_fid(kmod_object_p, fidp);
1067 	dbug_print(("ioctl", "   fid \"%s\"", kmod_object_p->i_fidbuf));
1068 	dbug_print(("ioctl", "   aclcnt %d dfaclcnt %d", aclcnt, dfaclcnt));
1069 	kmod_print_cred(credp);
1070 	if (xx == 0) {
1071 		*ctimep = ret.sc_ctime;
1072 		*mtimep = ret.sc_mtime;
1073 		dbug_print(("ioctl", "   ctime %x %x", ctimep->tv_sec,
1074 		    ctimep->tv_nsec));
1075 		dbug_print(("ioctl", "   mtime %x %x", mtimep->tv_sec,
1076 		    mtimep->tv_nsec));
1077 	}
1078 	dbug_leave("kmod_setsecattr");
1079 	return (error);
1080 }
1081 
1082 /*
1083  * ------------------------------------------------------------
1084  *			kmod_remove
1085  *
1086  * Description:
1087  * Arguments:
1088  *	fidp
1089  *	namep
1090  *	credp
1091  *	ctimep
1092  * Returns:
1093  *	Returns ...
1094  * Preconditions:
1095  *	precond(fidp)
1096  *	precond(namep)
1097  *	precond(credp)
1098  */
1099 int
1100 kmod_remove(cfsd_kmod_object_t *kmod_object_p,
1101 	const cfs_fid_t *fidp,
1102 	const cfs_cid_t *cidp,
1103 	const char *namep,
1104 	const dl_cred_t *credp,
1105 	cfs_timestruc_t *ctimep)
1106 {
1107 	cachefsio_remove_t info;
1108 	int len;
1109 	int error = 0;
1110 	int xx;
1111 
1112 	dbug_enter("kmod_remove");
1113 	dbug_precond(kmod_object_p);
1114 
1115 	dbug_precond(fidp);
1116 	dbug_precond(cidp);
1117 	dbug_precond(namep);
1118 	dbug_precond(credp);
1119 
1120 	info.rm_fid = *fidp;
1121 	info.rm_cid = *cidp;
1122 	dbug_assert(strlen(namep) < (size_t)MAXNAMELEN);
1123 	strlcpy(info.rm_name, namep, sizeof (info.rm_name));
1124 	copy_cred(&info.rm_cred, credp);
1125 	info.rm_getctime = ctimep ? 1 : 0;
1126 
1127 	if (ctimep)
1128 		len = sizeof (*ctimep);
1129 	else
1130 		len = 0;
1131 
1132 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_REMOVE, &info, sizeof (info),
1133 	    ctimep, len);
1134 	if (xx)
1135 		error = errno;
1136 
1137 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
1138 	kmod_format_fid(kmod_object_p, fidp);
1139 	dbug_print(("ioctl", "   fid '%s'", kmod_object_p->i_fidbuf));
1140 	dbug_print(("ioctl", "   name '%s'", namep));
1141 	kmod_print_cred(credp);
1142 	if ((xx == 0) && ctimep) {
1143 		dbug_print(("ioctl", "   ctime %x %x", ctimep->tv_sec,
1144 		    ctimep->tv_nsec));
1145 	}
1146 	dbug_leave("kmod_remove");
1147 	return (error);
1148 }
1149 
1150 /*
1151  * ------------------------------------------------------------
1152  *			kmod_link
1153  *
1154  * Description:
1155  * Arguments:
1156  *	dirfidp
1157  *	namep
1158  *	filefidp
1159  *	credp
1160  *	ctimep
1161  * Returns:
1162  *	Returns ...
1163  * Preconditions:
1164  *	precond(dirfidp)
1165  *	precond(namep)
1166  *	precond(filefidp)
1167  *	precond(credp)
1168  */
1169 int
1170 kmod_link(cfsd_kmod_object_t *kmod_object_p,
1171 	const cfs_fid_t *dirfidp,
1172 	const char *namep,
1173 	const cfs_fid_t *filefidp,
1174 	const cfs_cid_t *cidp,
1175 	const dl_cred_t *credp,
1176 	cfs_timestruc_t *ctimep)
1177 {
1178 	cachefsio_link_t info;
1179 	int error = 0;
1180 	int xx;
1181 
1182 	dbug_enter("kmod_link");
1183 	dbug_precond(kmod_object_p);
1184 
1185 	dbug_precond(dirfidp);
1186 	dbug_precond(namep);
1187 	dbug_precond(filefidp);
1188 	dbug_precond(cidp);
1189 	dbug_precond(credp);
1190 	dbug_precond(ctimep);
1191 
1192 	info.ln_dirfid = *dirfidp;
1193 	dbug_assert(strlen(namep) < (size_t)MAXNAMELEN);
1194 	strlcpy(info.ln_name, namep, sizeof (info.ln_name));
1195 	info.ln_filefid = *filefidp;
1196 	info.ln_cid = *cidp;
1197 	copy_cred(&info.ln_cred, credp);
1198 
1199 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_LINK, &info, sizeof (info),
1200 	    ctimep, sizeof (*ctimep));
1201 	if (xx)
1202 		error = errno;
1203 
1204 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
1205 	kmod_format_fid(kmod_object_p, dirfidp);
1206 	dbug_print(("ioctl", "   dir fid '%s'", kmod_object_p->i_fidbuf));
1207 	dbug_print(("ioctl", "   name '%s'", namep));
1208 	kmod_format_fid(kmod_object_p, filefidp);
1209 	dbug_print(("ioctl", "   file fid '%s'", kmod_object_p->i_fidbuf));
1210 	kmod_print_cred(credp);
1211 	if (xx == 0) {
1212 		dbug_print(("ioctl", "   ctime %x %x", ctimep->tv_sec,
1213 		    ctimep->tv_nsec));
1214 	}
1215 	dbug_leave("kmod_link");
1216 	return (error);
1217 }
1218 
1219 /*
1220  * ------------------------------------------------------------
1221  *			kmod_mkdir
1222  *
1223  * Description:
1224  * Arguments:
1225  *	dirfidp
1226  *	namep
1227  *	vattrp
1228  *	credp
1229  *	newfidp
1230  * Returns:
1231  *	Returns ...
1232  * Preconditions:
1233  *	precond(dirfidp)
1234  *	precond(namep)
1235  *	precond(vattrp)
1236  *	precond(credp)
1237  *	precond(newfidp)
1238  */
1239 int
1240 kmod_mkdir(cfsd_kmod_object_t *kmod_object_p,
1241 	const cfs_fid_t *dirfidp,
1242 	const char *namep,
1243 	const cfs_cid_t *cidp,
1244 	const vattr_t *vattrp,
1245 	const dl_cred_t *credp,
1246 	cfs_fid_t *newfidp)
1247 {
1248 	cachefsio_mkdir_t info;
1249 	int error = 0;
1250 	int xx;
1251 
1252 	dbug_enter("kmod_mkdir");
1253 	dbug_precond(kmod_object_p);
1254 
1255 	dbug_precond(dirfidp);
1256 	dbug_precond(namep);
1257 	dbug_precond(cidp);
1258 	dbug_precond(vattrp);
1259 	dbug_precond(credp);
1260 	dbug_precond(newfidp);
1261 
1262 	info.md_dirfid = *dirfidp;
1263 	dbug_assert(strlen(namep) < (size_t)MAXNAMELEN);
1264 	strlcpy(info.md_name, namep, sizeof (info.md_name));
1265 	info.md_cid = *cidp;
1266 	info.md_vattr = *vattrp;
1267 	copy_cred(&info.md_cred, credp);
1268 
1269 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_MKDIR, &info, sizeof (info),
1270 	    newfidp, sizeof (*newfidp));
1271 	if (xx)
1272 		error = errno;
1273 
1274 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
1275 	kmod_format_fid(kmod_object_p, dirfidp);
1276 	dbug_print(("ioctl", "   dir fid '%s'", kmod_object_p->i_fidbuf));
1277 	dbug_print(("ioctl", "   name '%s'", namep));
1278 	kmod_print_attr(vattrp);
1279 	kmod_print_cred(credp);
1280 	if (xx == 0) {
1281 		kmod_format_fid(kmod_object_p, newfidp);
1282 		dbug_print(("ioctl", "   file fid '%s'",
1283 		    kmod_object_p->i_fidbuf));
1284 	}
1285 	dbug_leave("kmod_mkdir");
1286 	return (error);
1287 }
1288 
1289 /*
1290  * ------------------------------------------------------------
1291  *			kmod_rmdir
1292  *
1293  * Description:
1294  * Arguments:
1295  *	dirfidp
1296  *	namep
1297  *	credp
1298  * Returns:
1299  *	Returns ...
1300  * Preconditions:
1301  *	precond(dirfidp)
1302  *	precond(namep)
1303  *	precond(credp)
1304  */
1305 int
1306 kmod_rmdir(cfsd_kmod_object_t *kmod_object_p,
1307 	const cfs_fid_t *dirfidp,
1308 	const char *namep,
1309 	const dl_cred_t *credp)
1310 {
1311 	cachefsio_rmdir_t info;
1312 	int error = 0;
1313 	int xx;
1314 
1315 	dbug_enter("kmod_rmdir");
1316 	dbug_precond(kmod_object_p);
1317 
1318 	dbug_precond(dirfidp);
1319 	dbug_precond(namep);
1320 	dbug_precond(credp);
1321 
1322 	info.rd_dirfid = *dirfidp;
1323 	dbug_assert(strlen(namep) < (size_t)MAXNAMELEN);
1324 	strlcpy(info.rd_name, namep, sizeof (info.rd_name));
1325 	copy_cred(&info.rd_cred, credp);
1326 
1327 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_RMDIR, &info, sizeof (info),
1328 	    NULL, 0);
1329 	if (xx)
1330 		error = errno;
1331 
1332 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
1333 	kmod_format_fid(kmod_object_p, dirfidp);
1334 	dbug_print(("ioctl", "   dir fid '%s'", kmod_object_p->i_fidbuf));
1335 	dbug_print(("ioctl", "   name '%s'", namep));
1336 	kmod_print_cred(credp);
1337 	dbug_leave("kmod_rmdir");
1338 	return (error);
1339 }
1340 
1341 /*
1342  * ------------------------------------------------------------
1343  *			kmod_symlink
1344  *
1345  * Description:
1346  * Arguments:
1347  *	dirfidp
1348  *	namep
1349  *	linkvalp
1350  *	vattrp
1351  *	credp
1352  *	ctimep
1353  *	mtimep
1354  * Returns:
1355  *	Returns ...
1356  * Preconditions:
1357  *	precond(dirfidp)
1358  *	precond(namep)
1359  *	precond(linkvalp)
1360  *	precond(vattrp)
1361  *	precond(credp)
1362  *	precond(ctimep)
1363  *	precond(mtimep)
1364  */
1365 int
1366 kmod_symlink(cfsd_kmod_object_t *kmod_object_p,
1367 	const cfs_fid_t *dirfidp,
1368 	const char *namep,
1369 	const cfs_cid_t *cidp,
1370 	const char *linkvalp,
1371 	const vattr_t *vattrp,
1372 	const dl_cred_t *credp,
1373 	cfs_fid_t *newfidp,
1374 	cfs_timestruc_t *ctimep,
1375 	cfs_timestruc_t *mtimep)
1376 {
1377 	cachefsio_symlink_arg_t info;
1378 	cachefsio_symlink_return_t ret;
1379 	int error = 0;
1380 	int xx;
1381 
1382 	dbug_enter("kmod_symlink");
1383 	dbug_precond(kmod_object_p);
1384 
1385 	dbug_precond(dirfidp);
1386 	dbug_precond(namep);
1387 	dbug_precond(cidp);
1388 	dbug_precond(linkvalp);
1389 	dbug_precond(vattrp);
1390 	dbug_precond(credp);
1391 	dbug_precond(newfidp);
1392 	dbug_precond(ctimep);
1393 	dbug_precond(mtimep);
1394 
1395 	info.sy_dirfid = *dirfidp;
1396 	dbug_assert(strlen(namep) < (size_t)MAXNAMELEN);
1397 	strlcpy(info.sy_name, namep, sizeof (info.sy_name));
1398 	dbug_assert(strlen(linkvalp) < (size_t)MAXPATHLEN);
1399 	info.sy_cid = *cidp;
1400 	strlcpy(info.sy_link, linkvalp, sizeof (info.sy_link));
1401 	info.sy_vattr = *vattrp;
1402 	copy_cred(&info.sy_cred, credp);
1403 
1404 	xx = kmod_doioctl(kmod_object_p, CFSDCMD_SYMLINK, &info, sizeof (info),
1405 	    &ret, sizeof (ret));
1406 	if (xx)
1407 		error = errno;
1408 
1409 	dbug_print(("ioctl", "returns %d, error %d", xx, error));
1410 	kmod_format_fid(kmod_object_p, dirfidp);
1411 	dbug_print(("ioctl", "   dir fid '%s'", kmod_object_p->i_fidbuf));
1412 	dbug_print(("ioctl", "   name '%s'", namep));
1413 	dbug_print(("ioctl", "   link '%s'", linkvalp));
1414 	kmod_print_attr(vattrp);
1415 	kmod_print_cred(credp);
1416 	if (xx == 0) {
1417 		*ctimep = ret.sy_ctime;
1418 		*mtimep = ret.sy_mtime;
1419 		*newfidp = ret.sy_newfid;
1420 		dbug_print(("ioctl", "   ctime %x %x", ctimep->tv_sec,
1421 		    ctimep->tv_nsec));
1422 		dbug_print(("ioctl", "   mtime %x %x", mtimep->tv_sec,
1423 		    mtimep->tv_nsec));
1424 		kmod_format_fid(kmod_object_p, newfidp);
1425 		dbug_print(("ioctl", "   child fid '%s'",
1426 		    kmod_object_p->i_fidbuf));
1427 	}
1428 	dbug_leave("kmod_symlink");
1429 	return (error);
1430 }
1431 #ifndef DBUG_OFF
1432 /*
1433  * ------------------------------------------------------------
1434  *			kmod_format_fid
1435  *
1436  * Description:
1437  * Arguments:
1438  *	fidp
1439  * Returns:
1440  * Preconditions:
1441  *	precond(fidp)
1442  */
1443 void
1444 kmod_format_fid(cfsd_kmod_object_t *kmod_object_p, const cfs_fid_t *fidp)
1445 {
1446 	uint_t val;
1447 	int index;
1448 	char format[10];
1449 	kmod_object_p->i_fidbuf[0] = '\0';
1450 
1451 	for (index = 0; index < (int)fidp->fid_len; index += sizeof (uint_t)) {
1452 		memcpy(&val, &fidp->fid_data[index], sizeof (uint_t));
1453 		snprintf(format, sizeof (format), "%08x ", val);
1454 		strlcat(kmod_object_p->i_fidbuf, format,
1455 		    sizeof (kmod_object_p->i_fidbuf));
1456 	}
1457 }
1458 
1459 /*
1460  * ------------------------------------------------------------
1461  *			kmod_print_cred
1462  *
1463  * Description:
1464  * Arguments:
1465  *	credp
1466  * Returns:
1467  * Preconditions:
1468  *	precond(credp)
1469  */
1470 void
1471 kmod_print_cred(const dl_cred_t *credp)
1472 {
1473 	char buf[100];
1474 	char format[10];
1475 	int xx;
1476 
1477 	dbug_enter("kmod_print_cred");
1478 	dbug_precond(credp);
1479 
1480 	buf[0] = '\0';
1481 	dbug_print(("ioctl", "credentials"));
1482 	dbug_print(("ioctl", "  uid %d, gid %d",
1483 	    credp->cr_uid, credp->cr_gid));
1484 	dbug_print(("ioctl", "  ruid %d, rgid %d, suid %d, sgid %d",
1485 	    credp->cr_ruid, credp->cr_rgid,
1486 	    credp->cr_suid, credp->cr_sgid));
1487 
1488 	for (xx = 0; xx < credp->cr_ngroups; xx++) {
1489 		snprintf(format, sizeof (format), " %d", credp->cr_groups[xx]);
1490 		strlcat(buf, format, sizeof (buf));
1491 	}
1492 
1493 	dbug_print(("ioctl", "  ngroups %d,  %s", credp->cr_ngroups, buf));
1494 	dbug_leave("kmod_print_cred");
1495 }
1496 
1497 /*
1498  * ------------------------------------------------------------
1499  *			kmod_print_attr
1500  *
1501  * Description:
1502  * Arguments:
1503  *	vattrp
1504  * Returns:
1505  * Preconditions:
1506  *	precond(vattrp)
1507  */
1508 void
1509 kmod_print_attr(const vattr_t *vp)
1510 {
1511 	dbug_enter("kmod_print_attr");
1512 	dbug_precond(vp);
1513 
1514 	dbug_print(("ioctl", "attributes"));
1515 	dbug_print(("ioctl", "  mask 0x%x", vp->va_mask));
1516 	if (vp->va_mask & AT_TYPE)
1517 		dbug_print(("ioctl", "  type %d", vp->va_type));
1518 	if (vp->va_mask & AT_MODE)
1519 		dbug_print(("ioctl", "  mode 0%o", vp->va_mode));
1520 	if (vp->va_mask & AT_UID)
1521 		dbug_print(("ioctl", "  uid %d", vp->va_uid));
1522 	if (vp->va_mask & AT_GID)
1523 		dbug_print(("ioctl", "  gid %d", vp->va_gid));
1524 	if (vp->va_mask & AT_FSID)
1525 		dbug_print(("ioctl", "  fsid %08x", vp->va_fsid));
1526 	if (vp->va_mask & AT_NODEID)
1527 		dbug_print(("ioctl", "  nodeid %08x", vp->va_nodeid));
1528 	if (vp->va_mask & AT_NLINK)
1529 		dbug_print(("ioctl", "  nlink %d", vp->va_nlink));
1530 	if (vp->va_mask & AT_SIZE)
1531 		dbug_print(("ioctl", "  size %d", vp->va_size));
1532 	if (vp->va_mask & AT_ATIME)
1533 		dbug_print(("ioctl", "  atime %08x %08x",
1534 		    vp->va_atime.tv_sec, vp->va_atime.tv_nsec));
1535 	if (vp->va_mask & AT_MTIME)
1536 		dbug_print(("ioctl", "  mtime %08x %08x",
1537 		    vp->va_mtime.tv_sec, vp->va_mtime.tv_nsec));
1538 	if (vp->va_mask & AT_CTIME)
1539 		dbug_print(("ioctl", "  ctime %08x %08x",
1540 		    vp->va_ctime.tv_sec, vp->va_ctime.tv_nsec));
1541 	if (vp->va_mask & AT_RDEV)
1542 		dbug_print(("ioctl", "  rdev %08x", vp->va_rdev));
1543 	if (vp->va_mask & AT_BLKSIZE)
1544 		dbug_print(("ioctl", "  blksize %08x", vp->va_blksize));
1545 	if (vp->va_mask & AT_NBLOCKS)
1546 		dbug_print(("ioctl", "  nblocks %d", vp->va_nblocks));
1547 	if (vp->va_mask & AT_SEQ)
1548 		dbug_print(("ioctl", "  seq %d", vp->va_seq));
1549 	dbug_leave("kmod_print_attr");
1550 }
1551 #endif /* DBUG_OFF */
1552 /*
1553  *			kmod_doioctl
1554  *
1555  * Description:
1556  *	Helper routine for others in this file.  Just packages up
1557  *	arguments and does the ioctl operation.
1558  * Arguments:
1559  *	cmd
1560  *	sdata
1561  *	slen
1562  *	rdata
1563  *	rlen
1564  * Returns:
1565  *	Returns the result of the ioctl operation.
1566  * Preconditions:
1567  */
1568 int
1569 kmod_doioctl(cfsd_kmod_object_t *kmod_object_p,
1570 	enum cfsdcmd_cmds cmd,
1571 	void *sdata,
1572 	int slen,
1573 	void *rdata,
1574 	int rlen)
1575 {
1576 	cachefsio_dcmd_t dcmd;
1577 	int xx;
1578 
1579 	dbug_enter("kmod_doioctl");
1580 	dbug_precond(kmod_object_p);
1581 	dcmd.d_cmd = cmd;
1582 	dcmd.d_sdata = sdata;
1583 	dcmd.d_slen = slen;
1584 	dcmd.d_rdata = rdata;
1585 	dcmd.d_rlen = rlen;
1586 	dbug_print(("ioctl", "about to do cmd = %d", cmd));
1587 	xx = ioctl(kmod_object_p->i_fd, CACHEFSIO_DCMD, &dcmd);
1588 	if (xx) {
1589 		dbug_print(("ioctl", "ioctl errno = %d", errno));
1590 	}
1591 	dbug_leave("kmod_doioctl");
1592 	return (xx);
1593 }
1594