@@ -27,13 +27,15 @@
int rmi_mailbox_xfer(struct sbrmi_data *data,
struct apml_message *msg)
{
- unsigned int bytes;
+ unsigned int bytes, ec;
int i, ret, retry = 10;
int sw_status;
u8 byte;
mutex_lock(&data->lock);
+ msg->fw_ret_code = 0;
+
/* Indicate firmware a command is to be serviced */
ret = regmap_write(data->regmap, SBRMI_INBNDMSG7, START_CMD);
if (ret < 0)
@@ -85,6 +87,9 @@ int rmi_mailbox_xfer(struct sbrmi_data *data,
goto exit_unlock;
}
+ ret = regmap_read(data->regmap, SBRMI_OUTBNDMSG7, &ec);
+ if (ret || ec)
+ goto exit_clear_alert;
/*
* For a read operation, the initiator (BMC) reads the firmware
* response Command Data Out[31:0] from SBRMI::OutBndMsg_inst[4:1]
@@ -100,12 +105,17 @@ int rmi_mailbox_xfer(struct sbrmi_data *data,
}
}
+exit_clear_alert:
/*
* BMC must write 1'b1 to SBRMI::Status[SwAlertSts] to clear the
* ALERT to initiator
*/
ret = regmap_write(data->regmap, SBRMI_STATUS,
sw_status | SW_ALERT_MASK);
+ if (ec) {
+ ret = -EPROTOTYPE;
+ msg->fw_ret_code = ec;
+ }
exit_unlock:
mutex_unlock(&data->lock);
return ret;
@@ -38,6 +38,10 @@ struct apml_message {
__u32 mb_in[2];
__u8 reg_in[8];
} data_in;
+ /*
+ * Error code is returned in case of soft mailbox
+ */
+ __u32 fw_ret_code;
} __attribute__((packed));
/* ioctl command for mailbox msgs using generic _IOWR */