diff options
author | Sekhar Nori <[email protected]> | 2017-04-03 17:34:28 +0530 |
---|---|---|
committer | David S. Miller <[email protected]> | 2017-04-04 10:33:33 -0700 |
commit | 30c57f073449e09ae42f908bfff56c08c8751a6f (patch) | |
tree | 5a1316ef175e9b93befe4eee447c339aa60a8f74 /tools/lib/api/fs | |
parent | 249ee819e24c180909f43c1173c8ef6724d21faf (diff) |
net: ethernet: ti: cpsw: fix race condition during open()
TI's cpsw driver handles both OF and non-OF case for phy
connect. Unfortunately of_phy_connect() returns NULL on
error while phy_connect() returns ERR_PTR().
To handle this, cpsw_slave_open() overrides the return value
from phy_connect() to make it NULL or error.
This leaves a small window, where cpsw_adjust_link() may be
invoked for a slave while slave->phy pointer is temporarily
set to -ENODEV (or some other error) before it is finally set
to NULL.
_cpsw_adjust_link() only handles the NULL case, and an oops
results when ERR_PTR() is seen by it.
Note that cpsw_adjust_link() checks PHY status for each
slave whenever it is invoked. It can so happen that even
though phy_connect() for a given slave returns error,
_cpsw_adjust_link() is still called for that slave because
the link status of another slave changed.
Fix this by using a temporary pointer to store return value
of {of_}phy_connect() and do a one-time write to slave->phy.
Reviewed-by: Grygorii Strashko <[email protected]>
Reported-by: Yan Liu <[email protected]>
Signed-off-by: Sekhar Nori <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
Diffstat (limited to 'tools/lib/api/fs')
0 files changed, 0 insertions, 0 deletions