ec/chromeec: Merge upstream V3 structure and constant definition.
Chrome EC protocol V3 has several new command structure and constants defined. Simply cherry-picking changes from upstream. Change-Id: I7cb61d3b632ff32743e4fa312e0cc691c1c4c663 Signed-off-by: Hung-Te Lin <hungte@chromium.org> Reviewed-on: http://review.coreboot.org/3748 Tested-by: build bot (Jenkins) Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
This commit is contained in:
parent
3a0d0d8622
commit
ce7a5a790b
|
@ -28,6 +28,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Current version of this protocol */
|
/* Current version of this protocol */
|
||||||
|
/* TODO: This is effectively useless; protocol is determined in other ways */
|
||||||
#define EC_PROTO_VERSION 0x00000002
|
#define EC_PROTO_VERSION 0x00000002
|
||||||
|
|
||||||
/* Command version mask */
|
/* Command version mask */
|
||||||
|
@ -45,6 +46,8 @@
|
||||||
#define EC_LPC_ADDR_HOST_ARGS 0x800 /* and 0x801, 0x802, 0x803 */
|
#define EC_LPC_ADDR_HOST_ARGS 0x800 /* and 0x801, 0x802, 0x803 */
|
||||||
#define EC_LPC_ADDR_HOST_PARAM 0x804
|
#define EC_LPC_ADDR_HOST_PARAM 0x804
|
||||||
#define EC_HOST_PARAM_SIZE 0x0fc /* Size of param area in bytes */
|
#define EC_HOST_PARAM_SIZE 0x0fc /* Size of param area in bytes */
|
||||||
|
#define EC_LPC_ADDR_HOST_PACKET 0x800 /* Offset of version 3 packet */
|
||||||
|
#define EC_HOST_PACKET_SIZE 0x100 /* Max size of version 3 packet */
|
||||||
|
|
||||||
/* The actual block is 0x800-0x8ff, but some BIOSes think it's 0x880-0x8ff
|
/* The actual block is 0x800-0x8ff, but some BIOSes think it's 0x880-0x8ff
|
||||||
* and they tell the kernel that so we have to think of it as two parts. */
|
* and they tell the kernel that so we have to think of it as two parts. */
|
||||||
|
@ -134,6 +137,8 @@
|
||||||
/* Host command interface flags */
|
/* Host command interface flags */
|
||||||
/* Host command interface supports LPC args (LPC interface only) */
|
/* Host command interface supports LPC args (LPC interface only) */
|
||||||
#define EC_HOST_CMD_FLAG_LPC_ARGS_SUPPORTED 0x01
|
#define EC_HOST_CMD_FLAG_LPC_ARGS_SUPPORTED 0x01
|
||||||
|
/* Host command interface supports version 3 protocol */
|
||||||
|
#define EC_HOST_CMD_FLAG_VERSION_3 0x02
|
||||||
|
|
||||||
/* Wireless switch flags */
|
/* Wireless switch flags */
|
||||||
#define EC_WIRELESS_SWITCH_WLAN 0x01
|
#define EC_WIRELESS_SWITCH_WLAN 0x01
|
||||||
|
@ -194,6 +199,9 @@ enum ec_status {
|
||||||
EC_RES_UNAVAILABLE = 9, /* No response available */
|
EC_RES_UNAVAILABLE = 9, /* No response available */
|
||||||
EC_RES_TIMEOUT = 10, /* We got a timeout */
|
EC_RES_TIMEOUT = 10, /* We got a timeout */
|
||||||
EC_RES_OVERFLOW = 11, /* Table / data overflow */
|
EC_RES_OVERFLOW = 11, /* Table / data overflow */
|
||||||
|
EC_RES_INVALID_HEADER = 12, /* Header contains invalid data */
|
||||||
|
EC_RES_REQUEST_TRUNCATED = 13, /* Didn't get the entire request */
|
||||||
|
EC_RES_RESPONSE_TOO_BIG = 14 /* Response was too big to handle */
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -275,6 +283,68 @@ struct ec_lpc_host_args {
|
||||||
*/
|
*/
|
||||||
#define EC_HOST_ARGS_FLAG_TO_HOST 0x02
|
#define EC_HOST_ARGS_FLAG_TO_HOST 0x02
|
||||||
|
|
||||||
|
/*****************************************************************************/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Value written to legacy command port / prefix byte to indicate protocol
|
||||||
|
* 3+ structs are being used. Usage is bus-dependent.
|
||||||
|
*/
|
||||||
|
#define EC_COMMAND_PROTOCOL_3 0xda
|
||||||
|
|
||||||
|
#define EC_HOST_REQUEST_VERSION 3
|
||||||
|
|
||||||
|
/* Version 3 request from host */
|
||||||
|
struct ec_host_request {
|
||||||
|
/* Struct version (=3)
|
||||||
|
*
|
||||||
|
* EC will return EC_RES_INVALID_HEADER if it receives a header with a
|
||||||
|
* version it doesn't know how to parse.
|
||||||
|
*/
|
||||||
|
uint8_t struct_version;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Checksum of request and data; sum of all bytes including checksum
|
||||||
|
* should total to 0.
|
||||||
|
*/
|
||||||
|
uint8_t checksum;
|
||||||
|
|
||||||
|
/* Command code */
|
||||||
|
uint16_t command;
|
||||||
|
|
||||||
|
/* Command version */
|
||||||
|
uint8_t command_version;
|
||||||
|
|
||||||
|
/* Unused byte in current protocol version; set to 0 */
|
||||||
|
uint8_t reserved;
|
||||||
|
|
||||||
|
/* Length of data which follows this header */
|
||||||
|
uint16_t data_len;
|
||||||
|
} __packed;
|
||||||
|
|
||||||
|
#define EC_HOST_RESPONSE_VERSION 3
|
||||||
|
|
||||||
|
/* Version 3 response from EC */
|
||||||
|
struct ec_host_response {
|
||||||
|
/* Struct version (=3) */
|
||||||
|
uint8_t struct_version;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Checksum of response and data; sum of all bytes including checksum
|
||||||
|
* should total to 0.
|
||||||
|
*/
|
||||||
|
uint8_t checksum;
|
||||||
|
|
||||||
|
/* Result code (EC_RES_*) */
|
||||||
|
uint16_t result;
|
||||||
|
|
||||||
|
/* Length of data which follows this header */
|
||||||
|
uint16_t data_len;
|
||||||
|
|
||||||
|
/* Unused bytes in current protocol version; set to 0 */
|
||||||
|
uint16_t reserved;
|
||||||
|
} __packed;
|
||||||
|
|
||||||
|
/*****************************************************************************/
|
||||||
/*
|
/*
|
||||||
* Notes on commands:
|
* Notes on commands:
|
||||||
*
|
*
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
/*
|
||||||
|
* Chromium OS Matrix Keyboard Message Protocol definitions
|
||||||
|
*
|
||||||
|
* Copyright (c) 2012 The Chromium OS Authors.
|
||||||
|
* See file CREDITS for list of people who contributed to this
|
||||||
|
* project.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation; either version 2 of
|
||||||
|
* the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that 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.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||||
|
* MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _CROS_MESSAGE_H
|
||||||
|
#define _CROS_MESSAGE_H
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Command interface between EC and AP, for LPC, I2C and SPI interfaces.
|
||||||
|
*
|
||||||
|
* This is copied from the Chromium OS Open Source Embedded Controller code.
|
||||||
|
*/
|
||||||
|
enum {
|
||||||
|
/* The header byte, which follows the preamble */
|
||||||
|
MSG_HEADER = 0xec,
|
||||||
|
|
||||||
|
MSG_HEADER_BYTES = 3,
|
||||||
|
MSG_TRAILER_BYTES = 2,
|
||||||
|
MSG_PROTO_BYTES = MSG_HEADER_BYTES + MSG_TRAILER_BYTES,
|
||||||
|
|
||||||
|
/* Max length of messages */
|
||||||
|
MSG_BYTES = EC_HOST_PARAM_SIZE + MSG_PROTO_BYTES,
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue