Commit ab6e439f authored by Thomas Petazzoni's avatar Thomas Petazzoni Committed by Jason Cooper

dma: mv_xor: fix error handling of mv_xor_channel_add()

When mv_xor_channel_add() fails for one XOR channel, we jump to the
err_channel_add label to clean up all previous channels that had been
initialized correctly. Unfortunately, while handling this error
condition, we were disposing the IRQ mapping before calling
mv_xor_channel_remove() (which does the free_irq()), which is
incorrect.

Instead, do things properly in the reverse order of the
initialization: first remove the XOR channel (so that free_irq() is
done), and then dispose the IRQ mapping.

This avoids ugly warnings when for some reason one of the XOR channel
fails to initialize.
Signed-off-by: default avatarThomas Petazzoni <thomas.petazzoni@free-electrons.com>
Signed-off-by: default avatarJason Cooper <jason@lakedaemon.net>
parent 41be8dc1
...@@ -1361,9 +1361,9 @@ static int mv_xor_probe(struct platform_device *pdev) ...@@ -1361,9 +1361,9 @@ static int mv_xor_probe(struct platform_device *pdev)
err_channel_add: err_channel_add:
for (i = 0; i < MV_XOR_MAX_CHANNELS; i++) for (i = 0; i < MV_XOR_MAX_CHANNELS; i++)
if (xordev->channels[i]) { if (xordev->channels[i]) {
mv_xor_channel_remove(xordev->channels[i]);
if (pdev->dev.of_node) if (pdev->dev.of_node)
irq_dispose_mapping(xordev->channels[i]->irq); irq_dispose_mapping(xordev->channels[i]->irq);
mv_xor_channel_remove(xordev->channels[i]);
} }
clk_disable_unprepare(xordev->clk); clk_disable_unprepare(xordev->clk);
......
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