diff options
Diffstat (limited to 'net/ipv4/tcp.c')
| -rw-r--r-- | net/ipv4/tcp.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/net/ipv4/tcp.c b/net/ipv4/tcp.c index 1d7f49c6f0ca..7a0f0b27bf1f 100644 --- a/net/ipv4/tcp.c +++ b/net/ipv4/tcp.c | |||
| @@ -1321,6 +1321,7 @@ int tcp_recvmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg, | |||
| 1321 | struct task_struct *user_recv = NULL; | 1321 | struct task_struct *user_recv = NULL; |
| 1322 | int copied_early = 0; | 1322 | int copied_early = 0; |
| 1323 | struct sk_buff *skb; | 1323 | struct sk_buff *skb; |
| 1324 | u32 urg_hole = 0; | ||
| 1324 | 1325 | ||
| 1325 | lock_sock(sk); | 1326 | lock_sock(sk); |
| 1326 | 1327 | ||
| @@ -1532,7 +1533,8 @@ do_prequeue: | |||
| 1532 | } | 1533 | } |
| 1533 | } | 1534 | } |
| 1534 | } | 1535 | } |
| 1535 | if ((flags & MSG_PEEK) && peek_seq != tp->copied_seq) { | 1536 | if ((flags & MSG_PEEK) && |
| 1537 | (peek_seq - copied - urg_hole != tp->copied_seq)) { | ||
| 1536 | if (net_ratelimit()) | 1538 | if (net_ratelimit()) |
| 1537 | printk(KERN_DEBUG "TCP(%s:%d): Application bug, race in MSG_PEEK.\n", | 1539 | printk(KERN_DEBUG "TCP(%s:%d): Application bug, race in MSG_PEEK.\n", |
| 1538 | current->comm, task_pid_nr(current)); | 1540 | current->comm, task_pid_nr(current)); |
| @@ -1553,6 +1555,7 @@ do_prequeue: | |||
| 1553 | if (!urg_offset) { | 1555 | if (!urg_offset) { |
| 1554 | if (!sock_flag(sk, SOCK_URGINLINE)) { | 1556 | if (!sock_flag(sk, SOCK_URGINLINE)) { |
| 1555 | ++*seq; | 1557 | ++*seq; |
| 1558 | urg_hole++; | ||
| 1556 | offset++; | 1559 | offset++; |
| 1557 | used--; | 1560 | used--; |
| 1558 | if (!used) | 1561 | if (!used) |
