diff options
author | Pierre Peiffer <pierre.peiffer@bull.net> | 2008-02-08 07:18:57 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2008-02-08 12:22:26 -0500 |
commit | ed2ddbf88c0ddeeae4c78bb306a116dfd867c55c (patch) | |
tree | de6d6828c03f98be6fc41e8acf3b3e52df28be9b /ipc/namespace.c | |
parent | 4b9fcb0ec60584d639ad105c42b75a3447071e47 (diff) |
IPC: make struct ipc_ids static in ipc_namespace
Each ipc_namespace contains a table of 3 pointers to struct ipc_ids (3 for
msg, sem and shm, structure used to store all ipcs) These 'struct ipc_ids'
are dynamically allocated for each icp_namespace as the ipc_namespace
itself (for the init namespace, they are initialized with pointers to
static variables instead)
It is so for historical reason: in fact, before the use of idr to store the
ipcs, the ipcs were stored in tables of variable length, depending of the
maximum number of ipc allowed. Now, these 'struct ipc_ids' have a fixed
size. As they are allocated in any cases for each new ipc_namespace, there
is no gain of memory in having them allocated separately of the struct
ipc_namespace.
This patch proposes to make this table static in the struct ipc_namespace.
Thus, we can allocate all in once and get rid of all the code needed to
allocate and free these ipc_ids separately.
Signed-off-by: Pierre Peiffer <pierre.peiffer@bull.net>
Acked-by: Cedric Le Goater <clg@fr.ibm.com>
Cc: Pavel Emelyanov <xemul@openvz.org>
Cc: Nadia Derbey <Nadia.Derbey@bull.net>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'ipc/namespace.c')
-rw-r--r-- | ipc/namespace.c | 25 |
1 files changed, 4 insertions, 21 deletions
diff --git a/ipc/namespace.c b/ipc/namespace.c index cef1139e6c96..1fed8922d475 100644 --- a/ipc/namespace.c +++ b/ipc/namespace.c | |||
@@ -14,35 +14,18 @@ | |||
14 | 14 | ||
15 | static struct ipc_namespace *clone_ipc_ns(struct ipc_namespace *old_ns) | 15 | static struct ipc_namespace *clone_ipc_ns(struct ipc_namespace *old_ns) |
16 | { | 16 | { |
17 | int err; | ||
18 | struct ipc_namespace *ns; | 17 | struct ipc_namespace *ns; |
19 | 18 | ||
20 | err = -ENOMEM; | ||
21 | ns = kmalloc(sizeof(struct ipc_namespace), GFP_KERNEL); | 19 | ns = kmalloc(sizeof(struct ipc_namespace), GFP_KERNEL); |
22 | if (ns == NULL) | 20 | if (ns == NULL) |
23 | goto err_mem; | 21 | return ERR_PTR(-ENOMEM); |
24 | 22 | ||
25 | err = sem_init_ns(ns); | 23 | sem_init_ns(ns); |
26 | if (err) | 24 | msg_init_ns(ns); |
27 | goto err_sem; | 25 | shm_init_ns(ns); |
28 | err = msg_init_ns(ns); | ||
29 | if (err) | ||
30 | goto err_msg; | ||
31 | err = shm_init_ns(ns); | ||
32 | if (err) | ||
33 | goto err_shm; | ||
34 | 26 | ||
35 | kref_init(&ns->kref); | 27 | kref_init(&ns->kref); |
36 | return ns; | 28 | return ns; |
37 | |||
38 | err_shm: | ||
39 | msg_exit_ns(ns); | ||
40 | err_msg: | ||
41 | sem_exit_ns(ns); | ||
42 | err_sem: | ||
43 | kfree(ns); | ||
44 | err_mem: | ||
45 | return ERR_PTR(err); | ||
46 | } | 29 | } |
47 | 30 | ||
48 | struct ipc_namespace *copy_ipcs(unsigned long flags, struct ipc_namespace *ns) | 31 | struct ipc_namespace *copy_ipcs(unsigned long flags, struct ipc_namespace *ns) |