diff options
author | Dan Carpenter <dan.carpenter@oracle.com> | 2022-01-15 14:51:46 +0300 |
---|---|---|
committer | Vinod Koul <vkoul@kernel.org> | 2022-01-24 07:05:31 +0300 |
commit | 29afbd769ca338fa14cbfbbc824f7dc457ed7f2e (patch) | |
tree | 7eadebf507bee603c9a8a47e0f9e2f7257983acb /drivers/phy/st | |
parent | 6d1e6bcb31663ee83aaea1f171f3dbfe95dd4a69 (diff) | |
download | linux-29afbd769ca338fa14cbfbbc824f7dc457ed7f2e.tar.xz |
phy: cadence: Sierra: fix error handling bugs in probe()
There are two bugs in the error handling:
1: If devm_of_phy_provider_register() fails then there was no cleanup.
2: The error handling called of_node_put(child) improperly leading to
a use after free. We are only holding the reference inside the loop
so the last two gotos after the loop lead to a use after free bug.
Fix this by cleaning up the partial allocations (or partial iterations)
in the loop before doing the goto.
Fixes: a43f72ae136a ("phy: cadence: Sierra: Change MAX_LANES of Sierra to 16")
Fixes: 44d30d622821 ("phy: cadence: Add driver for Sierra PHY")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Link: https://lore.kernel.org/r/20220115115146.GC7552@kili
Signed-off-by: Vinod Koul <vkoul@kernel.org>
Diffstat (limited to 'drivers/phy/st')
0 files changed, 0 insertions, 0 deletions