blob: e4ede3c1c9c2386f138612472196f496b3ed7596 [file] [log] [blame]
// SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
/*
* On some chiptod errors, ask the FSP for a new topology
*
* Copyright 2013-2017 IBM Corp.
*/
#define pr_fmt(fmt) "CHIPTOD: " fmt
#include <skiboot.h>
#include <chiptod.h>
#include <fsp.h>
/* Response status for fsp command 0xE6, s/c 0x06 (Enable/Disable Topology) */
#define FSP_STATUS_TOPO_IN_USE 0xb8 /* topology is in use */
static bool fsp_chiptod_update_topology(uint32_t cmd_sub_mod,
struct fsp_msg *msg)
{
struct fsp_msg *resp;
enum chiptod_topology topo;
bool action;
uint8_t status = 0;
switch (cmd_sub_mod) {
case FSP_CMD_TOPO_ENABLE_DISABLE:
/*
* Action Values: 0x00 = Disable, 0x01 = Enable
* Topology Values: 0x00 = Primary, 0x01 = Secondary
*/
action = !!msg->data.bytes[2];
topo = msg->data.bytes[3];
prlog(PR_DEBUG, "Topology update event:\n");
prlog(PR_DEBUG, " Action = %s, Topology = %s\n",
action ? "Enable" : "Disable",
topo ? "Secondary" : "Primary");
if (!chiptod_adjust_topology(topo, action))
status = FSP_STATUS_TOPO_IN_USE;
else
status = 0x00;
resp = fsp_mkmsg(FSP_RSP_TOPO_ENABLE_DISABLE | status, 0);
if (!resp) {
prerror("Response allocation failed\n");
return false;
}
if (fsp_queue_msg(resp, fsp_freemsg)) {
fsp_freemsg(resp);
prerror("Failed to queue response msg\n");
return false;
}
return true;
default:
prlog(PR_DEBUG, "Unhandled sub cmd: %06x\n", cmd_sub_mod);
break;
}
return false;
}
static struct fsp_client fsp_chiptod_client = {
.message = fsp_chiptod_update_topology,
};
void fsp_chiptod_init(void)
{
/* Register for Class E6 (HW maintanance) */
fsp_register_client(&fsp_chiptod_client, FSP_MCLASS_HW_MAINT);
}