]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
soc: Switch to irq_domain_create_*()
authorJiri Slaby (SUSE) <jirislaby@kernel.org>
Wed, 19 Mar 2025 09:29:27 +0000 (10:29 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Fri, 16 May 2025 19:06:11 +0000 (21:06 +0200)
irq_domain_add_*() interfaces are going away as being obsolete now.
Switch to the preferred irq_domain_create_*() ones. Those differ in the
node parameter: They take more generic struct fwnode_handle instead of
struct device_node. Therefore, of_fwnode_handle() is added around the
original parameter.

Note some of the users can likely use dev->fwnode directly instead of
indirect of_fwnode_handle(dev->of_node). But dev->fwnode is not
guaranteed to be set for all, so this has to be investigated on case to
case basis (by people who can actually test with the HW).

[ tglx: Fix up subject prefix ]

Signed-off-by: Jiri Slaby (SUSE) <jirislaby@kernel.org>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Acked-by: Christophe Leroy <christophe.leroy@csgroup.eu> # For soc/fsl
Link: https://lore.kernel.org/all/20250319092951.37667-35-jirislaby@kernel.org
drivers/soc/dove/pmu.c
drivers/soc/fsl/qe/qe_ic.c
drivers/soc/qcom/smp2p.c
drivers/soc/qcom/smsm.c
drivers/soc/tegra/pmc.c

index 6202dbcd20a810ff6bc82e69a1eeb58d98e08003..cfc0efab27d74a35c07319de65e1f34dac4fc899 100644 (file)
@@ -274,8 +274,8 @@ static int __init dove_init_pmu_irq(struct pmu_data *pmu, int irq)
        writel(0, pmu->pmc_base + PMC_IRQ_MASK);
        writel(0, pmu->pmc_base + PMC_IRQ_CAUSE);
 
-       domain = irq_domain_add_linear(pmu->of_node, NR_PMU_IRQS,
-                                      &irq_generic_chip_ops, NULL);
+       domain = irq_domain_create_linear(of_fwnode_handle(pmu->of_node), NR_PMU_IRQS,
+                                         &irq_generic_chip_ops, NULL);
        if (!domain) {
                pr_err("%s: unable to add irq domain\n", name);
                return -ENOMEM;
index 77bf0e83ffccc1e1e6050c3bc6b785deb032c768..e4b6ff2cc76b7a37e614d98a08b886aabd149d42 100644 (file)
@@ -446,8 +446,8 @@ static int qe_ic_init(struct platform_device *pdev)
                high_handler = NULL;
        }
 
-       qe_ic->irqhost = irq_domain_add_linear(node, NR_QE_IC_INTS,
-                                              &qe_ic_host_ops, qe_ic);
+       qe_ic->irqhost = irq_domain_create_linear(of_fwnode_handle(node), NR_QE_IC_INTS,
+                                                 &qe_ic_host_ops, qe_ic);
        if (qe_ic->irqhost == NULL) {
                dev_err(dev, "failed to add irq domain\n");
                return -ENODEV;
index a3e88ced328a91f1eb9dbaaaeb12fc901838bdaa..8c8878bc87f5120724b4a22094f68b4818e3b032 100644 (file)
@@ -399,7 +399,7 @@ static int qcom_smp2p_inbound_entry(struct qcom_smp2p *smp2p,
                                    struct smp2p_entry *entry,
                                    struct device_node *node)
 {
-       entry->domain = irq_domain_add_linear(node, 32, &smp2p_irq_ops, entry);
+       entry->domain = irq_domain_create_linear(of_fwnode_handle(node), 32, &smp2p_irq_ops, entry);
        if (!entry->domain) {
                dev_err(smp2p->dev, "failed to add irq_domain\n");
                return -ENOMEM;
index e803ea342c971ef1410d79538e47b11707b35a8e..021e9d1f61dc5200514c5a239d52be97f7e82825 100644 (file)
@@ -456,7 +456,7 @@ static int smsm_inbound_entry(struct qcom_smsm *smsm,
                return ret;
        }
 
-       entry->domain = irq_domain_add_linear(node, 32, &smsm_irq_ops, entry);
+       entry->domain = irq_domain_create_linear(of_fwnode_handle(node), 32, &smsm_irq_ops, entry);
        if (!entry->domain) {
                dev_err(smsm->dev, "failed to add irq_domain\n");
                return -ENOMEM;
index 51b9d852bb6afad5ff5a7322f78fd8b81cc769b3..e0d67bfe955cdea6b4703952741b0b9970084d66 100644 (file)
@@ -2500,8 +2500,9 @@ static int tegra_pmc_irq_init(struct tegra_pmc *pmc)
        pmc->irq.irq_set_type = pmc->soc->irq_set_type;
        pmc->irq.irq_set_wake = pmc->soc->irq_set_wake;
 
-       pmc->domain = irq_domain_add_hierarchy(parent, 0, 96, pmc->dev->of_node,
-                                              &tegra_pmc_irq_domain_ops, pmc);
+       pmc->domain = irq_domain_create_hierarchy(parent, 0, 96,
+                                                 of_fwnode_handle(pmc->dev->of_node),
+                                                 &tegra_pmc_irq_domain_ops, pmc);
        if (!pmc->domain) {
                dev_err(pmc->dev, "failed to allocate domain\n");
                return -ENOMEM;