Please let me describe the issue here. The test case is: 1) Unload module with script "sudo ./sof_remove.sh" , 2) reload module with script "sudo ./sof_insert.sh" After several rounds of removing and inserting kernel modules, system will complain like below: "BUG: unable to handle kernel paging request at 000000292a282031" sof_remove.sh is used to remove the modules: remove_module sof_pci_dev remove_module snd_sof_intel_hda_common remove_module snd_soc_skl_hda_dsp remove_module snd_soc_hdac_hdmi remove_module snd_hda_codec_realtek remove_module snd_hda_codec_generic remove_module snd_soc_dmic remove_module snd_soc_hdac_hda remove_module snd_sof_intel_hda remove_module snd_hda_ext_core remove_module snd_hda_codec remove_module snd_hda_core remove_module sof_acpi_dev remove_module snd_soc_acpi_intel_match remove_module snd_sof_intel_byt remove_module snd_sof_intel_hsw remove_module snd_sof_intel_bdw remove_module snd_sof_xtensa_dsp remove_module snd_sof_intel_ipc remove_module snd_soc_sst_bytcr_rt5640 remove_module snd_soc_sst_bytcr_rt5651 remove_module snd_soc_sst_cht_bsw_rt5645 remove_module snd_soc_sst_cht_bsw_rt5670 remove_module snd_soc_sst_byt_cht_da7213 remove_module snd_soc_sst_bxt_pcm512x remove_module snd_soc_sst_bxt_tdf8532 remove_module snd_soc_cnl_rt274 remove_module snd_sof_nocodec remove_module snd_sof remove_module snd_soc_acpi_intel_match remove_module snd_soc_rt5670 remove_module snd_soc_rt5645 remove_module snd_soc_rt5651 remove_module snd_soc_rt5640 remove_module snd_soc_rl6231 remove_module snd_soc_da7213 remove_module snd_soc_pcm512x_i2c remove_module snd_soc_pcm512x remove_module snd_soc_tdf8532 remove_module snd_soc_rt274 remove_module snd_soc_acpi remove_module snd_soc_core remove_module snd_pcm And sof_insert.sh is to insert the modules: modprobe snd_soc_rt5670 modprobe snd_soc_rt5645 modprobe snd_soc_rt5651 modprobe snd_soc_rt5640 modprobe snd_soc_da7213 modprobe snd_soc_pcm512x_i2c #modprobe snd_soc_tdf8532 #modprobe snd_soc_rt274 modprobe sof_acpi_dev modprobe sof_pci_dev Regards, Libin >-----Original Message----- >From: Yang, Libin >Sent: Thursday, May 23, 2019 12:10 PM >To: 'Pierre-Louis Bossart' <pierre-louis.bossart@xxxxxxxxxxxxxxx>; alsa- >devel@xxxxxxxxxxxxxxxx >Cc: tiwai@xxxxxxx; broonie@xxxxxxxxxx >Subject: RE: [PATCH v2 12/12] ASoC: SOF: Intel: hda-codec: fix memory >allocation > >Please hold on this patch. It seems there is some corner case failed because of >this patch. > >Regards, >Libin > > >>-----Original Message----- >>From: Pierre-Louis Bossart >>[mailto:pierre-louis.bossart@xxxxxxxxxxxxxxx] >>Sent: Thursday, May 23, 2019 12:22 AM >>To: alsa-devel@xxxxxxxxxxxxxxxx >>Cc: tiwai@xxxxxxx; broonie@xxxxxxxxxx; Yang, Libin >><libin.yang@xxxxxxxxx>; Pierre-Louis Bossart >><pierre-louis.bossart@xxxxxxxxxxxxxxx> >>Subject: [PATCH v2 12/12] ASoC: SOF: Intel: hda-codec: fix memory >>allocation >> >>From: Libin Yang <libin.yang@xxxxxxxxx> >> >>Align all users of the hdac library to use devm_kzalloc. >> >>Note for backports/stable: the patch ("ALSA: hdac: fix memory release >>for SST and SOF drivers") needs to be applied as well. >> >>Fixes: 5507b8103e26 ("ASoC: SOF: Intel: Add support for HDAudio >>codecs") >>Reviewed-by: Takashi Iwai <tiwai@xxxxxxx> >>Signed-off-by: Libin Yang <libin.yang@xxxxxxxxx> >>Signed-off-by: Pierre-Louis Bossart >><pierre-louis.bossart@xxxxxxxxxxxxxxx> >>--- >> sound/soc/sof/intel/hda-codec.c | 6 ++---- >> 1 file changed, 2 insertions(+), 4 deletions(-) >> >>diff --git a/sound/soc/sof/intel/hda-codec.c b/sound/soc/sof/intel/hda- >>codec.c index b8b37f082309..0d8437b080bf 100644 >>--- a/sound/soc/sof/intel/hda-codec.c >>+++ b/sound/soc/sof/intel/hda-codec.c >>@@ -62,8 +62,7 @@ static int hda_codec_probe(struct snd_sof_dev *sdev, >>int address) >> address, resp); >> >> #if IS_ENABLED(CONFIG_SND_SOC_SOF_HDA_AUDIO_CODEC) >>- /* snd_hdac_ext_bus_device_exit will use kfree to free hdev */ >>- hda_priv = kzalloc(sizeof(*hda_priv), GFP_KERNEL); >>+ hda_priv = devm_kzalloc(sdev->dev, sizeof(*hda_priv), GFP_KERNEL); >> if (!hda_priv) >> return -ENOMEM; >> >>@@ -82,8 +81,7 @@ static int hda_codec_probe(struct snd_sof_dev *sdev, >>int address) >> >> return 0; >> #else >>- /* snd_hdac_ext_bus_device_exit will use kfree to free hdev */ >>- hdev = kzalloc(sizeof(*hdev), GFP_KERNEL); >>+ hdev = devm_kzalloc(sdev->dev, sizeof(*hdev), GFP_KERNEL); >> if (!hdev) >> return -ENOMEM; >> >>-- >>2.20.1 _______________________________________________ Alsa-devel mailing list Alsa-devel@xxxxxxxxxxxxxxxx https://mailman.alsa-project.org/mailman/listinfo/alsa-devel