* [PATCH] efi: Use GFP_ATOMIC instead of GFP_KERNEL
@ 2016-04-11 10:53 Vaishali Thakkar
[not found] ` <1460372009-10785-1-git-send-email-vaishali.thakkar-QHcLZuEGTsvQT0dZR+AlfA@public.gmane.org>
0 siblings, 1 reply; 4+ messages in thread
From: Vaishali Thakkar @ 2016-04-11 10:53 UTC (permalink / raw)
To: matt-mF/unelCI9GS6iBeEJttW/XRex20P6io
Cc: linux-efi-u79uwXL29TY76Z2rM5mHXA,
linux-kernel-u79uwXL29TY76Z2rM5mHXA, Vaishali Thakkar
Function dup_variable_bug is called inside the spinlock.
This may lead to issues when kzalloc sleeps, so it is
better to use GFP_ATOMIC in this spinlocked context.
Problem found using Coccinelle.
Signed-off-by: Vaishali Thakkar <vaishali.thakkar-QHcLZuEGTsvQT0dZR+AlfA@public.gmane.org>
---
drivers/firmware/efi/vars.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/drivers/firmware/efi/vars.c b/drivers/firmware/efi/vars.c
index 0ac594c..d5e2f28 100644
--- a/drivers/firmware/efi/vars.c
+++ b/drivers/firmware/efi/vars.c
@@ -411,7 +411,7 @@ static void dup_variable_bug(efi_char16_t *str16, efi_guid_t *vendor_guid,
*/
efivar_wq_enabled = false;
- str8 = kzalloc(len8, GFP_KERNEL);
+ str8 = kzalloc(len8, GFP_ATOMIC);
if (!str8)
return;
--
2.1.4
^ permalink raw reply related [flat|nested] 4+ messages in thread[parent not found: <1460372009-10785-1-git-send-email-vaishali.thakkar-QHcLZuEGTsvQT0dZR+AlfA@public.gmane.org>]
* Re: [PATCH] efi: Use GFP_ATOMIC instead of GFP_KERNEL [not found] ` <1460372009-10785-1-git-send-email-vaishali.thakkar-QHcLZuEGTsvQT0dZR+AlfA@public.gmane.org> @ 2016-04-14 21:49 ` Matt Fleming [not found] ` <20160414214949.GS2829-mF/unelCI9GS6iBeEJttW/XRex20P6io@public.gmane.org> 0 siblings, 1 reply; 4+ messages in thread From: Matt Fleming @ 2016-04-14 21:49 UTC (permalink / raw) To: Vaishali Thakkar Cc: linux-efi-u79uwXL29TY76Z2rM5mHXA, linux-kernel-u79uwXL29TY76Z2rM5mHXA, Julia Lawall, Saurabh Sengar On Mon, 11 Apr, at 04:23:29PM, Vaishali Thakkar wrote: > Function dup_variable_bug is called inside the spinlock. > This may lead to issues when kzalloc sleeps, so it is > better to use GFP_ATOMIC in this spinlocked context. > > Problem found using Coccinelle. Dang it, I broke coccinelle ;) > Signed-off-by: Vaishali Thakkar <vaishali.thakkar-QHcLZuEGTsvQT0dZR+AlfA@public.gmane.org> > --- > drivers/firmware/efi/vars.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/firmware/efi/vars.c b/drivers/firmware/efi/vars.c > index 0ac594c..d5e2f28 100644 > --- a/drivers/firmware/efi/vars.c > +++ b/drivers/firmware/efi/vars.c > @@ -411,7 +411,7 @@ static void dup_variable_bug(efi_char16_t *str16, efi_guid_t *vendor_guid, > */ > efivar_wq_enabled = false; > > - str8 = kzalloc(len8, GFP_KERNEL); > + str8 = kzalloc(len8, GFP_ATOMIC); > if (!str8) > return; > This was brought up by Saurabh last year, https://lkml.kernel.org/r/1446003747-3760-1-git-send-email-saurabh.truth-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org dup_variable_bug() is never called while holding the spinlock in practice, and I'm guessing Coccinelle cannot understand that because it'd need to look at program control flow, across multiple compilation units. If anyone wants to send a patch to clean up the EFI code so that it's easier for coccinelle to check it, I'd be happy to review it. ^ permalink raw reply [flat|nested] 4+ messages in thread
[parent not found: <20160414214949.GS2829-mF/unelCI9GS6iBeEJttW/XRex20P6io@public.gmane.org>]
* Re: [PATCH] efi: Use GFP_ATOMIC instead of GFP_KERNEL [not found] ` <20160414214949.GS2829-mF/unelCI9GS6iBeEJttW/XRex20P6io@public.gmane.org> @ 2016-04-15 6:38 ` Julia Lawall 2016-04-17 21:18 ` Matt Fleming 0 siblings, 1 reply; 4+ messages in thread From: Julia Lawall @ 2016-04-15 6:38 UTC (permalink / raw) To: Matt Fleming Cc: Vaishali Thakkar, linux-efi-u79uwXL29TY76Z2rM5mHXA, linux-kernel-u79uwXL29TY76Z2rM5mHXA, Saurabh Sengar On Thu, 14 Apr 2016, Matt Fleming wrote: > On Mon, 11 Apr, at 04:23:29PM, Vaishali Thakkar wrote: > > Function dup_variable_bug is called inside the spinlock. > > This may lead to issues when kzalloc sleeps, so it is > > better to use GFP_ATOMIC in this spinlocked context. > > > > Problem found using Coccinelle. > > Dang it, I broke coccinelle ;) > > > Signed-off-by: Vaishali Thakkar <vaishali.thakkar-QHcLZuEGTsvQT0dZR+AlfA@public.gmane.org> > > --- > > drivers/firmware/efi/vars.c | 2 +- > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > diff --git a/drivers/firmware/efi/vars.c b/drivers/firmware/efi/vars.c > > index 0ac594c..d5e2f28 100644 > > --- a/drivers/firmware/efi/vars.c > > +++ b/drivers/firmware/efi/vars.c > > @@ -411,7 +411,7 @@ static void dup_variable_bug(efi_char16_t *str16, efi_guid_t *vendor_guid, > > */ > > efivar_wq_enabled = false; > > > > - str8 = kzalloc(len8, GFP_KERNEL); > > + str8 = kzalloc(len8, GFP_ATOMIC); > > if (!str8) > > return; > > > > This was brought up by Saurabh last year, > > https://lkml.kernel.org/r/1446003747-3760-1-git-send-email-saurabh.truth-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org > > dup_variable_bug() is never called while holding the spinlock in > practice, and I'm guessing Coccinelle cannot understand that because > it'd need to look at program control flow, across multiple compilation > units. > > If anyone wants to send a patch to clean up the EFI code so that it's > easier for coccinelle to check it, I'd be happy to review it. I looked at it a bit with Vaishali. I wonder if it would be possible at least to have only one flag? Then one wouldn't have to maintain the subtle relationship between atomic and duplicates. I'm not sure that it would help Coccinelle, but at least one could see more quickly that Coccinelle is giving a false positive. julia ^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] efi: Use GFP_ATOMIC instead of GFP_KERNEL 2016-04-15 6:38 ` Julia Lawall @ 2016-04-17 21:18 ` Matt Fleming 0 siblings, 0 replies; 4+ messages in thread From: Matt Fleming @ 2016-04-17 21:18 UTC (permalink / raw) To: Julia Lawall; +Cc: Vaishali Thakkar, linux-efi, linux-kernel, Saurabh Sengar On Fri, 15 Apr, at 08:38:37AM, Julia Lawall wrote: > > I looked at it a bit with Vaishali. I wonder if it would be possible at > least to have only one flag? Then one wouldn't have to maintain the > subtle relationship between atomic and duplicates. I'm not sure that it > would help Coccinelle, but at least one could see more quickly that > Coccinelle is giving a false positive. Yeah, that would be a good idea. How about we drop the @atomic parameter and simply use @duplicates to figure out whether to perform duplicate detection, which we should note in the comment of efivar_init() cannot be performed atomically. Bonus points if someone can clean up the code flow too. Otherwise, efivar_init() is done while holding a spinlock. ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2016-04-17 21:18 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-04-11 10:53 [PATCH] efi: Use GFP_ATOMIC instead of GFP_KERNEL Vaishali Thakkar
[not found] ` <1460372009-10785-1-git-send-email-vaishali.thakkar-QHcLZuEGTsvQT0dZR+AlfA@public.gmane.org>
2016-04-14 21:49 ` Matt Fleming
[not found] ` <20160414214949.GS2829-mF/unelCI9GS6iBeEJttW/XRex20P6io@public.gmane.org>
2016-04-15 6:38 ` Julia Lawall
2016-04-17 21:18 ` Matt Fleming
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).