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 __HECI_INTRFACE_H__ 32*9203SMark.Logan@Sun.COM #define __HECI_INTRFACE_H__ 33*9203SMark.Logan@Sun.COM 34*9203SMark.Logan@Sun.COM typedef unsigned char UINT8; 35*9203SMark.Logan@Sun.COM typedef unsigned short UINT16; 36*9203SMark.Logan@Sun.COM typedef unsigned int UINT32; 37*9203SMark.Logan@Sun.COM typedef char CHAR; 38*9203SMark.Logan@Sun.COM typedef unsigned long ULONG; 39*9203SMark.Logan@Sun.COM typedef UINT32 AMT_STATUS; 40*9203SMark.Logan@Sun.COM typedef UINT32 AMT_BOOLEAN; 41*9203SMark.Logan@Sun.COM 42*9203SMark.Logan@Sun.COM typedef enum _HECI_STATUS { 43*9203SMark.Logan@Sun.COM HECI_STATUS_OK = 0x0, 44*9203SMark.Logan@Sun.COM HECI_STATUS_GENERAL_ERROR = 0x2000, 45*9203SMark.Logan@Sun.COM HECI_STATUS_LOCATE_DEVICE_ERROR, 46*9203SMark.Logan@Sun.COM HECI_STATUS_MEMORY_ACCESS_ERROR, 47*9203SMark.Logan@Sun.COM HECI_STATUS_WRITE_REGISTER_ERROR, 48*9203SMark.Logan@Sun.COM HECI_STATUS_MEMORY_ALLOCATION_ERROR, 49*9203SMark.Logan@Sun.COM HECI_STATUS_BUFFER_OVEREFLOW_ERROR, 50*9203SMark.Logan@Sun.COM HECI_STATUS_NOT_ENOUGH_MEMORY, 51*9203SMark.Logan@Sun.COM HECI_STATUS_MSG_TRANSMISSION_ERROR, 52*9203SMark.Logan@Sun.COM HECI_STATUS_VERSION_MISMATCH, 53*9203SMark.Logan@Sun.COM HECI_STATUS_UNEXPECTED_INTERRUPT_REASON, 54*9203SMark.Logan@Sun.COM HECI_STATUS_TIMEOUT_ERROR, 55*9203SMark.Logan@Sun.COM HECI_STATUS_UNEXPECTED_RESPONSE, 56*9203SMark.Logan@Sun.COM HECI_STATUS_UNKNOWN_MESSAGE, 57*9203SMark.Logan@Sun.COM HECI_STATUS_CANNOT_FOUND_HOST_CLIENT, 58*9203SMark.Logan@Sun.COM HECI_STATUS_CANNOT_FOUND_ME_CLIENT, 59*9203SMark.Logan@Sun.COM HECI_STATUS_CLIENT_ALREADY_CONNECTED, 60*9203SMark.Logan@Sun.COM HECI_STATUS_NO_FREE_CONNECTION, 61*9203SMark.Logan@Sun.COM HECI_STATUS_ILLEGAL_PARAMETER, 62*9203SMark.Logan@Sun.COM HECI_STATUS_FLOW_CONTROL_ERROR, 63*9203SMark.Logan@Sun.COM HECI_STATUS_NO_MESSAGE, 64*9203SMark.Logan@Sun.COM HECI_STATUS_BUFFER_TOO_LARGE, 65*9203SMark.Logan@Sun.COM HECI_STATUS_BUFFER_TOO_SMALL, 66*9203SMark.Logan@Sun.COM HECI_STATUS_BUFFER_NOT_EMPTY, 67*9203SMark.Logan@Sun.COM NUM_OF_HECI_STATUSES 68*9203SMark.Logan@Sun.COM } HECI_STATUS; 69*9203SMark.Logan@Sun.COM 70*9203SMark.Logan@Sun.COM const GUID HECI_PTHI = {0x12f80028, 0xb4b7, 0x4b2d, {0xac, 0xa8, 0x46, 0xe0, 0xff, 0x65, 0x81, 0x4c}}; 71*9203SMark.Logan@Sun.COM 72*9203SMark.Logan@Sun.COM // Define GUID used to connect to the FWUpdate client (via the HECI device) 73*9203SMark.Logan@Sun.COM // {309DCDE8-CCB1-4062-8F78-600115A34327} 74*9203SMark.Logan@Sun.COM const GUID FW_UPDATE_GUID = {0x309dcde8, 0xccb1, 0x4062, {0x8f, 0x78, 0x60, 0x1, 0x15, 0xa3, 0x43, 0x27}}; 75*9203SMark.Logan@Sun.COM 76*9203SMark.Logan@Sun.COM const GUID WD_GUID = {0x05B79A6F, 0x4628, 0x4D7F, {0x89, 0x9D, 0xA9, 0x15, 0x14, 0xCB, 0x32, 0xAB}}; 77*9203SMark.Logan@Sun.COM 78*9203SMark.Logan@Sun.COM #pragma pack(1) 79*9203SMark.Logan@Sun.COM 80*9203SMark.Logan@Sun.COM typedef struct _HECI_VERSION { 81*9203SMark.Logan@Sun.COM UINT8 major; 82*9203SMark.Logan@Sun.COM UINT8 minor; 83*9203SMark.Logan@Sun.COM UINT8 hotfix; 84*9203SMark.Logan@Sun.COM UINT16 build; 85*9203SMark.Logan@Sun.COM } HECI_VERSION; 86*9203SMark.Logan@Sun.COM 87*9203SMark.Logan@Sun.COM typedef struct _HECI_CLIENT { 88*9203SMark.Logan@Sun.COM UINT32 MaxMessageLength; 89*9203SMark.Logan@Sun.COM UINT8 ProtocolVersion; 90*9203SMark.Logan@Sun.COM } HECI_CLIENT; 91*9203SMark.Logan@Sun.COM 92*9203SMark.Logan@Sun.COM typedef union _MEFWCAPS_SKU 93*9203SMark.Logan@Sun.COM { 94*9203SMark.Logan@Sun.COM UINT32 Data; 95*9203SMark.Logan@Sun.COM struct { 96*9203SMark.Logan@Sun.COM UINT32 Reserved :1; //Legacy 97*9203SMark.Logan@Sun.COM UINT32 Qst :1; //QST 98*9203SMark.Logan@Sun.COM UINT32 Asf :1; //ASF2 99*9203SMark.Logan@Sun.COM UINT32 Amt :1; //AMT Professional 100*9203SMark.Logan@Sun.COM UINT32 AmtFund :1; //AMT Fundamental 101*9203SMark.Logan@Sun.COM UINT32 Tpm :1; //TPM 102*9203SMark.Logan@Sun.COM UINT32 Dt :1; //Danbury Technology 103*9203SMark.Logan@Sun.COM UINT32 Fps :1; //Fingerprint Sensor 104*9203SMark.Logan@Sun.COM UINT32 HomeIT :1; //Home IT 105*9203SMark.Logan@Sun.COM UINT32 Mctp :1; //MCTP 106*9203SMark.Logan@Sun.COM UINT32 WoX :1; //Wake on X 107*9203SMark.Logan@Sun.COM UINT32 PmcPatch :1; //PMC Patch 108*9203SMark.Logan@Sun.COM UINT32 Ve :1; //VE 109*9203SMark.Logan@Sun.COM UINT32 Tdt :1; //Theft Deterrent Technology 110*9203SMark.Logan@Sun.COM UINT32 Corp :1; //Corporate 111*9203SMark.Logan@Sun.COM UINT32 Reserved2 :17; 112*9203SMark.Logan@Sun.COM } Fields; 113*9203SMark.Logan@Sun.COM } MEFWCAPS_SKU; 114*9203SMark.Logan@Sun.COM 115*9203SMark.Logan@Sun.COM typedef enum _MEFWCAPS_MANAGEABILITY_SUPP 116*9203SMark.Logan@Sun.COM { 117*9203SMark.Logan@Sun.COM MEFWCAPS_MANAGEABILITY_SUPP_NONE = 0, 118*9203SMark.Logan@Sun.COM MEFWCAPS_MANAGEABILITY_SUPP_AMT, 119*9203SMark.Logan@Sun.COM MEFWCAPS_MANAGEABILITY_SUPP_ASF, 120*9203SMark.Logan@Sun.COM MEFWCAPS_MANAGEABILITY_SUPP_CP 121*9203SMark.Logan@Sun.COM } MEFWCAPS_MANAGEABILITY_SUPP; 122*9203SMark.Logan@Sun.COM 123*9203SMark.Logan@Sun.COM 124*9203SMark.Logan@Sun.COM #pragma pack() 125*9203SMark.Logan@Sun.COM 126*9203SMark.Logan@Sun.COM #endif // __HECI_INTRFACE_H__ 127