Re: [PATCH] irqchip/gic: add WARN_ON() to facilitate backtracking

From: Marc Zyngier
Date: Tue Dec 29 2020 - 04:29:03 EST


Yejune,

On 2020-12-29 07:15, Yejune Deng wrote:
There is two function gic_of_init() and gic_of_init_child() called
gic_of_setup(),so add WARN_ON() to facilitate backtracking.

Signed-off-by: Yejune Deng <yejune.deng@xxxxxxxxx>
---
drivers/irqchip/irq-gic.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/irqchip/irq-gic.c b/drivers/irqchip/irq-gic.c
index b1d9c22..7c11705 100644
--- a/drivers/irqchip/irq-gic.c
+++ b/drivers/irqchip/irq-gic.c
@@ -1380,7 +1380,7 @@ static bool gic_check_eoimode(struct device_node
*node, void __iomem **base)

static int gic_of_setup(struct gic_chip_data *gic, struct device_node *node)
{
- if (!gic || !node)
+ if (WARN_ON(!gic || !node))
return -EINVAL;

gic->raw_dist_base = of_iomap(node, 0);

I don't immediately see what you gain with this. If you end-up here
with NULL pointers, that either because:

- you have failed to allocate the GIC private data structure:
but as it turns out, these allocations either cannot fail (gic_data[]
is static), or the dynamic allocation in gic_of_init_child() is already
checked.

- node is NULL: both paths already check for a NULL node, so that cannot
fail either.

My conclusion is that these checks can never trigger, and we should be
able to *remove* them altogether.

Am I missing something?

M.
--
Jazz is not dead. It just smells funny...