mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-10-26 23:37:20 +00:00 
			
		
		
		
	 0164fc8e76
			
		
	
	
		0164fc8e76
		
	
	
	
	
		
			
			StdLib\
  BsdSocketLib\
    ns_print.c
      Use "%lu" format instead of "%Lu".  A capital 'L' specifies (long double) in print formats.
      Add a cast from char to (unsigned int) to match its sprintf format.
    res_debug.c
      Use "%lu" format instead of "%Lu".  A capital 'L' specifies (long double) in print formats.
  EfiSocketLib\
    Socket.c
      Update copyright & correct formatting
  Include\
    sys\
      EfiCdefs.h
        Update copyright date
        Change type of LONGN and ULONGN to INTN and UINTN, respectively.
      errno.h
        Update copyright date
        Add enum member '__ESUCCESS = 0'
      fcntl.h
        Update copyright date
        Improve comment for O_EXCL
      stat.h
        Update copyright date
        Reorder the S_* flags
        Put the S_* predicate macros in the same order as their flag definitions
        Add a function header comment to the stat() function declaration.
    errno.h
      Update copyright date
      Define new ESUCCESS error code
    wchar.h
      Update copyright date
      Correct the description of the Nptr parameter to the wcstol, wcstoll, wcstoul, and wcstoull functions.
    x86\float.h
      Update copyright date
      Define 'long double' limits for non-Microsoft compilers
  LibC\
    Containers\Queues\Fifo.c
      Rewrite to make more robust and secure (zeros out old data)
    StdLib\realpath.c
      Update copyright date
      Reformat descriptive comment for realpath()
      Add terminating CRLF
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by:  daryl.mcdaniel@intel.com
Reviewed-by:  Erik Bjorge <erik.c.bjorge@intel.com>
Reviewed-by:  Jaben Carsey <Jaben.carsey@intel.com>
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16096 6f19259b-4bc3-4df7-8a09-765794883524
		
	
			
		
			
				
	
	
		
			201 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			201 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|     This file includes the definitions for open and fcntl described by POSIX
 | |
|     for <fcntl.h>; it also includes related kernel definitions.
 | |
| 
 | |
|     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 which
 | |
|     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) 1983, 1990, 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.
 | |
| 
 | |
|     fcntl.h 8.3 (Berkeley) 1/21/94
 | |
|     NetBSD: fcntl.h,v 1.34 2006/10/05 14:48:33 chs Exp
 | |
|  */
 | |
| #ifndef _SYS_FCNTL_H_
 | |
| #define _SYS_FCNTL_H_
 | |
| 
 | |
| #include <sys/featuretest.h>
 | |
| #include <sys/types.h>
 | |
| 
 | |
| #include <sys/stat.h>
 | |
| 
 | |
| /** @{
 | |
|     File status flags used by open(2), fcntl(2).
 | |
|     They are also used (indirectly) in the kernel file structure f_flags,
 | |
|     which is a superset of the open/fcntl flags.
 | |
|     Open/fcntl flags begin with O_; kernel-internal flags begin with F.
 | |
| **/
 | |
| /* open-only flags */
 | |
| #define O_RDONLY    0x00000000  ///< open for reading only
 | |
| #define O_WRONLY    0x00000001  ///< open for writing only
 | |
| #define O_RDWR      0x00000002  ///< open for reading and writing
 | |
| #define O_ACCMODE   0x00000003  ///< mask for above modes
 | |
| 
 | |
| #define O_NONBLOCK  0x00000004  ///< no delay
 | |
| #define O_APPEND    0x00000008  ///< set append mode
 | |
| #define O_CREAT     0x00000200  ///< create if nonexistent
 | |
| #define O_TRUNC     0x00000400  ///< truncate to zero length
 | |
| #define O_EXCL      0x00000800  ///< Grant EXCLusive access, or error if already exists and O_CREAT
 | |
| 
 | |
| #define O_DIRECTORY 0x00001000  ///< error if path is not a directory
 | |
| #define O_NOCTTY    0x00002000  ///< Don't make this the controlling TTY
 | |
| #define O_TTY_INIT  0x00004000  ///< Initialize TTY to "sane" values on open
 | |
| 
 | |
| /* UEFI-specific open-only flags. */
 | |
| #define O_HIDDEN    0x00010000  ///< Hidden file attribute
 | |
| #define O_SYSTEM    0x00020000  ///< System file attribute
 | |
| #define O_ARCHIVE   0x00040000  ///< Archive file attribute
 | |
| /// @}
 | |
| 
 | |
| #define O_SETMASK     0x0000000F  ///< Flags modifiable by F_SETFD (fcntl)
 | |
| 
 | |
| /*
 | |
|  * Constants used for fcntl(2)
 | |
|  */
 | |
| 
 | |
| /** @{ command values used for fcntl(2). **/
 | |
| #define F_DUPFD      0  ///< duplicate file descriptor
 | |
| #define F_GETFD      1  ///< get file descriptor flags
 | |
| #define F_SETFD      2  ///< set file descriptor flags
 | |
| #define F_GETFL      3  ///< get file status flags
 | |
| #define F_SETFL      4  ///< set file status flags
 | |
| #define F_GETOWN     5  ///< get SIGIO/SIGURG proc/pgrp
 | |
| #define F_SETOWN     6  ///< set SIGIO/SIGURG proc/pgrp
 | |
| #define F_GETLK      7  ///< get record locking information
 | |
| #define F_SETLK      8  ///< set record locking information
 | |
