mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-24 21:54:01 +00:00
net: explicitly assign errno to return code in case of network failure
When dealing with two ethernet ports and having "netretry" set to "once", it could occur that the connection (e.g. an ARP request) failed, hence the status of the netloop was "NETLOOP_FAIL". Due to the setting of "netretry", the network logic would then switch to the other network interface, assigning "ret" with the return value of "net_start_again()". If this call succeeded we would return 0 (i.e. success) to the caller when in reality the network action failed. Signed-off-by: Thomas RIENOESSL <thomas.rienoessl@bachmann.info> Reviewed-by: Christian Gmeiner <christian.gmeiner@gmail.com> Acked-by: Joe Hershberger <joe.hershberger@ni.com>
This commit is contained in:
parent
21586cdd50
commit
a735e6e9d6
2 changed files with 2 additions and 1 deletions
|
@ -657,6 +657,7 @@ restart:
|
|||
/* Invalidate the last protocol */
|
||||
eth_set_last_protocol(BOOTP);
|
||||
debug_cond(DEBUG_INT_STATE, "--- net_loop Fail!\n");
|
||||
ret = -ENONET;
|
||||
goto done;
|
||||
|
||||
case NETLOOP_CONTINUE:
|
||||
|
|
|
@ -237,7 +237,7 @@ static int _dm_test_net_retry(struct unit_test_state *uts)
|
|||
env_set("ethact", "eth@10004000");
|
||||
env_set("netretry", "no");
|
||||
sandbox_eth_skip_timeout();
|
||||
ut_asserteq(-ETIMEDOUT, net_loop(PING));
|
||||
ut_asserteq(-ENONET, net_loop(PING));
|
||||
ut_asserteq_str("eth@10004000", env_get("ethact"));
|
||||
|
||||
return 0;
|
||||
|
|
Loading…
Reference in a new issue