Add helper functions that make it more convenient to send and receive the most common types of commands to the Wilco embedded controller. Change-Id: I9cee1a3b2f9d507f6ecdfae9f4a34ba59056cb91 Signed-off-by: Duncan Laurie <dlaurie@google.com> Reviewed-on: https://review.coreboot.org/29114 Reviewed-by: Aaron Durbin <adurbin@chromium.org> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
120 lines
3.5 KiB
C
120 lines
3.5 KiB
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright 2018 Google LLC
|
|
*
|
|
* 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; version 2 of the License.
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
#ifndef EC_GOOGLE_WILCO_EC_H
|
|
#define EC_GOOGLE_WILCO_EC_H
|
|
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
|
|
/* Different supported message types */
|
|
enum wilco_ec_msg_type {
|
|
WILCO_EC_MSG_RAW, /* Raw message, do not skip any data */
|
|
WILCO_EC_MSG_DEFAULT, /* Skip 1 byte of response data */
|
|
WILCO_EC_MSG_NO_RESPONSE, /* EC does not respond to command */
|
|
};
|
|
|
|
/**
|
|
* wilco_ec_mailbox
|
|
*
|
|
* Send a command request to the EC mailbox and receive the response.
|
|
*
|
|
* @type: Mailbox message type, see enum above
|
|
* @command: Command to execute
|
|
* @request_data: Request data buffer
|
|
* @request_size: Number of bytes in request data buffer (max 32)
|
|
* @response_data: Response data buffer
|
|
* @response_size: Number of bytes in response data buffer (max 32)
|
|
*
|
|
* @return number of bytes received, negative error code on failure
|
|
*/
|
|
int wilco_ec_mailbox(enum wilco_ec_msg_type type, uint8_t command,
|
|
const void *request_data, size_t request_size,
|
|
void *response_data, size_t response_size);
|
|
|
|
/**
|
|
* wilco_ec_send
|
|
*
|
|
* Send a basic EC command with a one byte parameter with no
|
|
* returned data;
|
|
*
|
|
* @command: Command to execute
|
|
* @param: Command parameter to send
|
|
*
|
|
* @return negative error code on failure
|
|
*/
|
|
static inline int wilco_ec_send(uint8_t command, uint8_t param)
|
|
{
|
|
return wilco_ec_mailbox(WILCO_EC_MSG_DEFAULT, command,
|
|
¶m, sizeof(param), NULL, 0);
|
|
}
|
|
|
|
/**
|
|
* wilco_ec_send_noargs
|
|
*
|
|
* Send a basic EC command with no parameters and no returned data.
|
|
*
|
|
* @command: Command to execute
|
|
*
|
|
* @return negative error code on failure
|
|
*/
|
|
static inline int wilco_ec_send_noargs(uint8_t command)
|
|
{
|
|
return wilco_ec_mailbox(WILCO_EC_MSG_DEFAULT, command,
|
|
NULL, 0, NULL, 0);
|
|
}
|
|
|
|
/**
|
|
* wilco_ec_sendrecv
|
|
*
|
|
* Send a basic EC command with a one byte parameter, ignoring the
|
|
* first byte of returned data to match the common behavior.
|
|
* The maximum response size is 31 due to the ignored byte.
|
|
*
|
|
* @command: Command to execute
|
|
* @param: Command parameter to send
|
|
* @data: Response data buffer
|
|
* @size: Number of bytes in response data buffer (max 31)
|
|
*
|
|
* @return number of bytes received, negative error code on failure
|
|
*/
|
|
static inline int wilco_ec_sendrecv(uint8_t command, uint8_t param,
|
|
void *data, size_t size)
|
|
{
|
|
return wilco_ec_mailbox(WILCO_EC_MSG_DEFAULT, command,
|
|
¶m, sizeof(param), data, size);
|
|
}
|
|
|
|
/**
|
|
* wilco_ec_sendrecv_noargs
|
|
*
|
|
* Send a basic EC command with no parameters, ignoring the
|
|
* first byte of returned data to match the common behavior.
|
|
* The maximum response size is 31 due to the ignored byte.
|
|
*
|
|
* @command: Command to execute
|
|
* @data: Response data buffer
|
|
* @size: Number of bytes in response data buffer (max 31)
|
|
*
|
|
* @return number of bytes received, negative error code on failure
|
|
*/
|
|
static inline int wilco_ec_sendrecv_noargs(uint8_t command,
|
|
void *data, size_t size)
|
|
{
|
|
return wilco_ec_mailbox(WILCO_EC_MSG_DEFAULT, command,
|
|
NULL, 0, data, size);
|
|
}
|
|
|
|
#endif /* EC_GOOGLE_WILCO_EC_H */
|