mailbox: mtk-cmdq: Validate alias_id on probe
authorFei Shao <fshao@chromium.org>
Thu, 14 Oct 2021 12:03:51 +0000 (20:03 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 18 Nov 2021 18:16:34 +0000 (19:16 +0100)
[ Upstream commit 5c154b6a51c2d2d7f266b3ef49b7dd1dc8cb5b65 ]

of_alias_get_id() may return -ENODEV which leads to illegal access to
the cmdq->clocks array.
Adding a check over alias_id to prevent the unexpected behavior.

Fixes: 85dfdbfc13ea ("mailbox: cmdq: add multi-gce clocks support for mt8195")
Signed-off-by: Fei Shao <fshao@chromium.org>
Reviewed-by: Tzung-Bi Shih <tzungbi@google.com>
Signed-off-by: Jassi Brar <jaswinder.singh@linaro.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/mailbox/mtk-cmdq-mailbox.c

index c591dab9d5a48da8957d168ab55726deb89d733f..9b0cc3bb5b23a24b3dc3223a105dc5f815d1e794 100644 (file)
@@ -572,7 +572,7 @@ static int cmdq_probe(struct platform_device *pdev)
                        char clk_id[8];
 
                        alias_id = of_alias_get_id(node, clk_name);
-                       if (alias_id < cmdq->gce_num) {
+                       if (alias_id >= 0 && alias_id < cmdq->gce_num) {
                                snprintf(clk_id, sizeof(clk_id), "%s%d", clk_name, alias_id);
                                cmdq->clocks[alias_id].id = clk_id;
                                cmdq->clocks[alias_id].clk = of_clk_get(node, 0);