1*8329232eSGordon Ross /*
2*8329232eSGordon Ross  * CDDL HEADER START
3*8329232eSGordon Ross  *
4*8329232eSGordon Ross  * The contents of this file are subject to the terms of the
5*8329232eSGordon Ross  * Common Development and Distribution License (the "License").
6*8329232eSGordon Ross  * You may not use this file except in compliance with the License.
7*8329232eSGordon Ross  *
8*8329232eSGordon Ross  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9*8329232eSGordon Ross  * or http://www.opensolaris.org/os/licensing.
10*8329232eSGordon Ross  * See the License for the specific language governing permissions
11*8329232eSGordon Ross  * and limitations under the License.
12*8329232eSGordon Ross  *
13*8329232eSGordon Ross  * When distributing Covered Code, include this CDDL HEADER in each
14*8329232eSGordon Ross  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15*8329232eSGordon Ross  * If applicable, add the following below this CDDL HEADER, with the
16*8329232eSGordon Ross  * fields enclosed by brackets "[]" replaced with your own identifying
17*8329232eSGordon Ross  * information: Portions Copyright [yyyy] [name of copyright owner]
18*8329232eSGordon Ross  *
19*8329232eSGordon Ross  * CDDL HEADER END
20*8329232eSGordon Ross  */
21*8329232eSGordon Ross 
22*8329232eSGordon Ross /*
23*8329232eSGordon Ross  * Copyright (c) 1989, 2010, Oracle and/or its affiliates. All rights reserved.
24*8329232eSGordon Ross  * Copyright 2015, Joyent Inc.
25*8329232eSGordon Ross  * Copyright 2017 Nexenta Systems, Inc.  All rights reserved.
26*8329232eSGordon Ross  */
27*8329232eSGordon Ross 
28*8329232eSGordon Ross /*	Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T	*/
29*8329232eSGordon Ross /*	All Rights Reserved */
30*8329232eSGordon Ross 
31*8329232eSGordon Ross /*
32*8329232eSGordon Ross  * The kTLI "shim" over in ./fake_ktli.c uses getf(), releasef() to
33*8329232eSGordon Ross  * represent an open socket FD in "fake" vnode_t and file_t objects.
34*8329232eSGordon Ross  * This implements minimal getf()/releasef() shims for that purpose.
35*8329232eSGordon Ross  */
36*8329232eSGordon Ross 
37*8329232eSGordon Ross #include <sys/types.h>
38*8329232eSGordon Ross #include <sys/sysmacros.h>
39*8329232eSGordon Ross #include <sys/param.h>
40*8329232eSGordon Ross #include <sys/systm.h>
41*8329232eSGordon Ross #include <sys/errno.h>
42*8329232eSGordon Ross #include <sys/cred.h>
43*8329232eSGordon Ross #include <sys/user.h>
44*8329232eSGordon Ross #include <sys/vfs.h>
45*8329232eSGordon Ross #include <sys/vnode.h>
46*8329232eSGordon Ross #include <sys/file.h>
47*8329232eSGordon Ross #include <sys/debug.h>
48*8329232eSGordon Ross #include <sys/kmem.h>
49*8329232eSGordon Ross 
50*8329232eSGordon Ross #define	FAKEFDS	256
51*8329232eSGordon Ross 
52*8329232eSGordon Ross kmutex_t ftlock;
53*8329232eSGordon Ross file_t *ftab[FAKEFDS];
54*8329232eSGordon Ross 
55*8329232eSGordon Ross file_t *
getf(int fd)56*8329232eSGordon Ross getf(int fd)
57*8329232eSGordon Ross {
58*8329232eSGordon Ross 	file_t *fp;
59*8329232eSGordon Ross 	vnode_t *vp;
60*8329232eSGordon Ross 
61*8329232eSGordon Ross 	if (fd >= FAKEFDS)
62*8329232eSGordon Ross 		return (NULL);
63*8329232eSGordon Ross 
64*8329232eSGordon Ross 	mutex_enter(&ftlock);
65*8329232eSGordon Ross 	if ((fp = ftab[fd]) != NULL) {
66*8329232eSGordon Ross 		fp->f_count++;
67*8329232eSGordon Ross 		mutex_exit(&ftlock);
68*8329232eSGordon Ross 		return (fp);
69*8329232eSGordon Ross 	}
70*8329232eSGordon Ross 
71*8329232eSGordon Ross 	fp = kmem_zalloc(sizeof (*fp), KM_SLEEP);
72*8329232eSGordon Ross 	vp = kmem_zalloc(sizeof (*vp), KM_SLEEP);
73*8329232eSGordon Ross 	vp->v_fd = fd;
74*8329232eSGordon Ross 	fp->f_vnode = vp;
75*8329232eSGordon Ross 	fp->f_count = 1;
76*8329232eSGordon Ross 	ftab[fd] = fp;
77*8329232eSGordon Ross 
78*8329232eSGordon Ross 	mutex_exit(&ftlock);
79*8329232eSGordon Ross 
80*8329232eSGordon Ross 	return (fp);
81*8329232eSGordon Ross }
82*8329232eSGordon Ross 
83*8329232eSGordon Ross void
releasef(int fd)84*8329232eSGordon Ross releasef(int fd)
85*8329232eSGordon Ross {
86*8329232eSGordon Ross 	file_t *fp;
87*8329232eSGordon Ross 	vnode_t *vp;
88*8329232eSGordon Ross 
89*8329232eSGordon Ross 	mutex_enter(&ftlock);
90*8329232eSGordon Ross 	if ((fp = ftab[fd]) == NULL) {
91*8329232eSGordon Ross 		mutex_exit(&ftlock);
92*8329232eSGordon Ross 		return;
93*8329232eSGordon Ross 	}
94*8329232eSGordon Ross 	fp->f_count--;
95*8329232eSGordon Ross 	if (fp->f_count > 0) {
96*8329232eSGordon Ross 		mutex_exit(&ftlock);
97*8329232eSGordon Ross 		return;
98*8329232eSGordon Ross 	}
99*8329232eSGordon Ross 	ftab[fd] = NULL;
100*8329232eSGordon Ross 	mutex_exit(&ftlock);
101*8329232eSGordon Ross 
102*8329232eSGordon Ross 	vp = fp->f_vnode;
103*8329232eSGordon Ross 	kmem_free(vp, sizeof (*vp));
104*8329232eSGordon Ross 	kmem_free(fp, sizeof (*fp));
105*8329232eSGordon Ross }
106