Commit d681c246 authored by Seth Forshee's avatar Seth Forshee Committed by Greg Kroah-Hartman

powerpc: Always initialize input array when calling epapr_hypercall()

commit 186b8f15 upstream.

Several callers to epapr_hypercall() pass an uninitialized stack
allocated array for the input arguments, presumably because they
have no input arguments. However this can produce errors like
this one

 arch/powerpc/include/asm/epapr_hcalls.h:470:42: error: 'in' may be used uninitialized in this function [-Werror=maybe-uninitialized]
  unsigned long register r3 asm("r3") = in[0];
                                        ~~^~~

Fix callers to this function to always zero-initialize the input
arguments array to prevent this.
Signed-off-by: default avatarSeth Forshee <seth.forshee@canonical.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Cc: "A. Wilcox" <awilfox@adelielinux.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 7c0d76ee
...@@ -508,7 +508,7 @@ static unsigned long epapr_hypercall(unsigned long *in, ...@@ -508,7 +508,7 @@ static unsigned long epapr_hypercall(unsigned long *in,
static inline long epapr_hypercall0_1(unsigned int nr, unsigned long *r2) static inline long epapr_hypercall0_1(unsigned int nr, unsigned long *r2)
{ {
unsigned long in[8]; unsigned long in[8] = {0};
unsigned long out[8]; unsigned long out[8];
unsigned long r; unsigned long r;
...@@ -520,7 +520,7 @@ static inline long epapr_hypercall0_1(unsigned int nr, unsigned long *r2) ...@@ -520,7 +520,7 @@ static inline long epapr_hypercall0_1(unsigned int nr, unsigned long *r2)
static inline long epapr_hypercall0(unsigned int nr) static inline long epapr_hypercall0(unsigned int nr)
{ {
unsigned long in[8]; unsigned long in[8] = {0};
unsigned long out[8]; unsigned long out[8];
return epapr_hypercall(in, out, nr); return epapr_hypercall(in, out, nr);
...@@ -528,7 +528,7 @@ static inline long epapr_hypercall0(unsigned int nr) ...@@ -528,7 +528,7 @@ static inline long epapr_hypercall0(unsigned int nr)
static inline long epapr_hypercall1(unsigned int nr, unsigned long p1) static inline long epapr_hypercall1(unsigned int nr, unsigned long p1)
{ {
unsigned long in[8]; unsigned long in[8] = {0};
unsigned long out[8]; unsigned long out[8];
in[0] = p1; in[0] = p1;
...@@ -538,7 +538,7 @@ static inline long epapr_hypercall1(unsigned int nr, unsigned long p1) ...@@ -538,7 +538,7 @@ static inline long epapr_hypercall1(unsigned int nr, unsigned long p1)
static inline long epapr_hypercall2(unsigned int nr, unsigned long p1, static inline long epapr_hypercall2(unsigned int nr, unsigned long p1,
unsigned long p2) unsigned long p2)
{ {
unsigned long in[8]; unsigned long in[8] = {0};
unsigned long out[8]; unsigned long out[8];
in[0] = p1; in[0] = p1;
...@@ -549,7 +549,7 @@ static inline long epapr_hypercall2(unsigned int nr, unsigned long p1, ...@@ -549,7 +549,7 @@ static inline long epapr_hypercall2(unsigned int nr, unsigned long p1,
static inline long epapr_hypercall3(unsigned int nr, unsigned long p1, static inline long epapr_hypercall3(unsigned int nr, unsigned long p1,
unsigned long p2, unsigned long p3) unsigned long p2, unsigned long p3)
{ {
unsigned long in[8]; unsigned long in[8] = {0};
unsigned long out[8]; unsigned long out[8];
in[0] = p1; in[0] = p1;
...@@ -562,7 +562,7 @@ static inline long epapr_hypercall4(unsigned int nr, unsigned long p1, ...@@ -562,7 +562,7 @@ static inline long epapr_hypercall4(unsigned int nr, unsigned long p1,
unsigned long p2, unsigned long p3, unsigned long p2, unsigned long p3,
unsigned long p4) unsigned long p4)
{ {
unsigned long in[8]; unsigned long in[8] = {0};
unsigned long out[8]; unsigned long out[8];
in[0] = p1; in[0] = p1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment