firmware: turris-mox-rwtm: Deduplicate command execution code
Deduplicate rWTM command execution calls mbox_send_message() wait_for_completion() mox_get_status() to one function mox_rwtm_exec() Signed-off-by: Marek Behún <kabel@kernel.org> Reviewed-by: Andy Shevchenko <andy@kernel.org> Link: https://lore.kernel.org/r/20240831092050.23093-17-kabel@kernel.org Signed-off-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
parent
82944f65a0
commit
a79f256fc9
@ -157,6 +157,34 @@ static void mox_rwtm_rx_callback(struct mbox_client *cl, void *data)
|
|||||||
complete(&rwtm->cmd_done);
|
complete(&rwtm->cmd_done);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int mox_rwtm_exec(struct mox_rwtm *rwtm, enum mbox_cmd cmd,
|
||||||
|
struct armada_37xx_rwtm_tx_msg *msg,
|
||||||
|
bool interruptible)
|
||||||
|
{
|
||||||
|
struct armada_37xx_rwtm_tx_msg _msg = {};
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (!msg)
|
||||||
|
msg = &_msg;
|
||||||
|
|
||||||
|
msg->command = cmd;
|
||||||
|
|
||||||
|
ret = mbox_send_message(rwtm->mbox, msg);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
if (interruptible) {
|
||||||
|
ret = wait_for_completion_interruptible(&rwtm->cmd_done);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
} else {
|
||||||
|
if (!wait_for_completion_timeout(&rwtm->cmd_done, HZ / 2))
|
||||||
|
return -ETIMEDOUT;
|
||||||
|
}
|
||||||
|
|
||||||
|
return mox_get_status(cmd, rwtm->reply.retval);
|
||||||
|
}
|
||||||
|
|
||||||
static void reply_to_mac_addr(u8 *mac, u32 t1, u32 t2)
|
static void reply_to_mac_addr(u8 *mac, u32 t1, u32 t2)
|
||||||
{
|
{
|
||||||
mac[0] = t1 >> 8;
|
mac[0] = t1 >> 8;
|
||||||
@ -170,19 +198,10 @@ static void reply_to_mac_addr(u8 *mac, u32 t1, u32 t2)
|
|||||||
static int mox_get_board_info(struct mox_rwtm *rwtm)
|
static int mox_get_board_info(struct mox_rwtm *rwtm)
|
||||||
{
|
{
|
||||||
struct device *dev = rwtm_dev(rwtm);
|
struct device *dev = rwtm_dev(rwtm);
|
||||||
struct armada_37xx_rwtm_tx_msg msg;
|
|
||||||
struct armada_37xx_rwtm_rx_msg *reply = &rwtm->reply;
|
struct armada_37xx_rwtm_rx_msg *reply = &rwtm->reply;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
msg.command = MBOX_CMD_BOARD_INFO;
|
ret = mox_rwtm_exec(rwtm, MBOX_CMD_BOARD_INFO, NULL, false);
|
||||||
ret = mbox_send_message(rwtm->mbox, &msg);
|
|
||||||
if (ret < 0)
|
|
||||||
return ret;
|
|
||||||
|
|
||||||
if (!wait_for_completion_timeout(&rwtm->cmd_done, HZ / 2))
|
|
||||||
return -ETIMEDOUT;
|
|
||||||
|
|
||||||
ret = mox_get_status(MBOX_CMD_BOARD_INFO, reply->retval);
|
|
||||||
if (ret == -ENODATA) {
|
if (ret == -ENODATA) {
|
||||||
dev_warn(dev,
|
dev_warn(dev,
|
||||||
"Board does not have manufacturing information burned!\n");
|
"Board does not have manufacturing information burned!\n");
|
||||||
@ -209,15 +228,7 @@ static int mox_get_board_info(struct mox_rwtm *rwtm)
|
|||||||
pr_info(" burned RAM size %i MiB\n", rwtm->ram_size);
|
pr_info(" burned RAM size %i MiB\n", rwtm->ram_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
msg.command = MBOX_CMD_ECDSA_PUB_KEY;
|
ret = mox_rwtm_exec(rwtm, MBOX_CMD_ECDSA_PUB_KEY, NULL, false);
|
||||||
ret = mbox_send_message(rwtm->mbox, &msg);
|
|
||||||
if (ret < 0)
|
|
||||||
return ret;
|
|
||||||
|
|
||||||
if (!wait_for_completion_timeout(&rwtm->cmd_done, HZ / 2))
|
|
||||||
return -ETIMEDOUT;
|
|
||||||
|
|
||||||
ret = mox_get_status(MBOX_CMD_ECDSA_PUB_KEY, reply->retval);
|
|
||||||
if (ret == -ENODATA) {
|
if (ret == -ENODATA) {
|
||||||
dev_warn(dev, "Board has no public key burned!\n");
|
dev_warn(dev, "Board has no public key burned!\n");
|
||||||
} else if (ret == -EOPNOTSUPP) {
|
} else if (ret == -EOPNOTSUPP) {
|
||||||
@ -240,37 +251,23 @@ static int mox_get_board_info(struct mox_rwtm *rwtm)
|
|||||||
|
|
||||||
static int check_get_random_support(struct mox_rwtm *rwtm)
|
static int check_get_random_support(struct mox_rwtm *rwtm)
|
||||||
{
|
{
|
||||||
struct armada_37xx_rwtm_tx_msg msg;
|
struct armada_37xx_rwtm_tx_msg msg = {
|
||||||
int ret;
|
.args = { 1, rwtm->buf_phys, 4 },
|
||||||
|
};
|
||||||
|
|
||||||
msg.command = MBOX_CMD_GET_RANDOM;
|
return mox_rwtm_exec(rwtm, MBOX_CMD_GET_RANDOM, &msg, false);
|
||||||
msg.args[0] = 1;
|
|
||||||
msg.args[1] = rwtm->buf_phys;
|
|
||||||
msg.args[2] = 4;
|
|
||||||
|
|
||||||
ret = mbox_send_message(rwtm->mbox, &msg);
|
|
||||||
if (ret < 0)
|
|
||||||
return ret;
|
|
||||||
|
|
||||||
if (!wait_for_completion_timeout(&rwtm->cmd_done, HZ / 2))
|
|
||||||
return -ETIMEDOUT;
|
|
||||||
|
|
||||||
return mox_get_status(MBOX_CMD_GET_RANDOM, rwtm->reply.retval);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int mox_hwrng_read(struct hwrng *rng, void *data, size_t max, bool wait)
|
static int mox_hwrng_read(struct hwrng *rng, void *data, size_t max, bool wait)
|
||||||
{
|
{
|
||||||
struct mox_rwtm *rwtm = container_of(rng, struct mox_rwtm, hwrng);
|
struct mox_rwtm *rwtm = container_of(rng, struct mox_rwtm, hwrng);
|
||||||
struct armada_37xx_rwtm_tx_msg msg;
|
struct armada_37xx_rwtm_tx_msg msg = {
|
||||||
|
.args = { 1, rwtm->buf_phys, ALIGN(max, 4) },
|
||||||
|
};
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
max = min(max, RWTM_DMA_BUFFER_SIZE);
|
max = min(max, RWTM_DMA_BUFFER_SIZE);
|
||||||
|
|
||||||
msg.command = MBOX_CMD_GET_RANDOM;
|
|
||||||
msg.args[0] = 1;
|
|
||||||
msg.args[1] = rwtm->buf_phys;
|
|
||||||
msg.args[2] = ALIGN(max, 4);
|
|
||||||
|
|
||||||
if (!wait) {
|
if (!wait) {
|
||||||
if (!mutex_trylock(&rwtm->busy))
|
if (!mutex_trylock(&rwtm->busy))
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
@ -278,15 +275,7 @@ static int mox_hwrng_read(struct hwrng *rng, void *data, size_t max, bool wait)
|
|||||||
mutex_lock(&rwtm->busy);
|
mutex_lock(&rwtm->busy);
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = mbox_send_message(rwtm->mbox, &msg);
|
ret = mox_rwtm_exec(rwtm, MBOX_CMD_GET_RANDOM, &msg, true);
|
||||||
if (ret < 0)
|
|
||||||
goto unlock_mutex;
|
|
||||||
|
|
||||||
ret = wait_for_completion_interruptible(&rwtm->cmd_done);
|
|
||||||
if (ret < 0)
|
|
||||||
goto unlock_mutex;
|
|
||||||
|
|
||||||
ret = mox_get_status(MBOX_CMD_GET_RANDOM, rwtm->reply.retval);
|
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto unlock_mutex;
|
goto unlock_mutex;
|
||||||
|
|
||||||
@ -333,7 +322,6 @@ static ssize_t do_sign_write(struct file *file, const char __user *buf,
|
|||||||
size_t len, loff_t *ppos)
|
size_t len, loff_t *ppos)
|
||||||
{
|
{
|
||||||
struct mox_rwtm *rwtm = file->private_data;
|
struct mox_rwtm *rwtm = file->private_data;
|
||||||
struct armada_37xx_rwtm_rx_msg *reply = &rwtm->reply;
|
|
||||||
struct armada_37xx_rwtm_tx_msg msg;
|
struct armada_37xx_rwtm_tx_msg msg;
|
||||||
loff_t dummy = 0;
|
loff_t dummy = 0;
|
||||||
ssize_t ret;
|
ssize_t ret;
|
||||||
@ -366,23 +354,15 @@ static ssize_t do_sign_write(struct file *file, const char __user *buf,
|
|||||||
goto unlock_mutex;
|
goto unlock_mutex;
|
||||||
be32_to_cpu_array(rwtm->buf, rwtm->buf, MOX_ECC_NUMBER_WORDS);
|
be32_to_cpu_array(rwtm->buf, rwtm->buf, MOX_ECC_NUMBER_WORDS);
|
||||||
|
|
||||||
msg.command = MBOX_CMD_SIGN;
|
|
||||||
msg.args[0] = 1;
|
msg.args[0] = 1;
|
||||||
msg.args[1] = rwtm->buf_phys;
|
msg.args[1] = rwtm->buf_phys;
|
||||||
msg.args[2] = rwtm->buf_phys + MOX_ECC_NUMBER_LEN;
|
msg.args[2] = rwtm->buf_phys + MOX_ECC_NUMBER_LEN;
|
||||||
msg.args[3] = rwtm->buf_phys + 2 * MOX_ECC_NUMBER_LEN;
|
msg.args[3] = rwtm->buf_phys + 2 * MOX_ECC_NUMBER_LEN;
|
||||||
ret = mbox_send_message(rwtm->mbox, &msg);
|
|
||||||
if (ret < 0)
|
|
||||||
goto unlock_mutex;
|
|
||||||
|
|
||||||
ret = wait_for_completion_interruptible(&rwtm->cmd_done);
|
ret = mox_rwtm_exec(rwtm, MBOX_CMD_SIGN, &msg, true);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto unlock_mutex;
|
goto unlock_mutex;
|
||||||
|
|
||||||
ret = MBOX_STS_VALUE(reply->retval);
|
|
||||||
if (MBOX_STS_ERROR(reply->retval) != MBOX_STS_SUCCESS)
|
|
||||||
goto unlock_mutex;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Here we read the R and S values of the ECDSA signature
|
* Here we read the R and S values of the ECDSA signature
|
||||||
* computed by the rWTM firmware and convert their words from
|
* computed by the rWTM firmware and convert their words from
|
||||||
|
Loading…
Reference in New Issue
Block a user