hw.h 6.9 KB
Newer Older
1 2 3
/*
 *
 * Intel Management Engine Interface (Intel MEI) Linux driver
4
 * Copyright (c) 2003-2012, Intel Corporation.
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms and conditions of the GNU General Public License,
 * version 2, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 * more details.
 *
 */

#ifndef _MEI_HW_TYPES_H_
#define _MEI_HW_TYPES_H_

#include <linux/uuid.h>

/*
23
 * Timeouts in Seconds
24
 */
25
#define MEI_HW_READY_TIMEOUT        2  /* Timeout on ready message */
26
#define MEI_CONNECT_TIMEOUT         3  /* HPS: at least 2 seconds */
27

28 29
#define MEI_CL_CONNECT_TIMEOUT     15  /* HPS: Client Connect Timeout */
#define MEI_CLIENTS_INIT_TIMEOUT   15  /* HPS: Clients Enumeration Timeout */
30

31 32
#define MEI_IAMTHIF_STALL_TIMER    12  /* HPS */
#define MEI_IAMTHIF_READ_TIMER     10  /* HPS */
33

34
#define MEI_PGI_TIMEOUT            1  /* PG Isolation time response 1 sec */
35
#define MEI_HBM_TIMEOUT            1   /* 1 second */
36 37 38 39

/*
 * MEI Version
 */
40
#define HBM_MINOR_VERSION                   1
41 42
#define HBM_MAJOR_VERSION                   1

43 44 45 46 47 48
/*
 * MEI version with PGI support
 */
#define HBM_MINOR_VERSION_PGI               1
#define HBM_MAJOR_VERSION_PGI               1

49 50 51 52 53
/* Host bus message command opcode */
#define MEI_HBM_CMD_OP_MSK                  0x7f
/* Host bus message command RESPONSE */
#define MEI_HBM_CMD_RES_MSK                 0x80

54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
/*
 * MEI Bus Message Command IDs
 */
#define HOST_START_REQ_CMD                  0x01
#define HOST_START_RES_CMD                  0x81

#define HOST_STOP_REQ_CMD                   0x02
#define HOST_STOP_RES_CMD                   0x82

#define ME_STOP_REQ_CMD                     0x03

#define HOST_ENUM_REQ_CMD                   0x04
#define HOST_ENUM_RES_CMD                   0x84

#define HOST_CLIENT_PROPERTIES_REQ_CMD      0x05
#define HOST_CLIENT_PROPERTIES_RES_CMD      0x85

#define CLIENT_CONNECT_REQ_CMD              0x06
#define CLIENT_CONNECT_RES_CMD              0x86

#define CLIENT_DISCONNECT_REQ_CMD           0x07
#define CLIENT_DISCONNECT_RES_CMD           0x87

77
#define MEI_FLOW_CONTROL_CMD                0x08
78

79 80 81 82 83
#define MEI_PG_ISOLATION_ENTRY_REQ_CMD      0x0a
#define MEI_PG_ISOLATION_ENTRY_RES_CMD      0x8a
#define MEI_PG_ISOLATION_EXIT_REQ_CMD       0x0b
#define MEI_PG_ISOLATION_EXIT_RES_CMD       0x8b

84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
/*
 * MEI Stop Reason
 * used by hbm_host_stop_request.reason
 */
enum mei_stop_reason_types {
	DRIVER_STOP_REQUEST = 0x00,
	DEVICE_D1_ENTRY = 0x01,
	DEVICE_D2_ENTRY = 0x02,
	DEVICE_D3_ENTRY = 0x03,
	SYSTEM_S1_ENTRY = 0x04,
	SYSTEM_S2_ENTRY = 0x05,
	SYSTEM_S3_ENTRY = 0x06,
	SYSTEM_S4_ENTRY = 0x07,
	SYSTEM_S5_ENTRY = 0x08
};

100 101

/**
102
 * enum mei_hbm_status  - mei host bus messages return values
103
 *
104 105 106 107 108 109 110 111
 * @MEI_HBMS_SUCCESS           : status success
 * @MEI_HBMS_CLIENT_NOT_FOUND  : client not found
 * @MEI_HBMS_ALREADY_EXISTS    : connection already established
 * @MEI_HBMS_REJECTED          : connection is rejected
 * @MEI_HBMS_INVALID_PARAMETER : invalid parameter
 * @MEI_HBMS_NOT_ALLOWED       : operation not allowed
 * @MEI_HBMS_ALREADY_STARTED   : system is already started
 * @MEI_HBMS_NOT_STARTED       : system not started
A
Alexander Usyskin 已提交
112 113
 *
 * @MEI_HBMS_MAX               : sentinel
114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
 */
enum mei_hbm_status {
	MEI_HBMS_SUCCESS           = 0,
	MEI_HBMS_CLIENT_NOT_FOUND  = 1,
	MEI_HBMS_ALREADY_EXISTS    = 2,
	MEI_HBMS_REJECTED          = 3,
	MEI_HBMS_INVALID_PARAMETER = 4,
	MEI_HBMS_NOT_ALLOWED       = 5,
	MEI_HBMS_ALREADY_STARTED   = 6,
	MEI_HBMS_NOT_STARTED       = 7,

	MEI_HBMS_MAX
};


129 130 131 132
/*
 * Client Connect Status
 * used by hbm_client_connect_response.status
 */
