diff options
Diffstat (limited to 'ipc')
-rw-r--r-- | ipc/msg.c | 10 | ||||
-rw-r--r-- | ipc/namespace.c | 3 | ||||
-rw-r--r-- | ipc/util.c | 3 |
3 files changed, 13 insertions, 3 deletions
@@ -81,24 +81,28 @@ static int sysvipc_msg_proc_show(struct seq_file *s, void *it); | |||
81 | /* | 81 | /* |
82 | * Scale msgmni with the available lowmem size: the memory dedicated to msg | 82 | * Scale msgmni with the available lowmem size: the memory dedicated to msg |
83 | * queues should occupy at most 1/MSG_MEM_SCALE of lowmem. | 83 | * queues should occupy at most 1/MSG_MEM_SCALE of lowmem. |
84 | * This should be done staying within the (MSGMNI , IPCMNI) range. | 84 | * Also take into account the number of nsproxies created so far. |
85 | * This should be done staying within the (MSGMNI , IPCMNI/nr_ipc_ns) range. | ||
85 | */ | 86 | */ |
86 | static void recompute_msgmni(struct ipc_namespace *ns) | 87 | static void recompute_msgmni(struct ipc_namespace *ns) |
87 | { | 88 | { |
88 | struct sysinfo i; | 89 | struct sysinfo i; |
89 | unsigned long allowed; | 90 | unsigned long allowed; |
91 | int nb_ns; | ||
90 | 92 | ||
91 | si_meminfo(&i); | 93 | si_meminfo(&i); |
92 | allowed = (((i.totalram - i.totalhigh) / MSG_MEM_SCALE) * i.mem_unit) | 94 | allowed = (((i.totalram - i.totalhigh) / MSG_MEM_SCALE) * i.mem_unit) |
93 | / MSGMNB; | 95 | / MSGMNB; |
96 | nb_ns = atomic_read(&nr_ipc_ns); | ||
97 | allowed /= nb_ns; | ||
94 | 98 | ||
95 | if (allowed < MSGMNI) { | 99 | if (allowed < MSGMNI) { |
96 | ns->msg_ctlmni = MSGMNI; | 100 | ns->msg_ctlmni = MSGMNI; |
97 | goto out_callback; | 101 | goto out_callback; |
98 | } | 102 | } |
99 | 103 | ||
100 | if (allowed > IPCMNI) { | 104 | if (allowed > IPCMNI / nb_ns) { |
101 | ns->msg_ctlmni = IPCMNI; | 105 | ns->msg_ctlmni = IPCMNI / nb_ns; |
102 | goto out_callback; | 106 | goto out_callback; |
103 | } | 107 | } |
104 | 108 | ||
diff --git a/ipc/namespace.c b/ipc/namespace.c index 1b967655eb35..fe3c97aa99dc 100644 --- a/ipc/namespace.c +++ b/ipc/namespace.c | |||
@@ -20,6 +20,8 @@ static struct ipc_namespace *clone_ipc_ns(struct ipc_namespace *old_ns) | |||
20 | if (ns == NULL) | 20 | if (ns == NULL) |
21 | return ERR_PTR(-ENOMEM); | 21 | return ERR_PTR(-ENOMEM); |
22 | 22 | ||
23 | atomic_inc(&nr_ipc_ns); | ||
24 | |||
23 | sem_init_ns(ns); | 25 | sem_init_ns(ns); |
24 | msg_init_ns(ns); | 26 | msg_init_ns(ns); |
25 | shm_init_ns(ns); | 27 | shm_init_ns(ns); |
@@ -83,4 +85,5 @@ void free_ipc_ns(struct kref *kref) | |||
83 | msg_exit_ns(ns); | 85 | msg_exit_ns(ns); |
84 | shm_exit_ns(ns); | 86 | shm_exit_ns(ns); |
85 | kfree(ns); | 87 | kfree(ns); |
88 | atomic_dec(&nr_ipc_ns); | ||
86 | } | 89 | } |
diff --git a/ipc/util.c b/ipc/util.c index cb017c7b9370..c27f0e92f489 100644 --- a/ipc/util.c +++ b/ipc/util.c | |||
@@ -52,6 +52,9 @@ struct ipc_namespace init_ipc_ns = { | |||
52 | }, | 52 | }, |
53 | }; | 53 | }; |
54 | 54 | ||
55 | atomic_t nr_ipc_ns = ATOMIC_INIT(1); | ||
56 | |||
57 | |||
55 | /** | 58 | /** |
56 | * ipc_init - initialise IPC subsystem | 59 | * ipc_init - initialise IPC subsystem |
57 | * | 60 | * |