Commit 0a12875f authored by Franck Demathieu's avatar Franck Demathieu Committed by Greg Kroah-Hartman

irqchip/crossbar: Fix incorrect type of register size


[ Upstream commit 4b9de5da ]

The 'size' variable is unsigned according to the dt-bindings.
As this variable is used as integer in other places, create a new variable
that allows to fix the following sparse issue (-Wtypesign):

  drivers/irqchip/irq-crossbar.c:279:52: warning: incorrect type in argument 3 (different signedness)
  drivers/irqchip/irq-crossbar.c:279:52:    expected unsigned int [usertype] *out_value
  drivers/irqchip/irq-crossbar.c:279:52:    got int *<noident>
Signed-off-by: default avatarFranck Demathieu <fdemathieu@gmail.com>
Signed-off-by: default avatarMarc Zyngier <marc.zyngier@arm.com>
Signed-off-by: default avatarSasha Levin <alexander.levin@verizon.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 8a15c626
...@@ -199,7 +199,7 @@ static const struct irq_domain_ops crossbar_domain_ops = { ...@@ -199,7 +199,7 @@ static const struct irq_domain_ops crossbar_domain_ops = {
static int __init crossbar_of_init(struct device_node *node) static int __init crossbar_of_init(struct device_node *node)
{ {
int i, size, reserved = 0; int i, size, reserved = 0;
u32 max = 0, entry; u32 max = 0, entry, reg_size;
const __be32 *irqsr; const __be32 *irqsr;
int ret = -ENOMEM; int ret = -ENOMEM;
...@@ -276,9 +276,9 @@ static int __init crossbar_of_init(struct device_node *node) ...@@ -276,9 +276,9 @@ static int __init crossbar_of_init(struct device_node *node)
if (!cb->register_offsets) if (!cb->register_offsets)
goto err_irq_map; goto err_irq_map;
of_property_read_u32(node, "ti,reg-size", &size); of_property_read_u32(node, "ti,reg-size", &reg_size);
switch (size) { switch (reg_size) {
case 1: case 1:
cb->write = crossbar_writeb; cb->write = crossbar_writeb;
break; break;
...@@ -304,7 +304,7 @@ static int __init crossbar_of_init(struct device_node *node) ...@@ -304,7 +304,7 @@ static int __init crossbar_of_init(struct device_node *node)
continue; continue;
cb->register_offsets[i] = reserved; cb->register_offsets[i] = reserved;
reserved += size; reserved += reg_size;
} }
of_property_read_u32(node, "ti,irqs-safe-map", &cb->safe_map); of_property_read_u32(node, "ti,irqs-safe-map", &cb->safe_map);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment