[PATCH 4/7] phy: rockchip-usb: add missing of_node_put
From: heiko@sntech.de (Heiko Stübner)
Date: 2015-11-18 19:46:11
Also in:
kernel-janitors, linux-rockchip, lkml
From: heiko@sntech.de (Heiko Stübner)
Date: 2015-11-18 19:46:11
Also in:
kernel-janitors, linux-rockchip, lkml
Am Mittwoch, 18. November 2015, 11:31:29 schrieb Brian Norris:
On Wed, Nov 18, 2015 at 08:27:07PM +0100, Heiko St?bner wrote:quoted
Am Montag, 16. November 2015, 12:33:17 schrieb Julia Lawall: hmm, while I agree that the rockchip phy has an issue in the node lifecycle, I'm not sure that patch fixes it fully. It currently iterates over each phy, but would only of_node_put the phy it handled last. So if an error happens on the 3rd phy, the first 2 are already instantiated and would also get removed when the overall probe fails, but their of_node would never be "put".Note the behavior of of_get_next_child() (and of_get_next_available_child()); it "Decrements the refcount of prev." So the loop only keeps a reference for (at most) one node at a time. I believe Julia's patch is correct. It's possible the commit description could have made this aspect clearer though, since I was confused about this at first as well.
oh, I hadn't realized that :-) . Although in this case, what happens with the last child, if only "prev"s get decremented? When the loop finished I'd think that the last one would keep it's reference, as the patch stand right - or I'm just blind.