2008-04-09 09:00:57 +02:00
|
|
|
/** @file
|
|
|
|
|
|
|
|
Ipf platform related code to support FtwLite..
|
2007-06-27 16:52:40 +02:00
|
|
|
|
2008-04-09 09:00:57 +02:00
|
|
|
Copyright (c) 2006 - 2008, Intel Corporation
|
2007-06-27 16:52:40 +02:00
|
|
|
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.
|
|
|
|
|
2008-04-09 09:00:57 +02:00
|
|
|
**/
|
2007-06-27 16:52:40 +02:00
|
|
|
|
|
|
|
|
|
|
|
#include <FtwLite.h>
|
|
|
|
|
|
|
|
//
|
|
|
|
// MACROs for boot block update
|
|
|
|
//
|
|
|
|
#define BOOT_BLOCK_BASE
|
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
/**
|
|
|
|
|
|
|
|
Get swap state
|
|
|
|
This is a internal function.
|
|
|
|
|
|
|
|
@param FtwLiteDevice Calling context
|
|
|
|
@param SwapState Swap state
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS State successfully got
|
|
|
|
|
|
|
|
**/
|
2007-06-27 16:52:40 +02:00
|
|
|
EFI_STATUS
|
|
|
|
GetSwapState (
|
|
|
|
IN EFI_FTW_LITE_DEVICE *FtwLiteDevice,
|
|
|
|
OUT BOOLEAN *SwapState
|
|
|
|
)
|
2008-07-14 10:19:45 +02:00
|
|
|
{
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|
2007-06-27 16:52:40 +02:00
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
/**
|
|
|
|
Set swap state.
|
|
|
|
This is a internal function.
|
2007-06-27 16:52:40 +02:00
|
|
|
|
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
@param FtwLiteDevice Indicates a pointer to the calling context.
|
|
|
|
@param TopSwap New swap state
|
2007-06-27 16:52:40 +02:00
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
@retval EFI_SUCCESS The function completed successfully
|
|
|
|
Note:
|
|
|
|
the Top-Swap bit (bit 13, D31: F0, Offset D4h). Note that
|
|
|
|
software will not be able to clear the Top-Swap bit until the system is
|
|
|
|
rebooted without GNT[A]# being pulled down.
|
2007-06-27 16:52:40 +02:00
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
**/
|
2007-06-27 16:52:40 +02:00
|
|
|
EFI_STATUS
|
|
|
|
SetSwapState (
|
|
|
|
IN EFI_FTW_LITE_DEVICE *FtwLiteDevice,
|
|
|
|
IN BOOLEAN TopSwap
|
|
|
|
)
|
2008-07-14 10:19:45 +02:00
|
|
|
{
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|
2007-06-27 16:52:40 +02:00
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
/**
|
2007-06-27 16:52:40 +02:00
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
Check whether the block is a boot block.
|
2007-06-27 16:52:40 +02:00
|
|
|
|
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
@param FtwLiteDevice Calling context
|
|
|
|
@param FvBlock Fvb protocol instance
|
|
|
|
@param Lba Lba value
|
2007-06-27 16:52:40 +02:00
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
@retval FALSE This is a boot block.
|
|
|
|
@retval TRUE This is not a boot block.
|
2007-06-27 16:52:40 +02:00
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
**/
|
2007-06-27 16:52:40 +02:00
|
|
|
BOOLEAN
|
|
|
|
IsBootBlock (
|
|
|
|
EFI_FTW_LITE_DEVICE *FtwLiteDevice,
|
|
|
|
EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL *FvBlock,
|
|
|
|
EFI_LBA Lba
|
|
|
|
)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
// IPF doesn't support safe bootblock update
|
|
|
|
// so treat bootblock as normal block
|
|
|
|
//
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
/**
|
|
|
|
Copy the content of spare block to a boot block. Size is FTW_BLOCK_SIZE.
|
|
|
|
Spare block is accessed by FTW backup FVB protocol interface. LBA is
|
|
|
|
FtwLiteDevice->FtwSpareLba.
|
|
|
|
Boot block is accessed by BootFvb protocol interface. LBA is 0.
|
2007-06-27 16:52:40 +02:00
|
|
|
|
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
@param FtwLiteDevice The private data of FTW_LITE driver
|
2007-06-27 16:52:40 +02:00
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
@retval EFI_SUCCESS Spare block content is copied to boot block
|
|
|
|
@retval EFI_INVALID_PARAMETER Input parameter error
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Allocate memory error
|
|
|
|
@retval EFI_ABORTED The function could not complete successfully
|
|
|
|
Notes:
|
2007-06-27 16:52:40 +02:00
|
|
|
|
2008-07-14 10:19:45 +02:00
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
FlushSpareBlockToBootBlock (
|
|
|
|
EFI_FTW_LITE_DEVICE *FtwLiteDevice
|
|
|
|
)
|
2007-06-27 16:52:40 +02:00
|
|
|
{
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|