|
@@ -3216,6 +3216,16 @@ static int __init set_thash_entries(char *str)
|
|
|
}
|
|
|
__setup("thash_entries=", set_thash_entries);
|
|
|
|
|
|
+void tcp_init_mem(struct net *net)
|
|
|
+{
|
|
|
+ /* Set per-socket limits to no more than 1/128 the pressure threshold */
|
|
|
+ unsigned long limit = nr_free_buffer_pages() / 8;
|
|
|
+ limit = max(limit, 128UL);
|
|
|
+ net->ipv4.sysctl_tcp_mem[0] = limit / 4 * 3;
|
|
|
+ net->ipv4.sysctl_tcp_mem[1] = limit;
|
|
|
+ net->ipv4.sysctl_tcp_mem[2] = net->ipv4.sysctl_tcp_mem[0] * 2;
|
|
|
+}
|
|
|
+
|
|
|
void __init tcp_init(void)
|
|
|
{
|
|
|
struct sk_buff *skb = NULL;
|
|
@@ -3276,9 +3286,9 @@ void __init tcp_init(void)
|
|
|
sysctl_tcp_max_orphans = cnt / 2;
|
|
|
sysctl_max_syn_backlog = max(128, cnt / 256);
|
|
|
|
|
|
- /* Set per-socket limits to no more than 1/128 the pressure threshold */
|
|
|
- limit = ((unsigned long)init_net.ipv4.sysctl_tcp_mem[1])
|
|
|
- << (PAGE_SHIFT - 7);
|
|
|
+ tcp_init_mem(&init_net);
|
|
|
+ limit = nr_free_buffer_pages() / 8;
|
|
|
+ limit = max(limit, 128UL);
|
|
|
max_share = min(4UL*1024*1024, limit);
|
|
|
|
|
|
sysctl_tcp_wmem[0] = SK_MEM_QUANTUM;
|