Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp2469555pxb; Fri, 5 Feb 2021 20:27:47 -0800 (PST) X-Google-Smtp-Source: ABdhPJyrr7+zl/lC9nuKeU9vnGVMw1I4lcuKHAanidB8Je+Jnp1XxujsKTTIAXe8K3W8XwPlIYyg X-Received: by 2002:a17:906:7d4f:: with SMTP id l15mr7044332ejp.95.1612585667230; Fri, 05 Feb 2021 20:27:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612585667; cv=none; d=google.com; s=arc-20160816; b=Q4u2JZexKHdrHbYAaTfoz8I8WxnL+0I0KG+CmHZ/gX00wSVuJaH7/mlmDUUnExPBzg RVkcW12pP454qk1D2xQ3GYEikaabfJ6V74Qxadefuk7sqojWYsC4mm29BfNR8Kur4v1S vlLnFTlUMwwBt8MO8Kd+zDk4vEuRdPSB9Ssf5wa+EiHNvH6ZecIrH0wJAtrQi7/gpQ49 jdQyxe7Szsa4WyPMLtKVvdeDbomgqrb5wX4J3z7r4lSKbPDNgbtHUjAncwCWzG3MWZBC GrIwT7LgskwJ23LZW2mkzYiMosdEZYi5ZYqJTp7ow1wjaueksKPB+OfnrJOdGXiDgsf5 JV1g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:references:in-reply-to :subject:cc:to:from:message-id:date; bh=XScKVrpkyTUJ71fUDJ9V/my1CMa90HpQ4ERPYYUvqkw=; b=tEivBzwBGlWOTH+BMttXKGOTA4nQrf8nQFq9SfgGaBYPZO85+n3rVjFA5G3A5Htjt+ uQkfz5DQ4+VkAzB+q2PPr4ga2GwIabXF7e6gsDAgPrGXQ6SNbZ63PNa/iY7GZALLIukF 6DdYShyGHGvsFOFDFfkzjMichjeNpX2Qf9IiKkObuvDjEgZV9VNqKzeDY9P6rTl/g5mq uqTCUD5BQY7HiHqfNkB5oLHWduiQv6PxXnmC2nLArUq5apkyf2w6sfIM3ldBJrALntfp XCP1EbQXAgWj+xEkmrQj+TJJP3GEGBAgkffrAqiY0tqbDWIK8HZbycYQrJ3Ea2jikffd 2CIA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id jr21si6615518ejb.24.2021.02.05.20.27.23; Fri, 05 Feb 2021 20:27:47 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230262AbhBFEYL (ORCPT + 99 others); Fri, 5 Feb 2021 23:24:11 -0500 Received: from mx2.suse.de ([195.135.220.15]:55378 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231609AbhBFDOc (ORCPT ); Fri, 5 Feb 2021 22:14:32 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 4116CADE0; Fri, 5 Feb 2021 22:25:35 +0000 (UTC) Date: Fri, 05 Feb 2021 23:25:35 +0100 Message-ID: From: Takashi Iwai To: Mikhail Gavrilov Cc: zonque@gmail.com, Linux List Kernel Mailing , alsa-devel@alsa-project.org, linux-usb@vger.kernel.org Subject: Re: BUG: KASAN: use-after-free in snd_complete_urb+0x109e/0x1740 [snd_usb_audio] (5.11-rc6) In-Reply-To: References: User-Agent: Wanderlust/2.15.9 (Almost Unreal) SEMI/1.14.6 (Maruoka) FLIM/1.14.9 (=?UTF-8?B?R29qxY0=?=) APEL/10.8 Emacs/25.3 (x86_64-suse-linux-gnu) MULE/6.0 (HANACHIRUSATO) MIME-Version: 1.0 (generated by SEMI 1.14.6 - "Maruoka") Content-Type: text/plain; charset=US-ASCII Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 05 Feb 2021 22:02:16 +0100, Mikhail Gavrilov wrote: > > Hi folks. > On 5.11-rc6 (git 3aaf0a27ffc2) I caught a new issue. > For unknown reason sound disappeared in my headset Hyperx orbit s. > But after reconnecting to another USB port headset stopped being > detected as USB device in dmesg > and in log appears a record about bug KASAN: use-after-free. > > [37920.370627] xhci_hcd 0000:06:00.3: AMD-Vi: Event logged > [IO_PAGE_FAULT domain=0x0013 address=0xfe836480 flags=0x0000] > [37920.370720] xhci_hcd 0000:06:00.3: WARNING: Host System Error > [37925.514865] xhci_hcd 0000:06:00.3: xHCI host not responding to stop > endpoint command. > [37925.514875] xhci_hcd 0000:06:00.3: USBSTS: HCHalted HSE EINT HCE > [37925.514883] xhci_hcd 0000:06:00.3: xHCI host controller not > responding, assume dead > [37925.515700] xhci_hcd 0000:06:00.3: HC died; cleaning up > [37925.515760] usb 3-1: USB disconnect, device number 2 > [37925.515765] usb 3-1.1: USB disconnect, device number 5 > [37925.515896] ================================================================== > [37925.515899] BUG: KASAN: use-after-free in > snd_complete_urb+0x109e/0x1740 [snd_usb_audio] > [37925.515919] Read of size 8 at addr ffff88813a264260 by task > kworker/19:0/649395 > > [37925.515926] CPU: 19 PID: 649395 Comm: kworker/19:0 Tainted: G > W --------- --- > 5.11.0-0.rc6.20210203git3aaf0a27ffc2.144.fc34.x86_64 #1 > [37925.515930] Hardware name: System manufacturer System Product > Name/ROG STRIX X570-I GAMING, BIOS 3402 01/13/2021 > [37925.515934] Workqueue: usb_hub_wq hub_event > [37925.515940] Call Trace: > [37925.515943] > [37925.515945] dump_stack+0xae/0xe5 > [37925.515955] print_address_description.constprop.0+0x18/0x160 > [37925.515960] ? snd_complete_urb+0x109e/0x1740 [snd_usb_audio] (snip) This must be a stray URB processed after the disconnection. Does the patch below help? thanks, Takashi --- a/sound/usb/card.c +++ b/sound/usb/card.c @@ -127,6 +127,8 @@ static void snd_usb_stream_disconnect(struct snd_usb_stream *as) subs = &as->substream[idx]; if (!subs->num_formats) continue; + snd_usb_endpoint_sync_pending_stop(subs->sync_endpoint); + snd_usb_endpoint_sync_pending_stop(subs->data_endpoint); subs->data_endpoint = NULL; subs->sync_endpoint = NULL; }