[alsa-devel] [PATCH] ASoC: arm64: use the same dma mmap codepath both for arm and arm64
Takashi Iwai
tiwai at suse.de
Sat Oct 18 11:11:03 CEST 2014
At Fri, 17 Oct 2014 12:43:34 -0700,
Anatol Pomozov wrote:
>
> This avoids following kernel crash when try to playback on arm64
>
> [ 107.497203] [<ffffffc00046b310>] snd_pcm_mmap_data_fault+0x90/0xd4
> [ 107.503405] [<ffffffc0001541ac>] __do_fault+0xb0/0x498
> [ 107.508565] [<ffffffc0001576a0>] handle_mm_fault+0x224/0x7b0
> [ 107.514246] [<ffffffc000092640>] do_page_fault+0x11c/0x310
> [ 107.519738] [<ffffffc000081100>] do_mem_abort+0x38/0x98
>
> Tested: backported to 3.14 and tried to playback on arm64 machine
> Signed-off-by: Anatol Pomozov <anatol.pomozov at gmail.com>
It's not specific to ASoC, so I applied the patch with modified
subject now.
We should clean up the relevant part in general, as now more
architectures support dma_mmap_coherent(). But it'd be a change for
3.19.
thanks,
Takashi
> ---
> sound/core/pcm_native.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c
> index 8cd2f93..a95356f 100644
> --- a/sound/core/pcm_native.c
> +++ b/sound/core/pcm_native.c
> @@ -3193,7 +3193,7 @@ static const struct vm_operations_struct snd_pcm_vm_ops_data_fault = {
>
> #ifndef ARCH_HAS_DMA_MMAP_COHERENT
> /* This should be defined / handled globally! */
> -#ifdef CONFIG_ARM
> +#if defined(CONFIG_ARM) || defined(CONFIG_ARM64)
> #define ARCH_HAS_DMA_MMAP_COHERENT
> #endif
> #endif
> --
> 2.1.0.rc2.206.gedb03e5
>
More information about the Alsa-devel
mailing list