]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
ALSA: usb-audio: qcom: Free QMI handle
authorXu Rao <raoxu@uniontech.com>
Tue, 23 Jun 2026 07:13:08 +0000 (15:13 +0800)
committerTakashi Iwai <tiwai@suse.de>
Thu, 25 Jun 2026 11:56:21 +0000 (13:56 +0200)
qc_usb_audio_probe() allocates svc->uaudio_svc_hdl separately from the
uaudio_qmi_svc object.

qmi_handle_release() releases the resources owned by an initialized QMI
handle, but does not free the memory containing the struct qmi_handle
itself. The probe error path and the remove path currently release the
handle and then free svc, losing the last pointer to the separately
allocated handle.

This leaks one struct qmi_handle on each affected probe unwind and on
each successful probe/remove cycle.

Free the handle after qmi_handle_release() in both paths.

Signed-off-by: Xu Rao <raoxu@uniontech.com>
Link: https://patch.msgid.link/9108EC860F3F87DF+20260623071308.2549182-1-raoxu@uniontech.com
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/usb/qcom/qc_audio_offload.c

index 3a586fd16e7297fd5c4f391ea8f1f428d934ddc1..e4bfd43a2488b98841e3346d50b6e56c2f6d0494 100644 (file)
@@ -1988,6 +1988,7 @@ static int qc_usb_audio_probe(struct auxiliary_device *auxdev,
 release_qmi:
        qc_usb_audio_cleanup_qmi_dev();
        qmi_handle_release(svc->uaudio_svc_hdl);
+       kfree(svc->uaudio_svc_hdl);
 free_svc:
        kfree(svc);
 
@@ -2012,6 +2013,7 @@ static void qc_usb_audio_remove(struct auxiliary_device *auxdev)
        qc_usb_audio_cleanup_qmi_dev();
 
        qmi_handle_release(svc->uaudio_svc_hdl);
+       kfree(svc->uaudio_svc_hdl);
        kfree(svc);
        uaudio_svc = NULL;
 }