[alsa-devel] Bug in hdmi codec driver in DPCM
Patrick Lai
plai at codeaurora.org
Tue Oct 30 23:25:51 CET 2018
On 10/30/18 7:50 AM, Rohit Kumar wrote:
> Hi,
>
> We are facing crash in hdmi codec driver when we use DPCM based
> dai-links. Crash is happening in hdmi_codec_eld_chmap() while accessing
> chmap_info struct during hdmi_codec_startup(). However, chmap_info
> struct is allocated in hdmi_codec_pcm_new() which is only called in
> non-DPCM based dai-links.
>
> Below is the crash stack:
>
> [61.635493] Unable to handle kernel NULL pointer dereference at virtual
> address 00000018
>
> .....
>
> [61.666696]CM = 0, WnR = 1
>
> [61.669778] user pgtable: 4k pages, 39-bit VAs, pgd = ffffffc0d6633000
>
> [61.676526] [0000000000000018] *pgd=0000000153fc8003,
> *pud=0000000153fc8003, *pmd=0000000000000000
>
> [61.685793] Internal error: Oops: 96000046 [#1] PREEMPT SMP
>
> [61.722955] CPU: 7 PID: 2238 Comm: aplay Not tainted 4.14.72 #21
>
> ..
>
> [61.740269] PC is at hdmi_codec_startup+0x124/0x164
>
> [61.745308] LR is at hdmi_codec_startup+0xe4/0x164
>
> ..
>
> We would probably need to move the implementation on pcm_new() to some
> other function to make it compatible with DPCM.
>
> Can you please provide suggestions in solving the issue.
>
In my opinion, it is not responsibility of driver to speculate whether
the ops it exposes would only be called under certain usage (non-DPCM in
this case). I think ASoC framework should be updated to call pcm_new()
of each driver even though no actual PCM device would be created for
backend dailink.
>
> Thanks,
>
> Rohit
--
The Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum,
a Linux Foundation Collaborative Project
More information about the Alsa-devel
mailing list