| #define F_SETLKW     9  ///< F_SETLK; wait if blocked
 | |
| #define F_CLOSEM    10  ///< close all fds >= to the one given
 | |
| #define F_MAXFD     11  ///< return the max open fd
 | |
| /// @}
 | |
| 
 | |
| /** file descriptor flags (F_GETFD, F_SETFD). **/
 | |
| #define FD_CLOEXEC  1   ///< close-on-exec flag
 | |
| 
 | |
| /** @{ record locking flags (F_GETLK, F_SETLK, F_SETLKW). **/
 | |
| #define F_RDLCK     1   ///< shared or read lock
 | |
| #define F_UNLCK     2   ///< unlock
 | |
| #define F_WRLCK     3   ///< exclusive or write lock
 | |
| /// @}
 | |
| 
 | |
| /** @{ Constants for fcntl's passed to the underlying fs - like ioctl's. **/
 | |
| #define F_PARAM_MASK    0xfff
 | |
| #define F_PARAM_LEN(x)  (((x) >> 16) & F_PARAM_MASK)
 | |
| #define F_PARAM_MAX     4095
 | |
| #define F_FSCTL         (int)0x80000000   ///< This fcntl goes to the fs
 | |
| #define F_FSVOID        (int)0x40000000   ///< no parameters
 | |
| #define F_FSOUT         (int)0x20000000   ///< copy out parameter
 | |
| #define F_FSIN          (int)0x10000000   ///< copy in parameter
 | |
| #define F_FSINOUT       (F_FSIN | F_FSOUT)
 | |
| #define F_FSDIRMASK     (int)0x70000000   ///< mask for IN/OUT/VOID
 | |
| #define F_FSPRIV        (int)0x00008000   ///< command is fs-specific
 | |
| /// @}
 | |
| 
 | |
| /* Always ensure that these are consistent with <stdio.h> and <unistd.h>! */
 | |
| #ifndef SEEK_SET
 | |
|   #define SEEK_SET  0 /* set file offset to offset */
 | |
| #endif
 | |
| #ifndef SEEK_CUR
 | |
|   #define SEEK_CUR  1 /* set file offset to current plus offset */
 | |
| #endif
 | |
| #ifndef SEEK_END
 | |
|   #define SEEK_END  2 /* set file offset to EOF plus offset */
 | |
| #endif
 | |
| 
 | |
| #include  <sys/EfiCdefs.h>
 | |
| 
 | |
| __BEGIN_DECLS
 | |
| #ifndef __FCNTL_SYSCALLS_DECLARED
 | |
|   #define __FCNTL_SYSCALLS_DECLARED
 | |
| 
 | |
|   /** The open() function establishes the connection between a file and a file
 | |
|       descriptor.  It creates an open file description that refers to a file
 | |
|       and a file descriptor that refers to that open file description. The file
 | |
|       descriptor is used by other I/O functions to refer to that file.
 | |
| 
 | |
|       The open() function returns a file descriptor for the named file that is
 | |
|       the lowest file descriptor not currently open for that process. The open
 | |
|       file description is new, and therefore the file descriptor shall not
 | |
|       share it with any other process in the system.
 | |
| 
 | |
|       The file offset used to mark the current position within the file is set
 | |
|       to the beginning of the file.
 | |
| 
 | |
|       The file status flags and file access modes of the open file description
 | |
|       are set according to the value of oflags.
 | |
| 
 | |
|       Values for oflags are constructed by a bitwise-inclusive OR of flags from
 | |
|       the following list, defined in <fcntl.h>. Applications shall specify
 | |
|       exactly one of { O_RDONLY, O_RDWR, O_WRONLY } in the value of oflags.
 | |
|       Any combination of { O_NONBLOCK, O_APPEND, O_CREAT, O_TRUNC, O_EXCL } may
 | |
|       also be specified in oflags.
 | |
| 
 | |
|       Values for mode specify the access permissions for newly created files.
 | |
| 
 | |
|       @param[in]    Path      The path argument points to a pathname naming the
 | |
|                               object to be opened.
 | |
|       @param[in]    oflags    File status flags and file access modes of the
 | |
|                               open file description.
 | |
|       @param[in]    mode      File access permission bits as defined in
 | |
|                               <sys/stat.h>.
 | |
| 
 | |
|       @return     Upon successful completion, open() opens the file and returns
 | |
|                   a non-negative integer representing the lowest numbered
 | |
|                   unused file descriptor. Otherwise, open returns -1 and sets
 | |
|                   errno to indicate the error. If a negative value is
 | |
|                   returned, no files are created or modified.
 | |
| 
 | |
|       @retval   EMFILE      No file descriptors available -- Max number already open.
 | |
|       @retval   EINVAL      Bad value specified for oflags or mode.
 | |
|       @retval   ENOMEM      Failure allocating memory for internal buffers.
 | |
|       @retval   EEXIST      File exists and open attempted with (O_EXCL | O_CREAT) set.
 | |
|       @retval   EIO         UEFI failure.  Check value in EFIerrno.
 | |
|   **/
 | |
|   int open(const char *Path, int oflags, int mode);
 | |
| 
 | |
|   /**
 | |
|   **/
 | |
|   int creat(const char *, mode_t);
 | |
| 
 | |
|   /**
 | |
|   **/
 | |
|   int fcntl(int, int, ...);
 | |
| #endif  // __FCNTL_SYSCALLS_DECLARED
 | |
| __END_DECLS
 | |
| 
 | |
| #endif /* !_SYS_FCNTL_H_ */
 |