//************************************************************************* //************************************************************************* //** ** //** (C)Copyright 1985-2013, American Megatrends, Inc. ** //** ** //** All Rights Reserved. ** //** ** //** 5555 Oakbrook Parkway, Suite 200, Norcross, GA 30093 ** //** ** //** Phone: (770)-246-8600 ** //** ** //************************************************************************* //************************************************************************* //***************************************************************************** // $Header: /Alaska/SOURCE/Modules/SharkBayRefCodes/FIT/Smm/FitHook.c 1 7/03/13 10:06p Bensonlai $ // // $Revision: 1 $ // // $Date: 7/03/13 10:06p $ //***************************************************************************** // Revision History // ---------------- // $Log: /Alaska/SOURCE/Modules/SharkBayRefCodes/FIT/Smm/FitHook.c $ // // 1 7/03/13 10:06p Bensonlai // [TAG] EIP128151 // [Category] Improvement // [Description] Implement an option(/b) to flash FV_DATA region uisng // AFU flash utility. // [Files] FitHook.cif // FitHook.c // FitHook.sdl // FitHook.mak // //***************************************************************************** // // // Name: FitHook.c // // Description: SW SMI hook. // // //***************************************************************************** #include #include #include "token.h" #define FLASH_DEVICE_BASE_ADDRESS (0xFFFFFFFF-FLASH_SIZE+1) #define FV_DATA_BLOCK_ADDRESS (FV_DATA_BASE-FLASH_DEVICE_BASE_ADDRESS) #define FV_DATA_BLOCK_END (FV_DATA_BLOCK_ADDRESS+FV_DATA_SIZE) #define FV_DATA_TABLE_OFFSET (0xFFFFFFFF-FV_DATA_BASE+1) // //---------------------------------------------------------------------------- // // Procedure: AppendFvDataToAFU_UpdateBlockTypeId // // Description: This function is SW SMI hook that sets Flash Block Description // type for AMI AFU utility. (EIP#58139) // // Input: // SwSmiNum - SW SMI value number // Buffer - Flash descriptor address // // Output: VOID // //---------------------------------------------------------------------------- // VOID AppendFvDataToAFU_UpdateBlockTypeId ( IN UINT8 SwSmiNum, IN UINT64 Buffer ) { BLOCK_DESC *BlockDesc; UINTN i; // return if SW SMI value is not "Get Flash Info" if (SwSmiNum != SMIFLASH_GET_FLASH_INFO) return; BlockDesc = (BLOCK_DESC*)&((INFO_BLOCK*)Buffer)->Blocks; for (i = 0; i < ((INFO_BLOCK*)Buffer)->TotalBlocks; i++) { TRACE((TRACE_ALWAYS,"AppendFvDataToAFU_UpdateBlockTypeId: %08X(%08X), Block %08X\n", FV_DATA_BLOCK_ADDRESS, FV_DATA_BLOCK_END, BlockDesc[i].StartAddress)); if (BlockDesc[i].StartAddress < FV_DATA_BLOCK_ADDRESS) continue; if (BlockDesc[i].StartAddress >= FV_DATA_BLOCK_END) continue; TRACE((TRACE_ALWAYS,"AppendFvDataToAFU_UpdateBlockTypeId: Found Blocks %08X\n",BlockDesc[i].StartAddress)); BlockDesc[i].Type = BOOT_BLOCK; } } //************************************************************************* //************************************************************************* //** ** //** (C)Copyright 1985-2013, American Megatrends, Inc. ** //** ** //** All Rights Reserved. ** //** ** //** 5555 Oakbrook Parkway, Suite 200, Norcross, GA 30093 ** //** ** //** Phone: (770)-246-8600 ** //** ** //************************************************************************* //*************************************************************************