From e4739da96109d260f9b934b51a3714230e6bd984 Mon Sep 17 00:00:00 2001 From: goldsimon Date: Fri, 29 Apr 2011 11:23:04 +0000 Subject: [PATCH] Fixed overflow in tcp_new_port() after changing port range to IANA "Dynamic and/or Private Ports" range --- src/core/tcp.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/core/tcp.c b/src/core/tcp.c index 0de2efb2..c629bc4e 100644 --- a/src/core/tcp.c +++ b/src/core/tcp.c @@ -619,11 +619,11 @@ tcp_new_port(void) static u16_t port = TCP_LOCAL_PORT_RANGE_START; again: - if (++port > TCP_LOCAL_PORT_RANGE_END) { + if (port++ >= TCP_LOCAL_PORT_RANGE_END) { port = TCP_LOCAL_PORT_RANGE_START; } /* Check all PCB lists. */ - for (i = 0; i < NUM_TCP_PCB_LISTS; i++) { + for (i = 0; i < NUM_TCP_PCB_LISTS; i++) { for(pcb = *tcp_pcb_lists[i]; pcb != NULL; pcb = pcb->next) { if (pcb->local_port == port) { goto again;