From: rockly Date: Sat, 3 Aug 2013 10:09:05 +0000 (+0800) Subject: net: tftp: Make sure timeout will not effect wrap offset X-Git-Tag: v2025.01-rc5-pxa1908~15583^2~39 X-Git-Url: http://git.dujemihanovic.xyz/img/static/%7B%7B%20%24style.RelPermalink%20%7D%7D?a=commitdiff_plain;h=f754f5dc6fe4b6cfbd28a9a6d9d08059d9312101;p=u-boot.git net: tftp: Make sure timeout will not effect wrap offset When the block 0 store to the memory of client and timeout at this moment. Because of no ACK packet, the server will send block 0 again, if this client reconnect to the server at this time, TftpBlockWrapOffset will become larger than it should be. Signed-off-by: Rockly Patch: 264417 --- diff --git a/net/tftp.c b/net/tftp.c index 6d333d559c..2e06808d16 100644 --- a/net/tftp.c +++ b/net/tftp.c @@ -281,7 +281,7 @@ static void update_block_number(void) * number of 0 this means that there was a wrap * around of the (16 bit) counter. */ - if (TftpBlock == 0) { + if (TftpBlock == 0 && TftpLastBlock != 0) { TftpBlockWrap++; TftpBlockWrapOffset += TftpBlkSize * TFTP_SEQUENCE_SIZE; TftpTimeoutCount = 0; /* we've done well, reset thhe timeout */