[PATCH] mmc: sdio: fix alignment issue in struct sdio_func
Heiner Kallweit
hkallweit1 at gmail.com
Tue Apr 18 12:20:23 PDT 2017
Am 18.04.2017 um 21:15 schrieb Ulf Hansson:
> On 29 March 2017 at 20:54, Heiner Kallweit <hkallweit1 at gmail.com> wrote:
>> Certain 64-bit systems (e.g. Amlogic Meson GX) require buffers to be
>> used for DMA to be 8-byte-aligned. struct sdio_func has an embedded
>> small DMA buffer not meeting this requirement.
>> When testing switching to descriptor chain mode in meson-gx driver
>> SDIO is broken therefore. Fix this by allocating the small DMA buffer
>> separately as kmalloc ensures that the returned memory area is
>> properly aligned for every basic data type.
>>
>> Signed-off-by: Heiner Kallweit <hkallweit1 at gmail.com>
>> Tested-by: Helmut Klein <hgkr.klein at gmail.com>
>
> Heiner, sorry for the delay!
>
> I decided to pick this first version as it is more consistent for how
> we deal with DMA friendly buffers in the core.
>
I also like it more, it's a little more overhead but cleaner.
Thanks a lot!
> Thanks, applied for fixes!
>
> Kind regards
> Uffe
>
>> ---
>> drivers/mmc/core/sdio_bus.c | 12 +++++++++++-
>> include/linux/mmc/sdio_func.h | 2 +-
>> 2 files changed, 12 insertions(+), 2 deletions(-)
>>
>> diff --git a/drivers/mmc/core/sdio_bus.c b/drivers/mmc/core/sdio_bus.c
>> index e992a7f8..2b32b889 100644
>> --- a/drivers/mmc/core/sdio_bus.c
>> +++ b/drivers/mmc/core/sdio_bus.c
>> @@ -267,7 +267,7 @@ static void sdio_release_func(struct device *dev)
>> sdio_free_func_cis(func);
>>
>> kfree(func->info);
>> -
>> + kfree(func->tmpbuf);
>> kfree(func);
>> }
>>
>> @@ -282,6 +282,16 @@ struct sdio_func *sdio_alloc_func(struct mmc_card *card)
>> if (!func)
>> return ERR_PTR(-ENOMEM);
>>
>> + /*
>> + * allocate buffer separately to make sure it's properly aligned for
>> + * DMA usage (incl. 64 bit DMA)
>> + */
>> + func->tmpbuf = kmalloc(4, GFP_KERNEL);
>> + if (!func->tmpbuf) {
>> + kfree(func);
>> + return ERR_PTR(-ENOMEM);
>> + }
>> +
>> func->card = card;
>>
>> device_initialize(&func->dev);
>> diff --git a/include/linux/mmc/sdio_func.h b/include/linux/mmc/sdio_func.h
>> index aab032a6..97ca1053 100644
>> --- a/include/linux/mmc/sdio_func.h
>> +++ b/include/linux/mmc/sdio_func.h
>> @@ -53,7 +53,7 @@ struct sdio_func {
>> unsigned int state; /* function state */
>> #define SDIO_STATE_PRESENT (1<<0) /* present in sysfs */
>>
>> - u8 tmpbuf[4]; /* DMA:able scratch buffer */
>> + u8 *tmpbuf; /* DMA:able scratch buffer */
>>
>> unsigned num_info; /* number of info strings */
>> const char **info; /* info strings */
>> --
>> 2.12.1
>>
>
More information about the linux-amlogic
mailing list