1*9203SMark.Logan@Sun.COM /*******************************************************************************
2*9203SMark.Logan@Sun.COM * Copyright (C) 2004-2008 Intel Corp. All rights reserved.
3*9203SMark.Logan@Sun.COM *
4*9203SMark.Logan@Sun.COM * Redistribution and use in source and binary forms, with or without
5*9203SMark.Logan@Sun.COM * modification, are permitted provided that the following conditions are met:
6*9203SMark.Logan@Sun.COM *
7*9203SMark.Logan@Sun.COM * - Redistributions of source code must retain the above copyright notice,
8*9203SMark.Logan@Sun.COM * this list of conditions and the following disclaimer.
9*9203SMark.Logan@Sun.COM *
10*9203SMark.Logan@Sun.COM * - Redistributions in binary form must reproduce the above copyright notice,
11*9203SMark.Logan@Sun.COM * this list of conditions and the following disclaimer in the documentation
12*9203SMark.Logan@Sun.COM * and/or other materials provided with the distribution.
13*9203SMark.Logan@Sun.COM *
14*9203SMark.Logan@Sun.COM * - Neither the name of Intel Corp. nor the names of its
15*9203SMark.Logan@Sun.COM * contributors may be used to endorse or promote products derived from this
16*9203SMark.Logan@Sun.COM * software without specific prior written permission.
17*9203SMark.Logan@Sun.COM *
18*9203SMark.Logan@Sun.COM * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS''
19*9203SMark.Logan@Sun.COM * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20*9203SMark.Logan@Sun.COM * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21*9203SMark.Logan@Sun.COM * ARE DISCLAIMED. IN NO EVENT SHALL Intel Corp. OR THE CONTRIBUTORS
22*9203SMark.Logan@Sun.COM * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23*9203SMark.Logan@Sun.COM * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24*9203SMark.Logan@Sun.COM * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25*9203SMark.Logan@Sun.COM * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26*9203SMark.Logan@Sun.COM * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27*9203SMark.Logan@Sun.COM * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28*9203SMark.Logan@Sun.COM * POSSIBILITY OF SUCH DAMAGE.
29*9203SMark.Logan@Sun.COM *******************************************************************************/
30*9203SMark.Logan@Sun.COM
31*9203SMark.Logan@Sun.COM #ifdef HAVE_CONFIG_H
32*9203SMark.Logan@Sun.COM #include "config.h"
33*9203SMark.Logan@Sun.COM #endif
34*9203SMark.Logan@Sun.COM #include <cstdio>
35*9203SMark.Logan@Sun.COM #include <cstdlib>
36*9203SMark.Logan@Sun.COM
37*9203SMark.Logan@Sun.COM #ifdef __sun
38*9203SMark.Logan@Sun.COM #include <stdio.h>
39*9203SMark.Logan@Sun.COM #include <stdlib.h>
40*9203SMark.Logan@Sun.COM #endif // __sun
41*9203SMark.Logan@Sun.COM
42*9203SMark.Logan@Sun.COM #include "FWULCommand.h"
43*9203SMark.Logan@Sun.COM
FWULCommand(bool verbose)44*9203SMark.Logan@Sun.COM FWULCommand::FWULCommand(bool verbose) :
45*9203SMark.Logan@Sun.COM FWULClient(FW_UPDATE_GUID, verbose)
46*9203SMark.Logan@Sun.COM {
47*9203SMark.Logan@Sun.COM _verbose = verbose;
48*9203SMark.Logan@Sun.COM }
49*9203SMark.Logan@Sun.COM
~FWULCommand(void)50*9203SMark.Logan@Sun.COM FWULCommand::~FWULCommand(void)
51*9203SMark.Logan@Sun.COM {
52*9203SMark.Logan@Sun.COM }
53*9203SMark.Logan@Sun.COM
_call(const unsigned char * command,UINT32 command_size,UINT8 ** readBuffer,UINT32 * outBuffSize)54*9203SMark.Logan@Sun.COM HECI_STATUS FWULCommand::_call(const unsigned char *command, UINT32 command_size, UINT8 **readBuffer, UINT32 *outBuffSize)
55*9203SMark.Logan@Sun.COM {
56*9203SMark.Logan@Sun.COM UINT32 inBuffSize;
57*9203SMark.Logan@Sun.COM *outBuffSize = 0;
58*9203SMark.Logan@Sun.COM
59*9203SMark.Logan@Sun.COM inBuffSize = FWULClient.GetBufferSize();
60*9203SMark.Logan@Sun.COM if (NULL == *readBuffer)
61*9203SMark.Logan@Sun.COM {
62*9203SMark.Logan@Sun.COM *readBuffer = (UINT8 *)malloc(sizeof(UINT8) * inBuffSize);
63*9203SMark.Logan@Sun.COM if (NULL == *readBuffer)
64*9203SMark.Logan@Sun.COM {
65*9203SMark.Logan@Sun.COM if (_verbose)
66*9203SMark.Logan@Sun.COM {
67*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: Malloc failed\n");
68*9203SMark.Logan@Sun.COM }
69*9203SMark.Logan@Sun.COM return HECI_STATUS_MEMORY_ALLOCATION_ERROR;
70*9203SMark.Logan@Sun.COM }
71*9203SMark.Logan@Sun.COM }
72*9203SMark.Logan@Sun.COM memset(*readBuffer, 0, inBuffSize);
73*9203SMark.Logan@Sun.COM
74*9203SMark.Logan@Sun.COM int bytesWritten = FWULClient.SendMessage(command, command_size);
75*9203SMark.Logan@Sun.COM if ((UINT32)bytesWritten != command_size)
76*9203SMark.Logan@Sun.COM {
77*9203SMark.Logan@Sun.COM if (_verbose)
78*9203SMark.Logan@Sun.COM {
79*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: Could not send data to FWUpdate client through MEI\n");
80*9203SMark.Logan@Sun.COM }
81*9203SMark.Logan@Sun.COM return HECI_STATUS_MSG_TRANSMISSION_ERROR;
82*9203SMark.Logan@Sun.COM }
83*9203SMark.Logan@Sun.COM *outBuffSize = FWULClient.ReceiveMessage(*readBuffer, inBuffSize, 15000);
84*9203SMark.Logan@Sun.COM if (0 == *outBuffSize)
85*9203SMark.Logan@Sun.COM {
86*9203SMark.Logan@Sun.COM if (_verbose)
87*9203SMark.Logan@Sun.COM {
88*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: Could not read data from FWUpdate client through MEI\n");
89*9203SMark.Logan@Sun.COM }
90*9203SMark.Logan@Sun.COM return HECI_STATUS_UNEXPECTED_RESPONSE;
91*9203SMark.Logan@Sun.COM }
92*9203SMark.Logan@Sun.COM if (_verbose)
93*9203SMark.Logan@Sun.COM {
94*9203SMark.Logan@Sun.COM fprintf(stdout, "Data received from FWUpdate Client. %d bytes read\n", *outBuffSize);
95*9203SMark.Logan@Sun.COM }
96*9203SMark.Logan@Sun.COM return HECI_STATUS_OK;
97*9203SMark.Logan@Sun.COM }
98*9203SMark.Logan@Sun.COM
99*9203SMark.Logan@Sun.COM
100*9203SMark.Logan@Sun.COM /*
101*9203SMark.Logan@Sun.COM * Get ME data information from FW update client using AMTCommunication class
102*9203SMark.Logan@Sun.COM */
103*9203SMark.Logan@Sun.COM HECI_STATUS
GetFWUVersionAndInfo(FWU_GET_VERSION_MSG_REPLY & verMsg,FWU_GET_INFO_MSG_REPLY & infoMsg)104*9203SMark.Logan@Sun.COM FWULCommand::GetFWUVersionAndInfo(FWU_GET_VERSION_MSG_REPLY &verMsg, FWU_GET_INFO_MSG_REPLY &infoMsg)
105*9203SMark.Logan@Sun.COM {
106*9203SMark.Logan@Sun.COM UINT8 *readBuffer = NULL;
107*9203SMark.Logan@Sun.COM UINT32 command_size = sizeof(ME_GET_FW_UPDATE_INFO_REQUEST);
108*9203SMark.Logan@Sun.COM UINT32 replySize = 0;
109*9203SMark.Logan@Sun.COM ME_GET_FW_UPDATE_INFO_REQUEST msg;
110*9203SMark.Logan@Sun.COM HECI_STATUS status;
111*9203SMark.Logan@Sun.COM
112*9203SMark.Logan@Sun.COM msg.MessageID = FWU_GET_VERSION;
113*9203SMark.Logan@Sun.COM status = _call((const unsigned char *)&msg, command_size,
114*9203SMark.Logan@Sun.COM &readBuffer, &replySize);
115*9203SMark.Logan@Sun.COM if (status != HECI_STATUS_OK)
116*9203SMark.Logan@Sun.COM {
117*9203SMark.Logan@Sun.COM goto fwuvend;
118*9203SMark.Logan@Sun.COM }
119*9203SMark.Logan@Sun.COM if (replySize == sizeof(FWU_GET_VERSION_MSG_REPLY))
120*9203SMark.Logan@Sun.COM {
121*9203SMark.Logan@Sun.COM if (((FWU_MSG_REPLY_HEADER *)readBuffer)->MessageType != FWU_GET_VERSION_REPLY)
122*9203SMark.Logan@Sun.COM {
123*9203SMark.Logan@Sun.COM if (_verbose)
124*9203SMark.Logan@Sun.COM {
125*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: MessageType in MEI response is not as expected\n");
126*9203SMark.Logan@Sun.COM }
127*9203SMark.Logan@Sun.COM status = HECI_STATUS_UNEXPECTED_RESPONSE;
128*9203SMark.Logan@Sun.COM goto fwuvend;
129*9203SMark.Logan@Sun.COM }
130*9203SMark.Logan@Sun.COM if (((FWU_MSG_REPLY_HEADER *)readBuffer)->Status != PT_STATUS_SUCCESS)
131*9203SMark.Logan@Sun.COM {
132*9203SMark.Logan@Sun.COM if (_verbose)
133*9203SMark.Logan@Sun.COM {
134*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: Status in MEI response is not as expected\n");
135*9203SMark.Logan@Sun.COM }
136*9203SMark.Logan@Sun.COM status = HECI_STATUS_UNEXPECTED_RESPONSE;
137*9203SMark.Logan@Sun.COM goto fwuvend;
138*9203SMark.Logan@Sun.COM }
139*9203SMark.Logan@Sun.COM
140*9203SMark.Logan@Sun.COM memcpy(&verMsg, readBuffer, sizeof(FWU_GET_VERSION_MSG_REPLY));
141*9203SMark.Logan@Sun.COM
142*9203SMark.Logan@Sun.COM msg.MessageID = FWU_GET_INFO;
143*9203SMark.Logan@Sun.COM status = _call((const unsigned char *)&msg, command_size,
144*9203SMark.Logan@Sun.COM &readBuffer, &replySize);
145*9203SMark.Logan@Sun.COM if (status != HECI_STATUS_OK)
146*9203SMark.Logan@Sun.COM {
147*9203SMark.Logan@Sun.COM goto fwuvend;
148*9203SMark.Logan@Sun.COM }
149*9203SMark.Logan@Sun.COM if (replySize != sizeof(FWU_GET_INFO_MSG_REPLY))
150*9203SMark.Logan@Sun.COM {
151*9203SMark.Logan@Sun.COM if (_verbose)
152*9203SMark.Logan@Sun.COM {
153*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: MEI response size is not as expected\n");
154*9203SMark.Logan@Sun.COM }
155*9203SMark.Logan@Sun.COM status = HECI_STATUS_UNEXPECTED_RESPONSE;
156*9203SMark.Logan@Sun.COM goto fwuvend;
157*9203SMark.Logan@Sun.COM }
158*9203SMark.Logan@Sun.COM if (((FWU_MSG_REPLY_HEADER *)readBuffer)->MessageType != FWU_GET_INFO_REPLY)
159*9203SMark.Logan@Sun.COM {
160*9203SMark.Logan@Sun.COM if (_verbose)
161*9203SMark.Logan@Sun.COM {
162*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: MessageType in MEI response is not as expected\n");
163*9203SMark.Logan@Sun.COM }
164*9203SMark.Logan@Sun.COM status = HECI_STATUS_UNEXPECTED_RESPONSE;
165*9203SMark.Logan@Sun.COM goto fwuvend;
166*9203SMark.Logan@Sun.COM }
167*9203SMark.Logan@Sun.COM if (((FWU_MSG_REPLY_HEADER *)readBuffer)->Status != PT_STATUS_SUCCESS)
168*9203SMark.Logan@Sun.COM {
169*9203SMark.Logan@Sun.COM if (_verbose)
170*9203SMark.Logan@Sun.COM {
171*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: Status in MEI response is not as expected\n");
172*9203SMark.Logan@Sun.COM }
173*9203SMark.Logan@Sun.COM status = HECI_STATUS_UNEXPECTED_RESPONSE;
174*9203SMark.Logan@Sun.COM goto fwuvend;
175*9203SMark.Logan@Sun.COM }
176*9203SMark.Logan@Sun.COM
177*9203SMark.Logan@Sun.COM memcpy(&infoMsg, readBuffer, sizeof(FWU_GET_INFO_MSG_REPLY));
178*9203SMark.Logan@Sun.COM
179*9203SMark.Logan@Sun.COM }
180*9203SMark.Logan@Sun.COM else if (replySize == sizeof(FWU_GET_VERSION_MSG_REPLY_V3))
181*9203SMark.Logan@Sun.COM {
182*9203SMark.Logan@Sun.COM if (((FWU_MSG_REPLY_HEADER_V3 *)readBuffer)->MessageType != FWU_GET_VERSION_REPLY)
183*9203SMark.Logan@Sun.COM {
184*9203SMark.Logan@Sun.COM if (_verbose)
185*9203SMark.Logan@Sun.COM {
186*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: MessageType in MEI response is not as expected\n");
187*9203SMark.Logan@Sun.COM }
188*9203SMark.Logan@Sun.COM status = HECI_STATUS_UNEXPECTED_RESPONSE;
189*9203SMark.Logan@Sun.COM goto fwuvend;
190*9203SMark.Logan@Sun.COM }
191*9203SMark.Logan@Sun.COM if (((FWU_MSG_REPLY_HEADER_V3 *)readBuffer)->Status != PT_STATUS_SUCCESS)
192*9203SMark.Logan@Sun.COM {
193*9203SMark.Logan@Sun.COM if (_verbose)
194*9203SMark.Logan@Sun.COM {
195*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: Status in MEI response is not as expected\n");
196*9203SMark.Logan@Sun.COM }
197*9203SMark.Logan@Sun.COM status = HECI_STATUS_UNEXPECTED_RESPONSE;
198*9203SMark.Logan@Sun.COM goto fwuvend;
199*9203SMark.Logan@Sun.COM }
200*9203SMark.Logan@Sun.COM
201*9203SMark.Logan@Sun.COM FWU_GET_VERSION_MSG_REPLY_V3 *rep = (FWU_GET_VERSION_MSG_REPLY_V3 *)readBuffer;
202*9203SMark.Logan@Sun.COM verMsg.MessageType = FWU_GET_VERSION_REPLY;
203*9203SMark.Logan@Sun.COM verMsg.Status = rep->Status;
204*9203SMark.Logan@Sun.COM verMsg.Sku = rep->Sku;
205*9203SMark.Logan@Sun.COM verMsg.ICHVer = rep->ICHVer;
206*9203SMark.Logan@Sun.COM verMsg.MCHVer = rep->MCHVer;
207*9203SMark.Logan@Sun.COM verMsg.Vendor = rep->Vendor;
208*9203SMark.Logan@Sun.COM verMsg.LastFwUpdateStatus = rep->LastFwUpdateStatus;
209*9203SMark.Logan@Sun.COM verMsg.HwSku = rep->Sku;
210*9203SMark.Logan@Sun.COM memcpy(&verMsg.CodeVersion, &(rep->CodeVersion), sizeof(verMsg.CodeVersion));
211*9203SMark.Logan@Sun.COM memset(&verMsg.AMTVersion, 0, sizeof(verMsg.AMTVersion));
212*9203SMark.Logan@Sun.COM verMsg.EnabledUpdateInterfaces = rep->EnabledUpdateInterfaces;
213*9203SMark.Logan@Sun.COM verMsg.Reserved = 0;
214*9203SMark.Logan@Sun.COM
215*9203SMark.Logan@Sun.COM memset(&infoMsg, 0, sizeof(infoMsg));
216*9203SMark.Logan@Sun.COM } else {
217*9203SMark.Logan@Sun.COM if (_verbose)
218*9203SMark.Logan@Sun.COM {
219*9203SMark.Logan@Sun.COM fprintf(stderr, "Error: MEI response size is not as expected\n");
220*9203SMark.Logan@Sun.COM }
221*9203SMark.Logan@Sun.COM status = HECI_STATUS_UNEXPECTED_RESPONSE;
222*9203SMark.Logan@Sun.COM goto fwuvend;
223*9203SMark.Logan@Sun.COM }
224*9203SMark.Logan@Sun.COM
225*9203SMark.Logan@Sun.COM fwuvend:
226*9203SMark.Logan@Sun.COM
227*9203SMark.Logan@Sun.COM if (readBuffer != NULL)
228*9203SMark.Logan@Sun.COM {
229*9203SMark.Logan@Sun.COM free(readBuffer);
230*9203SMark.Logan@Sun.COM }
231*9203SMark.Logan@Sun.COM
232*9203SMark.Logan@Sun.COM return status;
233*9203SMark.Logan@Sun.COM }
234