From: Joe Hershberger Date: Sun, 22 Mar 2015 22:09:07 +0000 (-0500) Subject: net: Make netretry actually do something X-Git-Tag: KARO-TX6-2015-09-18~2755 X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=4b31268b4da82e10d5a2ecd8930816fe3f0f599f;hp=5cce2f820ce174e50106142a8d0997e3fa76f1dc;p=karo-tx-uboot.git net: Make netretry actually do something netretry previously would only retry in one specific case (your MAC address is not set) and no other. This is basically useless. In the DM implementation for eth it turns this into a completely useless case since an un-configured MAC address results in not even entering the NetLoop. The behavior is now changed to retry any failed command (rotating through the eth adapters if ethrotate != no). It also defaulted to retry forever. It is now changed to default to not retry Signed-off-by: Joe Hershberger Reviewed-by: Simon Glass --- diff --git a/net/net.c b/net/net.c index e40e0969ed..c0028f0690 100644 --- a/net/net.c +++ b/net/net.c @@ -532,6 +532,8 @@ restart: (*x)(); } + if (net_state == NETLOOP_FAIL) + NetStartAgain(); switch (net_state) { @@ -608,8 +610,10 @@ void NetStartAgain(void) retrycnt = 1; else retrycnt = simple_strtoul(nretry, NULL, 0); - } else - retry_forever = 1; + } else { + retrycnt = 0; + retry_forever = 0; + } if ((!retry_forever) && (NetTryCount >= retrycnt)) { eth_halt();