soc/intel/{cnl,icl,skl,tgl,common}: Make changes to send_heci_reset_req_message()
Below changes have been implemented in send_heci_reset_req_message(): 1. Modify return values to align with other functions in the same file. 2. Add additional logging. 3. Replace macro definitions of reset types with ENUM. 4. Make changes to caller functions to sync with new return values. 5. Rename send_heci_reset_req_message() to cse_request_global_reset(). Test=Verified on hatch board. Change-Id: I979b169a5bb3a5d4028ef030bcef2b8eeffe86e3 Signed-off-by: Sridhar Siricilla <sridhar.siricilla@intel.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/37584 Reviewed-by: Furquan Shaikh <furquan@google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
63be9181cb
commit
f2eb687d19
|
@ -24,7 +24,7 @@
|
||||||
void do_global_reset(void)
|
void do_global_reset(void)
|
||||||
{
|
{
|
||||||
/* Ask CSE to do the global reset */
|
/* Ask CSE to do the global reset */
|
||||||
if (!send_heci_reset_req_message(GLOBAL_RESET))
|
if (cse_request_global_reset(GLOBAL_RESET))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* global reset if CSE fail to reset */
|
/* global reset if CSE fail to reset */
|
||||||
|
|
|
@ -582,7 +582,7 @@ uint32_t me_read_config32(int offset)
|
||||||
* Sends GLOBAL_RESET_REQ cmd to CSE.The reset type can be GLOBAL_RESET/
|
* Sends GLOBAL_RESET_REQ cmd to CSE.The reset type can be GLOBAL_RESET/
|
||||||
* HOST_RESET_ONLY/CSE_RESET_ONLY.
|
* HOST_RESET_ONLY/CSE_RESET_ONLY.
|
||||||
*/
|
*/
|
||||||
int send_heci_reset_req_message(uint8_t rst_type)
|
int cse_request_global_reset(enum rst_req_type rst_type)
|
||||||
{
|
{
|
||||||
int status;
|
int status;
|
||||||
struct mkhi_hdr reply;
|
struct mkhi_hdr reply;
|
||||||
|
@ -601,27 +601,25 @@ int send_heci_reset_req_message(uint8_t rst_type)
|
||||||
};
|
};
|
||||||
size_t reply_size;
|
size_t reply_size;
|
||||||
|
|
||||||
|
printk(BIOS_DEBUG, "HECI: Global Reset(Type:%d) Command\n", rst_type);
|
||||||
if (!((rst_type == GLOBAL_RESET) ||
|
if (!((rst_type == GLOBAL_RESET) ||
|
||||||
(rst_type == HOST_RESET_ONLY) || (rst_type == CSE_RESET_ONLY)))
|
(rst_type == HOST_RESET_ONLY) || (rst_type == CSE_RESET_ONLY))) {
|
||||||
return -1;
|
printk(BIOS_ERR, "HECI: Unsupported reset type is requested\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
heci_reset();
|
heci_reset();
|
||||||
|
|
||||||
reply_size = sizeof(reply);
|
reply_size = sizeof(reply);
|
||||||
memset(&reply, 0, reply_size);
|
memset(&reply, 0, reply_size);
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "HECI: Global Reset(Type:%d) Command\n", rst_type);
|
|
||||||
if (rst_type == CSE_RESET_ONLY)
|
if (rst_type == CSE_RESET_ONLY)
|
||||||
status = heci_send_receive(&msg, sizeof(msg), NULL, 0);
|
status = heci_send(&msg, sizeof(msg), BIOS_HOST_ADDR, HECI_MKHI_ADDR);
|
||||||
else
|
else
|
||||||
status = heci_send_receive(&msg, sizeof(msg), &reply,
|
status = heci_send_receive(&msg, sizeof(msg), &reply, &reply_size);
|
||||||
&reply_size);
|
|
||||||
|
|
||||||
if (status != 1)
|
printk(BIOS_DEBUG, "HECI: Global Reset %s!\n", status ? "success" : "failure");
|
||||||
return -1;
|
return status;
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "HECI: Global Reset success!\n");
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Sends HMRFPO Enable command to CSE */
|
/* Sends HMRFPO Enable command to CSE */
|
||||||
|
|
|
@ -112,12 +112,18 @@ void cse_set_host_ready(void);
|
||||||
*/
|
*/
|
||||||
uint8_t cse_wait_sec_override_mode(void);
|
uint8_t cse_wait_sec_override_mode(void);
|
||||||
|
|
||||||
|
enum rst_req_type {
|
||||||
|
GLOBAL_RESET = 1,
|
||||||
|
HOST_RESET_ONLY = 2,
|
||||||
|
CSE_RESET_ONLY = 3,
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Sends GLOBAL_RESET_REQ cmd to CSE.The reset type can be
|
* Sends GLOBAL_RESET_REQ cmd to CSE.
|
||||||
* GLOBAL_RESET/HOST_RESET_ONLY/CSE_RESET_ONLY.
|
* The reset type can be one of the above defined reset type.
|
||||||
* Returns -1 on failure and 0 on success.
|
* Returns 0 on failure and 1 on success.
|
||||||
*/
|
*/
|
||||||
int send_heci_reset_req_message(uint8_t rst_type);
|
int cse_request_global_reset(enum rst_req_type rst_type);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Send HMRFPO_ENABLE command.
|
* Send HMRFPO_ENABLE command.
|
||||||
|
@ -138,11 +144,6 @@ int cse_hmrfpo_get_status(void);
|
||||||
/* Fixed Address MEI Header's ME Address field value */
|
/* Fixed Address MEI Header's ME Address field value */
|
||||||
#define HECI_MKHI_ADDR 0x07
|
#define HECI_MKHI_ADDR 0x07
|
||||||
|
|
||||||
/* Command GLOBAL_RESET_REQ Reset Types */
|
|
||||||
#define GLOBAL_RESET 1
|
|
||||||
#define HOST_RESET_ONLY 2
|
|
||||||
#define CSE_RESET_ONLY 3
|
|
||||||
|
|
||||||
/* HMRFPO Status types */
|
/* HMRFPO Status types */
|
||||||
/* Host can't access ME region */
|
/* Host can't access ME region */
|
||||||
#define MKHI_HMRFPO_DISABLED 0
|
#define MKHI_HMRFPO_DISABLED 0
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
void do_global_reset(void)
|
void do_global_reset(void)
|
||||||
{
|
{
|
||||||
/* Ask CSE to do the global reset */
|
/* Ask CSE to do the global reset */
|
||||||
if (!send_heci_reset_req_message(GLOBAL_RESET))
|
if (cse_request_global_reset(GLOBAL_RESET))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* global reset if CSE fail to reset */
|
/* global reset if CSE fail to reset */
|
||||||
|
|
|
@ -441,7 +441,7 @@ int send_global_reset(void)
|
||||||
goto ret;
|
goto ret;
|
||||||
|
|
||||||
/* ME should be in Normal Mode for this command */
|
/* ME should be in Normal Mode for this command */
|
||||||
status = send_heci_reset_req_message(GLOBAL_RESET);
|
status = cse_request_global_reset(GLOBAL_RESET);
|
||||||
ret:
|
ret:
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,7 +37,7 @@ static void do_force_global_reset(void)
|
||||||
|
|
||||||
void do_global_reset(void)
|
void do_global_reset(void)
|
||||||
{
|
{
|
||||||
if (send_global_reset() != 0) {
|
if (!send_global_reset()) {
|
||||||
/* If ME unable to reset platform then
|
/* If ME unable to reset platform then
|
||||||
* force global reset using PMC CF9GR register*/
|
* force global reset using PMC CF9GR register*/
|
||||||
do_force_global_reset();
|
do_force_global_reset();
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
void do_global_reset(void)
|
void do_global_reset(void)
|
||||||
{
|
{
|
||||||
/* Ask CSE to do the global reset */
|
/* Ask CSE to do the global reset */
|
||||||
if (!send_heci_reset_req_message(GLOBAL_RESET))
|
if (cse_request_global_reset(GLOBAL_RESET))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* global reset if CSE fail to reset */
|
/* global reset if CSE fail to reset */
|
||||||
|
|
Loading…
Reference in New Issue