133
enum mei_cl_connect_status {
134 135 136 137 138
	MEI_CL_CONN_SUCCESS          = MEI_HBMS_SUCCESS,
	MEI_CL_CONN_NOT_FOUND        = MEI_HBMS_CLIENT_NOT_FOUND,
	MEI_CL_CONN_ALREADY_STARTED  = MEI_HBMS_ALREADY_EXISTS,
	MEI_CL_CONN_OUT_OF_RESOURCES = MEI_HBMS_REJECTED,
	MEI_CL_CONN_MESSAGE_SMALL    = MEI_HBMS_INVALID_PARAMETER,
139 140 141 142 143
};

/*
 * Client Disconnect Status
 */
144
enum  mei_cl_disconnect_status {
145
	MEI_CL_DISCONN_SUCCESS = MEI_HBMS_SUCCESS
146 147 148 149 150 151 152 153 154
};

/*
 *  MEI BUS Interface Section
 */
struct mei_msg_hdr {
	u32 me_addr:8;
	u32 host_addr:8;
	u32 length:9;
155 156
	u32 reserved:5;
	u32 internal:1;
157 158 159 160 161
	u32 msg_complete:1;
} __packed;


struct mei_bus_message {
162 163
	u8 hbm_cmd;
	u8 data[0];
164 165
} __packed;

166 167 168 169
/**
 * struct hbm_cl_cmd - client specific host bus command
 *	CONNECT, DISCONNECT, and FlOW CONTROL
 *
170 171 172 173
 * @hbm_cmd: bus message command header
 * @me_addr: address of the client in ME
 * @host_addr: address of the client in the driver
 * @data: generic data
174 175 176 177 178 179 180 181
 */
struct mei_hbm_cl_cmd {
	u8 hbm_cmd;
	u8 me_addr;
	u8 host_addr;
	u8 data;
};

182 183 184 185 186 187
struct hbm_version {
	u8 minor_version;
	u8 major_version;
} __packed;

struct hbm_host_version_request {
188
	u8 hbm_cmd;
189 190 191 192 193
	u8 reserved;
	struct hbm_version host_version;
} __packed;

struct hbm_host_version_response {
194
	u8 hbm_cmd;
195
	u8 host_version_supported;
196 197 198 199
	struct hbm_version me_max_version;
} __packed;

struct hbm_host_stop_request {
200
	u8 hbm_cmd;
201 202 203 204 205
	u8 reason;
	u8 reserved[2];
} __packed;

struct hbm_host_stop_response {
206
	u8 hbm_cmd;
207 208 209 210
	u8 reserved[3];
} __packed;

struct hbm_me_stop_request {
211
	u8 hbm_cmd;
212 213 214 215 216
	u8 reason;
	u8 reserved[2];
} __packed;

struct hbm_host_enum_request {
217
	u8 hbm_cmd;
218 219 220 221
	u8 reserved[3];
} __packed;

struct hbm_host_enum_response {
222
	u8 hbm_cmd;
223 224 225 226 227 228 229 230 231 232 233 234 235 236
	u8 reserved[3];
	u8 valid_addresses[32];
} __packed;

struct mei_client_properties {
	uuid_le protocol_name;
	u8 protocol_version;
	u8 max_number_of_connections;
	u8 fixed_address;
	u8 single_recv_buf;
	u32 max_msg_length;
} __packed;

struct hbm_props_request {
237
	u8 hbm_cmd;
238
	u8 me_addr;
239 240 241 242
	u8 reserved[2];
} __packed;

struct hbm_props_response {
243
	u8 hbm_cmd;
244
	u8 me_addr;
245 246 247 248 249
	u8 status;
	u8 reserved[1];
	struct mei_client_properties client_properties;
} __packed;

250 251 252
/**
 * struct hbm_power_gate - power gate request/response
 *
253 254
 * @hbm_cmd: bus message command header
 * @reserved: reserved
255 256 257 258 259 260
 */
struct hbm_power_gate {
	u8 hbm_cmd;
	u8 reserved[3];
} __packed;

261 262 263
/**
 * struct hbm_client_connect_request - connect/disconnect request
 *
264 265 266 267
 * @hbm_cmd: bus message command header
 * @me_addr: address of the client in ME
 * @host_addr: address of the client in the driver
 * @reserved: reserved
268
 */
269
struct hbm_client_connect_request {
270
	u8 hbm_cmd;
271 272 273 274 275
	u8 me_addr;
	u8 host_addr;
	u8 reserved;
} __packed;

276 277 278
/**
 * struct hbm_client_connect_response - connect/disconnect response
 *
279 280 281 282
 * @hbm_cmd: bus message command header
 * @me_addr: address of the client in ME
 * @host_addr: address of the client in the driver
 * @status: status of the request
283
 */
284
struct hbm_client_connect_response {
285
	u8 hbm_cmd;
286 287 288 289 290 291 292 293 294
	u8 me_addr;
	u8 host_addr;
	u8 status;
} __packed;


#define MEI_FC_MESSAGE_RESERVED_LENGTH           5

struct hbm_flow_control {
295
	u8 hbm_cmd;
296 297 298 299 300 301 302
	u8 me_addr;
	u8 host_addr;
	u8 reserved[MEI_FC_MESSAGE_RESERVED_LENGTH];
} __packed;


#endif