mfd: cros_ec: move locking into cros_ec_cmd_xfer
Now that there's a central cros_ec_cmd_xfer(), move the locking out of the SPI driver. Signed-off-by: Andrew Bresticker <abrestic@chromium.org> Reviewed-by: Simon Glass <sjg@chromium.org> Signed-off-by: Javier Martinez Canillas <javier.martinez@collabora.co.uk> Reviewed-by: Doug Anderson <dianders@chromium.org> Signed-off-by: Lee Jones <lee.jones@linaro.org>
This commit is contained in:
Родитель
a6551a76ff
Коммит
63427530fa
|
@ -65,7 +65,13 @@ EXPORT_SYMBOL(cros_ec_check_result);
|
||||||
int cros_ec_cmd_xfer(struct cros_ec_device *ec_dev,
|
int cros_ec_cmd_xfer(struct cros_ec_device *ec_dev,
|
||||||
struct cros_ec_command *msg)
|
struct cros_ec_command *msg)
|
||||||
{
|
{
|
||||||
return ec_dev->cmd_xfer(ec_dev, msg);
|
int ret;
|
||||||
|
|
||||||
|
mutex_lock(&ec_dev->lock);
|
||||||
|
ret = ec_dev->cmd_xfer(ec_dev, msg);
|
||||||
|
mutex_unlock(&ec_dev->lock);
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(cros_ec_cmd_xfer);
|
EXPORT_SYMBOL(cros_ec_cmd_xfer);
|
||||||
|
|
||||||
|
@ -98,6 +104,8 @@ int cros_ec_register(struct cros_ec_device *ec_dev)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mutex_init(&ec_dev->lock);
|
||||||
|
|
||||||
err = mfd_add_devices(dev, 0, cros_devs,
|
err = mfd_add_devices(dev, 0, cros_devs,
|
||||||
ARRAY_SIZE(cros_devs),
|
ARRAY_SIZE(cros_devs),
|
||||||
NULL, ec_dev->irq, NULL);
|
NULL, ec_dev->irq, NULL);
|
||||||
|
|
|
@ -79,13 +79,11 @@
|
||||||
* if no record
|
* if no record
|
||||||
* @end_of_msg_delay: used to set the delay_usecs on the spi_transfer that
|
* @end_of_msg_delay: used to set the delay_usecs on the spi_transfer that
|
||||||
* is sent when we want to turn off CS at the end of a transaction.
|
* is sent when we want to turn off CS at the end of a transaction.
|
||||||
* @lock: mutex to ensure only one user of cros_ec_cmd_xfer_spi at a time
|
|
||||||
*/
|
*/
|
||||||
struct cros_ec_spi {
|
struct cros_ec_spi {
|
||||||
struct spi_device *spi;
|
struct spi_device *spi;
|
||||||
s64 last_transfer_ns;
|
s64 last_transfer_ns;
|
||||||
unsigned int end_of_msg_delay;
|
unsigned int end_of_msg_delay;
|
||||||
struct mutex lock;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static void debug_packet(struct device *dev, const char *name, u8 *ptr,
|
static void debug_packet(struct device *dev, const char *name, u8 *ptr,
|
||||||
|
@ -232,13 +230,6 @@ static int cros_ec_cmd_xfer_spi(struct cros_ec_device *ec_dev,
|
||||||
int sum;
|
int sum;
|
||||||
int ret = 0, final_ret;
|
int ret = 0, final_ret;
|
||||||
|
|
||||||
/*
|
|
||||||
* We have the shared ec_dev buffer plus we do lots of separate spi_sync
|
|
||||||
* calls, so we need to make sure only one person is using this at a
|
|
||||||
* time.
|
|
||||||
*/
|
|
||||||
mutex_lock(&ec_spi->lock);
|
|
||||||
|
|
||||||
len = cros_ec_prepare_tx(ec_dev, ec_msg);
|
len = cros_ec_prepare_tx(ec_dev, ec_msg);
|
||||||
dev_dbg(ec_dev->dev, "prepared, len=%d\n", len);
|
dev_dbg(ec_dev->dev, "prepared, len=%d\n", len);
|
||||||
|
|
||||||
|
@ -327,7 +318,6 @@ exit:
|
||||||
if (ec_msg->command == EC_CMD_REBOOT_EC)
|
if (ec_msg->command == EC_CMD_REBOOT_EC)
|
||||||
msleep(EC_REBOOT_DELAY_MS);
|
msleep(EC_REBOOT_DELAY_MS);
|
||||||
|
|
||||||
mutex_unlock(&ec_spi->lock);
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -359,7 +349,6 @@ static int cros_ec_spi_probe(struct spi_device *spi)
|
||||||
if (ec_spi == NULL)
|
if (ec_spi == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
ec_spi->spi = spi;
|
ec_spi->spi = spi;
|
||||||
mutex_init(&ec_spi->lock);
|
|
||||||
ec_dev = devm_kzalloc(dev, sizeof(*ec_dev), GFP_KERNEL);
|
ec_dev = devm_kzalloc(dev, sizeof(*ec_dev), GFP_KERNEL);
|
||||||
if (!ec_dev)
|
if (!ec_dev)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче