xref: /onnv-gate/usr/src/cmd/lms/heci/FWULCommand.cpp (revision 9203:3ebffd0a1b10)
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