提交 5be2190a 编写于 作者: D Dan Carpenter 提交者: Vinod Koul

dmaengine: ste_dma40: off by one in d40_of_probe()

If "num_disabled" is equal to STEDMA40_MAX_PHYS (32) then we would write
one space beyond the end of the pdata->disable_channels[] array.
Signed-off-by: NDan Carpenter <dan.carpenter@oracle.com>
Acked-by: NLinus Walleij <linus.walleij@linaro.org>
Signed-off-by: NVinod Koul <vinod.koul@intel.com>
上级 3a919d5b
...@@ -3516,7 +3516,7 @@ static int __init d40_of_probe(struct platform_device *pdev, ...@@ -3516,7 +3516,7 @@ static int __init d40_of_probe(struct platform_device *pdev,
list = of_get_property(np, "disabled-channels", &num_disabled); list = of_get_property(np, "disabled-channels", &num_disabled);
num_disabled /= sizeof(*list); num_disabled /= sizeof(*list);
if (num_disabled > STEDMA40_MAX_PHYS || num_disabled < 0) { if (num_disabled >= STEDMA40_MAX_PHYS || num_disabled < 0) {
d40_err(&pdev->dev, d40_err(&pdev->dev,
"Invalid number of disabled channels specified (%d)\n", "Invalid number of disabled channels specified (%d)\n",
num_disabled); num_disabled);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册