/** @file | |
Copyright (c) 2010 - 2014, Intel Corporation. All rights reserved.<BR> | |
This program and the accompanying materials are licensed and made | |
available under the terms and conditions of the BSD License that | |
accompanies this distribution. The full text of the license may be found at | |
http://opensource.org/licenses/bsd-license. | |
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | |
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |
Copyright (c) 1982, 1986, 1989, 1993 | |
The Regents of the University of California. All rights reserved. | |
(c) UNIX System Laboratories, Inc. | |
All or some portions of this file are derived from material licensed | |
to the University of California by American Telephone and Telegraph | |
Co. or Unix System Laboratories, Inc. and are reproduced herein with | |
the permission of UNIX System Laboratories, Inc. | |
Redistribution and use in source and binary forms, with or without | |
modification, are permitted provided that the following conditions | |
are met: | |
1. Redistributions of source code must retain the above copyright | |
notice, this list of conditions and the following disclaimer. | |
2. Redistributions in binary form must reproduce the above copyright | |
notice, this list of conditions and the following disclaimer in the | |
documentation and/or other materials provided with the distribution. | |
3. Neither the name of the University nor the names of its contributors | |
may be used to endorse or promote products derived from this software | |
without specific prior written permission. | |
THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND | |
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | |
ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE | |
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | |
OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | |
HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | |
LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | |
OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |
SUCH DAMAGE. | |
stat.h 8.12 (Berkeley) 8/17/94 | |
NetBSD: stat.h,v 1.54 2006/02/24 22:01:30 thorpej Exp | |
*/ | |
#ifndef _SYS_STAT_H_ | |
#define _SYS_STAT_H_ | |
#include <sys/featuretest.h> | |
#include <sys/types.h> | |
#include <sys/time.h> | |
struct stat { | |
off_t st_size; ///< file size, in bytes | |
off_t st_physsize; ///< physical space the file consumes | |
off_t st_curpos; ///< current position within the file, or XY coord. for Console | |
dtime_t st_birthtime; ///< time of creation | |
dtime_t st_atime; ///< time of last access | |
dtime_t st_mtime; ///< time of last data modification | |
mode_t st_mode; ///< file attributes | |
blksize_t st_blksize; ///< optimal blocksize for I/O | |
uint32_t st_spare[1]; | |
}; | |
#define S_ISUID 0004000 ///< set user id on execution | |
#define S_ISGID 0002000 ///< set group id on execution | |
#define S_ISTXT 0001000 ///< sticky bit | |
#define S_IRWXU 0000700 ///< RWX mask for owner | |
#define S_IRUSR 0000400 ///< R for owner | |
#define S_IWUSR 0000200 ///< W for owner | |
#define S_IXUSR 0000100 ///< X for owner | |
#define S_IREAD S_IRUSR | |
#define S_IWRITE S_IWUSR | |
#define S_IEXEC S_IXUSR | |
#define S_IRWXG 0000070 ///< RWX mask for group | |
#define S_IRGRP 0000040 ///< R for group | |
#define S_IWGRP 0000020 ///< W for group | |
#define S_IXGRP 0000010 ///< X for group | |
#define S_IRWXO 0000007 ///< RWX mask for other | |
#define S_IROTH 0000004 ///< R for other | |
#define S_IWOTH 0000002 ///< W for other | |
#define S_IXOTH 0000001 ///< X for other | |
/* The Octal access modes, above, fall into the Hex mask 0x00000FFF. | |
Traditionally, the remainder of the flags are specified in Octal | |
but they are expressed in Hex here for modern clarity. | |
The basic file types, specified within 0x0000F000, are mutually exclusive. | |
*/ | |
#define _S_IFMT 0x000FF000 ///< type-of-file mask | |
#define _S_IFIFO 0x00001000 ///< named pipe (fifo) | |
#define _S_IFCHR 0x00002000 ///< character special device | |
#define _S_IFDIR 0x00004000 ///< directory | |
#define _S_IFBLK 0x00006000 ///< block special device | |
#define _S_IFREG 0x00008000 ///< regular | |
#define _S_IFSOCK 0x0000C000 ///< socket | |
#define _S_ITTY 0x00010000 ///< File connects to a TTY device | |
#define _S_IWTTY 0x00020000 ///< TTY sends and receives Wide characters | |
#define _S_ICONSOLE 0x00030000 ///< UEFI Console Device | |
/* UEFI specific (FAT file system) File attributes. | |
Specified in Hexadecimal instead of Octal. | |
These bits correspond to the xx portion of _S_IFMT | |
*/ | |
#define S_IREADONLY 0x00100000 // Read Only File | |
#define S_IHIDDEN 0x00200000 // Hidden File | |
#define S_ISYSTEM 0x00400000 // System File | |
#define S_IDIRECTORY 0x01000000 // Directory | |
#define S_IARCHIVE 0x02000000 // Archive Bit | |
#define S_IROFS 0x08000000 ///< Read Only File System | |
#define S_EFIONLY 0xFFF00000 ///< Flags only used by the EFI system calls. | |
#define S_EFISHIFT 20 // LS bit of the UEFI attributes | |
#define S_IFMT _S_IFMT | |
#define S_IFIFO _S_IFIFO | |
#define S_IFCHR _S_IFCHR | |
#define S_IFDIR _S_IFDIR | |
#define S_IFBLK _S_IFBLK | |
#define S_IFREG _S_IFREG | |
#define S_IFSOCK _S_IFSOCK | |
#define S_ITTY _S_ITTY | |
#define S_IWTTY _S_IWTTY | |
#define S_ICONSOLE _S_ICONSOLE | |
#define S_ISFIFO(m) ((m & _S_IFMT) == _S_IFIFO) ///< fifo | |
#define S_ISCHR(m) ((m & _S_IFMT) == _S_IFCHR) ///< char special | |
#define S_ISDIR(m) ((m & _S_IFMT) == _S_IFDIR) ///< directory | |
#define S_ISBLK(m) ((m & _S_IFMT) == _S_IFBLK) ///< block special | |
#define S_ISREG(m) ((m & _S_IFMT) == _S_IFREG) ///< regular file | |
#define S_ISSOCK(m) ((m & _S_IFMT) == _S_IFSOCK) ///< socket | |
/* The following three macros have been changed to reflect | |
access permissions that better reflect the UEFI FAT file system. | |
UEFI only supports Read or Read+Write instead of the *nix | |
rwx paradigm. Thus, using 0777 is the closest analog. | |
*/ | |
#define ACCESSPERMS (S_IRWXU|S_IRWXG|S_IRWXO) ///< 0777 | |
#define ALLPERMS (S_IRWXU|S_IRWXG|S_IRWXO) ///< 0777 | |
#define DEFFILEMODE (S_IRWXU|S_IRWXG|S_IRWXO) ///< 0777 | |
#define READ_PERMS (S_IRUSR | S_IRGRP | S_IROTH) ///< 0444 | |
#define WRITE_PERMS (S_IWUSR | S_IWGRP | S_IWOTH) ///< 0222 | |
#define EXEC_PERMS (S_IXUSR | S_IXGRP | S_IXOTH) ///< 0111 | |
#define S_BLKSIZE 512 ///< block size used in the stat struct | |
/* | |
* Definitions of flags stored in file flags word. | |
* | |
* Super-user and owner changeable flags. | |
*/ | |
#define UF_SETTABLE 0x0000ffff ///< mask of owner changeable flags | |
#define UF_NODUMP 0x00000001 ///< do not dump file | |
#define UF_IMMUTABLE 0x00000002 ///< file may not be changed | |
#define UF_APPEND 0x00000004 ///< writes to file may only append | |
/* UF_NOUNLINK 0x00000010 [NOT IMPLEMENTED] */ | |
/* | |
* Super-user changeable flags. | |
*/ | |
#define SF_SETTABLE 0xffff0000 ///< mask of superuser changeable flags | |
#define SF_ARCHIVED 0x00010000 ///< file is archived | |
#define SF_IMMUTABLE 0x00020000 ///< file may not be changed | |
#define SF_APPEND 0x00040000 ///< writes to file may only append | |
/* SF_NOUNLINK 0x00100000 [NOT IMPLEMENTED] */ | |
#include <sys/EfiCdefs.h> | |
__BEGIN_DECLS | |
#ifndef __STAT_SYSCALLS_DECLARED | |
#define __STAT_SYSCALLS_DECLARED | |
/** | |
**/ | |
mode_t umask (mode_t); | |
/** | |
**/ | |
int mkdir (const char *, mode_t); | |
/** | |
**/ | |
int fstat (int, struct stat *); | |
/** | |
**/ | |
int lstat (const char *, struct stat *); | |
/** Obtains information about the file pointed to by path. | |
Opens the file pointed to by path, calls _EFI_FileInfo with the file's handle, | |
then closes the file. | |
@param[in] path Path to the file to obtain information about. | |
@param[out] statbuf Buffer in which the file status is put. | |
@retval 0 Successful Completion. | |
@retval -1 An error has occurred and errno has been set to | |
identify the error. | |
**/ | |
int stat (const char *, struct stat *); | |
/** | |
**/ | |
int chmod (const char *, mode_t); | |
#endif // __STAT_SYSCALLS_DECLARED | |
__END_DECLS | |
#endif /* !_SYS_STAT_H_ */ |