diff options
author | Stefan Brüns <stefan.bruens@rwth-aachen.de> | 2015-08-30 18:46:54 +0300 |
---|---|---|
committer | Joe Hershberger <joe.hershberger@ni.com> | 2015-10-28 22:57:37 +0300 |
commit | 45b47734a0788721c76e3bb621a5133554e0a640 (patch) | |
tree | fb8b5ce5c47435ff1683d918c563e48436809e5b /net | |
parent | 943231119f3caaaca7db4c588e4f3e9a6cec426a (diff) | |
download | u-boot-45b47734a0788721c76e3bb621a5133554e0a640.tar.xz |
net/arp: account for ARP delay, avoid duplicate packets on timeout
eth_rx() in the main reception loop may trigger sending a packet which
is already timed out (or will immediately) upon reception of an ARP reply.
As long as the ARP reply is pending, the timeout handler of a packet
should be postponed.
Happens on TFTP with bad network (e.g. WLAN).
Signed-off-by: Stefan Brüns <stefan.bruens@rwth-aachen.de>
Acked-by: Joe Hershberger <joe.hershberger@ni.com>
Diffstat (limited to 'net')
-rw-r--r-- | net/arp.c | 5 | ||||
-rw-r--r-- | net/arp.h | 2 | ||||
-rw-r--r-- | net/net.c | 4 |
3 files changed, 7 insertions, 4 deletions
@@ -96,12 +96,12 @@ void arp_request(void) arp_raw_request(net_ip, net_null_ethaddr, net_arp_wait_reply_ip); } -void arp_timeout_check(void) +int arp_timeout_check(void) { ulong t; if (!net_arp_wait_packet_ip.s_addr) - return; + return 0; t = get_timer(0); @@ -118,6 +118,7 @@ void arp_timeout_check(void) arp_request(); } } + return 1; } void arp_receive(struct ethernet_hdr *et, struct ip_udp_hdr *ip, int len) @@ -25,7 +25,7 @@ void arp_init(void); void arp_request(void); void arp_raw_request(struct in_addr source_ip, const uchar *targetEther, struct in_addr target_ip); -void arp_timeout_check(void); +int arp_timeout_check(void); void arp_receive(struct ethernet_hdr *et, struct ip_udp_hdr *ip, int len); #endif /* __ARP_H__ */ @@ -569,7 +569,9 @@ restart: goto done; } - arp_timeout_check(); + if (arp_timeout_check() > 0) { + time_start = get_timer(0); + } /* * Check for a timeout, and run the timeout handler |