diff options
| author | Len Brown <len.brown@intel.com> | 2005-08-23 22:12:23 -0400 | 
|---|---|---|
| committer | Len Brown <len.brown@intel.com> | 2005-08-23 22:12:23 -0400 | 
| commit | 84ffa747520edd4556b136bdfc9df9eb1673ce12 (patch) | |
| tree | 1cfe20bd31fce1b5b3024384fcb324c3338d1d32 /net/ipv4/tcp_ipv4.c | |
| parent | 702c7e7626deeabb057b6f529167b65ec2eefbdb (diff) | |
| parent | 81065e2f415af6c028eac13f481fb9e60a0b487b (diff) | |
Merge from-linus to-akpm
Diffstat (limited to 'net/ipv4/tcp_ipv4.c')
| -rw-r--r-- | net/ipv4/tcp_ipv4.c | 9 | 
1 files changed, 7 insertions, 2 deletions
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c index 5d91213d34c0..67c670886c1f 100644 --- a/net/ipv4/tcp_ipv4.c +++ b/net/ipv4/tcp_ipv4.c  | |||
| @@ -242,9 +242,14 @@ static int tcp_v4_get_port(struct sock *sk, unsigned short snum) | |||
| 242 | tcp_port_rover = rover; | 242 | tcp_port_rover = rover; | 
| 243 | spin_unlock(&tcp_portalloc_lock); | 243 | spin_unlock(&tcp_portalloc_lock); | 
| 244 | 244 | ||
| 245 | /* Exhausted local port range during search? */ | 245 | /* Exhausted local port range during search? It is not | 
| 246 | * possible for us to be holding one of the bind hash | ||
| 247 | * locks if this test triggers, because if 'remaining' | ||
| 248 | * drops to zero, we broke out of the do/while loop at | ||
| 249 | * the top level, not from the 'break;' statement. | ||
| 250 | */ | ||
| 246 | ret = 1; | 251 | ret = 1; | 
| 247 | if (remaining <= 0) | 252 | if (unlikely(remaining <= 0)) | 
| 248 | goto fail; | 253 | goto fail; | 
| 249 | 254 | ||
| 250 | /* OK, here is the one we will use. HEAD is | 255 | /* OK, here is the one we will use. HEAD is | 
