Commit 5d1e9c22 authored by Johan Hovold's avatar Johan Hovold Committed by Boris Brezillon

mtd: rawnand: atmel: fix OF child-node lookup

Use the new of_get_compatible_child() helper to lookup the nfc child
node instead of using of_find_compatible_node(), which searches the
entire tree from a given start node and thus can return an unrelated
(i.e. non-child) node.

This also addresses a potential use-after-free (e.g. after probe
deferral) as the tree-wide helper drops a reference to its first
argument (i.e. the node of the device being probed).

While at it, also fix a related nfc-node reference leak.

Fixes: f88fc122 ("mtd: nand: Cleanup/rework the atmel_nand driver")
Cc: stable <stable@vger.kernel.org>     # 4.11
Cc: Nicolas Ferre <nicolas.ferre@microchip.com>
Cc: Josh Wu <rainyfeeling@outlook.com>
Cc: Boris Brezillon <boris.brezillon@bootlin.com>
Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
Signed-off-by: default avatarBoris Brezillon <boris.brezillon@bootlin.com>
parent 1d5ceff2
...@@ -2032,8 +2032,7 @@ atmel_hsmc_nand_controller_legacy_init(struct atmel_hsmc_nand_controller *nc) ...@@ -2032,8 +2032,7 @@ atmel_hsmc_nand_controller_legacy_init(struct atmel_hsmc_nand_controller *nc)
int ret; int ret;
nand_np = dev->of_node; nand_np = dev->of_node;
nfc_np = of_find_compatible_node(dev->of_node, NULL, nfc_np = of_get_compatible_child(dev->of_node, "atmel,sama5d3-nfc");
"atmel,sama5d3-nfc");
if (!nfc_np) { if (!nfc_np) {
dev_err(dev, "Could not find device node for sama5d3-nfc\n"); dev_err(dev, "Could not find device node for sama5d3-nfc\n");
return -ENODEV; return -ENODEV;
...@@ -2447,15 +2446,19 @@ static int atmel_nand_controller_probe(struct platform_device *pdev) ...@@ -2447,15 +2446,19 @@ static int atmel_nand_controller_probe(struct platform_device *pdev)
} }
if (caps->legacy_of_bindings) { if (caps->legacy_of_bindings) {
struct device_node *nfc_node;
u32 ale_offs = 21; u32 ale_offs = 21;
/* /*
* If we are parsing legacy DT props and the DT contains a * If we are parsing legacy DT props and the DT contains a
* valid NFC node, forward the request to the sama5 logic. * valid NFC node, forward the request to the sama5 logic.
*/ */
if (of_find_compatible_node(pdev->dev.of_node, NULL, nfc_node = of_get_compatible_child(pdev->dev.of_node,
"atmel,sama5d3-nfc")) "atmel,sama5d3-nfc");
if (nfc_node) {
caps = &atmel_sama5_nand_caps; caps = &atmel_sama5_nand_caps;
of_node_put(nfc_node);
}
/* /*
* Even if the compatible says we are dealing with an * Even if the compatible says we are dealing with an
......
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