Received: by 2002:a05:7412:419a:b0:f3:1519:9f41 with SMTP id i26csp1586915rdh; Fri, 24 Nov 2023 17:31:28 -0800 (PST) X-Google-Smtp-Source: AGHT+IHG0EhBHQU1bgUMuDVc2GqBjT/H2zxJ5SLTYqdFr1emDv5m4UGznthjeyn2VlG2W6pboXh5 X-Received: by 2002:a05:6a20:1448:b0:18c:374c:6e64 with SMTP id a8-20020a056a20144800b0018c374c6e64mr1312040pzi.36.1700875888152; Fri, 24 Nov 2023 17:31:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700875888; cv=none; d=google.com; s=arc-20160816; b=IturDSr90YHD5sfAt5nugLqhZd1qcERvkDFJxnaOrtTXPgGUWSGK9mMvyIfhlA5xJJ sGn4jBbFgulUZo7xwYZG0j2vSJ8+uZYVk9iXqthJ1MvBBNolExIZGU1LjxSzScWh83Wz gPdAlf8yVDaVXC0ab8lWxHLfz2LU8MkPaVtNtpYtH7gcpTcY2TEUtnys8EUXsDBsPcHb DQehiMvGhIl7H/LvQa6ENItkvXhi0/yYt32GRJy3kv30M6DRDiXH/pBJPzBFbeq8BsgB pgtkMge1Xqdr97etBARaxcwvbPg9qD2uXPuIUgXieacFnT0Gco0rOBsrPhoNN0Ie/I2A WuqA== 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=JKCd3mvp8EhMZXPrdd/+Q/kZz56duRgmNMjj+zisTB0=; fh=V9AeBafJgTW96HdC48wsxGAfd7Fe9P2uAL8tLCjpUN4=; b=DaeRLtvGC9JKJ957EY1tMzsELcjO1gAU/4ismx5QIgvtM1N+Z+iz0xD6S/1NxnSz4o UDd5yk9z3w1PlSc3CXLvEtqQoetGD/x485oPZZ+r0jT0ha3DQ72Ug4zG5sVGYWqzeucd 0fB719md8WCTKD7EYsbWdkg/hHD6yYa3QVHgF7C0uuyEakShuR+nlZVwoBNel3QQcuDQ 6uISc0xR8K1S9Cvn64ZO4RxdTwm7bUThQPBH5ZLlZeCMrbLfP38vIYnIT4TQHEgczQLS U7vTAsU7Dn6z0yIf1xG9dTW25ICpnUPyki8TtDi2sgdpNymEJWdBrGdFv4PJkOiZN9gy aiYw== 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:6 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 pete.vger.email (pete.vger.email. [2620:137:e000::3:6]) by mx.google.com with ESMTPS id s18-20020a056a00195200b006cbbd597aa1si4839906pfk.242.2023.11.24.17.31.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 24 Nov 2023 17:31:28 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) client-ip=2620:137:e000::3:6; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 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 pete.vger.email (Postfix) with ESMTP id 8310D8026E27; Fri, 24 Nov 2023 17:31:20 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229810AbjKYBbG (ORCPT + 99 others); Fri, 24 Nov 2023 20:31:06 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54024 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229584AbjKYBbF (ORCPT ); Fri, 24 Nov 2023 20:31:05 -0500 Received: from mail-pj1-f72.google.com (mail-pj1-f72.google.com [209.85.216.72]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 68209170B for ; Fri, 24 Nov 2023 17:31:10 -0800 (PST) Received: by mail-pj1-f72.google.com with SMTP id 98e67ed59e1d1-2855e4715e4so2987433a91.0 for ; Fri, 24 Nov 2023 17:31:10 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1700875870; x=1701480670; 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=JKCd3mvp8EhMZXPrdd/+Q/kZz56duRgmNMjj+zisTB0=; b=syXg2pB8q32oQt7WJtohjlDnSnT1vklCi5ONEk+rTl6L+012yaYmfm5lgX0f4gIATD XVTUITW9hxLPHmVVMUlRKtv7LxJEoAxeXptYeiD2qRZQtaKr9k3yCrv1/gxQqXPTTWXh 1c45JgRC8JlkEALxFJzef9gErg2HGD1bYd4S5HqErwo41DEYEM/Lze5QNzMl6Q32OZom VnkVP2bo9ENE9LrjVGsCZeL2nJipnntfxCCIjwjNxYJsK6pF3nOrjTC4BSrfCllWm62m Wo21Fq/K56o5Miu7mWMabWQ4ZN4tc2yBRh5nx7iCQTn/KCvh/I6zYpd/0fW5VrQXJFW1 w8SQ== X-Gm-Message-State: AOJu0YyalK/nRfBGJxghy5lMs+42tHUbhrlAUF63j1GCW0FD5PberSGN dPYjVTqLX39g5Z4+NXr+nW8JCZJhmTsrUXTEeauxj5Z00UOPbY0= MIME-Version: 1.0 X-Received: by 2002:a17:90a:7564:b0:280:80ff:1c86 with SMTP id q91-20020a17090a756400b0028080ff1c86mr879251pjk.4.1700875870052; Fri, 24 Nov 2023 17:31:10 -0800 (PST) Date: Fri, 24 Nov 2023 17:31:09 -0800 In-Reply-To: <0000000000007b84a2060ac7d84b@google.com> X-Google-Appengine-App-Id: s~syzkaller X-Google-Appengine-App-Id-Alias: syzkaller Message-ID: <0000000000000aa95b060af0069b@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 pete.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 (pete.vger.email [0.0.0.0]); Fri, 24 Nov 2023 17:31:20 -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..0bf3d90c1442 100644 --- a/net/bluetooth/sco.c +++ b/net/bluetooth/sco.c @@ -285,6 +285,7 @@ static int sco_connect(struct sock *sk) goto unlock; } + hci_conn_get(hcon); /* Update source addr of the socket */ bacpy(&sco_pi(sk)->src, &hcon->src); @@ -297,10 +298,12 @@ static int sco_connect(struct sock *sk) } release_sock(sk); + printk("hd: %p, hcd: %p\n", &hdev->dev, &hcon->dev); unlock: hci_dev_unlock(hdev); - hci_dev_put(hdev); + if (err) + hci_dev_put(hdev); return err; } @@ -438,12 +441,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;