2008-05-21 03:40:12 +02:00
|
|
|
/** @file
|
2008-04-09 09:07:50 +02:00
|
|
|
Implements get/set firmware volume attributes
|
2007-07-04 12:51:54 +02:00
|
|
|
|
2008-05-21 03:40:12 +02:00
|
|
|
Copyright (c) 2006 - 2008, Intel Corporation. <BR>
|
|
|
|
All rights reserved. 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.php
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
2007-07-04 12:51:54 +02:00
|
|
|
|
2008-04-09 09:07:50 +02:00
|
|
|
**/
|
2007-07-04 12:51:54 +02:00
|
|
|
|
2008-08-27 16:29:23 +02:00
|
|
|
#include "DxeMain.h"
|
2008-09-23 09:35:34 +02:00
|
|
|
#include "FwVolDriver.h"
|
2007-07-04 12:51:54 +02:00
|
|
|
|
2008-05-09 09:08:30 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
Retrieves attributes, insures positive polarity of attribute bits, returns
|
|
|
|
resulting attributes in output parameter.
|
|
|
|
|
2008-07-24 04:54:45 +02:00
|
|
|
@param This Calling context
|
|
|
|
@param Attributes output buffer which contains attributes
|
2008-05-09 09:08:30 +02:00
|
|
|
|
|
|
|
@retval EFI_SUCCESS Successfully got volume attributes
|
|
|
|
|
|
|
|
**/
|
2007-07-04 12:51:54 +02:00
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvGetVolumeAttributes (
|
2007-09-04 08:12:48 +02:00
|
|
|
IN CONST EFI_FIRMWARE_VOLUME2_PROTOCOL *This,
|
|
|
|
OUT EFI_FV_ATTRIBUTES *Attributes
|
2007-07-04 12:51:54 +02:00
|
|
|
)
|
|
|
|
{
|
|
|
|
EFI_STATUS Status;
|
|
|
|
FV_DEVICE *FvDevice;
|
|
|
|
EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL *Fvb;
|
2008-09-03 10:55:55 +02:00
|
|
|
EFI_FVB_ATTRIBUTES_2 FvbAttributes;
|
2007-07-04 12:51:54 +02:00
|
|
|
|
|
|
|
FvDevice = FV_DEVICE_FROM_THIS (This);
|
|
|
|
Fvb = FvDevice->Fvb;
|
|
|
|
|
|
|
|
if (FvDevice->CachedFv == NULL) {
|
|
|
|
Status = FvCheck (FvDevice);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
return Status;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// First get the Firmware Volume Block Attributes
|
|
|
|
//
|
|
|
|
Status = Fvb->GetAttributes (Fvb, &FvbAttributes);
|
|
|
|
|
|
|
|
//
|
2008-07-24 04:54:45 +02:00
|
|
|
// Mask out Fvb bits that are not defined in FV
|
2007-07-04 12:51:54 +02:00
|
|
|
//
|
|
|
|
FvbAttributes &= 0xfffff0ff;
|
2008-07-24 04:54:45 +02:00
|
|
|
|
|
|
|
*Attributes = (EFI_FV_ATTRIBUTES)FvbAttributes;
|
|
|
|
|
2007-07-04 12:51:54 +02:00
|
|
|
return Status;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-05-09 09:08:30 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets current attributes for volume
|
|
|
|
|
2008-07-24 04:54:45 +02:00
|
|
|
@param This Calling context
|
|
|
|
@param Attributes At input, contains attributes to be set. At output
|
|
|
|
contains new value of FV
|
2008-05-09 09:08:30 +02:00
|
|
|
|
|
|
|
@retval EFI_UNSUPPORTED Could not be set.
|
|
|
|
|
|
|
|
**/
|
2007-07-04 12:51:54 +02:00
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvSetVolumeAttributes (
|
2007-09-04 08:12:48 +02:00
|
|
|
IN CONST EFI_FIRMWARE_VOLUME2_PROTOCOL *This,
|
|
|
|
IN OUT EFI_FV_ATTRIBUTES *Attributes
|
2007-07-04 12:51:54 +02:00
|
|
|
)
|
2008-05-09 09:08:30 +02:00
|
|
|
{
|
|
|
|
return EFI_UNSUPPORTED;
|
|
|
|
}
|
2007-07-04 12:51:54 +02:00
|
|
|
|
|
|
|
|
2008-05-09 09:08:30 +02:00
|
|
|
/**
|
|
|
|
Return information of type InformationType for the requested firmware
|
|
|
|
volume.
|
2007-07-04 12:51:54 +02:00
|
|
|
|
2008-07-24 04:54:45 +02:00
|
|
|
@param This Pointer to EFI_FIRMWARE_VOLUME2_PROTOCOL.
|
|
|
|
@param InformationType InformationType for requested.
|
|
|
|
@param BufferSize On input, size of Buffer.On output, the amount of data
|
|
|
|
returned in Buffer.
|
|
|
|
@param Buffer A poniter to the data buffer to return.
|
2007-07-04 12:51:54 +02:00
|
|
|
|
2008-05-09 09:08:30 +02:00
|
|
|
@retval EFI_SUCCESS Successfully got volume Information.
|
2007-07-04 12:51:54 +02:00
|
|
|
|
2008-05-09 09:08:30 +02:00
|
|
|
**/
|
2007-09-04 08:12:48 +02:00
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvGetVolumeInfo (
|
|
|
|
IN CONST EFI_FIRMWARE_VOLUME2_PROTOCOL *This,
|
|
|
|
IN CONST EFI_GUID *InformationType,
|
|
|
|
IN OUT UINTN *BufferSize,
|
|
|
|
OUT VOID *Buffer
|
|
|
|
)
|
|
|
|
{
|
|
|
|
return EFI_UNSUPPORTED;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-05-09 09:08:30 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
Set information of type InformationType for the requested firmware
|
|
|
|
volume.
|
|
|
|
|
2008-07-24 04:54:45 +02:00
|
|
|
@param This Pointer to EFI_FIRMWARE_VOLUME2_PROTOCOL.
|
|
|
|
@param InformationType InformationType for requested.
|
|
|
|
@param BufferSize On input, size of Buffer.On output, the amount of data
|
|
|
|
returned in Buffer.
|
|
|
|
@param Buffer A poniter to the data buffer to return.
|
2008-05-09 09:08:30 +02:00
|
|
|
|
|
|
|
@retval EFI_SUCCESS Successfully set volume Information.
|
|
|
|
|
|
|
|
**/
|
2007-09-04 08:12:48 +02:00
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
FvSetVolumeInfo (
|
|
|
|
IN CONST EFI_FIRMWARE_VOLUME2_PROTOCOL *This,
|
|
|
|
IN CONST EFI_GUID *InformationType,
|
|
|
|
IN UINTN BufferSize,
|
|
|
|
IN CONST VOID *Buffer
|
|
|
|
)
|
|
|
|
{
|
|
|
|
return EFI_UNSUPPORTED;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-05-09 09:08:30 +02:00
|
|
|
|