Received: by 2002:a05:6a10:d5a5:0:0:0:0 with SMTP id gn37csp3922978pxb; Mon, 4 Oct 2021 12:44:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyjmyy8fkNJT2MKpC8//w006ejtRzr+xiFcOGuWNIOhMrTLySos8hGXcjSh4t+09VVuBgnN X-Received: by 2002:a50:bec5:: with SMTP id e5mr20009931edk.373.1633376660369; Mon, 04 Oct 2021 12:44:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633376660; cv=none; d=google.com; s=arc-20160816; b=bGkzRuPOblTL8z07L0pRbQRWiJM0sfw6HcEiWUirQsIfN9mEfvmw90nHnQM8/P8feH FoYyMoEbjCO9Wdyoy/rIA8M+cxOU2/cjJh3Ygrwj20+3y6weqdAuUI8znbhS9FxGQyAW Erf4mClEmyAMUnWTYOel3UK7ioWJKm7cE8jl7e3b9xgFQNC4pbzMZ+K6arIvw9VIvJKy wmhkm6JXaQMbmepGZtBiDk9JPdLOnhg6x5wDWyUbhnzYolmqhYiutJ3BhHpWHRt+OI7L Lu2E0uioUtgOeDpCHOanNx0uj+ZuYGCBF/twG2lURTPaAD1FT1zBGQlsRxIZb/Yioy5A vH8w== 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=6kBRFhDk2tT3CNtWNJ0U3cIQd+viw4pvJzvGWQsZHJ4=; b=CZ0scVOkhHWrFlLibnC9UO9MZAOgkYUnc+tCvlLPVp40rk83aTKgOqM5Wrh5v9/m2c L734WkAS+T07oOgnKtwrrzIWHFotZmo7gp6n59jvWz9su2E1NMHGkN2kvnZ60lcV79mW NJVwbIEVLReKOi6Kn8UnLPAsVLJnEJkAN9uqmcRtZGZydNPwgsKafLgE+HgGvEI257oL 3ujIXi0Ksm8rRaNRc8bA0W7IWVMyO0URq5CSwAFeoRaCEfTDEfUek8DUEIm2iHkFQSST vlaFr8cZCHIGXQb2G2g4YYg5eaEqqrVkj3hh8Vc/BElgYebkg1oZua1cAyWyzpWkfySh vn7w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=2XWuTFv4; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id kx10si14484520ejc.472.2021.10.04.12.43.56; Mon, 04 Oct 2021 12:44:20 -0700 (PDT) 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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=2XWuTFv4; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235887AbhJDNOm (ORCPT + 99 others); Mon, 4 Oct 2021 09:14:42 -0400 Received: from mail.kernel.org ([198.145.29.99]:45800 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236016AbhJDNMm (ORCPT ); Mon, 4 Oct 2021 09:12:42 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id C51DC61B2B; Mon, 4 Oct 2021 13:04:56 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1633352697; bh=cUTiwfggWkTkoBOnHrKaY3s6iBGG2/Iy51L4KfSG/gg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=2XWuTFv47kabhc7Ljz3AWHT3ek5YFid76WW/wZ+tknuyn4bj6ZNolZvhiiz9tmbNu 5ctICIQ66GtleB+hhpH7foMvctWjTm0fXgRYIpsXyoLPkR84WORi8HcnuF+q+/u+EG Rf4z9AyO24a1UuU/0kVzV0EFaD1Yu9HQaMI4qvnE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, James Morse , "Rafael J. Wysocki" , Sasha Levin Subject: [PATCH 4.19 58/95] cpufreq: schedutil: Destroy mutex before kobject_put() frees the memory Date: Mon, 4 Oct 2021 14:52:28 +0200 Message-Id: <20211004125035.468096286@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20211004125033.572932188@linuxfoundation.org> References: <20211004125033.572932188@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: James Morse [ Upstream commit cdef1196608892b9a46caa5f2b64095a7f0be60c ] Since commit e5c6b312ce3c ("cpufreq: schedutil: Use kobject release() method to free sugov_tunables") kobject_put() has kfree()d the attr_set before gov_attr_set_put() returns. kobject_put() isn't the last user of attr_set in gov_attr_set_put(), the subsequent mutex_destroy() triggers a use-after-free: | BUG: KASAN: use-after-free in mutex_is_locked+0x20/0x60 | Read of size 8 at addr ffff000800ca4250 by task cpuhp/2/20 | | CPU: 2 PID: 20 Comm: cpuhp/2 Not tainted 5.15.0-rc1 #12369 | Hardware name: ARM LTD ARM Juno Development Platform/ARM Juno Development | Platform, BIOS EDK II Jul 30 2018 | Call trace: | dump_backtrace+0x0/0x380 | show_stack+0x1c/0x30 | dump_stack_lvl+0x8c/0xb8 | print_address_description.constprop.0+0x74/0x2b8 | kasan_report+0x1f4/0x210 | kasan_check_range+0xfc/0x1a4 | __kasan_check_read+0x38/0x60 | mutex_is_locked+0x20/0x60 | mutex_destroy+0x80/0x100 | gov_attr_set_put+0xfc/0x150 | sugov_exit+0x78/0x190 | cpufreq_offline.isra.0+0x2c0/0x660 | cpuhp_cpufreq_offline+0x14/0x24 | cpuhp_invoke_callback+0x430/0x6d0 | cpuhp_thread_fun+0x1b0/0x624 | smpboot_thread_fn+0x5e0/0xa6c | kthread+0x3a0/0x450 | ret_from_fork+0x10/0x20 Swap the order of the calls. Fixes: e5c6b312ce3c ("cpufreq: schedutil: Use kobject release() method to free sugov_tunables") Cc: 4.7+ # 4.7+ Signed-off-by: James Morse Signed-off-by: Rafael J. Wysocki Signed-off-by: Sasha Levin --- drivers/cpufreq/cpufreq_governor_attr_set.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/cpufreq/cpufreq_governor_attr_set.c b/drivers/cpufreq/cpufreq_governor_attr_set.c index 52841f807a7e..45fdf30cade3 100644 --- a/drivers/cpufreq/cpufreq_governor_attr_set.c +++ b/drivers/cpufreq/cpufreq_governor_attr_set.c @@ -77,8 +77,8 @@ unsigned int gov_attr_set_put(struct gov_attr_set *attr_set, struct list_head *l if (count) return count; - kobject_put(&attr_set->kobj); mutex_destroy(&attr_set->update_lock); + kobject_put(&attr_set->kobj); return 0; } EXPORT_SYMBOL_GPL(gov_attr_set_put); -- 2.33.0