Changes for V4 ============== 1) Move delete of QuarkSocPkg\QuarkNorthCluster\Binary\QuarkMicrocode from QuarkPlatformPkg commit to QuarkSocPkg commit 2) Fix incorrect license header in PlatformSecLibModStrs.uni Changes for V3 ============== 1) Set PcdResetOnMemoryTypeInformationChange FALSE in QuarkMin.dsc This is required because QuarkMin.dsc uses the emulated variable driver that does not preserve any non-volatile UEFI variables across reset. If the condition is met where the memory type information variable needs to be updated, then the system will reset every time the UEFI Shell is run. By setting this PCD to FALSE, then reset action is disabled. 2) Move one binary file to QuarkSocBinPkg 3) Change RMU.bin FILE statements to INF statement in DSC FD region to be compatible with PACKAGES_PATH search for QuarkSocBinPkg Changes for V2 ============== 1) Use new generic PCI serial driver PciSioSerialDxe in MdeModulePkg 2) Configure PcdPciSerialParameters for PCI serial driver for Quark 3) Use new MtrrLib API to reduce time to set MTRRs for all DRAM 4) Convert all UNI files to utf-8 5) Replace tabs with spaces and remove trailing spaces 6) Add License.txt Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Michael Kinney <michael.d.kinney@intel.com> Acked-by: Jordan Justen <jordan.l.justen@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@19287 6f19259b-4bc3-4df7-8a09-765794883524
733 lines
22 KiB
C
733 lines
22 KiB
C
/** @file
|
|
Implementation of helper routines for DXE environment.
|
|
|
|
Copyright (c) 2013 Intel Corporation.
|
|
|
|
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.
|
|
|
|
**/
|
|
|
|
#include <PiDxe.h>
|
|
|
|
#include <Library/UefiBootServicesTableLib.h>
|
|
#include <Library/S3BootScriptLib.h>
|
|
#include <Library/DxeServicesLib.h>
|
|
#include <Library/UefiRuntimeServicesTableLib.h>
|
|
#include <Library/I2cLib.h>
|
|
#include <Protocol/SmmBase2.h>
|
|
#include <Protocol/Spi.h>
|
|
#include <Protocol/VariableLock.h>
|
|
|
|
#include <Guid/MemoryConfigData.h>
|
|
#include <Guid/QuarkVariableLock.h>
|
|
|
|
#include "CommonHeader.h"
|
|
|
|
#define FLASH_BLOCK_SIZE SIZE_4KB
|
|
|
|
//
|
|
// Global variables.
|
|
//
|
|
EFI_SPI_PROTOCOL *mPlatHelpSpiProtocolRef = NULL;
|
|
|
|
//
|
|
// Routines defined in other source modules of this component.
|
|
//
|
|
|
|
//
|
|
// Routines local to this component.
|
|
//
|
|
|
|
//
|
|
// Routines shared with other souce modules in this component.
|
|
//
|
|
|
|
BOOLEAN
|
|
Pcal9555GetPortRegBit (
|
|
IN CONST UINT32 Pcal9555SlaveAddr,
|
|
IN CONST UINT32 GpioNum,
|
|
IN CONST UINT8 RegBase
|
|
)
|
|
{
|
|
EFI_STATUS Status;
|
|
UINTN ReadLength;
|
|
UINTN WriteLength;
|
|
UINT8 Data[2];
|
|
EFI_I2C_DEVICE_ADDRESS I2cDeviceAddr;
|
|
EFI_I2C_ADDR_MODE I2cAddrMode;
|
|
UINT8 *RegValuePtr;
|
|
UINT8 GpioNumMask;
|
|
UINT8 SubAddr;
|
|
|
|
I2cDeviceAddr.I2CDeviceAddress = (UINTN) Pcal9555SlaveAddr;
|
|
I2cAddrMode = EfiI2CSevenBitAddrMode;
|
|
|
|
if (GpioNum < 8) {
|
|
SubAddr = RegBase;
|
|
GpioNumMask = (UINT8) (1 << GpioNum);
|
|
} else {
|
|
SubAddr = RegBase + 1;
|
|
GpioNumMask = (UINT8) (1 << (GpioNum - 8));
|
|
}
|
|
|
|
//
|
|
// Output port value always at 2nd byte in Data variable.
|
|
//
|
|
RegValuePtr = &Data[1];
|
|
|
|
//
|
|
// On read entry sub address at 2nd byte, on read exit output
|
|
// port value in 2nd byte.
|
|
//
|
|
Data[1] = SubAddr;
|
|
WriteLength = 1;
|
|
ReadLength = 1;
|
|
Status = I2cReadMultipleByte (
|
|
I2cDeviceAddr,
|
|
I2cAddrMode,
|
|
&WriteLength,
|
|
&ReadLength,
|
|
&Data[1]
|
|
);
|
|
ASSERT_EFI_ERROR (Status);
|
|
|
|
//
|
|
// Adjust output port bit given callers request.
|
|
//
|
|
return ((*RegValuePtr & GpioNumMask) != 0);
|
|
}
|
|
|
|
VOID
|
|
Pcal9555SetPortRegBit (
|
|
IN CONST UINT32 Pcal9555SlaveAddr,
|
|
IN CONST UINT32 GpioNum,
|
|
IN CONST UINT8 RegBase,
|
|
IN CONST BOOLEAN LogicOne
|
|
)
|
|
{
|
|
EFI_STATUS Status;
|
|
UINTN ReadLength;
|
|
UINTN WriteLength;
|
|
UINT8 Data[2];
|
|
EFI_I2C_DEVICE_ADDRESS I2cDeviceAddr;
|
|
EFI_I2C_ADDR_MODE I2cAddrMode;
|
|
UINT8 *RegValuePtr;
|
|
UINT8 GpioNumMask;
|
|
UINT8 SubAddr;
|
|
|
|
I2cDeviceAddr.I2CDeviceAddress = (UINTN) Pcal9555SlaveAddr;
|
|
I2cAddrMode = EfiI2CSevenBitAddrMode;
|
|
|
|
if (GpioNum < 8) {
|
|
SubAddr = RegBase;
|
|
GpioNumMask = (UINT8) (1 << GpioNum);
|
|
} else {
|
|
SubAddr = RegBase + 1;
|
|
GpioNumMask = (UINT8) (1 << (GpioNum - 8));
|
|
}
|
|
|
|
//
|
|
// Output port value always at 2nd byte in Data variable.
|
|
//
|
|
RegValuePtr = &Data[1];
|
|
|
|
//
|
|
// On read entry sub address at 2nd byte, on read exit output
|
|
// port value in 2nd byte.
|
|
//
|
|
Data[1] = SubAddr;
|
|
WriteLength = 1;
|
|
ReadLength = 1;
|
|
Status = I2cReadMultipleByte (
|
|
I2cDeviceAddr,
|
|
I2cAddrMode,
|
|
&WriteLength,
|
|
&ReadLength,
|
|
&Data[1]
|
|
);
|
|
ASSERT_EFI_ERROR (Status);
|
|
|
|
//
|
|
// Adjust output port bit given callers request.
|
|
//
|
|
if (LogicOne) {
|
|
*RegValuePtr = *RegValuePtr | GpioNumMask;
|
|
} else {
|
|
*RegValuePtr = *RegValuePtr & ~(GpioNumMask);
|
|
}
|
|
|
|
//
|
|
// Update register. Sub address at 1st byte, value at 2nd byte.
|
|
//
|
|
WriteLength = 2;
|
|
Data[0] = SubAddr;
|
|
Status = I2cWriteMultipleByte (
|
|
I2cDeviceAddr,
|
|
I2cAddrMode,
|
|
&WriteLength,
|
|
Data
|
|
);
|
|
ASSERT_EFI_ERROR (Status);
|
|
}
|
|
|
|
|
|
EFI_SPI_PROTOCOL *
|
|
LocateSpiProtocol (
|
|
IN EFI_SMM_SYSTEM_TABLE2 *Smst
|
|
)
|
|
{
|
|
if (mPlatHelpSpiProtocolRef == NULL) {
|
|
if (Smst != NULL) {
|
|
Smst->SmmLocateProtocol (
|
|
&gEfiSmmSpiProtocolGuid,
|
|
NULL,
|
|
(VOID **) &mPlatHelpSpiProtocolRef
|
|
);
|
|
} else {
|
|
gBS->LocateProtocol (
|
|
&gEfiSpiProtocolGuid,
|
|
NULL,
|
|
(VOID **) &mPlatHelpSpiProtocolRef
|
|
);
|
|
}
|
|
ASSERT (mPlatHelpSpiProtocolRef != NULL);
|
|
}
|
|
return mPlatHelpSpiProtocolRef;
|
|
}
|
|
|
|
//
|
|
// Routines exported by this source module.
|
|
//
|
|
|
|
/**
|
|
Find pointer to RAW data in Firmware volume file.
|
|
|
|
@param FvNameGuid Firmware volume to search. If == NULL search all.
|
|
@param FileNameGuid Firmware volume file to search for.
|
|
@param SectionData Pointer to RAW data section of found file.
|
|
@param SectionDataSize Pointer to UNITN to get size of RAW data.
|
|
|
|
@retval EFI_SUCCESS Raw Data found.
|
|
@retval EFI_INVALID_PARAMETER FileNameGuid == NULL.
|
|
@retval EFI_NOT_FOUND Firmware volume file not found.
|
|
@retval EFI_UNSUPPORTED Unsupported in current enviroment (PEI or DXE).
|
|
|
|
**/
|
|
EFI_STATUS
|
|
EFIAPI
|
|
PlatformFindFvFileRawDataSection (
|
|
IN CONST EFI_GUID *FvNameGuid OPTIONAL,
|
|
IN CONST EFI_GUID *FileNameGuid,
|
|
OUT VOID **SectionData,
|
|
OUT UINTN *SectionDataSize
|
|
)
|
|
{
|
|
if (FileNameGuid == NULL || SectionData == NULL || SectionDataSize == NULL) {
|
|
return EFI_INVALID_PARAMETER;
|
|
}
|
|
if (FvNameGuid != NULL) {
|
|
return EFI_UNSUPPORTED; // Searching in specific FV unsupported in DXE.
|
|
}
|
|
|
|
return GetSectionFromAnyFv (FileNameGuid, EFI_SECTION_RAW, 0, SectionData, SectionDataSize);
|
|
}
|
|
|
|
/**
|
|
Find free spi protect register and write to it to protect a flash region.
|
|
|
|
@param DirectValue Value to directly write to register.
|
|
if DirectValue == 0 the use Base & Length below.
|
|
@param BaseAddress Base address of region in Flash Memory Map.
|
|
@param Length Length of region to protect.
|
|
|
|
@retval EFI_SUCCESS Free spi protect register found & written.
|
|
@retval EFI_NOT_FOUND Free Spi protect register not found.
|
|
@retval EFI_DEVICE_ERROR Unable to write to spi protect register.
|
|
**/
|
|
EFI_STATUS
|
|
EFIAPI
|
|
PlatformWriteFirstFreeSpiProtect (
|
|
IN CONST UINT32 DirectValue,
|
|
IN CONST UINT32 BaseAddress,
|
|
IN CONST UINT32 Length
|
|
)
|
|
{
|
|
UINT32 FreeOffset;
|
|
UINT32 PchRootComplexBar;
|
|
EFI_STATUS Status;
|
|
|
|
PchRootComplexBar = QNC_RCRB_BASE;
|
|
|
|
Status = WriteFirstFreeSpiProtect (
|
|
PchRootComplexBar,
|
|
DirectValue,
|
|
BaseAddress,
|
|
Length,
|
|
&FreeOffset
|
|
);
|
|
|
|
if (!EFI_ERROR (Status)) {
|
|
S3BootScriptSaveMemWrite (
|
|
S3BootScriptWidthUint32,
|
|
(UINTN) (PchRootComplexBar + FreeOffset),
|
|
1,
|
|
(VOID *) (UINTN) (PchRootComplexBar + FreeOffset)
|
|
);
|
|
}
|
|
|
|
return Status;
|
|
}
|
|
|
|
/**
|
|
Lock legacy SPI static configuration information.
|
|
|
|
Function will assert if unable to lock config.
|
|
|
|
**/
|
|
VOID
|
|
EFIAPI
|
|
PlatformFlashLockConfig (
|
|
VOID
|
|
)
|
|
{
|
|
EFI_STATUS Status;
|
|
EFI_SPI_PROTOCOL *SpiProtocol;
|
|
|
|
//
|
|
// Enable lock of legacy SPI static configuration information.
|
|
//
|
|
|
|
SpiProtocol = LocateSpiProtocol (NULL); // This routine will not be called in SMM.
|
|
ASSERT_EFI_ERROR (SpiProtocol != NULL);
|
|
if (SpiProtocol != NULL) {
|
|
Status = SpiProtocol->Lock (SpiProtocol);
|
|
|
|
if (!EFI_ERROR (Status)) {
|
|
DEBUG ((EFI_D_INFO, "Platform: Spi Config Locked Down\n"));
|
|
} else if (Status == EFI_ACCESS_DENIED) {
|
|
DEBUG ((EFI_D_INFO, "Platform: Spi Config already locked down\n"));
|
|
} else {
|
|
ASSERT_EFI_ERROR (Status);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
Platform Variable Lock.
|
|
|
|
@retval EFI_SUCCESS Platform Variable Lock successful.
|
|
@retval EFI_NOT_FOUND No protocol instances were found that match Protocol and
|
|
Registration.
|
|
|
|
**/
|
|
VOID
|
|
EFIAPI
|
|
PlatformVariableLock (
|
|
)
|
|
{
|
|
EFI_STATUS Status;
|
|
EDKII_VARIABLE_LOCK_PROTOCOL *VariableLockProtocol;
|
|
|
|
Status = gBS->LocateProtocol (&gEdkiiVariableLockProtocolGuid, NULL, (VOID **)&VariableLockProtocol);
|
|
ASSERT_EFI_ERROR (Status);
|
|
|
|
Status = VariableLockProtocol->RequestToLock (
|
|
VariableLockProtocol,
|
|
QUARK_VARIABLE_LOCK_NAME,
|
|
&gQuarkVariableLockGuid
|
|
);
|
|
ASSERT_EFI_ERROR (Status);
|
|
|
|
// Memory Config Data shouldn't be writable when Quark Variable Lock is enabled.
|
|
Status = VariableLockProtocol->RequestToLock (
|
|
VariableLockProtocol,
|
|
EFI_MEMORY_CONFIG_DATA_NAME,
|
|
&gEfiMemoryConfigDataGuid
|
|
);
|
|
ASSERT_EFI_ERROR (Status);
|
|
}
|
|
|
|
/**
|
|
Lock regions and config of SPI flash given the policy for this platform.
|
|
|
|
Function will assert if unable to lock regions or config.
|
|
|
|
@param PreBootPolicy If TRUE do Pre Boot Flash Lock Policy.
|
|
|
|
**/
|
|
VOID
|
|
EFIAPI
|
|
PlatformFlashLockPolicy (
|
|
IN CONST BOOLEAN PreBootPolicy
|
|
)
|
|
{
|
|
EFI_STATUS Status;
|
|
UINT64 CpuAddressNvStorage;
|
|
UINT64 CpuAddressFlashDevice;
|
|
UINT64 SpiAddress;
|
|
EFI_BOOT_MODE BootMode;
|
|
UINTN SpiFlashDeviceSize;
|
|
|
|
BootMode = GetBootModeHob ();
|
|
|
|
SpiFlashDeviceSize = (UINTN) PcdGet32 (PcdSpiFlashDeviceSize);
|
|
CpuAddressFlashDevice = SIZE_4GB - SpiFlashDeviceSize;
|
|
DEBUG (
|
|
(EFI_D_INFO,
|
|
"Platform:FlashDeviceSize = 0x%08x Bytes\n",
|
|
SpiFlashDeviceSize)
|
|
);
|
|
|
|
//
|
|
// If not in update or recovery mode, lock stuff down
|
|
//
|
|
if ((BootMode != BOOT_IN_RECOVERY_MODE) && (BootMode != BOOT_ON_FLASH_UPDATE)) {
|
|
|
|
//
|
|
// Lock regions
|
|
//
|
|
CpuAddressNvStorage = (UINT64) PcdGet32 (PcdFlashNvStorageVariableBase);
|
|
|
|
//
|
|
// Lock from start of flash device up to Smi writable flash storage areas.
|
|
//
|
|
SpiAddress = 0;
|
|
if (!PlatformIsSpiRangeProtected ((UINT32) SpiAddress, (UINT32) (CpuAddressNvStorage - CpuAddressFlashDevice))) {
|
|
DEBUG (
|
|
(EFI_D_INFO,
|
|
"Platform: Protect Region Base:Len 0x%08x:0x%08x\n",
|
|
(UINTN) SpiAddress, (UINTN)(CpuAddressNvStorage - CpuAddressFlashDevice))
|
|
);
|
|
Status = PlatformWriteFirstFreeSpiProtect (
|
|
0,
|
|
(UINT32) SpiAddress,
|
|
(UINT32) (CpuAddressNvStorage - CpuAddressFlashDevice)
|
|
);
|
|
|
|
ASSERT_EFI_ERROR (Status);
|
|
}
|
|
//
|
|
// Move Spi Address to after Smi writable flash storage areas.
|
|
//
|
|
SpiAddress = CpuAddressNvStorage - CpuAddressFlashDevice;
|
|
SpiAddress += ((UINT64) PcdGet32 (PcdFlashNvStorageVariableSize));
|
|
|
|
//
|
|
// Lock from end of OEM area to end of flash part.
|
|
//
|
|
if (!PlatformIsSpiRangeProtected ((UINT32) SpiAddress, SpiFlashDeviceSize - ((UINT32) SpiAddress))) {
|
|
DEBUG (
|
|
(EFI_D_INFO,
|
|
"Platform: Protect Region Base:Len 0x%08x:0x%08x\n",
|
|
(UINTN) SpiAddress,
|
|
(UINTN) (SpiFlashDeviceSize - ((UINT32) SpiAddress)))
|
|
);
|
|
ASSERT (SpiAddress < ((UINT64) SpiFlashDeviceSize));
|
|
Status = PlatformWriteFirstFreeSpiProtect (
|
|
0,
|
|
(UINT32) SpiAddress,
|
|
SpiFlashDeviceSize - ((UINT32) SpiAddress)
|
|
);
|
|
|
|
ASSERT_EFI_ERROR (Status);
|
|
}
|
|
}
|
|
|
|
//
|
|
// Always Lock flash config registers if about to boot a boot option
|
|
// else lock depending on boot mode.
|
|
//
|
|
if (PreBootPolicy || (BootMode != BOOT_ON_FLASH_UPDATE)) {
|
|
PlatformFlashLockConfig ();
|
|
}
|
|
|
|
//
|
|
// Enable Quark Variable lock if PreBootPolicy.
|
|
//
|
|
if (PreBootPolicy) {
|
|
PlatformVariableLock ();
|
|
}
|
|
}
|
|
|
|
/**
|
|
Erase and Write to platform flash.
|
|
|
|
Routine accesses one flash block at a time, each access consists
|
|
of an erase followed by a write of FLASH_BLOCK_SIZE. One or both
|
|
of DoErase & DoWrite params must be TRUE.
|
|
|
|
Limitations:-
|
|
CpuWriteAddress must be aligned to FLASH_BLOCK_SIZE.
|
|
DataSize must be a multiple of FLASH_BLOCK_SIZE.
|
|
|
|
@param Smst If != NULL then InSmm and use to locate
|
|
SpiProtocol.
|
|
@param CpuWriteAddress Address in CPU memory map of flash region.
|
|
@param Data The buffer containing the data to be written.
|
|
@param DataSize Amount of data to write.
|
|
@param DoErase Earse each block.
|
|
@param DoWrite Write to each block.
|
|
|
|
@retval EFI_SUCCESS Operation successful.
|
|
@retval EFI_NOT_READY Required resources not setup.
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
@retval Others Unexpected error happened.
|
|
|
|
**/
|
|
EFI_STATUS
|
|
EFIAPI
|
|
PlatformFlashEraseWrite (
|
|
IN VOID *Smst,
|
|
IN UINTN CpuWriteAddress,
|
|
IN UINT8 *Data,
|
|
IN UINTN DataSize,
|
|
IN BOOLEAN DoErase,
|
|
IN BOOLEAN DoWrite
|
|
)
|
|
{
|
|
EFI_STATUS Status;
|
|
UINT64 CpuBaseAddress;
|
|
SPI_INIT_INFO *SpiInfo;
|
|
UINT8 *WriteBuf;
|
|
UINTN Index;
|
|
UINTN SpiWriteAddress;
|
|
EFI_SPI_PROTOCOL *SpiProtocol;
|
|
|
|
if (!DoErase && !DoWrite) {
|
|
return EFI_INVALID_PARAMETER;
|
|
}
|
|
if (DoWrite && Data == NULL) {
|
|
return EFI_INVALID_PARAMETER;
|
|
}
|
|
if ((CpuWriteAddress % FLASH_BLOCK_SIZE) != 0) {
|
|
return EFI_INVALID_PARAMETER;
|
|
}
|
|
if ((DataSize % FLASH_BLOCK_SIZE) != 0) {
|
|
return EFI_INVALID_PARAMETER;
|
|
}
|
|
SpiProtocol = LocateSpiProtocol ((EFI_SMM_SYSTEM_TABLE2 *)Smst);
|
|
if (SpiProtocol == NULL) {
|
|
return EFI_NOT_READY;
|
|
}
|
|
|
|
//
|
|
// Find info to allow usage of SpiProtocol->Execute.
|
|
//
|
|
Status = SpiProtocol->Info (
|
|
SpiProtocol,
|
|
&SpiInfo
|
|
);
|
|
if (EFI_ERROR(Status)) {
|
|
return Status;
|
|
}
|
|
ASSERT (SpiInfo->InitTable != NULL);
|
|
ASSERT (SpiInfo->EraseOpcodeIndex < SPI_NUM_OPCODE);
|
|
ASSERT (SpiInfo->ProgramOpcodeIndex < SPI_NUM_OPCODE);
|
|
|
|
CpuBaseAddress = PcdGet32 (PcdFlashAreaBaseAddress) - (UINT32)SpiInfo->InitTable->BiosStartOffset;
|
|
ASSERT(CpuBaseAddress >= (SIZE_4GB - SIZE_8MB));
|
|
if (CpuWriteAddress < CpuBaseAddress) {
|
|
return (EFI_INVALID_PARAMETER);
|
|
}
|
|
|
|
SpiWriteAddress = CpuWriteAddress - ((UINTN) CpuBaseAddress);
|
|
WriteBuf = Data;
|
|
DEBUG (
|
|
(EFI_D_INFO, "PlatformFlashWrite:SpiWriteAddress=%08x EraseIndex=%d WriteIndex=%d\n",
|
|
SpiWriteAddress,
|
|
(UINTN) SpiInfo->EraseOpcodeIndex,
|
|
(UINTN) SpiInfo->ProgramOpcodeIndex
|
|
));
|
|
for (Index =0; Index < DataSize / FLASH_BLOCK_SIZE; Index++) {
|
|
if (DoErase) {
|
|
DEBUG (
|
|
(EFI_D_INFO, "PlatformFlashWrite:Erase[%04x] SpiWriteAddress=%08x\n",
|
|
Index,
|
|
SpiWriteAddress
|
|
));
|
|
Status = SpiProtocol->Execute (
|
|
SpiProtocol,
|
|
SpiInfo->EraseOpcodeIndex,// OpcodeIndex
|
|
0, // PrefixOpcodeIndex
|
|
FALSE, // DataCycle
|
|
TRUE, // Atomic
|
|
FALSE, // ShiftOut
|
|
SpiWriteAddress, // Address
|
|
0, // Data Number
|
|
NULL,
|
|
EnumSpiRegionAll // SPI_REGION_TYPE
|
|
);
|
|
if (EFI_ERROR(Status)) {
|
|
return Status;
|
|
}
|
|
}
|
|
|
|
if (DoWrite) {
|
|
DEBUG (
|
|
(EFI_D_INFO, "PlatformFlashWrite:Write[%04x] SpiWriteAddress=%08x\n",
|
|
Index,
|
|
SpiWriteAddress
|
|
));
|
|
Status = SpiProtocol->Execute (
|
|
SpiProtocol,
|
|
SpiInfo->ProgramOpcodeIndex, // OpcodeIndex
|
|
0, // PrefixOpcodeIndex
|
|
TRUE, // DataCycle
|
|
TRUE, // Atomic
|
|
TRUE, // ShiftOut
|
|
SpiWriteAddress, // Address
|
|
FLASH_BLOCK_SIZE, // Data Number
|
|
WriteBuf,
|
|
EnumSpiRegionAll
|
|
);
|
|
if (EFI_ERROR(Status)) {
|
|
return Status;
|
|
}
|
|
WriteBuf+=FLASH_BLOCK_SIZE;
|
|
}
|
|
SpiWriteAddress+=FLASH_BLOCK_SIZE;
|
|
}
|
|
return EFI_SUCCESS;
|
|
}
|
|
|
|
/** Check if System booted with recovery Boot Stage1 image.
|
|
|
|
@retval TRUE If system booted with recovery Boot Stage1 image.
|
|
@retval FALSE If system booted with normal stage1 image.
|
|
|
|
**/
|
|
BOOLEAN
|
|
EFIAPI
|
|
PlatformIsBootWithRecoveryStage1 (
|
|
VOID
|
|
)
|
|
{
|
|
ASSERT_EFI_ERROR (EFI_UNSUPPORTED);
|
|
return FALSE;
|
|
}
|
|
|
|
/**
|
|
Set the direction of Pcal9555 IO Expander GPIO pin.
|
|
|
|
@param Pcal9555SlaveAddr I2c Slave address of Pcal9555 Io Expander.
|
|
@param GpioNum Gpio direction to configure - values 0-7 for Port0
|
|
and 8-15 for Port1.
|
|
@param CfgAsInput If TRUE set pin direction as input else set as output.
|
|
|
|
**/
|
|
VOID
|
|
EFIAPI
|
|
PlatformPcal9555GpioSetDir (
|
|
IN CONST UINT32 Pcal9555SlaveAddr,
|
|
IN CONST UINT32 GpioNum,
|
|
IN CONST BOOLEAN CfgAsInput
|
|
)
|
|
{
|
|
Pcal9555SetPortRegBit (
|
|
Pcal9555SlaveAddr,
|
|
GpioNum,
|
|
PCAL9555_REG_CFG_PORT0,
|
|
CfgAsInput
|
|
);
|
|
}
|
|
|
|
/**
|
|
Set the level of Pcal9555 IO Expander GPIO high or low.
|
|
|
|
@param Pcal9555SlaveAddr I2c Slave address of Pcal9555 Io Expander.
|
|
@param GpioNum Gpio to change values 0-7 for Port0 and 8-15
|
|
for Port1.
|
|
@param HighLevel If TRUE set pin high else set pin low.
|
|
|
|
**/
|
|
VOID
|
|
EFIAPI
|
|
PlatformPcal9555GpioSetLevel (
|
|
IN CONST UINT32 Pcal9555SlaveAddr,
|
|
IN CONST UINT32 GpioNum,
|
|
IN CONST BOOLEAN HighLevel
|
|
)
|
|
{
|
|
Pcal9555SetPortRegBit (
|
|
Pcal9555SlaveAddr,
|
|
GpioNum,
|
|
PCAL9555_REG_OUT_PORT0,
|
|
HighLevel
|
|
);
|
|
}
|
|
|
|
/**
|
|
|
|
Enable pull-up/pull-down resistors of Pcal9555 GPIOs.
|
|
|
|
@param Pcal9555SlaveAddr I2c Slave address of Pcal9555 Io Expander.
|
|
@param GpioNum Gpio to change values 0-7 for Port0 and 8-15
|
|
for Port1.
|
|
|
|
**/
|
|
VOID
|
|
EFIAPI
|
|
PlatformPcal9555GpioEnablePull (
|
|
IN CONST UINT32 Pcal9555SlaveAddr,
|
|
IN CONST UINT32 GpioNum
|
|
)
|
|
{
|
|
Pcal9555SetPortRegBit (
|
|
Pcal9555SlaveAddr,
|
|
GpioNum,
|
|
PCAL9555_REG_PULL_EN_PORT0,
|
|
TRUE
|
|
);
|
|
}
|
|
|
|
/**
|
|
|
|
Disable pull-up/pull-down resistors of Pcal9555 GPIOs.
|
|
|
|
@param Pcal9555SlaveAddr I2c Slave address of Pcal9555 Io Expander.
|
|
@param GpioNum Gpio to change values 0-7 for Port0 and 8-15
|
|
for Port1.
|
|
|
|
**/
|
|
VOID
|
|
EFIAPI
|
|
PlatformPcal9555GpioDisablePull (
|
|
IN CONST UINT32 Pcal9555SlaveAddr,
|
|
IN CONST UINT32 GpioNum
|
|
)
|
|
{
|
|
Pcal9555SetPortRegBit (
|
|
Pcal9555SlaveAddr,
|
|
GpioNum,
|
|
PCAL9555_REG_PULL_EN_PORT0,
|
|
FALSE
|
|
);
|
|
}
|
|
|
|
/**
|
|
|
|
Get state of Pcal9555 GPIOs.
|
|
|
|
@param Pcal9555SlaveAddr I2c Slave address of Pcal9555 Io Expander.
|
|
@param GpioNum Gpio to change values 0-7 for Port0 and 8-15
|
|
for Port1.
|
|
|
|
@retval TRUE GPIO pin is high
|
|
@retval FALSE GPIO pin is low
|
|
**/
|
|
BOOLEAN
|
|
EFIAPI
|
|
PlatformPcal9555GpioGetState (
|
|
IN CONST UINT32 Pcal9555SlaveAddr,
|
|
IN CONST UINT32 GpioNum
|
|
)
|
|
{
|
|
return Pcal9555GetPortRegBit (Pcal9555SlaveAddr, GpioNum, PCAL9555_REG_IN_PORT0);
|
|
}
|