Commit 78a57931 authored by Cherry Zhang's avatar Cherry Zhang

cmd/compile: convert uint32 to int32 in ARM constant folding rules

MOVWconst's AuxInt is Int32. SSA check complains if the AuxInt
does not fit in int32. Convert uint32 to int32 to make it happy.

The generated code is unchanged. MOVW only cares low 32 bits.

Passes "toolstash -cmp" std cmd for ARM.

Fixes #25993.

Change-Id: I2b6532c9c285ea6d89652505fb7c553f85a98864
Reviewed-on: https://go-review.googlesource.com/120335
Run-TryBot: Cherry Zhang <cherryyz@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarKeith Randall <khr@golang.org>
parent 82d1c2a8
...@@ -829,14 +829,14 @@ ...@@ -829,14 +829,14 @@
(RSBconst [c] (SUBconst [d] x)) -> (RSBconst [int64(int32(c+d))] x) (RSBconst [c] (SUBconst [d] x)) -> (RSBconst [int64(int32(c+d))] x)
(RSCconst [c] (ADDconst [d] x) flags) -> (RSCconst [int64(int32(c-d))] x flags) (RSCconst [c] (ADDconst [d] x) flags) -> (RSCconst [int64(int32(c-d))] x flags)
(RSCconst [c] (SUBconst [d] x) flags) -> (RSCconst [int64(int32(c+d))] x flags) (RSCconst [c] (SUBconst [d] x) flags) -> (RSCconst [int64(int32(c+d))] x flags)
(SLLconst [c] (MOVWconst [d])) -> (MOVWconst [int64(uint32(d)<<uint64(c))]) (SLLconst [c] (MOVWconst [d])) -> (MOVWconst [int64(int32(uint32(d)<<uint64(c)))])
(SRLconst [c] (MOVWconst [d])) -> (MOVWconst [int64(uint32(d)>>uint64(c))]) (SRLconst [c] (MOVWconst [d])) -> (MOVWconst [int64(int32(uint32(d)>>uint64(c)))])
(SRAconst [c] (MOVWconst [d])) -> (MOVWconst [int64(int32(d)>>uint64(c))]) (SRAconst [c] (MOVWconst [d])) -> (MOVWconst [int64(int32(d)>>uint64(c))])
(MUL (MOVWconst [c]) (MOVWconst [d])) -> (MOVWconst [int64(int32(c*d))]) (MUL (MOVWconst [c]) (MOVWconst [d])) -> (MOVWconst [int64(int32(c*d))])
(MULA (MOVWconst [c]) (MOVWconst [d]) a) -> (ADDconst [int64(int32(c*d))] a) (MULA (MOVWconst [c]) (MOVWconst [d]) a) -> (ADDconst [int64(int32(c*d))] a)
(MULS (MOVWconst [c]) (MOVWconst [d]) a) -> (SUBconst [int64(int32(c*d))] a) (MULS (MOVWconst [c]) (MOVWconst [d]) a) -> (SUBconst [int64(int32(c*d))] a)
(Select0 (CALLudiv (MOVWconst [c]) (MOVWconst [d]))) -> (MOVWconst [int64(uint32(c)/uint32(d))]) (Select0 (CALLudiv (MOVWconst [c]) (MOVWconst [d]))) -> (MOVWconst [int64(int32(uint32(c)/uint32(d)))])
(Select1 (CALLudiv (MOVWconst [c]) (MOVWconst [d]))) -> (MOVWconst [int64(uint32(c)%uint32(d))]) (Select1 (CALLudiv (MOVWconst [c]) (MOVWconst [d]))) -> (MOVWconst [int64(int32(uint32(c)%uint32(d)))])
(ANDconst [c] (MOVWconst [d])) -> (MOVWconst [c&d]) (ANDconst [c] (MOVWconst [d])) -> (MOVWconst [c&d])
(ANDconst [c] (ANDconst [d] x)) -> (ANDconst [c&d] x) (ANDconst [c] (ANDconst [d] x)) -> (ANDconst [c&d] x)
(ORconst [c] (MOVWconst [d])) -> (MOVWconst [c|d]) (ORconst [c] (MOVWconst [d])) -> (MOVWconst [c|d])
...@@ -853,7 +853,7 @@ ...@@ -853,7 +853,7 @@
(MOVWreg (MOVWconst [c])) -> (MOVWconst [c]) (MOVWreg (MOVWconst [c])) -> (MOVWconst [c])
// BFX: Width = c >> 8, LSB = c & 0xff, result = d << (32 - Width - LSB) >> (32 - Width) // BFX: Width = c >> 8, LSB = c & 0xff, result = d << (32 - Width - LSB) >> (32 - Width)
(BFX [c] (MOVWconst [d])) -> (MOVWconst [int64(int32(d)<<(32-uint32(c&0xff)-uint32(c>>8))>>(32-uint32(c>>8)))]) (BFX [c] (MOVWconst [d])) -> (MOVWconst [int64(int32(d)<<(32-uint32(c&0xff)-uint32(c>>8))>>(32-uint32(c>>8)))])
(BFXU [c] (MOVWconst [d])) -> (MOVWconst [int64(uint32(d)<<(32-uint32(c&0xff)-uint32(c>>8))>>(32-uint32(c>>8)))]) (BFXU [c] (MOVWconst [d])) -> (MOVWconst [int64(int32(uint32(d)<<(32-uint32(c&0xff)-uint32(c>>8))>>(32-uint32(c>>8))))])
// absorb shifts into ops // absorb shifts into ops
(ADD x (SLLconst [c] y)) -> (ADDshiftLL x y [c]) (ADD x (SLLconst [c] y)) -> (ADDshiftLL x y [c])
......
...@@ -4044,7 +4044,7 @@ func rewriteValueARM_OpARMBFX_0(v *Value) bool { ...@@ -4044,7 +4044,7 @@ func rewriteValueARM_OpARMBFX_0(v *Value) bool {
func rewriteValueARM_OpARMBFXU_0(v *Value) bool { func rewriteValueARM_OpARMBFXU_0(v *Value) bool {
// match: (BFXU [c] (MOVWconst [d])) // match: (BFXU [c] (MOVWconst [d]))
// cond: // cond:
// result: (MOVWconst [int64(uint32(d)<<(32-uint32(c&0xff)-uint32(c>>8))>>(32-uint32(c>>8)))]) // result: (MOVWconst [int64(int32(uint32(d)<<(32-uint32(c&0xff)-uint32(c>>8))>>(32-uint32(c>>8))))])
for { for {
c := v.AuxInt c := v.AuxInt
v_0 := v.Args[0] v_0 := v.Args[0]
...@@ -4053,7 +4053,7 @@ func rewriteValueARM_OpARMBFXU_0(v *Value) bool { ...@@ -4053,7 +4053,7 @@ func rewriteValueARM_OpARMBFXU_0(v *Value) bool {
} }
d := v_0.AuxInt d := v_0.AuxInt
v.reset(OpARMMOVWconst) v.reset(OpARMMOVWconst)
v.AuxInt = int64(uint32(d) << (32 - uint32(c&0xff) - uint32(c>>8)) >> (32 - uint32(c>>8))) v.AuxInt = int64(int32(uint32(d) << (32 - uint32(c&0xff) - uint32(c>>8)) >> (32 - uint32(c>>8))))
return true return true
} }
return false return false
...@@ -14103,7 +14103,7 @@ func rewriteValueARM_OpARMSLL_0(v *Value) bool { ...@@ -14103,7 +14103,7 @@ func rewriteValueARM_OpARMSLL_0(v *Value) bool {
func rewriteValueARM_OpARMSLLconst_0(v *Value) bool { func rewriteValueARM_OpARMSLLconst_0(v *Value) bool {
// match: (SLLconst [c] (MOVWconst [d])) // match: (SLLconst [c] (MOVWconst [d]))
// cond: // cond:
// result: (MOVWconst [int64(uint32(d)<<uint64(c))]) // result: (MOVWconst [int64(int32(uint32(d)<<uint64(c)))])
for { for {
c := v.AuxInt c := v.AuxInt
v_0 := v.Args[0] v_0 := v.Args[0]
...@@ -14112,7 +14112,7 @@ func rewriteValueARM_OpARMSLLconst_0(v *Value) bool { ...@@ -14112,7 +14112,7 @@ func rewriteValueARM_OpARMSLLconst_0(v *Value) bool {
} }
d := v_0.AuxInt d := v_0.AuxInt
v.reset(OpARMMOVWconst) v.reset(OpARMMOVWconst)
v.AuxInt = int64(uint32(d) << uint64(c)) v.AuxInt = int64(int32(uint32(d) << uint64(c)))
return true return true
} }
return false return false
...@@ -14274,7 +14274,7 @@ func rewriteValueARM_OpARMSRL_0(v *Value) bool { ...@@ -14274,7 +14274,7 @@ func rewriteValueARM_OpARMSRL_0(v *Value) bool {
func rewriteValueARM_OpARMSRLconst_0(v *Value) bool { func rewriteValueARM_OpARMSRLconst_0(v *Value) bool {
// match: (SRLconst [c] (MOVWconst [d])) // match: (SRLconst [c] (MOVWconst [d]))
// cond: // cond:
// result: (MOVWconst [int64(uint32(d)>>uint64(c))]) // result: (MOVWconst [int64(int32(uint32(d)>>uint64(c)))])
for { for {
c := v.AuxInt c := v.AuxInt
v_0 := v.Args[0] v_0 := v.Args[0]
...@@ -14283,7 +14283,7 @@ func rewriteValueARM_OpARMSRLconst_0(v *Value) bool { ...@@ -14283,7 +14283,7 @@ func rewriteValueARM_OpARMSRLconst_0(v *Value) bool {
} }
d := v_0.AuxInt d := v_0.AuxInt
v.reset(OpARMMOVWconst) v.reset(OpARMMOVWconst)
v.AuxInt = int64(uint32(d) >> uint64(c)) v.AuxInt = int64(int32(uint32(d) >> uint64(c)))
return true return true
} }
// match: (SRLconst (SLLconst x [c]) [d]) // match: (SRLconst (SLLconst x [c]) [d])
...@@ -21295,7 +21295,7 @@ func rewriteValueARM_OpSelect0_0(v *Value) bool { ...@@ -21295,7 +21295,7 @@ func rewriteValueARM_OpSelect0_0(v *Value) bool {
} }
// match: (Select0 (CALLudiv (MOVWconst [c]) (MOVWconst [d]))) // match: (Select0 (CALLudiv (MOVWconst [c]) (MOVWconst [d])))
// cond: // cond:
// result: (MOVWconst [int64(uint32(c)/uint32(d))]) // result: (MOVWconst [int64(int32(uint32(c)/uint32(d)))])
for { for {
v_0 := v.Args[0] v_0 := v.Args[0]
if v_0.Op != OpARMCALLudiv { if v_0.Op != OpARMCALLudiv {
...@@ -21313,7 +21313,7 @@ func rewriteValueARM_OpSelect0_0(v *Value) bool { ...@@ -21313,7 +21313,7 @@ func rewriteValueARM_OpSelect0_0(v *Value) bool {
} }
d := v_0_1.AuxInt d := v_0_1.AuxInt
v.reset(OpARMMOVWconst) v.reset(OpARMMOVWconst)
v.AuxInt = int64(uint32(c) / uint32(d)) v.AuxInt = int64(int32(uint32(c) / uint32(d)))
return true return true
} }
return false return false
...@@ -21364,7 +21364,7 @@ func rewriteValueARM_OpSelect1_0(v *Value) bool { ...@@ -21364,7 +21364,7 @@ func rewriteValueARM_OpSelect1_0(v *Value) bool {
} }
// match: (Select1 (CALLudiv (MOVWconst [c]) (MOVWconst [d]))) // match: (Select1 (CALLudiv (MOVWconst [c]) (MOVWconst [d])))
// cond: // cond:
// result: (MOVWconst [int64(uint32(c)%uint32(d))]) // result: (MOVWconst [int64(int32(uint32(c)%uint32(d)))])
for { for {
v_0 := v.Args[0] v_0 := v.Args[0]
if v_0.Op != OpARMCALLudiv { if v_0.Op != OpARMCALLudiv {
...@@ -21382,7 +21382,7 @@ func rewriteValueARM_OpSelect1_0(v *Value) bool { ...@@ -21382,7 +21382,7 @@ func rewriteValueARM_OpSelect1_0(v *Value) bool {
} }
d := v_0_1.AuxInt d := v_0_1.AuxInt
v.reset(OpARMMOVWconst) v.reset(OpARMMOVWconst)
v.AuxInt = int64(uint32(c) % uint32(d)) v.AuxInt = int64(int32(uint32(c) % uint32(d)))
return true return true
} }
return false return false
......
// compile -d=ssa/check/on
// Copyright 2018 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Issue 25993: SSA check fails on ARM.
package p
func f() {
var x int
var B0 bool
B0 = !B0 || B0
if B0 && B0 {
x = -1
}
var AI []int
var AB []bool
_ = AI[x] > 0 && AB[x]
}
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