diff mbox

target-arm: fix incorrect assertion in access_check_cp_reg helper

Message ID 1433161632-5752-1-git-send-email-chianglungyu@gmail.com
State New
Headers show

Commit Message

Leon Yu June 1, 2015, 12:27 p.m. UTC
as comparing boolean with constant 3 is always false.

Signed-off-by: Leon Yu <chianglungyu@gmail.com>
---
 target-arm/op_helper.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Peter Maydell June 1, 2015, 2:20 p.m. UTC | #1
On 1 June 2015 at 13:27, Leon Yu <chianglungyu@gmail.com> wrote:
> as comparing boolean with constant 3 is always false.
>
> Signed-off-by: Leon Yu <chianglungyu@gmail.com>
> ---
>  target-arm/op_helper.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/target-arm/op_helper.c b/target-arm/op_helper.c
> index 3f5b9ab..30f2374 100644
> --- a/target-arm/op_helper.c
> +++ b/target-arm/op_helper.c
> @@ -421,7 +421,7 @@ void HELPER(access_check_cp_reg)(CPUARMState *env, void *rip, uint32_t syndrome)
>          /* Requesting a trap to EL2 when we're in EL3 or S-EL0/1 is
>           * a bug in the access function.
>           */
> -        assert(!arm_is_secure(env) && !arm_current_el(env) == 3);
> +        assert(!arm_is_secure(env) && !(arm_current_el(env) == 3));
>          target_el = 2;
>          break;

Yep. There's a fix onlist already:
http://patchwork.ozlabs.org/patch/477597/

thanks
-- PMM
Leon Yu June 2, 2015, 2:05 p.m. UTC | #2
Argh, that fix is cleaner and I should have checked patchwork first.
Lesson learned, thanks.

-Leon

On Mon, Jun 1, 2015 at 10:20 PM, Peter Maydell <peter.maydell@linaro.org> wrote:
> On 1 June 2015 at 13:27, Leon Yu <chianglungyu@gmail.com> wrote:
>> as comparing boolean with constant 3 is always false.
>>
>> Signed-off-by: Leon Yu <chianglungyu@gmail.com>
>> ---
>>  target-arm/op_helper.c | 2 +-
>>  1 file changed, 1 insertion(+), 1 deletion(-)
>>
>> diff --git a/target-arm/op_helper.c b/target-arm/op_helper.c
>> index 3f5b9ab..30f2374 100644
>> --- a/target-arm/op_helper.c
>> +++ b/target-arm/op_helper.c
>> @@ -421,7 +421,7 @@ void HELPER(access_check_cp_reg)(CPUARMState *env, void *rip, uint32_t syndrome)
>>          /* Requesting a trap to EL2 when we're in EL3 or S-EL0/1 is
>>           * a bug in the access function.
>>           */
>> -        assert(!arm_is_secure(env) && !arm_current_el(env) == 3);
>> +        assert(!arm_is_secure(env) && !(arm_current_el(env) == 3));
>>          target_el = 2;
>>          break;
>
> Yep. There's a fix onlist already:
> http://patchwork.ozlabs.org/patch/477597/
>
> thanks
> -- PMM
diff mbox

Patch

diff --git a/target-arm/op_helper.c b/target-arm/op_helper.c
index 3f5b9ab..30f2374 100644
--- a/target-arm/op_helper.c
+++ b/target-arm/op_helper.c
@@ -421,7 +421,7 @@  void HELPER(access_check_cp_reg)(CPUARMState *env, void *rip, uint32_t syndrome)
         /* Requesting a trap to EL2 when we're in EL3 or S-EL0/1 is
          * a bug in the access function.
          */
-        assert(!arm_is_secure(env) && !arm_current_el(env) == 3);
+        assert(!arm_is_secure(env) && !(arm_current_el(env) == 3));
         target_el = 2;
         break;
     case CP_ACCESS_TRAP_EL3: