From: Dan Carpenter Date: Sat, 16 Mar 2013 09:48:11 +0000 (+0300) Subject: selinux: use GFP_ATOMIC under spin_lock X-Git-Tag: firefly_0821_release~3680^2~880^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=4502403dcf8f5c76abd4dbab8726c8e4ecb5cd34;p=firefly-linux-kernel-4.4.55.git selinux: use GFP_ATOMIC under spin_lock The call tree here is: sk_clone_lock() <- takes bh_lock_sock(newsk); xfrm_sk_clone_policy() __xfrm_sk_clone_policy() clone_policy() <- uses GFP_ATOMIC for allocations security_xfrm_policy_clone() security_ops->xfrm_policy_clone_security() selinux_xfrm_policy_clone() Signed-off-by: Dan Carpenter Cc: stable@kernel.org Signed-off-by: James Morris --- diff --git a/security/selinux/xfrm.c b/security/selinux/xfrm.c index 48665ecd1197..8ab295154517 100644 --- a/security/selinux/xfrm.c +++ b/security/selinux/xfrm.c @@ -310,7 +310,7 @@ int selinux_xfrm_policy_clone(struct xfrm_sec_ctx *old_ctx, if (old_ctx) { new_ctx = kmalloc(sizeof(*old_ctx) + old_ctx->ctx_len, - GFP_KERNEL); + GFP_ATOMIC); if (!new_ctx) return -ENOMEM;