[alsa-devel] [PATCH] fix the kernel panic due to wrong use the dev memory API
Pierre-Louis Bossart
pierre-louis.bossart at linux.intel.com
Tue Nov 6 15:39:46 CET 2018
On 11/5/18 6:58 PM, He, Bo wrote:
> Hi,
> I submit the patch based on tag v4.19.
Please don't post on mailing lists.
>
> -----Original Message-----
> From: Pierre-Louis Bossart <pierre-louis.bossart at linux.intel.com>
> Sent: Tuesday, November 6, 2018 1:02 AM
> To: He, Bo <bo.he at intel.com>; alsa-devel at alsa-project.org; linux-kernel at vger.kernel.org
> Cc: liam.r.girdwood at linux.intel.com; perex at perex.cz; tiwai at suse.com; Singh, Guneshwor O <guneshwor.o.singh at intel.com>; Periyasamy, SriramX <sriramx.periyasamy at intel.com>; Kale, Sanyog R <sanyog.r.kale at intel.com>; Kesapragada, Pardha Saradhi <pardha.saradhi.kesapragada at intel.com>; kuninori.morimoto.gx at renesas.com; guruprasadx.pawse at intel.com; Ughreja, Rakesh A <rakesh.a.ughreja at intel.com>; Prakash, Divya1 <divya1.prakash at intel.com>; Diwakar, Praveen <praveen.diwakar at intel.com>; Zhang, Yanmin <yanmin.zhang at intel.com>
> Subject: Re: [alsa-devel] [PATCH] fix the kernel panic due to wrong use the dev memory API
>
>
> On 11/5/18 2:29 AM, He, Bo wrote:
>> skl->dais is allocated with devm_kcalloc, can't free with
>> the krealloc. Memory allocated with devm API is automatically freed on
>> driver detach, Like all other devres resources.
>>
>> Refer to drivers/base/devres.c devm_kmalloc for more details.
>
> What code are you looking at?
>
> I see this in the Mark's tree
>
> int skl_platform_register(struct device *dev) {
> int ret;
> struct snd_soc_dai_driver *dais;
> int num_dais = ARRAY_SIZE(skl_platform_dai);
> struct hdac_bus *bus = dev_get_drvdata(dev);
> struct skl *skl = bus_to_skl(bus);
>
> INIT_LIST_HEAD(&skl->ppl_list);
> INIT_LIST_HEAD(&skl->bind_list);
>
> skl->dais = kmemdup(skl_platform_dai, sizeof(skl_platform_dai),
> GFP_KERNEL);
> if (!skl->dais) {
> ret = -ENOMEM;
> goto err;
> }
>
> if (!skl->use_tplg_pcm) {
> dais = krealloc(skl->dais, sizeof(skl_fe_dai) +
> sizeof(skl_platform_dai), GFP_KERNEL);
>
>
> No trace of devm as you mention it? I checked the Chrome tree as well and it's not there.
>
> What am I missing?
The code is completely identical in v4.19. skl->dais is allocated with
kmemdup, which is a kmalloc+memcpy, i just don't understand what you are
trying to fix.
>
>
>>
>> Signed-off-by: he, bo <bo.he at intel.com>
>> ---
>> sound/soc/intel/skylake/skl-pcm.c | 5 ++---
>> 1 file changed, 2 insertions(+), 3 deletions(-)
>>
>> diff --git a/sound/soc/intel/skylake/skl-pcm.c
>> b/sound/soc/intel/skylake/skl-pcm.c
>> index 823e391..928d314 100644
>> --- a/sound/soc/intel/skylake/skl-pcm.c
>> +++ b/sound/soc/intel/skylake/skl-pcm.c
>> @@ -1438,7 +1438,8 @@ int skl_platform_register(struct device *dev)
>> }
>>
>> if (!skl->use_tplg_pcm) {
>> - dais = krealloc(skl->dais, sizeof(skl_fe_dai) +
>> + devm_kfree(dev, skl->dais);
>> + dais = devm_kcalloc(dev, skl->dais, sizeof(skl_fe_dai) +
>> sizeof(skl_platform_dai), GFP_KERNEL);
>> if (!dais) {
>> ret = -ENOMEM;
>> @@ -1472,7 +1473,5 @@ int skl_platform_unregister(struct device *dev)
>> }
>> }
>>
>> - kfree(skl->dais);
>> -
>> return 0;
>> }
More information about the Alsa-devel
mailing list