summaryrefslogtreecommitdiff
path: root/Core/EM/OFBD/MEUD/InitMEUDString.c
blob: 00c0ac27591d14702346e2197bd5a9fb0c8870d1 (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
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
//*************************************************************************
//*************************************************************************
//**                                                                     **
//**        (C)Copyright 1985-2009, American Megatrends, Inc.            **
//**                                                                     **
//**                       All Rights Reserved.                          **
//**                                                                     **
//**      5555 Oakbrook Parkway, Suite 200, Norcross, GA 30093           **
//**                                                                     **
//**                       Phone: (770)-246-8600                         **
//**                                                                     **
//*************************************************************************
//*************************************************************************

//**********************************************************************
// $Header: /Alaska/SOURCE/Modules/OFBD Intel ME Update/InitMEUDString.c 6     11/01/11 2:54a Klzhan $
//
// $Revision: 6 $
//
// $Date: 11/01/11 2:54a $
//**********************************************************************
// Revision History
// ----------------
// $Log: /Alaska/SOURCE/Modules/OFBD Intel ME Update/InitMEUDString.c $
// 
// 6     11/01/11 2:54a Klzhan
// [TAG]  		EIP73028
// [Category]  	Improvement
// [Description]  	Pointer might be used without initial.
// 
// 5     2/10/11 4:04a Klzhan
// Improvement : Update output string for SPS FW when disabled ME.
// 
// 4     12/27/10 3:15a Klzhan
// Improvement : Output message for Disabled ME setup item.
// 
// 3     6/10/10 5:54a Klzhan
// Improvement : Implement Setup call back by Elink.
// 
// 2     10/30/09 6:43a Klzhan
// 1. Remove un-used function.
// 
// 1     10/20/09 3:31a Klzhan
// Initail check-in.
//
// 
//**********************************************************************
//<AMI_FHDR_START>
//
// Name:	InitMEUDString.c
//
// Description:
//
//<AMI_FHDR_END>
//**********************************************************************
#include "Efi.h"
#include "token.h"
#include <AmiLib.h>
#include <AmiDxeLib.h>
#include "..\OFBD.h"
#include "MEUD.h"
#if EFI_SPECIFICATION_VERSION>0x20000
#include <Protocol/HiiString.h>
#include <Protocol/HiiDatabase.h>
#else
#include <Protocol\Hii.h>
#endif
#include <Setup.h>
#include <Protocol/AMIPostMgr.h>

extern EFI_GUID guidHII;
#if EFI_SPECIFICATION_VERSION>0x20000
EFI_STATUS MEUDSetupCallbackFunction(
    EFI_HII_HANDLE HiiHandle, 
    UINT16 Class, 
    UINT16 SubClass, 
    UINT16 Key);
#else
EFI_STATUS MEUDSetupCallbackFunction(
  IN  EFI_FORM_CALLBACK_PROTOCOL    *This,
  IN  UINT16                        KeyValue,
  IN  EFI_IFR_DATA_ARRAY            *Data,
  OUT EFI_HII_CALLBACK_PACKET       **Packet );
EFI_FORM_CALLBACK_PROTOCOL MEUDSetupCallBack = { NULL,NULL,MEUDSetupCallbackFunction };
#endif
//<AMI_PHDR_START>
//----------------------------------------------------------------------------
// Procedure:	MEUDSetupCallbackFunction
//
// Description:	TSE Callbeck Function.
//              To make ME enter Disable Mode.
//
// Input:
//      VOID
//
// Output: 
//      VOID
//
//----------------------------------------------------------------------------
//<AMI_PHDR_END>
#if EFI_SPECIFICATION_VERSION>0x20000
EFI_STATUS MEUDSetupCallbackFunction(
    EFI_HII_HANDLE HiiHandle, 
    UINT16 Class, 
    UINT16 SubClass, 
    UINT16 Key)
#else
EFI_STATUS MEUDSetupCallbackFunction(
    IN  EFI_FORM_CALLBACK_PROTOCOL    *This,
    IN  UINT16                        KeyValue,
    IN  EFI_IFR_DATA_ARRAY            *Data,
    OUT EFI_HII_CALLBACK_PACKET       **Packet )
#endif
{
    UINTN      VariableSize = 1;
    UINT8      Flag,MsgBoxSel;
    EFI_GUID   gMEUDErrorguid = MEUD_ERROR_GUID;
    EFI_GUID   AmiPostMgrProtocolGuid = AMI_POST_MANAGER_PROTOCOL_GUID;
    EFI_STATUS Status;
    CHAR16     *OutputString = L"Disable ME fail !!";

    IoWrite8(0xB2,Disable_ME_SW_SMI);

    Status = pRS->GetVariable( L"ShowMEUDFailMSG", &gMEUDErrorguid,
                               NULL, &VariableSize, &Flag);

    // In SPS, BIOS doesn't send reset message.
    // Add message for User to know what happened.
    if(!EFI_ERROR(Status))
    {
        AMI_POST_MANAGER_PROTOCOL *AmiPostMgr = NULL;

        switch(Flag)
        {
            case 0:
#ifdef CSP_SPSUD_SUPPORT 
#if CSP_SPSUD_SUPPORT
            OutputString = L"ME been Disabled !! Please boot your system to OS for updating ME!!";
#endif
#endif
#ifdef CSP_MEUD_SUPPORT 
#if CSP_MEUD_SUPPORT
            OutputString = L"ME been Disabled !! Please reboot your system !!";
#endif
#endif
            break;

            default:
            OutputString = L"Disable ME fail !!";
            break;
        }
        if (!EFI_ERROR(pBS->LocateProtocol
             (&AmiPostMgrProtocolGuid, NULL, &AmiPostMgr)))
        {
            AmiPostMgr->DisplayMsgBox(
                        L"ME Update Info",
                        OutputString,
                        MSGBOX_TYPE_NULL,
                        &MsgBoxSel
                        );

        }
    }

    return EFI_SUCCESS ;
}
//<AMI_PHDR_START>
//----------------------------------------------------------------------------
// Procedure:	InitMEUDInfo
//
// Description:	Register a Setup Item CallBack Info.
//
// Input:
//      IN EFI_HII_HANDLE   HiiHandle
//      IN UINT16           Class
//
// Output:
//      VOID
//
//----------------------------------------------------------------------------
//<AMI_PHDR_END>
EFI_STATUS InitMEUDInfo(EFI_HII_HANDLE HiiHandle, UINT16 Class)
{
/*
    EFI_GUID    guidFormCallback = EFI_FORM_CALLBACK_PROTOCOL_GUID;
    EFI_HANDLE    Handle=0;
    EFI_GUID    guidHii = EFI_HII_PROTOCOL_GUID;
    EFI_HII_PROTOCOL    *MEUDHii = NULL;
    EFI_HII_UPDATE_DATA	UpdateData;
    UINT16        RegData = 0;
    EFI_STATUS    Status;

    if (Class != EXIT_FORM_SET_CLASS)
        return EFI_NOT_FOUND ;    

	Status = pBS->LocateProtocol(&guidHii,NULL,&MEUDHii);
	if( EFI_ERROR(Status) )
	{
		TRACE((0x800,"ERROR=%X Locate HII",Status)); 
	}

	// Install a form callback
	TRACE((0x800,"Installing form callback\n"));
	if (EFI_ERROR(
		Status = pBS->InstallProtocolInterface (
	              &Handle,
	              &guidFormCallback,
	              EFI_NATIVE_INTERFACE,
	              &MEUDSetupCallBack
	              )
	))
	{
		TRACE((0x800,"ERROR=%X - InstallProtocolInterface",Status));
	}


	UpdateData.FormSetUpdate = TRUE;	// Flag update pending in FormSet
	UpdateData.FormCallbackHandle = (EFI_PHYSICAL_ADDRESS) Handle;	// Register CallbackHandle data for FormSet
	UpdateData.FormUpdate  = FALSE;
	UpdateData.FormTitle   = 0;
	UpdateData.DataCount   = 0;
	Status = MEUDHii->UpdateForm(MEUDHii, HiiHandle, (EFI_FORM_LABEL)0x0000, FALSE, &UpdateData);
	if( EFI_ERROR(Status) )
	{
		TRACE((0x800,"ERROR=%X UpdateForm",Status)); 
	}
*/
	return EFI_SUCCESS;

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