StdLib: Add isDirSep character classification macro and function. Implement several Posix functions and clean up EfiSysCall.h. Align file mode handling with UEFI file protocol flags.
Include/ctype.h: Function declaration and Macro definition of isDirSep Include/unistd.h: Declarations added from EfiSysCall.h Include/utime.h: New file. For the Posix utime() function. Include/sys/_ctype.h: Update character class bit maps. Include/sys/EfiSysCall.h: Move declarations to unistd.h Include/sys/fcntl.h: Improve comments. Add UEFI-specific macros. Include/sys/filio.h: Remove declarations for unsupported file ioctls. Include/sys/stat.h: Fix flags. Add macros and declarations. Include/sys/time.h: Add declarations for new functions Tm2Efi() and Time2Efi(). Include/sys/types.h: Use EFI-specific instead of BSD-specific definitions for typedefs. Include/sys/unistd.h: Delete inappropriate content. Guard macro definitions. LibC/Locale/setlocale.c LibC/Stdio/{fdopen.c, findfp.c, fopen.c, freopen.c, gettemp.c, makebuf.c, mktemp.c, remove.c, stdio.c, tempnam.c, tmpfile.c, tmpnam.c} LibC/Time/{itimer.c, ZoneProc.c} LibC/Uefi/SysCalls.c LibC/Uefi/Devices/Console/daConsole.c LibC/Uefi/Devices/UefiShell/daShell.c PosixLib/Gen/readdir.c Include unistd.h instead of EfiSysCall.h LibC/Ctype/CClass.c: Character classification function implementation for isDirSep. LibC/Ctype/iCtype.c: Update character classification and case conversion tables. LibC/Time/TimeEfi.c: Improve comments. Implement new functions Tm2Efi() and Time2Efi(). LibC/Uefi/StubFunctions.c: Add missing include. Cosmetic changes to declarations. LibC/Uefi/SysCalls.c: Add support function for utime(). LibC/Uefi/Uefi.inf: Add LibGen library class dependency. LibC/Uefi/Xform.c: Enhance Omode2EFI(). LibC/Uefi/Devices/UefiShell/daShell.c: Enhance da_ShellMkdir. Implement da_ShellIoctl to set file times. PosixLib/Gen/access.c: New file. Implement the access() function. PosixLib/Gen/dirname.c: Enhance to use isDirSep and differentiate between the device, path, and filename components of UEFI Shell-style paths. PosixLib/Gen/utime.c: New file. Implement the utime() function. PosixLib/Gen/LibGen.inf: Change MODULE_TYPE. Add new files. Signed-off-by: darylm503 Reviewed-by: geekboy15a Reviewed-by: jljusten Reviewed-by: Rahul Khana Reviewed-by: leegrosenbaum git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@12800 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
@@ -57,8 +57,9 @@ Oflags2EFI( int oflags )
|
||||
return flags;
|
||||
}
|
||||
|
||||
/* Transform the permissions flags from the open() call into the
|
||||
Attributes bits needed by UEFI.
|
||||
/* Transform the permissions flags into their equivalent UEFI File Attribute bits.
|
||||
This transformation is most frequently used when translating attributes for use
|
||||
by the UEFI EFI_FILE_PROTOCOL.SetInfo() function.
|
||||
|
||||
The UEFI File attributes are:
|
||||
// ******************************************************
|
||||
@@ -72,27 +73,40 @@ Oflags2EFI( int oflags )
|
||||
#define EFI_FILE_ARCHIVE 0x0000000000000020
|
||||
#define EFI_FILE_VALID_ATTR 0x0000000000000037
|
||||
|
||||
The input permission flags consist of two groups:
|
||||
( S_IRUSR | S_IRGRP | S_IROTH ) -- S_ACC_READ
|
||||
( S_IWUSR | S_IWGRP | S_IWOTH ) -- S_ACC_WRITE
|
||||
|
||||
The only thing we can set, at this point, is whether or not
|
||||
this is a SYSTEM file. If the group and other bits are
|
||||
zero and the user bits are non-zero then set SYSTEM. Otherwise
|
||||
the attributes are zero.
|
||||
|
||||
The attributes can be set later using fcntl().
|
||||
The input permission flags consist of the following flags:
|
||||
O_RDONLY -- open for reading only
|
||||
O_WRONLY -- open for writing only
|
||||
O_RDWR -- open for reading and writing
|
||||
O_ACCMODE -- mask for above modes
|
||||
O_NONBLOCK -- no delay
|
||||
O_APPEND -- set append mode
|
||||
O_CREAT -- create if nonexistent
|
||||
O_TRUNC -- truncate to zero length
|
||||
O_EXCL -- error if already exists
|
||||
O_HIDDEN -- Hidden file attribute
|
||||
O_SYSTEM -- System file attribute
|
||||
O_ARCHIVE -- Archive file attribute
|
||||
*/
|
||||
UINT64
|
||||
Omode2EFI( int mode)
|
||||
{
|
||||
UINT64 flags = 0;
|
||||
|
||||
if((mode & (S_IRWXG | S_IRWXO)) == 0) {
|
||||
if((mode & S_IRWXU) != 0) {
|
||||
// Only user permissions so set system
|
||||
flags = EFI_FILE_SYSTEM;
|
||||
/* File is Read-Only. */
|
||||
if((mode & O_ACCMODE) == 0) {
|
||||
flags = EFI_FILE_READ_ONLY;
|
||||
}
|
||||
/* Set the Hidden attribute. */
|
||||
if((mode & O_HIDDEN) != 0) {
|
||||
flags |= EFI_FILE_HIDDEN;
|
||||
}
|
||||
/* Set the System attribute. */
|
||||
if((mode & O_SYSTEM) != 0) {
|
||||
flags |= EFI_FILE_SYSTEM;
|
||||
}
|
||||
/* Set the Archive attribute. */
|
||||
if((mode & O_ARCHIVE) != 0) {
|
||||
flags |= EFI_FILE_ARCHIVE;
|
||||
}
|
||||
return flags;
|
||||
}
|
||||
|
Reference in New Issue
Block a user