OpenSolaris_b135/cmd/lms/heci/FWULCommand.h

/*******************************************************************************
 * Copyright (C) 2004-2008 Intel Corp. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 *  - Redistributions of source code must retain the above copyright notice,
 *    this list of conditions and the following disclaimer.
 *
 *  - Redistributions in binary form must reproduce the above copyright notice,
 *    this list of conditions and the following disclaimer in the documentation
 *    and/or other materials provided with the distribution.
 *
 *  - Neither the name of Intel Corp. nor the names of its
 *    contributors may be used to endorse or promote products derived from this
 *    software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS''
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED. IN NO EVENT SHALL Intel Corp. OR THE CONTRIBUTORS
 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 *******************************************************************************/

#ifndef __FWUL_COMMAND_H__
#define __FWUL_COMMAND_H__

#include "HECIUnix.h"
#include "StatusCodeDefinitions.h"

#pragma pack(1)

typedef struct _FWU_VERSION
{
	UINT16      Major;
	UINT16      Minor;
	UINT16      Hotfix;
	UINT16      Build;
} FWU_VERSION;

typedef enum
{
	FWU_GET_VERSION = 0,
	FWU_GET_VERSION_REPLY,
	FWU_START,
	FWU_START_REPLY,
	FWU_DATA,
	FWU_DATA_REPLY,
	FWU_END,
	FWU_END_REPLY,
	FWU_GET_INFO,
	FWU_GET_INFO_REPLY
} FWU_HECI_MESSAGE_TYPE;

typedef struct _ME_GET_FW_UPDATE_INFO_REQUEST
{
	UINT32      MessageID;
} ME_GET_FW_UPDATE_INFO_REQUEST;

typedef struct _FWU_MSG_REPLY_HEADER
{
	UINT32      MessageType;
	UINT32      Status;
} FWU_MSG_REPLY_HEADER;

typedef struct _FWU_MSG_REPLY_HEADER_V3
{
	UINT8       MessageType;
	UINT32      Status;
} FWU_MSG_REPLY_HEADER_V3;

typedef struct _FWU_GET_VERSION_MSG_REPLY
{
	UINT32      MessageType;
	UINT32      Status;
	UINT32      Sku;
	UINT32      ICHVer;
	UINT32      MCHVer;
	UINT32      Vendor;
	UINT32      LastFwUpdateStatus;
	UINT32      HwSku;
	FWU_VERSION CodeVersion;
	FWU_VERSION AMTVersion;
	UINT16      EnabledUpdateInterfaces;
	UINT16      Reserved;
} FWU_GET_VERSION_MSG_REPLY;

typedef struct _FWU_GET_VERSION_MSG_REPLY_V3
{
	UINT8       MessageType;
	UINT32      Status;
	UINT32      Sku;
	UINT32      ICHVer;
	UINT32      MCHVer;
	UINT32      Vendor;
	FWU_VERSION CodeVersion;
	FWU_VERSION RcvyVersion;
	UINT16      EnabledUpdateInterfaces;
	UINT32      LastFwUpdateStatus;
	UINT32      Reserved;
} FWU_GET_VERSION_MSG_REPLY_V3;

typedef struct _FWU_GET_INFO_MSG_REPLY
{
	UINT32      MessageType;
	UINT32      Status;
	FWU_VERSION MEBxVersion;
	UINT32      FlashOverridePolicy;
	UINT32      ManageabilityMode;
	UINT32      BiosBootState;
	struct {
		UINT32          CryptoFuse   :1;
		UINT32          FlashProtection:1;
		UINT32          FwOverrideQualifier:2;
		UINT32          MeResetReason:2;
		UINT32          FwOverrideCounter:8;
		UINT32          reserved:18;
	} Fields;
	UINT8       BiosVersion[20];
} FWU_GET_INFO_MSG_REPLY;

#pragma pack(0)

class FWULCommand
{
public:
	FWULCommand(bool verbose = false);
	~FWULCommand();

	HECI_STATUS GetFWUVersionAndInfo(FWU_GET_VERSION_MSG_REPLY &verMsg, FWU_GET_INFO_MSG_REPLY &infoMsg);

	HECILinux FWULClient;

private:
	HECI_STATUS _call(const unsigned char *command, UINT32 command_size, UINT8 **readBuffer, UINT32 *outBuffSize);

	bool _verbose;
};

#endif //__FWUL_COMMAND_H__