iio: commom: st_sensors: ensure proper DMA alignment
authorNuno Sa <nuno.sa@analog.com>
Wed, 31 Jan 2024 09:16:47 +0000 (10:16 +0100)
committerJonathan Cameron <Jonathan.Cameron@huawei.com>
Sun, 4 Feb 2024 15:01:14 +0000 (15:01 +0000)
commit862cf85fef85becc55a173387527adb4f076fab0
tree862e503454483c8c5c7aa7dcf273b3686247a4eb
parent621c6257128149e45b36ffb973a01c3f3461b893
iio: commom: st_sensors: ensure proper DMA alignment

Aligning the buffer to the L1 cache is not sufficient in some platforms
as they might have larger cacheline sizes for caches after L1 and thus,
we can't guarantee DMA safety.

That was the whole reason to introduce IIO_DMA_MINALIGN in [1]. Do the same
for st_sensors common buffer.

While at it, moved the odr_lock before buffer_data as we definitely
don't want any other data to share a cacheline with the buffer.

[1]: https://lore.kernel.org/linux-iio/20220508175712.647246-2-jic23@kernel.org/

Fixes: e031d5f558f1 ("iio:st_sensors: remove buffer allocation at each buffer enable")
Signed-off-by: Nuno Sa <nuno.sa@analog.com>
Cc: <Stable@vger.kernel.org>
Link: https://lore.kernel.org/r/20240131-dev_dma_safety_stm-v2-1-580c07fae51b@analog.com
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
include/linux/iio/common/st_sensors.h