diff options
author | Kees Cook <keescook@chromium.org> | 2017-07-12 17:35:05 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2017-07-12 19:26:01 -0400 |
commit | 3e0c24042e5aa55eee817caeca67246df69931e1 (patch) | |
tree | cbc852c2acea7b8f0dfd9e3f31dc4f6291a6e128 /ipc | |
parent | 101ede01dfd5072651965e974bc6e30c8d0748e2 (diff) |
ipc/shm: avoid ipc_rcu_alloc()
Instead of using ipc_rcu_alloc() which only performs the refcount bump,
open code it. This also allows for shmid_kernel structure layout to be
randomized in the future.
Link: http://lkml.kernel.org/r/20170525185107.12869-11-manfred@colorfullife.com
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Manfred Spraul <manfred@colorfullife.com>
Cc: Davidlohr Bueso <dave@stgolabs.net>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'ipc')
-rw-r--r-- | ipc/shm.c | 18 |
1 files changed, 14 insertions, 4 deletions
@@ -518,6 +518,19 @@ static const struct vm_operations_struct shm_vm_ops = { | |||
518 | #endif | 518 | #endif |
519 | }; | 519 | }; |
520 | 520 | ||
521 | static struct shmid_kernel *shm_alloc(void) | ||
522 | { | ||
523 | struct shmid_kernel *shp; | ||
524 | |||
525 | shp = kvmalloc(sizeof(*shp), GFP_KERNEL); | ||
526 | if (unlikely(!shp)) | ||
527 | return NULL; | ||
528 | |||
529 | atomic_set(&shp->shm_perm.refcount, 1); | ||
530 | |||
531 | return shp; | ||
532 | } | ||
533 | |||
521 | /** | 534 | /** |
522 | * newseg - Create a new shared memory segment | 535 | * newseg - Create a new shared memory segment |
523 | * @ns: namespace | 536 | * @ns: namespace |
@@ -548,10 +561,7 @@ static int newseg(struct ipc_namespace *ns, struct ipc_params *params) | |||
548 | ns->shm_tot + numpages > ns->shm_ctlall) | 561 | ns->shm_tot + numpages > ns->shm_ctlall) |
549 | return -ENOSPC; | 562 | return -ENOSPC; |
550 | 563 | ||
551 | BUILD_BUG_ON(offsetof(struct shmid_kernel, shm_perm) != 0); | 564 | shp = shm_alloc(); |
552 | |||
553 | shp = container_of(ipc_rcu_alloc(sizeof(*shp)), struct shmid_kernel, | ||
554 | shm_perm); | ||
555 | if (!shp) | 565 | if (!shp) |
556 | return -ENOMEM; | 566 | return -ENOMEM; |
557 | 567 | ||