From mboxrd@z Thu Jan 1 00:00:00 1970 From: Satoshi OSHIMA Subject: [RFC/PATCH 1/3] UDP memory usage accounting: fix send buffer check Date: Fri, 21 Sep 2007 21:22:04 +0900 Message-ID: <46F3B76C.7020006@hitachi.com> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-2022-JP Content-Transfer-Encoding: 7bit Cc: haoki@redhat.com, =?ISO-2022-JP?B?GyRCNUhGIxsoQiAbJEIxUUxAGyhC?= To: netdev@vger.kernel.org Return-path: Received: from mailx.hitachi.co.jp ([133.145.228.49]:41396 "EHLO mailx.hitachi.co.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755860AbXIUMaN (ORCPT ); Fri, 21 Sep 2007 08:30:13 -0400 Received: from mlsv11.hitachi.co.jp (unknown [133.144.234.166]) by mail7.hitachi.co.jp (Postfix) with ESMTP id E064B37AC4 for ; Fri, 21 Sep 2007 21:22:10 +0900 (JST) Sender: netdev-owner@vger.kernel.org List-Id: netdev.vger.kernel.org This patch introduces sndbuf size check before memory allcation for send buffer. signed-off-by: Satoshi Oshima signed-off-by: Hideo Aoki Index: 2.6.23-rc7-udp_limit/net/ipv4/ip_output.c =================================================================== --- 2.6.23-rc7-udp_limit.orig/net/ipv4/ip_output.c +++ 2.6.23-rc7-udp_limit/net/ipv4/ip_output.c @@ -1004,6 +1004,11 @@ alloc_new_skb: frag = &skb_shinfo(skb)->frags[i]; } } else if (i < MAX_SKB_FRAGS) { + if (atomic_read(&sk->sk_wmem_alloc) + PAGE_SIZE + > 2 * sk->sk_sndbuf) { + err = -ENOBUFS; + goto error; + } if (copy > PAGE_SIZE) copy = PAGE_SIZE; page = alloc_pages(sk->sk_allocation, 0);