From: Greg KH <gregkh@linuxfoundation.org>
To: Chris Wulff <Chris.Wulff@biamp.com>
Cc: "linux-usb@vger.kernel.org" <linux-usb@vger.kernel.org>
Subject: Re: [PATCH] usb: gadget: u_audio: Fix race condition use of controls after free during gadget unbind.
Date: Tue, 23 Apr 2024 16:18:13 -0700 [thread overview]
Message-ID: <2024042346-pastime-platonic-7e28@gregkh> (raw)
In-Reply-To: <CO1PR17MB54190B898057616EEB3F9E51E10E2@CO1PR17MB5419.namprd17.prod.outlook.com>
On Thu, Apr 18, 2024 at 04:35:07PM +0000, Chris Wulff wrote:
> Hang on to the control IDs instead of pointers since those are correctly handled with locks.
> Prevent use of the uac data structure after it has been freed.
> Mark the endpoint as disabled sooner so that freed requests aren't used.
Nit, please wrap your changelog text at 72 columns. running
scripts/checkpatch.pl should show this.
>
> Signed-off-by: Chris Wulff <chris.wulff@biamp.com>
What commit id does this fix?
> ---
> drivers/usb/gadget/function/u_audio.c | 31 ++++++++++++++++-----------
> 1 file changed, 19 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/usb/gadget/function/u_audio.c b/drivers/usb/gadget/function/u_audio.c
> index 4a42574b4a7f..bcae95472455 100644
> --- a/drivers/usb/gadget/function/u_audio.c
> +++ b/drivers/usb/gadget/function/u_audio.c
> @@ -57,13 +57,13 @@ struct uac_rtd_params {
>
> /* Volume/Mute controls and their state */
> int fu_id; /* Feature Unit ID */
> - struct snd_kcontrol *snd_kctl_volume;
> - struct snd_kcontrol *snd_kctl_mute;
> + struct snd_ctl_elem_id snd_kctl_volume_id;
> + struct snd_ctl_elem_id snd_kctl_mute_id;
> s16 volume_min, volume_max, volume_res;
> s16 volume;
> int mute;
No tabs? Odd. Not your fault, just a meta-comment.
>
> - struct snd_kcontrol *snd_kctl_rate; /* read-only current rate */
> + struct snd_ctl_elem_id snd_kctl_rate_id; /* read-only current rate */
> int srate; /* selected samplerate */
> int active; /* playback/capture running */
>
> @@ -447,6 +447,8 @@ static inline void free_ep(struct uac_rtd_params *prm, struct usb_ep *ep)
> if (!prm->ep_enabled)
> return;
>
> + prm->ep_enabled = false;
> +
> audio_dev = uac->audio_dev;
> params = &audio_dev->params;
>
> @@ -464,8 +466,6 @@ static inline void free_ep(struct uac_rtd_params *prm, struct usb_ep *ep)
> }
> }
>
> - prm->ep_enabled = false;
> -
> if (usb_ep_disable(ep))
> dev_err(uac->card->dev, "%s:%d Error!\n", __func__, __LINE__);
> }
> @@ -494,14 +494,13 @@ static inline void free_ep_fback(struct uac_rtd_params *prm, struct usb_ep *ep)
> static void set_active(struct uac_rtd_params *prm, bool active)
> {
> // notifying through the Rate ctrl
> - struct snd_kcontrol *kctl = prm->snd_kctl_rate;
> unsigned long flags;
>
> spin_lock_irqsave(&prm->lock, flags);
> if (prm->active != active) {
> prm->active = active;
> snd_ctl_notify(prm->uac->card, SNDRV_CTL_EVENT_MASK_VALUE,
> - &kctl->id);
> + &prm->snd_kctl_rate_id);
> }
> spin_unlock_irqrestore(&prm->lock, flags);
> }
> @@ -792,6 +791,9 @@ int u_audio_set_volume(struct g_audio *audio_dev, int playback, s16 val)
> unsigned long flags;
> int change = 0;
>
> + if (!uac)
> + return 0;
> +
> if (playback)
> prm = &uac->p_prm;
> else
> @@ -807,7 +809,7 @@ int u_audio_set_volume(struct g_audio *audio_dev, int playback, s16 val)
>
> if (change)
> snd_ctl_notify(uac->card, SNDRV_CTL_EVENT_MASK_VALUE,
> - &prm->snd_kctl_volume->id);
> + &prm->snd_kctl_volume_id);
>
> return 0;
> }
> @@ -840,6 +842,9 @@ int u_audio_set_mute(struct g_audio *audio_dev, int playback, int val)
> int change = 0;
> int mute;
>
> + if (!uac)
> + return 0;
How can this happen? Is this a separate fix? Or the same issue?
thanks,
greg k-h
next prev parent reply other threads:[~2024-04-23 23:18 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-04-18 16:35 [PATCH] usb: gadget: u_audio: Fix race condition use of controls after free during gadget unbind Chris Wulff
2024-04-23 23:18 ` Greg KH [this message]
2024-04-24 17:57 ` Chris Wulff
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=2024042346-pastime-platonic-7e28@gregkh \
--to=gregkh@linuxfoundation.org \
--cc=Chris.Wulff@biamp.com \
--cc=linux-usb@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox