Received: by 2002:a05:7412:419a:b0:f3:1519:9f41 with SMTP id i26csp1013353rdh; Fri, 24 Nov 2023 03:29:45 -0800 (PST) X-Google-Smtp-Source: AGHT+IEshu8TZb9fmmKYcgCI5q/f08nb/eTxU1cCrEdBCxbG0SuiAkvXlk4v9oDFZDcNe5E0F5iR X-Received: by 2002:a17:90b:3e86:b0:285:93d4:1d0 with SMTP id rj6-20020a17090b3e8600b0028593d401d0mr651246pjb.6.1700825384700; Fri, 24 Nov 2023 03:29:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700825384; cv=none; d=google.com; s=arc-20160816; b=X9+Z+xGpcvdvd1YwN7KeMl/M4AjGSATzkeF2/38KQ0rTNHdiP/b/GU6q4DJQ7JjF0P 0wb9XgD5v0LhzkusJBW0bNnM22N9HJpY3V7FudW+r5ZKLGJgXZN/9LNtdaMVjWPXc6X7 fJ9znIBXyI82zwJhoEPXCXOYjSaMToyqMwgkvnYQFjGndI1SC/wowYleYrZHS0sAGjny 7Dw00de75dZhg0/2u6/ft/p/s/hS4nAUy9rtLM3ECm0bFs05ZgGsyHIzB5cVXw3KIrjd KeDF8l3LE0YIpFZ7Hz8W13csbQ7ljtnvT9UyICHUHUB4WQjqvK2yv6YwtaV+mPADLh3G r4sQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:to:from:subject:message-id:in-reply-to:date :mime-version; bh=DbVjBFBegUBKRhGHJFhM5Hhz1L9HgxzrvisoXWZeyIk=; fh=V9AeBafJgTW96HdC48wsxGAfd7Fe9P2uAL8tLCjpUN4=; b=fNJKtkbzwltDrbrAq4fJgxgKUJORTEWf6tVguLxb9PPQc9VP3XUHA8Air6LtSHtIBH 3mu+agESfnmtRF+aikH9tyafRlkJ25pqvsieaLuDLoTGEkxIg10VbyLslbOJWWlTCHYn wdWtRz/iu90O7nQzop9pu0WTFeA6greB3BuFJUMQf2N7yWq72DjSGhI2tyvHoysAT1hi fV75dqmFP5Ou6YEJhXu7U3d/C/8H0JQnSBzPCUK0+sDDHReZvKvW2COqQhCtItLrA1rX 4gLfIenuIFjJoTHBk864UurRqKLfuu48k9cZ487pB0SqWh36HXBM8rlA4XkkEgj6h+TN 5AJg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=appspotmail.com Return-Path: Received: from groat.vger.email (groat.vger.email. [2620:137:e000::3:5]) by mx.google.com with ESMTPS id u13-20020a17090341cd00b001cf6a75337dsi3389441ple.378.2023.11.24.03.29.44 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 24 Nov 2023 03:29:44 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) client-ip=2620:137:e000::3:5; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=appspotmail.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by groat.vger.email (Postfix) with ESMTP id 68631811C146; Fri, 24 Nov 2023 03:29:41 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at groat.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230303AbjKXL3S (ORCPT + 99 others); Fri, 24 Nov 2023 06:29:18 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54252 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229580AbjKXL3R (ORCPT ); Fri, 24 Nov 2023 06:29:17 -0500 Received: from mail-pf1-f197.google.com (mail-pf1-f197.google.com [209.85.210.197]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3EDEA10D7 for ; Fri, 24 Nov 2023 03:29:24 -0800 (PST) Received: by mail-pf1-f197.google.com with SMTP id d2e1a72fcca58-6cbb6ff734dso1871982b3a.0 for ; Fri, 24 Nov 2023 03:29:24 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1700825364; x=1701430164; h=to:from:subject:message-id:in-reply-to:date:mime-version :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=DbVjBFBegUBKRhGHJFhM5Hhz1L9HgxzrvisoXWZeyIk=; b=XauFtm50pRW7cNCtNjON/JknOUEOGkxjq4DbH20W3tiVbfobmEeDvfI6N/LdGH5iUG suFoYHBH1JTDtFjfPGYlt7SlCI6JTd53HcSeFW7IGfIyvtI/zr1lk5pXa14a3jXS9Lpu yv+Q8yDvK12BWM5ojGR/QfUuzhQPIBhZk08bqsWBKQUpOunTuXOHYqI+AEJGj5F5WRy+ M2wDCBF1oYViiu53TCnyTWZptBGmw5vatYwHpc0FAj70qMkHyrMOk3DkyX5ojMjRgNg6 0eElsxRU3VERYr6tHW8F8eiGEuPOabh+QtMyLpy+328fHwVR8DXu4NilihAf1NmAHPMN 4sBQ== X-Gm-Message-State: AOJu0YzQEgVvqauHLKADkUoWqEn+w8pCbC3Zt/soYU+PL3rZeg1mS18H KnROHYjDI3M43PO1Sz2bKDCF3OTYHVyjDIM/iOiT5vpBWpeUsms= MIME-Version: 1.0 X-Received: by 2002:a05:6a00:2d8f:b0:6c3:9efc:6840 with SMTP id fb15-20020a056a002d8f00b006c39efc6840mr702921pfb.0.1700825363819; Fri, 24 Nov 2023 03:29:23 -0800 (PST) Date: Fri, 24 Nov 2023 03:29:23 -0800 In-Reply-To: <0000000000007b84a2060ac7d84b@google.com> X-Google-Appengine-App-Id: s~syzkaller X-Google-Appengine-App-Id-Alias: syzkaller Message-ID: <000000000000a2b6b9060ae4439a@google.com> Subject: Re: [syzbot] [bluetooth?] KASAN: slab-use-after-free Read in __lock_sock From: syzbot To: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-0.4 required=5.0 tests=FROM_LOCAL_HEX, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on groat.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (groat.vger.email [0.0.0.0]); Fri, 24 Nov 2023 03:29:41 -0800 (PST) For archival purposes, forwarding an incoming command email to linux-kernel@vger.kernel.org. *** Subject: [bluetooth?] KASAN: slab-use-after-free Read in __lock_sock Author: eadavis@qq.com please test uaf in __lock_sock #syz test https://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux.git 8de1e7afcc1c diff --git a/net/bluetooth/sco.c b/net/bluetooth/sco.c index c736186aba26..062ab9926146 100644 --- a/net/bluetooth/sco.c +++ b/net/bluetooth/sco.c @@ -270,6 +270,7 @@ static int sco_connect(struct sock *sk) goto unlock; } + hci_conn_get(hcon); conn = sco_conn_add(hcon); if (!conn) { hci_conn_drop(hcon); @@ -300,7 +301,8 @@ static int sco_connect(struct sock *sk) unlock: hci_dev_unlock(hdev); - hci_dev_put(hdev); + if (err) + hci_dev_put(hdev); return err; } @@ -438,12 +440,13 @@ static void __sco_sock_close(struct sock *sk) case BT_CONNECTED: case BT_CONFIG: if (sco_pi(sk)->conn->hcon) { + struct hci_conn *hcon = sco_pi(sk)->conn->hcon; sk->sk_state = BT_DISCONN; sco_sock_set_timer(sk, SCO_DISCONN_TIMEOUT); sco_conn_lock(sco_pi(sk)->conn); - hci_conn_drop(sco_pi(sk)->conn->hcon); sco_pi(sk)->conn->hcon = NULL; sco_conn_unlock(sco_pi(sk)->conn); + hci_conn_put(hcon); } else sco_chan_del(sk, ECONNRESET); break;