Received: by 2002:a05:6358:bb9e:b0:b9:5105:a5b4 with SMTP id df30csp4483071rwb; Tue, 6 Sep 2022 08:08:25 -0700 (PDT) X-Google-Smtp-Source: AA6agR7xMPqMVfLaNbbXFsJKndi8w9ES4h6h+HgDhH7/KSiD1qZtVDE3sb9TLmZoQj2c+Id098mZ X-Received: by 2002:a17:906:8a70:b0:730:9c9e:edb2 with SMTP id hy16-20020a1709068a7000b007309c9eedb2mr39492487ejc.41.1662476905348; Tue, 06 Sep 2022 08:08:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662476905; cv=none; d=google.com; s=arc-20160816; b=PO4Go0zxQj0iDESdDOoMx37nfLd416x79iH8ETXS76gSsJQZhFbrR30hmCJUx1XLn8 AoFhUlB7w+loCAAvoe4xTy9/G5WeMS2DZzbOk/CRWHj4EQ0WzJb2JDL1xx7u8XTJDEX6 Uz7Upo8I2d51i7+DMM6OjH8SIXA7DZLav1nCRNWq3dT2l+tXbfaW2TL7w0m9WNbel1LS OUqgueasU+Xo/1ojxsgoOZBlRjl/zBjCVyccRgLe1pYRwtH2plOf7xE2GBLJqS1ftYkf tx3rsGqr/hPV3ERrRr59qhr4Uq0Y2pImdWhaMjj/Ts6NUWfaX8GHwG9JQal9xKZ8ANDs MyXw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=FTyp3cM0k74dULUUY0QsfJsmldFkOqG8lvsSOj0Q/Z0=; b=dOA/IQLk7vQL927xoUoTy6Fnk0BFAufJAxD2igUgCy61vq+JG52VUaLt8kpVM9JEoK MCNxO/H9BeqPjJN6fMY+bfbmLgNS1ABQsMHDIX92kizhPzMcM3QvNeVQDbct6X1q1M42 4PUPt3qNT0dNsBqc7DuJ5UuCQSXQ/j67OmZWkfH994lA/pd1BikDw+yZyL9u2nEKJKFd hLEVQn11oaXqRPUpHdJ3swR71WzYDFIphamC+6lxI3BDKviVmIQgg1K+/vORXFTtJga9 ZofydatRqyRaO2Cnyqh7yXAYFR24K5Q3TcmH+HSGyrHhFUacGkvxduiR5vUEVJnqZlv+ mFtQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=tJJoSxnj; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id z23-20020a170906435700b0073305fd2278si9283252ejm.864.2022.09.06.08.08.00; Tue, 06 Sep 2022 08:08:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=tJJoSxnj; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241191AbiIFOL7 (ORCPT + 99 others); Tue, 6 Sep 2022 10:11:59 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47882 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241488AbiIFOJ6 (ORCPT ); Tue, 6 Sep 2022 10:09:58 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 190E521F; Tue, 6 Sep 2022 06:46:53 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 96E0960F89; Tue, 6 Sep 2022 13:45:05 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id A80F4C433C1; Tue, 6 Sep 2022 13:45:04 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1662471905; bh=NXCp2eaXznJ9Fd0qfjNqHDvYHzOAwG68JEvZdL3PSP4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=tJJoSxnj++XFIM7d2uILAaUv3IqP2Ob2tW6DAhxkYeDMdH3By9kS8GIlxKmb5UQp1 4de4J4xj4KK8irwKy7slcgHpldKYdfJfPNWyLzIlZlMLJvgicIFBbt1ZYsjS+BvQCj BxxdDjVfwXAp7zGQsJ61gjHxsT1ZFS45I6gE5Srs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Christian Brauner (Microsoft)" , Carlos Llamas , stable Subject: [PATCH 5.19 080/155] binder: fix UAF of ref->proc caused by race condition Date: Tue, 6 Sep 2022 15:30:28 +0200 Message-Id: <20220906132832.817334545@linuxfoundation.org> X-Mailer: git-send-email 2.37.3 In-Reply-To: <20220906132829.417117002@linuxfoundation.org> References: <20220906132829.417117002@linuxfoundation.org> User-Agent: quilt/0.67 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Carlos Llamas commit a0e44c64b6061dda7e00b7c458e4523e2331b739 upstream. A transaction of type BINDER_TYPE_WEAK_HANDLE can fail to increment the reference for a node. In this case, the target proc normally releases the failed reference upon close as expected. However, if the target is dying in parallel the call will race with binder_deferred_release(), so the target could have released all of its references by now leaving the cleanup of the new failed reference unhandled. The transaction then ends and the target proc gets released making the ref->proc now a dangling pointer. Later on, ref->node is closed and we attempt to take spin_lock(&ref->proc->inner_lock), which leads to the use-after-free bug reported below. Let's fix this by cleaning up the failed reference on the spot instead of relying on the target to do so. ================================================================== BUG: KASAN: use-after-free in _raw_spin_lock+0xa8/0x150 Write of size 4 at addr ffff5ca207094238 by task kworker/1:0/590 CPU: 1 PID: 590 Comm: kworker/1:0 Not tainted 5.19.0-rc8 #10 Hardware name: linux,dummy-virt (DT) Workqueue: events binder_deferred_func Call trace: dump_backtrace.part.0+0x1d0/0x1e0 show_stack+0x18/0x70 dump_stack_lvl+0x68/0x84 print_report+0x2e4/0x61c kasan_report+0xa4/0x110 kasan_check_range+0xfc/0x1a4 __kasan_check_write+0x3c/0x50 _raw_spin_lock+0xa8/0x150 binder_deferred_func+0x5e0/0x9b0 process_one_work+0x38c/0x5f0 worker_thread+0x9c/0x694 kthread+0x188/0x190 ret_from_fork+0x10/0x20 Acked-by: Christian Brauner (Microsoft) Signed-off-by: Carlos Llamas Cc: stable # 4.14+ Link: https://lore.kernel.org/r/20220801182511.3371447-1-cmllamas@google.com Signed-off-by: Greg Kroah-Hartman --- drivers/android/binder.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/drivers/android/binder.c b/drivers/android/binder.c index c964d7c8c384..6428f6be69e3 100644 --- a/drivers/android/binder.c +++ b/drivers/android/binder.c @@ -1385,6 +1385,18 @@ static int binder_inc_ref_for_node(struct binder_proc *proc, } ret = binder_inc_ref_olocked(ref, strong, target_list); *rdata = ref->data; + if (ret && ref == new_ref) { + /* + * Cleanup the failed reference here as the target + * could now be dead and have already released its + * references by now. Calling on the new reference + * with strong=0 and a tmp_refs will not decrement + * the node. The new_ref gets kfree'd below. + */ + binder_cleanup_ref_olocked(new_ref); + ref = NULL; + } + binder_proc_unlock(proc); if (new_ref && ref != new_ref) /* -- 2.37.3