[PATCH V2 3/6] spi/spi-pl022: Don't allocate more sg than required.
Russell King - ARM Linux
linux at arm.linux.org.uk
Wed Aug 10 04:54:31 EDT 2011
On Wed, Aug 10, 2011 at 02:20:56PM +0530, Viresh Kumar wrote:
> In routine configure_dma(), if transfer->len = PAGE_SIZE, then pages is one more
> than required. While leads to one more sg getting allocated.
>
> This is wrong. Correct this to allocate correct number of sg.
>
> Signed-off-by: Viresh Kumar <viresh.kumar at st.com>
> Tested-by: Linus Walleij <linus.walleij at linaro.org>
> ---
> drivers/spi/spi-pl022.c | 3 ++-
> 1 files changed, 2 insertions(+), 1 deletions(-)
>
> diff --git a/drivers/spi/spi-pl022.c b/drivers/spi/spi-pl022.c
> index 80116be..1c8b9ec 100644
> --- a/drivers/spi/spi-pl022.c
> +++ b/drivers/spi/spi-pl022.c
> @@ -1016,7 +1016,8 @@ static int configure_dma(struct pl022 *pl022)
> dmaengine_slave_config(txchan, &tx_conf);
>
> /* Create sglists for the transfers */
> - pages = (pl022->cur_transfer->len >> PAGE_SHIFT) + 1;
> + pages = ((pl022->cur_transfer->len + (1 << PAGE_SHIFT) - 1)
> + >> PAGE_SHIFT);
It would be far better for this to be:
pages = DIV_ROUND_UP(pl022->cur_transfer->len, PAGE_SIZE);
The compiler will probably optimize it to the same code anyway.
More information about the linux-arm-kernel
mailing list