diff mbox series

target/ppc/excp_helper: Add a missing break for POWERPC_EXCP_HISI

Message ID 20201028041620.2168707-1-kuhn.chenqun@huawei.com
State New
Headers show
Series target/ppc/excp_helper: Add a missing break for POWERPC_EXCP_HISI | expand

Commit Message

Chenqun (kuhn) Oct. 28, 2020, 4:16 a.m. UTC
When using -Wimplicit-fallthrough in our CFLAGS, the compiler showed warning:
../target/ppc/excp_helper.c: In function ‘powerpc_excp’:
../target/ppc/excp_helper.c:529:13: warning: this statement may fall through [-Wimplicit-fallthrough=]
  529 |         msr |= env->error_code;
      |         ~~~~^~~~~~~~~~~~~~~~~~
../target/ppc/excp_helper.c:530:5: note: here
  530 |     case POWERPC_EXCP_HDECR:     /* Hypervisor decrementer exception         */
      |     ^~~~

A break statement may be required to enter this exception.

Reported-by: Euler Robot <euler.robot@huawei.com>
Signed-off-by: Chen Qun <kuhn.chenqun@huawei.com>

---
I guess there's a break missing in 'POWERPC_EXCP_HISI' branch,
just like the 'POWERPC_EXCP_ISI' branch.
---
 target/ppc/excp_helper.c | 1 +
 1 file changed, 1 insertion(+)

Comments

David Gibson Oct. 28, 2020, 4:27 a.m. UTC | #1
On Wed, Oct 28, 2020 at 12:16:20PM +0800, Chen Qun wrote:
> When using -Wimplicit-fallthrough in our CFLAGS, the compiler showed warning:
> ../target/ppc/excp_helper.c: In function ‘powerpc_excp’:
> ../target/ppc/excp_helper.c:529:13: warning: this statement may fall through [-Wimplicit-fallthrough=]
>   529 |         msr |= env->error_code;
>       |         ~~~~^~~~~~~~~~~~~~~~~~
> ../target/ppc/excp_helper.c:530:5: note: here
>   530 |     case POWERPC_EXCP_HDECR:     /* Hypervisor decrementer exception         */
>       |     ^~~~
> 
> A break statement may be required to enter this exception.
> 
> Reported-by: Euler Robot <euler.robot@huawei.com>
> Signed-off-by: Chen Qun <kuhn.chenqun@huawei.com>

This change is incorrect.  We definitely need the fallthrough to set
srr[01] properly.  So the correct fix is to annotate the fallthrough,
not remove it.

> 
> ---
> I guess there's a break missing in 'POWERPC_EXCP_HISI' branch,
> just like the 'POWERPC_EXCP_ISI' branch.
> ---
>  target/ppc/excp_helper.c | 1 +
>  1 file changed, 1 insertion(+)
> 
> diff --git a/target/ppc/excp_helper.c b/target/ppc/excp_helper.c
> index a988ba15f4..5e69ac1b33 100644
> --- a/target/ppc/excp_helper.c
> +++ b/target/ppc/excp_helper.c
> @@ -527,6 +527,7 @@ static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
>          break;
>      case POWERPC_EXCP_HISI:      /* Hypervisor instruction storage exception */
>          msr |= env->error_code;
> +        break;
>      case POWERPC_EXCP_HDECR:     /* Hypervisor decrementer exception         */
>      case POWERPC_EXCP_HDSI:      /* Hypervisor data storage exception        */
>      case POWERPC_EXCP_HDSEG:     /* Hypervisor data segment exception        */
Chenqun (kuhn) Oct. 28, 2020, 5:43 a.m. UTC | #2
> -----Original Message-----

> From: David Gibson [mailto:david@gibson.dropbear.id.au]

> Sent: Wednesday, October 28, 2020 12:28 PM

> To: Chenqun (kuhn) <kuhn.chenqun@huawei.com>

> Cc: qemu-devel@nongnu.org; qemu-trivial@nongnu.org; clg@kaod.org;

> Zhanghailiang <zhang.zhanghailiang@huawei.com>; ganqixin

> <ganqixin@huawei.com>; Euler Robot <euler.robot@huawei.com>

> Subject: Re: [PATCH] target/ppc/excp_helper: Add a missing break for

> POWERPC_EXCP_HISI

> 

> On Wed, Oct 28, 2020 at 12:16:20PM +0800, Chen Qun wrote:

> > When using -Wimplicit-fallthrough in our CFLAGS, the compiler showed

> warning:

> > ../target/ppc/excp_helper.c: In function ‘powerpc_excp’:

> > ../target/ppc/excp_helper.c:529:13: warning: this statement may fall through

> [-Wimplicit-fallthrough=]

> >   529 |         msr |= env->error_code;

> >       |         ~~~~^~~~~~~~~~~~~~~~~~

> > ../target/ppc/excp_helper.c:530:5: note: here

> >   530 |     case POWERPC_EXCP_HDECR:     /* Hypervisor

> decrementer exception         */

> >       |     ^~~~

> >

> > A break statement may be required to enter this exception.

> >

> > Reported-by: Euler Robot <euler.robot@huawei.com>

> > Signed-off-by: Chen Qun <kuhn.chenqun@huawei.com>

> 

> This change is incorrect.  We definitely need the fallthrough to set srr[01]

> properly.  So the correct fix is to annotate the fallthrough, not remove it.

> 

OK, I'll modify it later.
'
Thanks,
Chen Qun
> >

> > ---

> > I guess there's a break missing in 'POWERPC_EXCP_HISI' branch, just

> > like the 'POWERPC_EXCP_ISI' branch.

> > ---

> >  target/ppc/excp_helper.c | 1 +

> >  1 file changed, 1 insertion(+)

> >

> > diff --git a/target/ppc/excp_helper.c b/target/ppc/excp_helper.c index

> > a988ba15f4..5e69ac1b33 100644

> > --- a/target/ppc/excp_helper.c

> > +++ b/target/ppc/excp_helper.c

> > @@ -527,6 +527,7 @@ static inline void powerpc_excp(PowerPCCPU *cpu,

> int excp_model, int excp)

> >          break;

> >      case POWERPC_EXCP_HISI:      /* Hypervisor instruction storage

> exception */

> >          msr |= env->error_code;

> > +        break;

> >      case POWERPC_EXCP_HDECR:     /* Hypervisor decrementer

> exception         */

> >      case POWERPC_EXCP_HDSI:      /* Hypervisor data storage

> exception        */

> >      case POWERPC_EXCP_HDSEG:     /* Hypervisor data segment

> exception        */

> 

> --

> David Gibson			| I'll have my music baroque, and my code

> david AT gibson.dropbear.id.au	| minimalist, thank you.  NOT _the_

> _other_

> 				| _way_ _around_!

> http://www.ozlabs.org/~dgibson
diff mbox series

Patch

diff --git a/target/ppc/excp_helper.c b/target/ppc/excp_helper.c
index a988ba15f4..5e69ac1b33 100644
--- a/target/ppc/excp_helper.c
+++ b/target/ppc/excp_helper.c
@@ -527,6 +527,7 @@  static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
         break;
     case POWERPC_EXCP_HISI:      /* Hypervisor instruction storage exception */
         msr |= env->error_code;
+        break;
     case POWERPC_EXCP_HDECR:     /* Hypervisor decrementer exception         */
     case POWERPC_EXCP_HDSI:      /* Hypervisor data storage exception        */
     case POWERPC_EXCP_HDSEG:     /* Hypervisor data segment exception        */