diff options
Diffstat (limited to 'include/net/sock.h')
| -rw-r--r-- | include/net/sock.h | 12 | 
1 files changed, 8 insertions, 4 deletions
| diff --git a/include/net/sock.h b/include/net/sock.h index 312cb25cbd18..e51e626e9af1 100644 --- a/include/net/sock.h +++ b/include/net/sock.h | |||
| @@ -709,6 +709,12 @@ static inline int sk_stream_rmem_schedule(struct sock *sk, struct sk_buff *skb) | |||
| 709 | sk_stream_mem_schedule(sk, skb->truesize, 1); | 709 | sk_stream_mem_schedule(sk, skb->truesize, 1); | 
| 710 | } | 710 | } | 
| 711 | 711 | ||
| 712 | static inline int sk_stream_wmem_schedule(struct sock *sk, int size) | ||
| 713 | { | ||
| 714 | return size <= sk->sk_forward_alloc || | ||
| 715 | sk_stream_mem_schedule(sk, size, 0); | ||
| 716 | } | ||
| 717 | |||
| 712 | /* Used by processes to "lock" a socket state, so that | 718 | /* Used by processes to "lock" a socket state, so that | 
| 713 | * interrupts and bottom half handlers won't change it | 719 | * interrupts and bottom half handlers won't change it | 
| 714 | * from under us. It essentially blocks any incoming | 720 | * from under us. It essentially blocks any incoming | 
| @@ -1203,8 +1209,7 @@ static inline struct sk_buff *sk_stream_alloc_pskb(struct sock *sk, | |||
| 1203 | skb = alloc_skb_fclone(size + hdr_len, gfp); | 1209 | skb = alloc_skb_fclone(size + hdr_len, gfp); | 
| 1204 | if (skb) { | 1210 | if (skb) { | 
| 1205 | skb->truesize += mem; | 1211 | skb->truesize += mem; | 
| 1206 | if (sk->sk_forward_alloc >= (int)skb->truesize || | 1212 | if (sk_stream_wmem_schedule(sk, skb->truesize)) { | 
| 1207 | sk_stream_mem_schedule(sk, skb->truesize, 0)) { | ||
| 1208 | skb_reserve(skb, hdr_len); | 1213 | skb_reserve(skb, hdr_len); | 
| 1209 | return skb; | 1214 | return skb; | 
| 1210 | } | 1215 | } | 
| @@ -1227,8 +1232,7 @@ static inline struct page *sk_stream_alloc_page(struct sock *sk) | |||
| 1227 | { | 1232 | { | 
| 1228 | struct page *page = NULL; | 1233 | struct page *page = NULL; | 
| 1229 | 1234 | ||
| 1230 | if (sk->sk_forward_alloc >= (int)PAGE_SIZE || | 1235 | if (sk_stream_wmem_schedule(sk, PAGE_SIZE)) | 
| 1231 | sk_stream_mem_schedule(sk, PAGE_SIZE, 0)) | ||
| 1232 | page = alloc_pages(sk->sk_allocation, 0); | 1236 | page = alloc_pages(sk->sk_allocation, 0); | 
| 1233 | else { | 1237 | else { | 
| 1234 | sk->sk_prot->enter_memory_pressure(); | 1238 | sk->sk_prot->enter_memory_pressure(); | 
