Skip to content

Commit 0c21a18

Browse files
vlsunilrafaeljw
authored andcommitted
ACPI: irq: Fix incorrect return value in acpi_register_gsi()
acpi_register_gsi() should return a negative value in case of failure. Currently, it returns the return value from irq_create_fwspec_mapping(). However, irq_create_fwspec_mapping() returns 0 for failure. Fix the issue by returning -EINVAL if irq_create_fwspec_mapping() returns zero. Fixes: d44fa3d ("ACPI: Add support for ResourceSource/IRQ domain mapping") Cc: 4.11+ <[email protected]> # 4.11+ Signed-off-by: Sunil V L <[email protected]> [ rjw: Rename a new local variable ] Signed-off-by: Rafael J. Wysocki <[email protected]>
1 parent 5872080 commit 0c21a18

File tree

1 file changed

+6
-1
lines changed

1 file changed

+6
-1
lines changed

drivers/acpi/irq.c

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -57,6 +57,7 @@ int acpi_register_gsi(struct device *dev, u32 gsi, int trigger,
5757
int polarity)
5858
{
5959
struct irq_fwspec fwspec;
60+
unsigned int irq;
6061

6162
fwspec.fwnode = acpi_get_gsi_domain_id(gsi);
6263
if (WARN_ON(!fwspec.fwnode)) {
@@ -68,7 +69,11 @@ int acpi_register_gsi(struct device *dev, u32 gsi, int trigger,
6869
fwspec.param[1] = acpi_dev_get_irq_type(trigger, polarity);
6970
fwspec.param_count = 2;
7071

71-
return irq_create_fwspec_mapping(&fwspec);
72+
irq = irq_create_fwspec_mapping(&fwspec);
73+
if (!irq)
74+
return -EINVAL;
75+
76+
return irq;
7277
}
7378
EXPORT_SYMBOL_GPL(acpi_register_gsi);
7479

0 commit comments

Comments
 (0)