xref: /onnv-gate/usr/src/cmd/lms/heci/HECI_if.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 __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