xref: /netbsd-src/sys/sys/namei.h (revision d710132b4b8ce7f7cccaaf660cb16aa16b4077a0)
1 /*	$NetBSD: namei.h,v 1.27 2003/02/01 06:23:50 thorpej Exp $	*/
2 
3 /*
4  * Copyright (c) 1985, 1989, 1991, 1993
5  *	The Regents of the University of California.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  * 3. All advertising materials mentioning features or use of this software
16  *    must display the following acknowledgement:
17  *	This product includes software developed by the University of
18  *	California, Berkeley and its contributors.
19  * 4. Neither the name of the University nor the names of its contributors
20  *    may be used to endorse or promote products derived from this software
21  *    without specific prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33  * SUCH DAMAGE.
34  *
35  *	@(#)namei.h	8.5 (Berkeley) 8/20/94
36  */
37 
38 #ifndef _SYS_NAMEI_H_
39 #define	_SYS_NAMEI_H_
40 
41 #include <sys/queue.h>
42 
43 /*
44  * Encapsulation of namei parameters.
45  */
46 struct nameidata {
47 	/*
48 	 * Arguments to namei/lookup.
49 	 */
50 	const char *ni_dirp;		/* pathname pointer */
51 	enum	uio_seg ni_segflg;	/* location of pathname */
52      /* u_long	ni_nameiop;		   namei operation */
53      /* u_long	ni_flags;		   flags to namei */
54      /* struct	proc *ni_proc;		   process requesting lookup */
55 	/*
56 	 * Arguments to lookup.
57 	 */
58      /* struct	ucred *ni_cred;		   credentials */
59 	struct	vnode *ni_startdir;	/* starting directory */
60 	struct	vnode *ni_rootdir;	/* logical root directory */
61 	/*
62 	 * Results: returned from/manipulated by lookup
63 	 */
64 	struct	vnode *ni_vp;		/* vnode of result */
65 	struct	vnode *ni_dvp;		/* vnode of intermediate directory */
66 	/*
67 	 * Shared between namei and lookup/commit routines.
68 	 */
69 	size_t	ni_pathlen;		/* remaining chars in path */
70 	const char *ni_next;		/* next location in pathname */
71 	u_long	ni_loopcnt;		/* count of symlinks encountered */
72 	/*
73 	 * Lookup parameters: this structure describes the subset of
74 	 * information from the nameidata structure that is passed
75 	 * through the VOP interface.
76 	 */
77 	struct componentname {
78 		/*
79 		 * Arguments to lookup.
80 		 */
81 		u_long	cn_nameiop;	/* namei operation */
82 		u_long	cn_flags;	/* flags to namei */
83 		struct	proc *cn_proc;	/* process requesting lookup */
84 		struct	ucred *cn_cred;	/* credentials */
85 		/*
86 		 * Shared between lookup and commit routines.
87 		 */
88 		char	*cn_pnbuf;	/* pathname buffer */
89 		const char *cn_nameptr;	/* pointer to looked up name */
90 		long	cn_namelen;	/* length of looked up component */
91 		u_long	cn_hash;	/* hash value of looked up name */
92 		long	cn_consume;	/* chars to consume in lookup() */
93 	} ni_cnd;
94 };
95 
96 #ifdef _KERNEL
97 /*
98  * namei operations
99  */
100 #define	LOOKUP		0	/* perform name lookup only */
101 #define	CREATE		1	/* setup for file creation */
102 #define	DELETE		2	/* setup for file deletion */
103 #define	RENAME		3	/* setup for file renaming */
104 #define	OPMASK		3	/* mask for operation */
105 /*
106  * namei operational modifier flags, stored in ni_cnd.cn_flags
107  */
108 #define	LOCKLEAF	0x0004	/* lock inode on return */
109 #define	LOCKPARENT	0x0008	/* want parent vnode returned locked */
110 #define	WANTPARENT	0x0010	/* want parent vnode returned unlocked */
111 #define	NOCACHE		0x0020	/* name must not be left in cache */
112 #define	FOLLOW		0x0040	/* follow symbolic links */
113 #define	NOFOLLOW	0x0000	/* do not follow symbolic links (pseudo) */
114 #define	MODMASK		0x00fc	/* mask of operational modifiers */
115 /*
116  * Namei parameter descriptors.
117  *
118  * SAVENAME may be set by either the callers of namei or by VOP_LOOKUP.
119  * If the caller of namei sets the flag (for example execve wants to
120  * know the name of the program that is being executed), then it must
121  * free the buffer. If VOP_LOOKUP sets the flag, then the buffer must
122  * be freed by either the commit routine or the VOP_ABORT routine.
123  * SAVESTART is set only by the callers of namei. It implies SAVENAME
124  * plus the addition of saving the parent directory that contains the
125  * name in ni_startdir. It allows repeated calls to lookup for the
126  * name being sought. The caller is responsible for releasing the
127  * buffer and for vrele'ing ni_startdir.
128  */
129 #define	NOCROSSMOUNT	0x0000100	/* do not cross mount points */
130 #define	RDONLY		0x0000200	/* lookup with read-only semantics */
131 #define	HASBUF		0x0000400	/* has allocated pathname buffer */
132 #define	SAVENAME	0x0000800	/* save pathname buffer */
133 #define	SAVESTART	0x0001000	/* save starting directory */
134 #define ISDOTDOT	0x0002000	/* current component name is .. */
135 #define MAKEENTRY	0x0004000	/* entry is to be added to name cache */
136 #define ISLASTCN	0x0008000	/* this is last component of pathname */
137 #define ISSYMLINK	0x0010000	/* symlink needs interpretation */
138 #define	ISWHITEOUT	0x0020000	/* found whiteout */
139 #define	DOWHITEOUT	0x0040000	/* do whiteouts */
140 #define	REQUIREDIR	0x0080000	/* must be a directory */
141 #define PDIRUNLOCK	0x0100000	/* vfs_lookup() unlocked parent dir */
142 #define PARAMASK	0x01fff00	/* mask of parameter descriptors */
143 /*
144  * Initialization of an nameidata structure.
145  */
146 #define NDINIT(ndp, op, flags, segflg, namep, p) { \
147 	(ndp)->ni_cnd.cn_nameiop = op; \
148 	(ndp)->ni_cnd.cn_flags = flags; \
149 	(ndp)->ni_segflg = segflg; \
150 	(ndp)->ni_dirp = namep; \
151 	(ndp)->ni_cnd.cn_proc = p; \
152 	(ndp)->ni_cnd.cn_cred = p->p_ucred; \
153 }
154 #endif
155 
156 /*
157  * This structure describes the elements in the cache of recent
158  * names looked up by namei. NCHNAMLEN is sized to make structure
159  * size a power of two to optimize malloc's. Minimum reasonable
160  * size is 15.
161  */
162 
163 #define	NCHNAMLEN	31	/* maximum name segment length we bother with */
164 
165 struct	namecache {
166 	LIST_ENTRY(namecache) nc_hash;	/* hash chain */
167 	TAILQ_ENTRY(namecache) nc_lru;	/* LRU chain */
168 	LIST_ENTRY(namecache) nc_vhash;	/* directory hash chain */
169 	struct	vnode *nc_dvp;		/* vnode of parent of name */
170 	u_long	nc_dvpid;		/* capability number of nc_dvp */
171 	struct	vnode *nc_vp;		/* vnode the name refers to */
172 	u_long	nc_vpid;		/* capability number of nc_vp */
173 	char	nc_nlen;		/* length of name */
174 	char	nc_name[NCHNAMLEN];	/* segment name */
175 };
176 
177 #ifdef _KERNEL
178 #include <sys/mallocvar.h>
179 #include <sys/pool.h>
180 
181 extern struct pool pnbuf_pool;		/* pathname buffer pool */
182 extern struct pool_cache pnbuf_cache;	/* pathname buffer cache */
183 
184 MALLOC_DECLARE(M_NAMEI);
185 
186 #define	PNBUF_GET()	pool_cache_get(&pnbuf_cache, PR_WAITOK)
187 #define	PNBUF_PUT(pnb)	pool_cache_put(&pnbuf_cache, (pnb))
188 
189 int	namei __P((struct nameidata *ndp));
190 uint32_t namei_hash __P((const char *, const char **));
191 int	lookup __P((struct nameidata *ndp));
192 int	relookup __P((struct vnode *dvp, struct vnode **vpp,
193 		      struct componentname *cnp));
194 void cache_purge __P((struct vnode *));
195 int cache_lookup __P((struct vnode *, struct vnode **, struct componentname *));
196 int cache_revlookup __P((struct vnode *, struct vnode **, char **, char *));
197 void cache_enter __P((struct vnode *, struct vnode *, struct componentname *));
198 void nchinit __P((void));
199 void nchreinit __P((void));
200 struct mount;
201 void cache_purgevfs __P((struct mount *));
202 void namecache_print(struct vnode *, void (*)(const char *, ...));
203 #endif
204 
205 /*
206  * Stats on usefulness of namei caches.
207  */
208 struct	nchstats {
209 	long	ncs_goodhits;		/* hits that we can really use */
210 	long	ncs_neghits;		/* negative hits that we can use */
211 	long	ncs_badhits;		/* hits we must drop */
212 	long	ncs_falsehits;		/* hits with id mismatch */
213 	long	ncs_miss;		/* misses */
214 	long	ncs_long;		/* long names that ignore cache */
215 	long	ncs_pass2;		/* names found with passes == 2 */
216 	long	ncs_2passes;		/* number of times we attempt it */
217 	long	ncs_revhits;		/* reverse-cache hits */
218 	long	ncs_revmiss;		/* reverse-cache misses */
219 };
220 
221 #ifdef _KERNEL
222 extern struct nchstats nchstats;
223 #endif
224 #endif /* !_SYS_NAMEI_H_ */
225