Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp9640900rwb; Thu, 24 Nov 2022 16:30:05 -0800 (PST) X-Google-Smtp-Source: AA0mqf6vzxJv3RcE4vZFjbtZTYrboOkam7Q8clOmUNPcdOjsRs0Jh8yWKFV/4MNUtFLIAs/QSiqN X-Received: by 2002:a17:90a:fb84:b0:218:7e9d:9617 with SMTP id cp4-20020a17090afb8400b002187e9d9617mr16471406pjb.133.1669336204899; Thu, 24 Nov 2022 16:30:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1669336204; cv=none; d=google.com; s=arc-20160816; b=aWzkoi/vW2Ox4XcLrBTsDOY6nUb/HmHi2LGY92vJ9BHVQ1tbzScGb4bcsKStkEUFKy wgY/gHPH/iygDwyrptLo9FT+XsNyzdLC64oYJdYKtuUmO5eA1Txbu2x9Dq4ClGPaAWuN aXuVUI+mcVkZjB7oYn0EmKXLPTXyC9lH69ka9y2rZCdI8hAbn03/tsii0DqDyN+NJjYW ofbAxh6fyHQ5mFeexKdyOd1iwI96erFjVWsGVPHInH6zUlGi1UzLflCz100oicnvoDNJ Tfdfr1nfdnDMjdYa75x9iqITkXb7hMK1me4P+gWmuZvwthZlITDuh9A3asbdaA92hQ3P Ah6Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:date:mime-version:references:subject:cc:to:from :dkim-signature:dkim-signature:message-id; bh=r4t3gJp+Epgg61Tiq3or6HjYA/efOz+SN1LtRddhdOs=; b=RzhXY7S21JcgaQLCYCMFzv9iYtgtSKKYUnWLNHxfSOeH/QqQPJ02qj1Dbq3paLD4qK G82LlCiAyUBU4eTNjPmldJ2J9AdQEbbmDGDtqYutMc+EELvrltWfD9KORw0IcJTYDz/e +4Apg/bazojUyf6XvvFkkCvdqPMojLQRaivrA0mZFBVZ3FKShoY6uyW0hO95aH2f/rjt t/1xOpuUVvl/yueofO3Al+maN1OTMRy5sEKPWDXh6eWk1aahyIDmllVax++/JIGkD7a6 oTIwvo34GCDmgLBR5j5GEdyP7ihns+kjH1+8cYpnd8nzkvD3jtECIeKT6HIElvumeyRB xS3A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=suRBtcBW; dkim=neutral (no key) header.i=@linutronix.de; 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=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id f12-20020a65400c000000b00439ae523fd2si2566103pgp.289.2022.11.24.16.29.53; Thu, 24 Nov 2022 16:30:04 -0800 (PST) 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=@linutronix.de header.s=2020 header.b=suRBtcBW; dkim=neutral (no key) header.i=@linutronix.de; 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=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229646AbiKXXYV (ORCPT + 87 others); Thu, 24 Nov 2022 18:24:21 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42312 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229632AbiKXXYQ (ORCPT ); Thu, 24 Nov 2022 18:24:16 -0500 Received: from galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4EA8E827E2; Thu, 24 Nov 2022 15:24:15 -0800 (PST) Message-ID: <20221124230313.574541683@linutronix.de> DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1669332252; 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: references:references; bh=r4t3gJp+Epgg61Tiq3or6HjYA/efOz+SN1LtRddhdOs=; b=suRBtcBWsuoHnNDku70nvLLCb4ahDk0yeRe3n7IB9ZXig1+0hzWJXKCNi+orquLKd808FX EeVpL92NST/vy6i6kHvlErQxQJxEAkl4g8O6XO1QCbI3iP1mRs5fFeFgpLGtiyhSSCO09h 7uAl0iBEKamhsmB1uM+252+2pqHCf7T9Doo/yoBTpi4MgE6UG4rUEmTAcS/tuBTc/Gbo1w TreVB4jUWeLXMRQpaWBnlHOyrezYjdhmHLnjll3vIYSDFeVf/X4HB4taDqwdNXrhbaU+jE UHGSLlxGAj0d6fRRXQ/EKzDT+GMv0szf1rC9FrFKY/HWS5kFlliLMhZaKuTQhw== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1669332252; 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: references:references; bh=r4t3gJp+Epgg61Tiq3or6HjYA/efOz+SN1LtRddhdOs=; b=9WetNsKd7JDkoSylPgR4THzUKZKt1ot9g0kPKUk6OBfGuL+ndi0R7klTUzDj+yaftQroJA TexxN1RsK/qvgXDQ== From: Thomas Gleixner To: LKML Cc: x86@kernel.org, Joerg Roedel , Will Deacon , linux-pci@vger.kernel.org, Bjorn Helgaas , Lorenzo Pieralisi , Marc Zyngier , Greg Kroah-Hartman , Jason Gunthorpe , Dave Jiang , Alex Williamson , Kevin Tian , Dan Williams , Logan Gunthorpe , Ashok Raj , Jon Mason , Allen Hubbe , Jason Gunthorpe Subject: [patch V3 03/22] genirq/irqdomain: Rename irq_domain::dev to irq_domain::pm_dev References: <20221124225331.464480443@linutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Date: Fri, 25 Nov 2022 00:24:12 +0100 (CET) X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS 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 irq_domain::dev is a misnomer as it's usually the rule that a device pointer points to something which is directly related to the instance. irq_domain::dev can point to some other device for power management to ensure that this underlying device is not powered down when an interrupt is allocated. The upcoming per device MSI domains really require a pointer to the device which instantiated the irq domain and not to some random other device which is required for power management down the chain. Rename irq_domain::dev to irq_domain::pm_dev and fixup the few sites which use that pointer. Conversion was done with the help of coccinelle. Signed-off-by: Thomas Gleixner Reviewed-by: Jason Gunthorpe --- drivers/irqchip/irq-gic.c | 4 ++-- include/linux/irqdomain.h | 6 +++--- kernel/irq/chip.c | 8 ++++---- 3 files changed, 9 insertions(+), 9 deletions(-) --- a/drivers/irqchip/irq-gic.c +++ b/drivers/irqchip/irq-gic.c @@ -401,8 +401,8 @@ static void gic_irq_print_chip(struct ir { struct gic_chip_data *gic = irq_data_get_irq_chip_data(d); - if (gic->domain->dev) - seq_printf(p, gic->domain->dev->of_node->name); + if (gic->domain->pm_dev) + seq_printf(p, gic->domain->pm_dev->of_node->name); else seq_printf(p, "GIC-%d", (int)(gic - &gic_data[0])); } --- a/include/linux/irqdomain.h +++ b/include/linux/irqdomain.h @@ -131,7 +131,7 @@ struct irq_domain_chip_generic; * @gc: Pointer to a list of generic chips. There is a helper function for * setting up one or more generic chips for interrupt controllers * drivers using the generic chip library which uses this pointer. - * @dev: Pointer to a device that can be utilized for power management + * @pm_dev: Pointer to a device that can be utilized for power management * purposes related to the irq domain. * @parent: Pointer to parent irq_domain to support hierarchy irq_domains * @@ -153,7 +153,7 @@ struct irq_domain { struct fwnode_handle *fwnode; enum irq_domain_bus_token bus_token; struct irq_domain_chip_generic *gc; - struct device *dev; + struct device *pm_dev; #ifdef CONFIG_IRQ_DOMAIN_HIERARCHY struct irq_domain *parent; #endif @@ -206,7 +206,7 @@ static inline void irq_domain_set_pm_dev struct device *dev) { if (d) - d->dev = dev; + d->pm_dev = dev; } #ifdef CONFIG_IRQ_DOMAIN --- a/kernel/irq/chip.c +++ b/kernel/irq/chip.c @@ -1561,10 +1561,10 @@ int irq_chip_compose_msi_msg(struct irq_ return 0; } -static struct device *irq_get_parent_device(struct irq_data *data) +static struct device *irq_get_pm_device(struct irq_data *data) { if (data->domain) - return data->domain->dev; + return data->domain->pm_dev; return NULL; } @@ -1578,7 +1578,7 @@ static struct device *irq_get_parent_dev */ int irq_chip_pm_get(struct irq_data *data) { - struct device *dev = irq_get_parent_device(data); + struct device *dev = irq_get_pm_device(data); int retval = 0; if (IS_ENABLED(CONFIG_PM) && dev) @@ -1597,7 +1597,7 @@ int irq_chip_pm_get(struct irq_data *dat */ int irq_chip_pm_put(struct irq_data *data) { - struct device *dev = irq_get_parent_device(data); + struct device *dev = irq_get_pm_device(data); int retval = 0; if (IS_ENABLED(CONFIG_PM) && dev)