diff options
author | Rob Herring (Arm) <robh@kernel.org> | 2024-08-26 15:44:21 +0200 |
---|---|---|
committer | Rob Herring (Arm) <robh@kernel.org> | 2024-08-26 15:44:21 +0200 |
commit | d6ae27bb86fcc89b13448bb76e3d13b64837904f (patch) | |
tree | 0e87aa92024580a52418130f87f5901e0bf5a83e /drivers/of | |
parent | ASoC: dt-bindings: serial-midi: reference serial-peripheral-props.yaml (diff) | |
parent | of/irq: Prevent device address out-of-bounds read in interrupt map walk (diff) | |
download | linux-d6ae27bb86fcc89b13448bb76e3d13b64837904f.tar.xz linux-d6ae27bb86fcc89b13448bb76e3d13b64837904f.zip |
Merge branch 'dt/linus' into dt/next
Pull in fixes to apply further refactoring.
Diffstat (limited to 'drivers/of')
-rw-r--r-- | drivers/of/irq.c | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/drivers/of/irq.c b/drivers/of/irq.c index d0fd11490325..cc30b471e446 100644 --- a/drivers/of/irq.c +++ b/drivers/of/irq.c @@ -344,7 +344,8 @@ int of_irq_parse_one(struct device_node *device, int index, struct of_phandle_ar struct device_node *p; const __be32 *addr; u32 intsize; - int i, res; + int i, res, addr_len; + __be32 addr_buf[3] = { 0 }; pr_debug("of_irq_parse_one: dev=%pOF, index=%d\n", device, index); @@ -353,13 +354,19 @@ int of_irq_parse_one(struct device_node *device, int index, struct of_phandle_ar return of_irq_parse_oldworld(device, index, out_irq); /* Get the reg property (if any) */ - addr = of_get_property(device, "reg", NULL); + addr = of_get_property(device, "reg", &addr_len); + + /* Prevent out-of-bounds read in case of longer interrupt parent address size */ + if (addr_len > (3 * sizeof(__be32))) + addr_len = 3 * sizeof(__be32); + if (addr) + memcpy(addr_buf, addr, addr_len); /* Try the new-style interrupts-extended first */ res = of_parse_phandle_with_args(device, "interrupts-extended", "#interrupt-cells", index, out_irq); if (!res) - return of_irq_parse_raw(addr, out_irq); + return of_irq_parse_raw(addr_buf, out_irq); /* Look for the interrupt parent. */ p = of_irq_find_parent(device); @@ -389,7 +396,7 @@ int of_irq_parse_one(struct device_node *device, int index, struct of_phandle_ar /* Check if there are any interrupt-map translations to process */ - res = of_irq_parse_raw(addr, out_irq); + res = of_irq_parse_raw(addr_buf, out_irq); out: of_node_put(p); return res; |