UPSTREAM: irqdomain: Introduce is_fwnode_irqchip helper
authorSuravee Suthikulpanit <Suravee.Suthikulpanit@amd.com>
Thu, 10 Dec 2015 16:55:28 +0000 (08:55 -0800)
committerHuang, Tao <huangtao@rock-chips.com>
Fri, 1 Jul 2016 06:20:47 +0000 (14:20 +0800)
Since there will be several places checking if fwnode.type
is equal FWNODE_IRQCHIP, this patch adds a convenient function
for this purpose.

Change-Id: I65ab9e1350428de18864ba493256b959efc01f45
Acked-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Suravee Suthikulpanit <Suravee.Suthikulpanit@amd.com>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Caesar Wang <wxt@rock-chips.com>
(cherry picked from commit 75aba7b0e9ac416ca53c0c97680b8e9aedf09284)

drivers/irqchip/irq-gic.c
include/linux/irqdomain.h
kernel/irq/irqdomain.c

index abf2ffaed392270c97d14c7fdc2ab247e63a58e1..fcd327f49e8e3e5417575787b3113843a52b58e0 100644 (file)
@@ -972,7 +972,7 @@ static int gic_irq_domain_translate(struct irq_domain *d,
                return 0;
        }
 
-       if (fwspec->fwnode->type == FWNODE_IRQCHIP) {
+       if (is_fwnode_irqchip(fwspec->fwnode)) {
                if(fwspec->param_count != 2)
                        return -EINVAL;
 
index d5e5c5bef28c45e29bff88b175d581c0595b73f9..4950a71ef77d450e4a01e3d177b235a4fba70c0d 100644 (file)
@@ -211,6 +211,11 @@ static inline struct fwnode_handle *of_node_to_fwnode(struct device_node *node)
        return node ? &node->fwnode : NULL;
 }
 
+static inline bool is_fwnode_irqchip(struct fwnode_handle *fwnode)
+{
+       return fwnode && fwnode->type == FWNODE_IRQCHIP;
+}
+
 static inline struct irq_domain *irq_find_matching_host(struct device_node *node,
                                                        enum irq_domain_bus_token bus_token)
 {
index 22aa9612ef7ca98cd8796188a7021810cc86d05a..7f34d98ebfc45742e7c21d53dd0727fe6652aedf 100644 (file)
@@ -70,7 +70,7 @@ void irq_domain_free_fwnode(struct fwnode_handle *fwnode)
 {
        struct irqchip_fwid *fwid;
 
-       if (WARN_ON(fwnode->type != FWNODE_IRQCHIP))
+       if (WARN_ON(!is_fwnode_irqchip(fwnode)))
                return;
 
        fwid = container_of(fwnode, struct irqchip_fwid, fwnode);