xref: /onnv-gate/usr/src/cmd/lms/heci/FWULCommand.h (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 #ifndef __FWUL_COMMAND_H__
32*9203SMark.Logan@Sun.COM #define __FWUL_COMMAND_H__
33*9203SMark.Logan@Sun.COM 
34*9203SMark.Logan@Sun.COM #include "HECIUnix.h"
35*9203SMark.Logan@Sun.COM #include "StatusCodeDefinitions.h"
36*9203SMark.Logan@Sun.COM 
37*9203SMark.Logan@Sun.COM #pragma pack(1)
38*9203SMark.Logan@Sun.COM 
39*9203SMark.Logan@Sun.COM typedef struct _FWU_VERSION
40*9203SMark.Logan@Sun.COM {
41*9203SMark.Logan@Sun.COM 	UINT16      Major;
42*9203SMark.Logan@Sun.COM 	UINT16      Minor;
43*9203SMark.Logan@Sun.COM 	UINT16      Hotfix;
44*9203SMark.Logan@Sun.COM 	UINT16      Build;
45*9203SMark.Logan@Sun.COM } FWU_VERSION;
46*9203SMark.Logan@Sun.COM 
47*9203SMark.Logan@Sun.COM typedef enum
48*9203SMark.Logan@Sun.COM {
49*9203SMark.Logan@Sun.COM 	FWU_GET_VERSION = 0,
50*9203SMark.Logan@Sun.COM 	FWU_GET_VERSION_REPLY,
51*9203SMark.Logan@Sun.COM 	FWU_START,
52*9203SMark.Logan@Sun.COM 	FWU_START_REPLY,
53*9203SMark.Logan@Sun.COM 	FWU_DATA,
54*9203SMark.Logan@Sun.COM 	FWU_DATA_REPLY,
55*9203SMark.Logan@Sun.COM 	FWU_END,
56*9203SMark.Logan@Sun.COM 	FWU_END_REPLY,
57*9203SMark.Logan@Sun.COM 	FWU_GET_INFO,
58*9203SMark.Logan@Sun.COM 	FWU_GET_INFO_REPLY
59*9203SMark.Logan@Sun.COM } FWU_HECI_MESSAGE_TYPE;
60*9203SMark.Logan@Sun.COM 
61*9203SMark.Logan@Sun.COM typedef struct _ME_GET_FW_UPDATE_INFO_REQUEST
62*9203SMark.Logan@Sun.COM {
63*9203SMark.Logan@Sun.COM 	UINT32      MessageID;
64*9203SMark.Logan@Sun.COM } ME_GET_FW_UPDATE_INFO_REQUEST;
65*9203SMark.Logan@Sun.COM 
66*9203SMark.Logan@Sun.COM typedef struct _FWU_MSG_REPLY_HEADER
67*9203SMark.Logan@Sun.COM {
68*9203SMark.Logan@Sun.COM 	UINT32      MessageType;
69*9203SMark.Logan@Sun.COM 	UINT32      Status;
70*9203SMark.Logan@Sun.COM } FWU_MSG_REPLY_HEADER;
71*9203SMark.Logan@Sun.COM 
72*9203SMark.Logan@Sun.COM typedef struct _FWU_MSG_REPLY_HEADER_V3
73*9203SMark.Logan@Sun.COM {
74*9203SMark.Logan@Sun.COM 	UINT8       MessageType;
75*9203SMark.Logan@Sun.COM 	UINT32      Status;
76*9203SMark.Logan@Sun.COM } FWU_MSG_REPLY_HEADER_V3;
77*9203SMark.Logan@Sun.COM 
78*9203SMark.Logan@Sun.COM typedef struct _FWU_GET_VERSION_MSG_REPLY
79*9203SMark.Logan@Sun.COM {
80*9203SMark.Logan@Sun.COM 	UINT32      MessageType;
81*9203SMark.Logan@Sun.COM 	UINT32      Status;
82*9203SMark.Logan@Sun.COM 	UINT32      Sku;
83*9203SMark.Logan@Sun.COM 	UINT32      ICHVer;
84*9203SMark.Logan@Sun.COM 	UINT32      MCHVer;
85*9203SMark.Logan@Sun.COM 	UINT32      Vendor;
86*9203SMark.Logan@Sun.COM 	UINT32      LastFwUpdateStatus;
87*9203SMark.Logan@Sun.COM 	UINT32      HwSku;
88*9203SMark.Logan@Sun.COM 	FWU_VERSION CodeVersion;
89*9203SMark.Logan@Sun.COM 	FWU_VERSION AMTVersion;
90*9203SMark.Logan@Sun.COM 	UINT16      EnabledUpdateInterfaces;
91*9203SMark.Logan@Sun.COM 	UINT16      Reserved;
92*9203SMark.Logan@Sun.COM } FWU_GET_VERSION_MSG_REPLY;
93*9203SMark.Logan@Sun.COM 
94*9203SMark.Logan@Sun.COM typedef struct _FWU_GET_VERSION_MSG_REPLY_V3
95*9203SMark.Logan@Sun.COM {
96*9203SMark.Logan@Sun.COM 	UINT8       MessageType;
97*9203SMark.Logan@Sun.COM 	UINT32      Status;
98*9203SMark.Logan@Sun.COM 	UINT32      Sku;
99*9203SMark.Logan@Sun.COM 	UINT32      ICHVer;
100*9203SMark.Logan@Sun.COM 	UINT32      MCHVer;
101*9203SMark.Logan@Sun.COM 	UINT32      Vendor;
102*9203SMark.Logan@Sun.COM 	FWU_VERSION CodeVersion;
103*9203SMark.Logan@Sun.COM 	FWU_VERSION RcvyVersion;
104*9203SMark.Logan@Sun.COM 	UINT16      EnabledUpdateInterfaces;
105*9203SMark.Logan@Sun.COM 	UINT32      LastFwUpdateStatus;
106*9203SMark.Logan@Sun.COM 	UINT32      Reserved;
107*9203SMark.Logan@Sun.COM } FWU_GET_VERSION_MSG_REPLY_V3;
108*9203SMark.Logan@Sun.COM 
109*9203SMark.Logan@Sun.COM typedef struct _FWU_GET_INFO_MSG_REPLY
110*9203SMark.Logan@Sun.COM {
111*9203SMark.Logan@Sun.COM 	UINT32      MessageType;
112*9203SMark.Logan@Sun.COM 	UINT32      Status;
113*9203SMark.Logan@Sun.COM 	FWU_VERSION MEBxVersion;
114*9203SMark.Logan@Sun.COM 	UINT32      FlashOverridePolicy;
115*9203SMark.Logan@Sun.COM 	UINT32      ManageabilityMode;
116*9203SMark.Logan@Sun.COM 	UINT32      BiosBootState;
117*9203SMark.Logan@Sun.COM 	struct {
118*9203SMark.Logan@Sun.COM 		UINT32          CryptoFuse   :1;
119*9203SMark.Logan@Sun.COM 		UINT32          FlashProtection:1;
120*9203SMark.Logan@Sun.COM 		UINT32          FwOverrideQualifier:2;
121*9203SMark.Logan@Sun.COM 		UINT32          MeResetReason:2;
122*9203SMark.Logan@Sun.COM 		UINT32          FwOverrideCounter:8;
123*9203SMark.Logan@Sun.COM 		UINT32          reserved:18;
124*9203SMark.Logan@Sun.COM 	} Fields;
125*9203SMark.Logan@Sun.COM 	UINT8       BiosVersion[20];
126*9203SMark.Logan@Sun.COM } FWU_GET_INFO_MSG_REPLY;
127*9203SMark.Logan@Sun.COM 
128*9203SMark.Logan@Sun.COM #pragma pack(0)
129*9203SMark.Logan@Sun.COM 
130*9203SMark.Logan@Sun.COM class FWULCommand
131*9203SMark.Logan@Sun.COM {
132*9203SMark.Logan@Sun.COM public:
133*9203SMark.Logan@Sun.COM 	FWULCommand(bool verbose = false);
134*9203SMark.Logan@Sun.COM 	~FWULCommand();
135*9203SMark.Logan@Sun.COM 
136*9203SMark.Logan@Sun.COM 	HECI_STATUS GetFWUVersionAndInfo(FWU_GET_VERSION_MSG_REPLY &verMsg, FWU_GET_INFO_MSG_REPLY &infoMsg);
137*9203SMark.Logan@Sun.COM 
138*9203SMark.Logan@Sun.COM 	HECILinux FWULClient;
139*9203SMark.Logan@Sun.COM 
140*9203SMark.Logan@Sun.COM private:
141*9203SMark.Logan@Sun.COM 	HECI_STATUS _call(const unsigned char *command, UINT32 command_size, UINT8 **readBuffer, UINT32 *outBuffSize);
142*9203SMark.Logan@Sun.COM 
143*9203SMark.Logan@Sun.COM 	bool _verbose;
144*9203SMark.Logan@Sun.COM };
145*9203SMark.Logan@Sun.COM 
146*9203SMark.Logan@Sun.COM #endif //__FWUL_COMMAND_H__
147*9203SMark.Logan@Sun.COM 
148