(XORQ x x) -> (MOVQconst [0])
(XORL x x) -> (MOVLconst [0])
-(SHLLconst [d] (MOVLconst [c])) -> (MOVLconst [int64(int32(c)) << uint64(d)])
+(SHLLconst [d] (MOVLconst [c])) -> (MOVLconst [int64(int32(c) << uint64(d))])
(SHLQconst [d] (MOVQconst [c])) -> (MOVQconst [c << uint64(d)])
(SHLQconst [d] (MOVLconst [c])) -> (MOVQconst [int64(int32(c)) << uint64(d)])
return true
}
// match: (SHLLconst [d] (MOVLconst [c]))
- // result: (MOVLconst [int64(int32(c)) << uint64(d)])
+ // result: (MOVLconst [int64(int32(c) << uint64(d))])
for {
d := v.AuxInt
if v_0.Op != OpAMD64MOVLconst {
}
c := v_0.AuxInt
v.reset(OpAMD64MOVLconst)
- v.AuxInt = int64(int32(c)) << uint64(d)
+ v.AuxInt = int64(int32(c) << uint64(d))
return true
}
return false
--- /dev/null
+// compile -d=ssa/check/on
+
+// Copyright 2020 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.
+
+package main
+
+func f() uint32 {
+ s := "food"
+ x := uint32(s[0]) + uint32(s[1])<<8 + uint32(s[2])<<16 + uint32(s[3])<<24
+ // x is a constant, but that's not known until lowering.
+ // shifting it by 8 moves the high byte up into the high 32 bits of
+ // a 64-bit word. That word is not properly sign-extended by the faulty
+ // rule, which causes the compiler to fail.
+ return x << 8
+}