[PATCH 6/6] spi/pl022: add support for pm_runtime autosuspend
Viresh Kumar
viresh.kumar at st.com
Wed Nov 9 06:00:57 EST 2011
On 11/9/2011 4:09 PM, Linus WALLEIJ wrote:
> From: Chris Blair <chris.blair at stericsson.com>
>
> Adds support for configuring the spi bus to use autosuspend for
> runtime power management. This can reduce the latency in starting an
> spi transfer by not suspending the device immediately following
> completion of a transfer. If another transfer then takes place before
> the autosuspend timeout, the call to resume the device can return
> immediately rather than needing to risk sleeping in order to resume
> the device.
>
> Signed-off-by: Chris Blair <chris.blair at stericsson.com>
> Signed-off-by: Linus Walleij <linus.walleij at linaro.org>
> ---
> drivers/spi/spi-pl022.c | 20 ++++++++++++++++++--
> include/linux/amba/pl022.h | 4 ++++
> 2 files changed, 22 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/spi/spi-pl022.c b/drivers/spi/spi-pl022.c
> index 2e3522d..d3d6521 100644
> --- a/drivers/spi/spi-pl022.c
> +++ b/drivers/spi/spi-pl022.c
> @@ -1515,7 +1515,13 @@ static void pump_messages(struct work_struct *work)
> /* nothing more to do - disable spi/ssp and power off */
> writew((readw(SSP_CR1(pl022->virtbase)) &
> (~SSP_CR1_MASK_SSE)), SSP_CR1(pl022->virtbase));
> - pm_runtime_put(&pl022->adev->dev);
> +
> + if (pl022->master_info->autosuspend_delay > 0) {
> + pm_runtime_mark_last_busy(&pl022->adev->dev);
> + pm_runtime_put_autosuspend(&pl022->adev->dev);
> + } else {
> + pm_runtime_put(&pl022->adev->dev);
> + }
> }
> pl022->busy = false;
> spin_unlock_irqrestore(&pl022->queue_lock, flags);
> @@ -2245,7 +2251,17 @@ pl022_probe(struct amba_device *adev, const struct amba_id *id)
> dev_dbg(dev, "probe succeeded\n");
>
> /* let runtime pm put suspend */
> - pm_runtime_put(dev);
> + if (platform_info->autosuspend_delay > 0) {
> + dev_info(&adev->dev,
> + "will use autosuspend for runtime pm, delay %dms\n",
> + platform_info->autosuspend_delay);
> + pm_runtime_set_autosuspend_delay(dev,
> + platform_info->autosuspend_delay);
> + pm_runtime_use_autosuspend(dev);
> + pm_runtime_put_autosuspend(dev);
> + } else {
> + pm_runtime_put(dev);
> + }
> return 0;
>
> err_spi_register:
> diff --git a/include/linux/amba/pl022.h b/include/linux/amba/pl022.h
> index 4ce98f5..572f637 100644
> --- a/include/linux/amba/pl022.h
> +++ b/include/linux/amba/pl022.h
> @@ -238,6 +238,9 @@ struct dma_chan;
> * @enable_dma: if true enables DMA driven transfers.
> * @dma_rx_param: parameter to locate an RX DMA channel.
> * @dma_tx_param: parameter to locate a TX DMA channel.
> + * @autosuspend_delay: delay in ms following transfer completion before the
> + * runtime power management system suspends the device. A setting of 0
> + * indicates no delay and the device will be suspended immediately.
> */
> struct pl022_ssp_controller {
> u16 bus_id;
> @@ -246,6 +249,7 @@ struct pl022_ssp_controller {
> bool (*dma_filter)(struct dma_chan *chan, void *filter_param);
> void *dma_rx_param;
> void *dma_tx_param;
> + int autosuspend_delay;
> };
>
> /**
Reviewed-by: Viresh Kumar <viresh.kumar at st.com>
--
viresh
More information about the linux-arm-kernel
mailing list