The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/sys/nlookup.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*
    2  * Copyright (c) 2004 The DragonFly Project.  All rights reserved.
    3  * 
    4  * This code is derived from software contributed to The DragonFly Project
    5  * by Matthew Dillon <dillon@backplane.com>
    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  * 
   11  * 1. Redistributions of source code must retain the above copyright
   12  *    notice, this list of conditions and the following disclaimer.
   13  * 2. Redistributions in binary form must reproduce the above copyright
   14  *    notice, this list of conditions and the following disclaimer in
   15  *    the documentation and/or other materials provided with the
   16  *    distribution.
   17  * 3. Neither the name of The DragonFly Project nor the names of its
   18  *    contributors may be used to endorse or promote products derived
   19  *    from this software without specific, prior written permission.
   20  * 
   21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
   22  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
   23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
   24  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE
   25  * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
   26  * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING,
   27  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
   28  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
   29  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
   30  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
   31  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   32  * SUCH DAMAGE.
   33  *
   34  * $DragonFly: src/sys/sys/nlookup.h,v 1.6 2008/05/09 17:52:18 dillon Exp $
   35  */
   36 
   37 #ifndef _SYS_NLOOKUP_H_
   38 #define _SYS_NLOOKUP_H_
   39 
   40 #ifndef _SYS_UIO_H_
   41 #include <sys/uio.h>
   42 #endif
   43 #ifndef _SYS_NAMECACHE_H_
   44 #include <sys/namecache.h>
   45 #endif
   46 #ifndef _SYS_FILE_H_
   47 #include <sys/file.h>
   48 #endif
   49 
   50 struct vnode;
   51 struct vattr;
   52 struct mount;
   53 struct thread;
   54 struct ucred;
   55 
   56 /*
   57  * nlookup component
   58  */
   59 struct nlcomponent {
   60         char            *nlc_nameptr;
   61         int             nlc_namelen;
   62 };
   63 
   64 /*
   65  * Encapsulation of nlookup parameters.
   66  *
   67  * Note on nl_flags and nl_op: nl_flags supports a simplified subset of 
   68  * namei's original CNP flags.  nl_op (e.g. NAMEI_*) does no in any way
   69  * effect the state of the returned namecache and is only used to enforce
   70  * access checks.
   71  */
   72 struct nlookupdata {
   73         /*
   74          * These fields are setup by nlookup_init() with nl_nch set to
   75          * the current directory if a process or the root directory if
   76          * a pure thread.  The result from nlookup() will be returned in
   77          * nl_nch.
   78          */
   79         struct nchandle nl_nch;         /* start-point and result */
   80         struct nchandle nl_rootnch;     /* root directory */
   81         struct nchandle nl_jailnch;     /* jail directory */
   82 
   83         char            *nl_path;       /* path buffer */
   84         struct thread   *nl_td;         /* thread requesting the nlookup */
   85         struct ucred    *nl_cred;       /* credentials for nlookup */
   86         struct vnode    *nl_dvp;        /* NLC_REFDVP */
   87 
   88         int             nl_flags;       /* operations flags */
   89         int             nl_loopcnt;     /* symlinks encountered */
   90 
   91         /*
   92          * These fields are populated by vn_open().  nlookup_done() will
   93          * vn_close() a non-NULL vp so if you extract it be sure to NULL out
   94          * nl_open_vp.
   95          */
   96         struct  vnode   *nl_open_vp;    
   97         int             nl_vp_fmode;
   98 };
   99 
  100 /*
  101  * NOTE: nlookup() flags related to open checks do not actually perform
  102  *       any modifying operation.  e.g. the file isn't created, truncated,
  103  *       etc.  vn_open() handles that.
  104  */
  105 #define NLC_FOLLOW              0x00000001      /* follow leaf symlink */
  106 #define NLC_NOCROSSMOUNT        0x00000002      /* do not cross mount points */
  107 #define NLC_HASBUF              0x00000004      /* nl_path is allocated */
  108 #define NLC_ISWHITEOUT          0x00000008
  109 #define NLC_WILLBEDIR           0x00000010
  110 #define NLC_NCPISLOCKED         0x00000020
  111 #define NLC_LOCKVP              0x00000040      /* nl_open_vp from vn_open */
  112 #define NLC_CREATE              0x00000080      /* do create checks */
  113 #define NLC_DELETE              0x00000100      /* do delete checks */
  114 #define NLC_RENAME_DST          0x00000200      /* do rename checks (target) */
  115 #define NLC_OPEN                0x00000400      /* do open checks */
  116 #define NLC_TRUNCATE            0x00000800      /* do truncation checks */
  117 #define NLC_HLINK               0x00001000      /* do hardlink checks */
  118 #define NLC_RENAME_SRC          0x00002000      /* do rename checks (source) */
  119 #define NLC_SHAREDLOCK          0x00004000      /* allow shared ncp & vp lock */
  120 #define NLC_UNUSED00008000      0x00008000
  121 #define NLC_NFS_RDONLY          0x00010000      /* set by nfs_namei() only */
  122 #define NLC_NFS_NOSOFTLINKTRAV  0x00020000      /* do not traverse softlnks */
  123 #define NLC_REFDVP              0x00040000      /* set ref'd/unlocked nl_dvp */
  124 
  125 #define NLC_APPEND              0x00100000      /* open check: append */
  126 #define NLC_UNUSED00200000      0x00200000
  127 
  128 #define NLC_READ                0x00400000      /* require read access */
  129 #define NLC_WRITE               0x00800000      /* require write access */
  130 #define NLC_EXEC                0x01000000      /* require execute access */
  131 #define NLC_EXCL                0x02000000      /* open check: exclusive */
  132 #define NLC_OWN                 0x04000000      /* open check: owner override */
  133 #define NLC_UNUSED08000000      0x08000000
  134 #define NLC_STICKY              0x10000000      /* indicate sticky case */
  135 #define NLC_APPENDONLY          0x20000000      /* indicate append-only */
  136 #define NLC_IMMUTABLE           0x40000000      /* indicate immutable set */
  137 #define NLC_WRITABLE            0x80000000      /* indicate writeable */
  138 
  139 /*
  140  * All checks.  If any of these bits are set general user/group/world
  141  * permission checks will be done by nlookup().
  142  */
  143 #define NLC_ALLCHKS             (NLC_CREATE | NLC_DELETE | NLC_RENAME_DST | \
  144                                  NLC_OPEN | NLC_TRUNCATE | NLC_RENAME_SRC | \
  145                                  NLC_READ | NLC_WRITE | NLC_EXEC | NLC_OWN)
  146 
  147 #ifdef _KERNEL
  148 
  149 int nlookup_init(struct nlookupdata *, const char *, enum uio_seg, int);
  150 int nlookup_init_at(struct nlookupdata *, struct file **, int, const char *, 
  151                 enum uio_seg, int);
  152 int nlookup_init_raw(struct nlookupdata *, const char *, enum uio_seg, int, struct ucred *, struct nchandle *);
  153 int nlookup_init_root(struct nlookupdata *, const char *, enum uio_seg, int, struct ucred *, struct nchandle *, struct nchandle *);
  154 void nlookup_set_cred(struct nlookupdata *nd, struct ucred *cred);
  155 void nlookup_zero(struct nlookupdata *);
  156 void nlookup_done(struct nlookupdata *);
  157 void nlookup_done_at(struct nlookupdata *, struct file *);
  158 struct nchandle nlookup_simple(const char *str, enum uio_seg seg, 
  159                                 int niflags, int *error);
  160 int nlookup_mp(struct mount *mp, struct nchandle *nch);
  161 int nlookup(struct nlookupdata *);
  162 int nreadsymlink(struct nlookupdata *nd, struct nchandle *nch, 
  163                                 struct nlcomponent *nlc);
  164 int naccess_va(struct vattr *va, int nflags, struct ucred *cred);
  165 
  166 #endif
  167 
  168 #endif /* !_SYS_NAMEI_H_ */

Cache object: 5124e12f6052d46f3782511e69614bdb


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.