2020-02-10 18:12:21

by Daniel Jordan

[permalink] [raw]
Subject: [PATCH] padata: fix uninitialized return value in padata_replace()

According to Geert's report[0],

kernel/padata.c: warning: 'err' may be used uninitialized in this
function [-Wuninitialized]: => 539:2

Warning is seen only with older compilers on certain archs. The
runtime effect is potentially returning garbage down the stack when
padata's cpumasks are modified before any pcrypt requests have run.

Simplest fix is to initialize err to the success value.

[0] http://lkml.kernel.org/r/[email protected]

Reported-by: Geert Uytterhoeven <[email protected]>
Fixes: bbefa1dd6a6d ("crypto: pcrypt - Avoid deadlock by using per-instance padata queues")
Signed-off-by: Daniel Jordan <[email protected]>
Cc: Herbert Xu <[email protected]>
Cc: Steffen Klassert <[email protected]>
Cc: [email protected]
Cc: [email protected]
---
kernel/padata.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/kernel/padata.c b/kernel/padata.c
index 72777c10bb9c..62082597d4a2 100644
--- a/kernel/padata.c
+++ b/kernel/padata.c
@@ -512,7 +512,7 @@ static int padata_replace_one(struct padata_shell *ps)
static int padata_replace(struct padata_instance *pinst)
{
struct padata_shell *ps;
- int err;
+ int err = 0;

pinst->flags |= PADATA_RESET;

--
2.24.1


2020-02-22 01:42:02

by Herbert Xu

[permalink] [raw]
Subject: Re: [PATCH] padata: fix uninitialized return value in padata_replace()

On Mon, Feb 10, 2020 at 01:11:00PM -0500, Daniel Jordan wrote:
> According to Geert's report[0],
>
> kernel/padata.c: warning: 'err' may be used uninitialized in this
> function [-Wuninitialized]: => 539:2
>
> Warning is seen only with older compilers on certain archs. The
> runtime effect is potentially returning garbage down the stack when
> padata's cpumasks are modified before any pcrypt requests have run.
>
> Simplest fix is to initialize err to the success value.
>
> [0] http://lkml.kernel.org/r/[email protected]
>
> Reported-by: Geert Uytterhoeven <[email protected]>
> Fixes: bbefa1dd6a6d ("crypto: pcrypt - Avoid deadlock by using per-instance padata queues")
> Signed-off-by: Daniel Jordan <[email protected]>
> Cc: Herbert Xu <[email protected]>
> Cc: Steffen Klassert <[email protected]>
> Cc: [email protected]
> Cc: [email protected]
> ---
> kernel/padata.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)

Patch applied. Thanks.
--
Email: Herbert Xu <[email protected]>
Home Page: http://gondor.apana.org.au/~herbert/
PGP Key: http://gondor.apana.org.au/~herbert/pubkey.txt