summaryrefslogtreecommitdiff
path: root/Core/EM/OemActivation/OemActivationHook.c
blob: 9211bc488b03f61cf973c24b8ce395867f5d400d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
//*************************************************************************
//*************************************************************************
//**                                                                     **
//**        (C)Copyright 1985-2011, American Megatrends, Inc.            **
//**                                                                     **
//**                       All Rights Reserved.                          **
//**                                                                     **
//**      5555 Oakbrook Parkway, Suite 200, Norcross, GA 30093           **
//**                                                                     **
//**                       Phone: (770)-246-8600                         **
//**                                                                     **
//*************************************************************************
//*************************************************************************

//*****************************************************************************
// $Header: /Alaska/SOURCE/Modules/OemActivation/OemActivationHook.c 3     6/10/11 10:57a Vyacheslava $
//
// $Revision: 3 $
//
// $Date: 6/10/11 10:57a $
//*****************************************************************************
// Revision History
// ----------------
// $Log: /Alaska/SOURCE/Modules/OemActivation/OemActivationHook.c $
// 
// 3     6/10/11 10:57a Vyacheslava
// 
// 2     5/26/11 11:34a Vyacheslava
// 
// 1     4/29/11 12:39p Vyacheslava
// [TAG]  		EIP58139 
// [Category]  	New Feature
// [Description]  	Added SW SMI hook to place Oem Activation Key in NCB.
// 
//
//*****************************************************************************
//<AMI_FHDR_START>
//
// Name:    OemActivationHook.c
//
// Description: SW SMI hook. 
//
//<AMI_FHDR_END>
//*****************************************************************************


#include <AmiDxeLib.h>
#include <Protocol/SmiFlash.h>
#include "OemActivation.h"

//----------------------------------------------------------------------------


#if OEM_ACTIVATION_TABLE_LOCATION == 1

//<AMI_PHDR_START>
//----------------------------------------------------------------------------
//
// Procedure:   OemActivationUpdateBlockTypeId
//
// 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
//
//----------------------------------------------------------------------------
//<AMI_PHDR_END>

VOID OemActivationUpdateBlockTypeId (
    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,"OemActivationUpdateBlockTypeId: %08X(%08X), Block %08X\n",OEM_ACTIVATION_BLOCK_ADDRESS,OEM_ACTIVATION_BLOCK_END,BlockDesc[i].StartAddress));
        
        if (BlockDesc[i].StartAddress < OEM_ACTIVATION_BLOCK_ADDRESS) 
            continue;
        
        if (BlockDesc[i].StartAddress >= OEM_ACTIVATION_BLOCK_END) 
            continue;
        
        TRACE((TRACE_ALWAYS,"OemActivationUpdateBlockTypeId: Found Blocks %08X\n",BlockDesc[i].StartAddress));
        
        BlockDesc[i].Type = OA3_FLASH_BLOCK_DESC_TYPE;
    }
}

#endif

//*************************************************************************
//*************************************************************************
//**                                                                     **
//**        (C)Copyright 1985-2011, American Megatrends, Inc.            **
//**                                                                     **
//**                       All Rights Reserved.                          **
//**                                                                     **
//**      5555 Oakbrook Parkway, Suite 200, Norcross, GA 30093           **
//**                                                                     **
//**                       Phone: (770)-246-8600                         **
//**                                                                     **
//*************************************************************************
//*************************************************************************