Commit f9942591 authored by Stefan Bader's avatar Stefan Bader

Revert "net: increase fragment memory usage limits"

This reverts commit c2a93660. It
made denial of service attacks on the IP fragment handling easier to
carry out.

CVE-2018-5391
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
parent e0ab8464
...@@ -327,8 +327,8 @@ static inline int ip6_frag_mem(struct net *net) ...@@ -327,8 +327,8 @@ static inline int ip6_frag_mem(struct net *net)
} }
#endif #endif
#define IPV6_FRAG_HIGH_THRESH (4 * 1024*1024) /* 4194304 */ #define IPV6_FRAG_HIGH_THRESH (256 * 1024) /* 262144 */
#define IPV6_FRAG_LOW_THRESH (3 * 1024*1024) /* 3145728 */ #define IPV6_FRAG_LOW_THRESH (192 * 1024) /* 196608 */
#define IPV6_FRAG_TIMEOUT (60 * HZ) /* 60 seconds */ #define IPV6_FRAG_TIMEOUT (60 * HZ) /* 60 seconds */
int __ipv6_addr_type(const struct in6_addr *addr); int __ipv6_addr_type(const struct in6_addr *addr);
......
...@@ -849,22 +849,14 @@ static void __init ip4_frags_ctl_register(void) ...@@ -849,22 +849,14 @@ static void __init ip4_frags_ctl_register(void)
static int __net_init ipv4_frags_init_net(struct net *net) static int __net_init ipv4_frags_init_net(struct net *net)
{ {
/* Fragment cache limits. /*
* * Fragment cache limits. We will commit 256K at one time. Should we
* The fragment memory accounting code, (tries to) account for * cross that limit we will prune down to 192K. This should cope with
* the real memory usage, by measuring both the size of frag * even the most extreme cases without allowing an attacker to
* queue struct (inet_frag_queue (ipv4:ipq/ipv6:frag_queue)) * measurably harm machine performance.
* and the SKB's truesize.
*
* A 64K fragment consumes 129736 bytes (44*2944)+200
* (1500 truesize == 2944, sizeof(struct ipq) == 200)
*
* We will commit 4MB at one time. Should we cross that limit
* we will prune down to 3MB, making room for approx 8 big 64K
* fragments 8x128k.
*/ */
net->ipv4.frags.high_thresh = 4 * 1024 * 1024; net->ipv4.frags.high_thresh = 256 * 1024;
net->ipv4.frags.low_thresh = 3 * 1024 * 1024; net->ipv4.frags.low_thresh = 192 * 1024;
/* /*
* Important NOTE! Fragment queue must be destroyed before MSL expires. * Important NOTE! Fragment queue must be destroyed before MSL expires.
* RFC791 is wrong proposing to prolongate timer each fragment arrival * RFC791 is wrong proposing to prolongate timer each fragment arrival
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment