Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2476658pxj; Sat, 19 Jun 2021 13:34:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwm4t53BkkDmEJ5eEtD+nJFQE2M1+2NLEBdFTWAjm1NJmUW0fEyBoUSgWRChNDkShnMRnYZ X-Received: by 2002:a5e:d512:: with SMTP id e18mr8270827iom.149.1624134890961; Sat, 19 Jun 2021 13:34:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1624134890; cv=none; d=google.com; s=arc-20160816; b=h4FKMP1FKH1KnDn58+KZYeBv8AzduV2fGl4KO03CuQbQN3kr71wchKNOu+RvHCGMwa EOzBeW9v59U81ez6XuR28JG3VGFYvSoxECvhflkJ7TkPN3pSBEN89tpgYOTunczFhbcZ FSx+rn6vWBt8cSH1PTOeYSNoUyMiWX4ijShaooqGzvGjCW4F8POg7hSt/wzUIoA4VkVF g3s83cQuV9J62on2dfzB92bT1RZRNpOyU5tBz56ZPU07WoIwd14hVDQPIIdCya+oCC2Y pmkQdguLVYbPSv3iuUSekqL4zsfXOlxSmenYD2G1Ya8O/rwN0lsvL3sSlnvgSYcGjgcz mgZA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:references :in-reply-to:subject:cc:to:dkim-signature:dkim-signature:from; bh=ums+h3Qr4LeMZdW3sa2+1i2S4XpLBjN7KS0U3VAjUCc=; b=Fsu6NakF7SS0aQEuo8/DuUzd4nL6a03R9eH6ARBNwI4dO11vBsZ7rY9WWCJreTl4ll DnCcJ/GmHY36tCMmeMJq+Vhgnpi0Bh4WvolyZJiE/tN/VH4xVq5ADXHjEG+PyEjwrMz5 DizGt81w05gy9OtFMRMrR/iiE0Kggozqq8meotGFDr5AsWQa/cKutVq9XYGxfoHhaD0D xpevdQyIuAXIYYs/nKNxkCnMUg81YyTs8JKbWPSQFqlq+tBMJWwYEk+6aNrOGXtD9IN9 F4YGOruXu67pprDyTGABICqPTWRgqvkmaxoVise91KNWRnoH1n9IAlfmLLmLIABhhwSV uyyw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=TDFuKC2N; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e header.b=QljFLa8+; 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=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q10si7240762ilu.60.2021.06.19.13.34.39; Sat, 19 Jun 2021 13:34:50 -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=@linutronix.de header.s=2020 header.b=TDFuKC2N; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e header.b=QljFLa8+; 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=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233766AbhFSLjs (ORCPT + 99 others); Sat, 19 Jun 2021 07:39:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43496 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230437AbhFSLjs (ORCPT ); Sat, 19 Jun 2021 07:39:48 -0400 Received: from galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D0DEEC061574 for ; Sat, 19 Jun 2021 04:37:37 -0700 (PDT) From: Thomas Gleixner DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1624102654; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=ums+h3Qr4LeMZdW3sa2+1i2S4XpLBjN7KS0U3VAjUCc=; b=TDFuKC2NjnHaaPfa3ipTmLHktR1lXcAl4IiUrBoa+5fZ3fuN3QoM0h3hYSu/jbWaichDUS X+2/o8O5enb091NmBaEtTiFgVHfvN++EVfBElBYYNf+0rlpsr10UCMlgE3M1QA5uoYhDJ2 wfz2lYmyURjV5aOh2gop5OcVO/u+9K871feHYeXidbNld3dPNFjWvb36xzh5Y/5pxINP5T 1BKsVeVkecYJfzEMjpRT8nJtdaHmZSzs0vLl3asOL//4JXvUjtxQ71z+UwyCDkBstAl2T3 MHSEzG3OMGAluJgEWg2QVI5+rz0RbkfqS3qqkAJpoHclH5hcj/mloqYfwBx/fg== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1624102654; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=ums+h3Qr4LeMZdW3sa2+1i2S4XpLBjN7KS0U3VAjUCc=; b=QljFLa8+AHJO0aSz3EEe7DT8kh3JVsUemjJQxevrjWPntcFXkCAuCAxBCOcrE1QU8xsM1H AvkwvB3KDJm9R9Cg== To: Marc Zyngier , linux-kernel@vger.kernel.org Cc: Michael Ellerman , Benjamin Herrenschmidt , Paul Mackerras , Ley Foon Tan , Chris Zankel , Max Filippov , Vineet Gupta , Thomas Bogendoerfer , Robert Jarzmik , Russell King , Krzysztof Kozlowski , Yoshinori Sato , Rich Felker , Geert Uytterhoeven , Alex Deucher , Christian =?utf-8?Q?K=C3=B6nig?= , David Airlie , Daniel Vetter , Rob Clark , Linus Walleij , Lee Jones , Lorenzo Pieralisi , Rob Herring , Bjorn Helgaas , Bartosz Golaszewski , kernel-team@android.com Subject: Re: [PATCH 20/39] irqdomain: Protect the linear revmap with RCU In-Reply-To: <20210520163751.27325-21-maz@kernel.org> References: <20210520163751.27325-1-maz@kernel.org> <20210520163751.27325-21-maz@kernel.org> Date: Sat, 19 Jun 2021 13:37:33 +0200 Message-ID: <87zgvmccg2.ffs@nanos.tec.linutronix.de> MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, May 20 2021 at 17:37, Marc Zyngier wrote: > static void irq_domain_clear_mapping(struct irq_domain *domain, > @@ -902,12 +901,12 @@ unsigned int irq_find_mapping(struct irq_domain *domain, > return 0; > } > > + rcu_read_lock(); > /* Check if the hwirq is in the linear revmap. */ > if (hwirq < domain->revmap_size) > - return domain->revmap[hwirq]->irq; > - > - rcu_read_lock(); > - data = radix_tree_lookup(&domain->revmap_tree, hwirq); > + data = rcu_dereference(domain->revmap[hwirq]); > + else > + data = radix_tree_lookup(&domain->revmap_tree, hwirq); > rcu_read_unlock(); > return data ? data->irq : 0; This is wrong and was wrong before. This wants to be: irq = data ? data->irq : 0; rcu_read_unlock(); return irq; Thanks, tglx