mirror of https://github.com/acidanthera/audk.git
EFI_FILE_PROTOCOL spec conformance bug fix.
1. Write() should return Unsupported instead of WriteProtected when operating above a directory in read-only media. 2. SetInfo() should return Unsupported instead of WriteProtected when operating above a directory using a undefined GUID in read-only media. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Ruiyu Ni <ruiyu.ni@intel.com> Reviewed-by: Eric Jin <eric.jin@intel.com> Reviewed-by: Feng Tian <feng.tian@intel.com> (based on FatPkg commit 8ff136aaa3fff82d81514fd3091961ec4a63c873) [jordan.l.justen@intel.com: Use script to relicense to 2-clause BSD] Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Jordan Justen <jordan.l.justen@intel.com> Acked-by: Mark Doran <mark.doran@intel.com> Acked-by: Laszlo Ersek <lersek@redhat.com>
This commit is contained in:
parent
2433260edf
commit
55248f85d1
|
@ -1,6 +1,6 @@
|
|||
/*++
|
||||
|
||||
Copyright (c) 2005 - 2013, Intel Corporation. All rights reserved.<BR>
|
||||
Copyright (c) 2005 - 2015, 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
|
||||
|
@ -528,20 +528,16 @@ Returns:
|
|||
//
|
||||
Status = EFI_UNSUPPORTED;
|
||||
if (IsSet) {
|
||||
if (Volume->ReadOnly) {
|
||||
Status = EFI_WRITE_PROTECTED;
|
||||
} else {
|
||||
if (CompareGuid (Type, &gEfiFileInfoGuid)) {
|
||||
Status = FatSetFileInfo (Volume, IFile, OFile, *BufferSize, Buffer);
|
||||
}
|
||||
if (CompareGuid (Type, &gEfiFileInfoGuid)) {
|
||||
Status = Volume->ReadOnly ? EFI_WRITE_PROTECTED : FatSetFileInfo (Volume, IFile, OFile, *BufferSize, Buffer);
|
||||
}
|
||||
|
||||
if (CompareGuid (Type, &gEfiFileSystemInfoGuid)) {
|
||||
Status = FatSetVolumeInfo (Volume, *BufferSize, Buffer);
|
||||
}
|
||||
if (CompareGuid (Type, &gEfiFileSystemInfoGuid)) {
|
||||
Status = Volume->ReadOnly ? EFI_WRITE_PROTECTED : FatSetVolumeInfo (Volume, *BufferSize, Buffer);
|
||||
}
|
||||
|
||||
if (CompareGuid (Type, &gEfiFileSystemVolumeLabelInfoIdGuid)) {
|
||||
Status = FatSetVolumeLabelInfo (Volume, *BufferSize, Buffer);
|
||||
}
|
||||
if (CompareGuid (Type, &gEfiFileSystemVolumeLabelInfoIdGuid)) {
|
||||
Status = Volume->ReadOnly ? EFI_WRITE_PROTECTED : FatSetVolumeLabelInfo (Volume, *BufferSize, Buffer);
|
||||
}
|
||||
} else {
|
||||
if (CompareGuid (Type, &gEfiFileInfoGuid)) {
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
/*++
|
||||
|
||||
Copyright (c) 2005 - 2013, Intel Corporation. All rights reserved.<BR>
|
||||
Copyright (c) 2005 - 2015, 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
|
||||
|
@ -250,6 +250,13 @@ Returns:
|
|||
Volume = OFile->Volume;
|
||||
Task = NULL;
|
||||
|
||||
//
|
||||
// Write to a directory is unsupported
|
||||
//
|
||||
if ((OFile->ODir != NULL) && (IoMode == WRITE_DATA)) {
|
||||
return EFI_UNSUPPORTED;
|
||||
}
|
||||
|
||||
if (OFile->Error == EFI_NOT_FOUND) {
|
||||
return EFI_DEVICE_ERROR;
|
||||
}
|
||||
|
@ -296,16 +303,10 @@ Returns:
|
|||
if (!EFI_ERROR (Status)) {
|
||||
if (OFile->ODir != NULL) {
|
||||
//
|
||||
// Access a directory
|
||||
// Read a directory is supported
|
||||
//
|
||||
Status = EFI_UNSUPPORTED;
|
||||
if (IoMode == READ_DATA) {
|
||||
//
|
||||
// Read a directory is supported
|
||||
//
|
||||
Status = FatIFileReadDir (IFile, BufferSize, Buffer);
|
||||
}
|
||||
|
||||
ASSERT (IoMode == READ_DATA);
|
||||
Status = FatIFileReadDir (IFile, BufferSize, Buffer);
|
||||
OFile = NULL;
|
||||
} else {
|
||||
//
|
||||
|
|
Loading…
Reference in New Issue