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