Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp3114996iog; Mon, 20 Jun 2022 11:39:05 -0700 (PDT) X-Google-Smtp-Source: AGRyM1tLSVJyzIpGAEIGzABi8nXUsa6f14Rzz++G87qv5NdG72LYULgOTphibaEiB7PLq50wuFOK X-Received: by 2002:a05:6402:4246:b0:42f:3a4b:cc71 with SMTP id g6-20020a056402424600b0042f3a4bcc71mr30682182edb.107.1655750345039; Mon, 20 Jun 2022 11:39:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655750345; cv=none; d=google.com; s=arc-20160816; b=TFk0ozQNvIJHpn6Ubtm8T6/mHp+Wm5bVv1oDNAzR0lDPscJ6WI1ZW0AsWBflXFemAW Xj+BlxZosoS81JsmzLCDVjwDBkLmDm9gPRuU/fhFeSSw7HKUwbyqajbVHgFCtNu28SYB WbpFppqi6PRSTQiqoDNGPtiEMXxZ4gTo9jP05KlE6cYFomOwwP923oUr6LpVi4YEW6+k WvdvV+04e5xE0PYFJ06dSFsoPUVMH/VF0KAcLDzktcz0vHzt5wlE5uw50fOMkfkcx5B3 YXEiHiVXhgx6Ra7kEcVYH7uRBoKETG6PMuv3IxqJjO8cQMFWYcU2zr8+Gj59G4Dtgwns y9fw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=2gvDReOcSCJLK1hpjqtTlbllYa6SFFtTKZwlUiOnn00=; b=n0KB/APL5hpVEDX3eqKzfwougKzk0Ht6YlQf7Ls4RVIMiqcVbfOGu30OBDV3OwFVSA BCRNVyYm29dmtCv8gBrqE+5unJBvMvZpWiNOfymSQ6vhOl5vf6e2624ujq5HVM2uKMFY y2c7+MmI33inpH8/e0dIny9lxO6k5sJPf+v61PrB34jkmLU/pxIlPJRID3M5hkKaMt2L /GmgSve2zx3EvsHn096v+VOiSbokmszjfiqJuCSlf2qCtpQQfHNv8+4OluhlN/NewlnO qvvLIVb5Sd4n3kzsxkbH93Wc5N0HkV9nGSFjO/SQU5h/i6oA5Ow3Xo27OJOF+haxT/S2 dVIg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=EjhnPh27; 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=linaro.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id sb7-20020a1709076d8700b00718cbb74b81si10183491ejc.695.2022.06.20.11.38.39; Mon, 20 Jun 2022 11:39:05 -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=@linaro.org header.s=google header.b=EjhnPh27; 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=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244634AbiFTR5m (ORCPT + 99 others); Mon, 20 Jun 2022 13:57:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43440 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244766AbiFTR5Z (ORCPT ); Mon, 20 Jun 2022 13:57:25 -0400 Received: from mail-pl1-x635.google.com (mail-pl1-x635.google.com [IPv6:2607:f8b0:4864:20::635]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BA2EC20BE6 for ; Mon, 20 Jun 2022 10:56:59 -0700 (PDT) Received: by mail-pl1-x635.google.com with SMTP id y6so10415498plg.0 for ; Mon, 20 Jun 2022 10:56:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=2gvDReOcSCJLK1hpjqtTlbllYa6SFFtTKZwlUiOnn00=; b=EjhnPh27T742JtvTSdZvPxxgMZzNj2Dx8+ZRkOUSHiRqYsATWleiPsyAVkSvD+ZdbI pGoJyCSttyegdfaqaVbbjeHi9L6AFvIaGLI5LTvizvkzVV12lAKEwzOXpw5g7Q5MGtsG /8mxq9PH7NcnhBOgGDPZbFHEPWhPsMziMShqOqRq+vQnRsWQF9fyzaGHUM/81+S5n9Je 5AGzwU6+Tl6njlLkKUuoa814j8IvrMuj2HCbeVDSt8oX2CbXBa6iv34Vh1MxQSAHWoBv oKv/XAvlOf0LPRTIzXCxX3wDUaUyD0sWXH9PjMPCO0F28gS2HTYEQu0xwhmdxm2POik0 gSXg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=2gvDReOcSCJLK1hpjqtTlbllYa6SFFtTKZwlUiOnn00=; b=LL3OnP3FoV4R0+wvZR3dVg+JHkSqJPCnQkLoMEgo5fUvs6WHcJddlEDEo/2Zdr40p4 TUgq4JAELyd/Vi2W2rbXVXlfBOvA6kr2mC6FCCv31/0jg/R/7PEKUN6BbT2jkTQSmlJh 9ekJAcpZwNAryigR90kbH/cX7CYCOV5QssHWu+I1b0yZ2jGCP9lHlY8nR2Jx6DJp2EiN 1+X29H2UdEdlpOX3duZPLfz5u9aSMK5oeeMHCdN6+hcQOq0TxjfO2cc8Vmj4xz0819nx 8QsB/AkywdwpFPx9NLkhx1dhJnA6gN047SOo9SFAnfd88IvxhH3p2G5/r2NUbCkWrmwP vIUQ== X-Gm-Message-State: AJIora97MVBpKaZaZXRhpd3TkJVBZwtpM55QrFPqv5lD4YtxG4M59bnv zlNcL+PjucNZ2LgtOf0W82V7lx4nYoWwGg== X-Received: by 2002:a17:90a:6b45:b0:1e3:3cfa:3104 with SMTP id x5-20020a17090a6b4500b001e33cfa3104mr39032055pjl.113.1655747819262; Mon, 20 Jun 2022 10:56:59 -0700 (PDT) Received: from p14s (S0106889e681aac74.cg.shawcable.net. [68.147.0.187]) by smtp.gmail.com with ESMTPSA id k8-20020a170902760800b0016223b5d228sm8973317pll.288.2022.06.20.10.56.57 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 20 Jun 2022 10:56:58 -0700 (PDT) Date: Mon, 20 Jun 2022 11:56:55 -0600 From: Mathieu Poirier To: Suzuki K Poulose Cc: coresight@lists.linaro.org, linux-arm-kernel@lists.infradead.org, anshuman.khandual@arm.com, linux-kernel@vger.kernel.org, stable@vger.kernel.org, Mike Leach , Leo Yan Subject: Re: [PATCH] coresight: Clear the connection field properly Message-ID: <20220620175655.GC1458883@p14s> References: <20220614214024.3005275-1-suzuki.poulose@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20220614214024.3005275-1-suzuki.poulose@arm.com> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, 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 lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jun 14, 2022 at 10:40:24PM +0100, Suzuki K Poulose wrote: > coresight devices track their connections (output connections) and > hold a reference to the fwnode. When a device goes away, we walk through > the devices on the coresight bus and make sure that the references > are dropped. This happens both ways: > a) For all output connections from the device, drop the reference to > the target device via coresight_release_platform_data() > > b) Iterate over all the devices on the coresight bus and drop the > reference to fwnode if *this* device is the target of the output > connection, via coresight_remove_conns()->coresight_remove_match(). > > However, the coresight_remove_match() doesn't clear the fwnode field, > after dropping the reference, this causes use-after-free and > additional refcount drops on the fwnode. > > e.g., if we have two devices, A and B, with a connection, A -> B. > If we remove B first, B would clear the reference on B, from A > via coresight_remove_match(). But when A is removed, it still has > a connection with fwnode still pointing to B. Thus it tries to drops > the reference in coresight_release_platform_data(), raising the bells > like : > > [ 91.990153] ------------[ cut here ]------------ > [ 91.990163] refcount_t: addition on 0; use-after-free. > [ 91.990212] WARNING: CPU: 0 PID: 461 at lib/refcount.c:25 refcount_warn_saturate+0xa0/0x144 > [ 91.990260] Modules linked in: coresight_funnel coresight_replicator coresight_etm4x(-) > crct10dif_ce coresight ip_tables x_tables ipv6 [last unloaded: coresight_cpu_debug] > [ 91.990398] CPU: 0 PID: 461 Comm: rmmod Tainted: G W T 5.19.0-rc2+ #53 > [ 91.990418] Hardware name: ARM LTD ARM Juno Development Platform/ARM Juno Development Platform, BIOS EDK II Feb 1 2019 > [ 91.990434] pstate: 600000c5 (nZCv daIF -PAN -UAO -TCO -DIT -SSBS BTYPE=--) > [ 91.990454] pc : refcount_warn_saturate+0xa0/0x144 > [ 91.990476] lr : refcount_warn_saturate+0xa0/0x144 > [ 91.990496] sp : ffff80000c843640 > [ 91.990509] x29: ffff80000c843640 x28: ffff800009957c28 x27: ffff80000c8439a8 > [ 91.990560] x26: ffff00097eff1990 x25: ffff8000092b6ad8 x24: ffff00097eff19a8 > [ 91.990610] x23: ffff80000c8439a8 x22: 0000000000000000 x21: ffff80000c8439c2 > [ 91.990659] x20: 0000000000000000 x19: ffff00097eff1a10 x18: ffff80000ab99c40 > [ 91.990708] x17: 0000000000000000 x16: 0000000000000000 x15: ffff80000abf6fa0 > [ 91.990756] x14: 000000000000001d x13: 0a2e656572662d72 x12: 657466612d657375 > [ 91.990805] x11: 203b30206e6f206e x10: 6f69746964646120 x9 : ffff8000081aba28 > [ 91.990854] x8 : 206e6f206e6f6974 x7 : 69646461203a745f x6 : 746e756f63666572 > [ 91.990903] x5 : ffff00097648ec58 x4 : 0000000000000000 x3 : 0000000000000027 > [ 91.990952] x2 : 0000000000000000 x1 : 0000000000000000 x0 : ffff00080260ba00 > [ 91.991000] Call trace: > [ 91.991012] refcount_warn_saturate+0xa0/0x144 > [ 91.991034] kobject_get+0xac/0xb0 > [ 91.991055] of_node_get+0x2c/0x40 > [ 91.991076] of_fwnode_get+0x40/0x60 > [ 91.991094] fwnode_handle_get+0x3c/0x60 > [ 91.991116] fwnode_get_nth_parent+0xf4/0x110 > [ 91.991137] fwnode_full_name_string+0x48/0xc0 > [ 91.991158] device_node_string+0x41c/0x530 > [ 91.991178] pointer+0x320/0x3ec > [ 91.991198] vsnprintf+0x23c/0x750 > [ 91.991217] vprintk_store+0x104/0x4b0 > [ 91.991238] vprintk_emit+0x8c/0x360 > [ 91.991257] vprintk_default+0x44/0x50 > [ 91.991276] vprintk+0xcc/0xf0 > [ 91.991295] _printk+0x68/0x90 > [ 91.991315] of_node_release+0x13c/0x14c > [ 91.991334] kobject_put+0x98/0x114 > [ 91.991354] of_node_put+0x24/0x34 > [ 91.991372] of_fwnode_put+0x40/0x5c > [ 91.991390] fwnode_handle_put+0x38/0x50 > [ 91.991411] coresight_release_platform_data+0x74/0xb0 [coresight] > [ 91.991472] coresight_unregister+0x64/0xcc [coresight] > [ 91.991525] etm4_remove_dev+0x64/0x78 [coresight_etm4x] > [ 91.991563] etm4_remove_amba+0x1c/0x2c [coresight_etm4x] > [ 91.991598] amba_remove+0x3c/0x19c > > Reproducible by: (Build all coresight components as modules): > > #!/bin/sh > while true > do > for m in tmc stm cpu_debug etm4x replicator funnel > do > modprobe coresight_${m} > done > > for m in tmc stm cpu_debug etm4x replicator funnel > do > rmmode coresight_${m} > done > done > > Cc: stable@vger.kernel.org > Cc: Mathieu Poirier > Cc: Mike Leach > Cc: Leo Yan > Signed-off-by: Suzuki K Poulose > --- > drivers/hwtracing/coresight/coresight-core.c | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/drivers/hwtracing/coresight/coresight-core.c b/drivers/hwtracing/coresight/coresight-core.c > index ee6ce92ab4c3..1edfec1e9d18 100644 > --- a/drivers/hwtracing/coresight/coresight-core.c > +++ b/drivers/hwtracing/coresight/coresight-core.c > @@ -1424,6 +1424,7 @@ static int coresight_remove_match(struct device *dev, void *data) > * platform data. > */ > fwnode_handle_put(conn->child_fwnode); > + conn->child_fwnode = NULL; > /* No need to continue */ I have applied this patch. Thanks, Mathieu > break; > } > -- > 2.35.3 >