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/include/sys/stat.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 /* The <sys/stat.h> header defines a struct that is used in the stat() and
    2  * fstat functions.  The information in this struct comes from the i-node of
    3  * some file.  These calls are the only approved way to inspect i-nodes.
    4  */
    5 
    6 #ifndef _STAT_H
    7 #define _STAT_H
    8 
    9 #ifndef _TYPES_H
   10 #include <sys/types.h>
   11 #endif
   12 
   13 struct stat {
   14   dev_t st_dev;                 /* major/minor device number */
   15   ino_t st_ino;                 /* i-node number */
   16   mode_t st_mode;               /* file mode, protection bits, etc. */
   17   short int st_nlink;           /* # links; TEMPORARY HACK: should be nlink_t*/
   18   uid_t st_uid;                 /* uid of the file's owner */
   19   short int st_gid;             /* gid; TEMPORARY HACK: should be gid_t */
   20   dev_t st_rdev;
   21   off_t st_size;                /* file size */
   22   time_t st_atime;              /* time of last access */
   23   time_t st_mtime;              /* time of last data modification */
   24   time_t st_ctime;              /* time of last file status change */
   25 };
   26 
   27 /* Traditional mask definitions for st_mode. */
   28 /* The ugly casts on only some of the definitions are to avoid suprising sign
   29  * extensions such as S_IFREG != (mode_t) S_IFREG when ints are 32 bits.
   30  */
   31 #define S_IFMT  ((mode_t) 0170000)      /* type of file */
   32 #define S_IFLNK ((mode_t) 0120000)      /* symbolic link, not implemented */
   33 #define S_IFREG ((mode_t) 0100000)      /* regular */
   34 #define S_IFBLK 0060000         /* block special */
   35 #define S_IFDIR 0040000         /* directory */
   36 #define S_IFCHR 0020000         /* character special */
   37 #define S_IFIFO 0010000         /* this is a FIFO */
   38 #define S_ISUID 0004000         /* set user id on execution */
   39 #define S_ISGID 0002000         /* set group id on execution */
   40                                 /* next is reserved for future use */
   41 #define S_ISVTX   01000         /* save swapped text even after use */
   42 
   43 /* POSIX masks for st_mode. */
   44 #define S_IRWXU   00700         /* owner:  rwx------ */
   45 #define S_IRUSR   00400         /* owner:  r-------- */
   46 #define S_IWUSR   00200         /* owner:  -w------- */
   47 #define S_IXUSR   00100         /* owner:  --x------ */
   48 
   49 #define S_IRWXG   00070         /* group:  ---rwx--- */
   50 #define S_IRGRP   00040         /* group:  ---r----- */
   51 #define S_IWGRP   00020         /* group:  ----w---- */
   52 #define S_IXGRP   00010         /* group:  -----x--- */
   53 
   54 #define S_IRWXO   00007         /* others: ------rwx */
   55 #define S_IROTH   00004         /* others: ------r-- */ 
   56 #define S_IWOTH   00002         /* others: -------w- */
   57 #define S_IXOTH   00001         /* others: --------x */
   58 
   59 /* The following macros test st_mode (from POSIX Sec. 5.6.1.1). */
   60 #define S_ISREG(m)      (((m) & S_IFMT) == S_IFREG)     /* is a reg file */
   61 #define S_ISDIR(m)      (((m) & S_IFMT) == S_IFDIR)     /* is a directory */
   62 #define S_ISCHR(m)      (((m) & S_IFMT) == S_IFCHR)     /* is a char spec */
   63 #define S_ISBLK(m)      (((m) & S_IFMT) == S_IFBLK)     /* is a block spec */
   64 #define S_ISFIFO(m)     (((m) & S_IFMT) == S_IFIFO)     /* is a pipe/FIFO */
   65 #define S_ISLNK(m)      (((m) & S_IFMT) == S_IFLNK)     /* is a sym link */
   66 
   67 /* Function Prototypes. */
   68 _PROTOTYPE( int chmod, (const char *_path, _mnx_Mode_t _mode)           );
   69 _PROTOTYPE( int fstat, (int _fildes, struct stat *_buf)                 );
   70 _PROTOTYPE( int mkdir, (const char *_path, _mnx_Mode_t _mode)           );
   71 _PROTOTYPE( int mkfifo, (const char *_path, _mnx_Mode_t _mode)          );
   72 _PROTOTYPE( int stat, (const char *_path, struct stat *_buf)            );
   73 _PROTOTYPE( mode_t umask, (_mnx_Mode_t _cmask)                          );
   74 
   75 /* Open Group Base Specifications Issue 6 (not complete) */
   76 _PROTOTYPE( int lstat, (const char *_path, struct stat *_buf)           );
   77 
   78 #endif /* _STAT_H */

Cache object: b33c51c104736be8c977a183db61e052


[ 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.