2015-06-06 16:03:33 -07:00
|
|
|
// autogenerated from gen/generic.rules: do not edit!
|
|
|
|
|
// generated with: cd gen; go run *.go
|
|
|
|
|
package ssa
|
|
|
|
|
|
|
|
|
|
func rewriteValuegeneric(v *Value, config *Config) bool {
|
|
|
|
|
switch v.Op {
|
2015-07-19 15:48:20 -07:00
|
|
|
case OpAdd64:
|
|
|
|
|
// match: (Add64 (Const [c]) (Const [d]))
|
|
|
|
|
// cond:
|
2015-06-11 21:29:25 -07:00
|
|
|
// result: (Const [c+d])
|
2015-06-06 16:03:33 -07:00
|
|
|
{
|
|
|
|
|
if v.Args[0].Op != OpConst {
|
2015-07-19 15:48:20 -07:00
|
|
|
goto endd2f4bfaaf6c937171a287b73e5c2f73e
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
2015-06-11 21:29:25 -07:00
|
|
|
c := v.Args[0].AuxInt
|
2015-06-06 16:03:33 -07:00
|
|
|
if v.Args[1].Op != OpConst {
|
2015-07-19 15:48:20 -07:00
|
|
|
goto endd2f4bfaaf6c937171a287b73e5c2f73e
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
2015-06-11 21:29:25 -07:00
|
|
|
d := v.Args[1].AuxInt
|
2015-07-19 15:48:20 -07:00
|
|
|
v.Op = OpConst
|
|
|
|
|
v.AuxInt = 0
|
|
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
|
|
|
|
v.AuxInt = c + d
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
goto endd2f4bfaaf6c937171a287b73e5c2f73e
|
|
|
|
|
endd2f4bfaaf6c937171a287b73e5c2f73e:
|
|
|
|
|
;
|
|
|
|
|
case OpAdd64U:
|
|
|
|
|
// match: (Add64U (Const [c]) (Const [d]))
|
|
|
|
|
// cond:
|
|
|
|
|
// result: (Const [c+d])
|
|
|
|
|
{
|
|
|
|
|
if v.Args[0].Op != OpConst {
|
|
|
|
|
goto endfedc373d8be0243cb5dbbc948996fe3a
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
2015-07-19 15:48:20 -07:00
|
|
|
c := v.Args[0].AuxInt
|
|
|
|
|
if v.Args[1].Op != OpConst {
|
|
|
|
|
goto endfedc373d8be0243cb5dbbc948996fe3a
|
|
|
|
|
}
|
|
|
|
|
d := v.Args[1].AuxInt
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Op = OpConst
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = c + d
|
2015-06-06 16:03:33 -07:00
|
|
|
return true
|
|
|
|
|
}
|
2015-07-19 15:48:20 -07:00
|
|
|
goto endfedc373d8be0243cb5dbbc948996fe3a
|
|
|
|
|
endfedc373d8be0243cb5dbbc948996fe3a:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
|
|
|
|
case OpArrayIndex:
|
|
|
|
|
// match: (ArrayIndex (Load ptr mem) idx)
|
|
|
|
|
// cond:
|
2015-06-12 11:01:13 -07:00
|
|
|
// result: (Load (PtrIndex <v.Type.PtrTo()> ptr idx) mem)
|
2015-06-06 16:03:33 -07:00
|
|
|
{
|
|
|
|
|
if v.Args[0].Op != OpLoad {
|
2015-06-12 11:01:13 -07:00
|
|
|
goto end4894dd7b58383fee5f8a92be08437c33
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
ptr := v.Args[0].Args[0]
|
|
|
|
|
mem := v.Args[0].Args[1]
|
|
|
|
|
idx := v.Args[1]
|
|
|
|
|
v.Op = OpLoad
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
2015-06-11 21:29:25 -07:00
|
|
|
v0 := v.Block.NewValue0(v.Line, OpPtrIndex, TypeInvalid)
|
2015-06-12 11:01:13 -07:00
|
|
|
v0.Type = v.Type.PtrTo()
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.AddArg(ptr)
|
|
|
|
|
v0.AddArg(idx)
|
|
|
|
|
v.AddArg(v0)
|
|
|
|
|
v.AddArg(mem)
|
|
|
|
|
return true
|
|
|
|
|
}
|
2015-06-12 11:01:13 -07:00
|
|
|
goto end4894dd7b58383fee5f8a92be08437c33
|
|
|
|
|
end4894dd7b58383fee5f8a92be08437c33:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
|
|
|
|
case OpConst:
|
2015-06-11 21:29:25 -07:00
|
|
|
// match: (Const <t> {s})
|
2015-06-06 16:03:33 -07:00
|
|
|
// cond: t.IsString()
|
2015-07-19 15:48:20 -07:00
|
|
|
// result: (StringMake (OffPtr <TypeBytePtr> [2*config.PtrSize] (Addr <TypeBytePtr> {config.fe.StringSym(s.(string))} (SB <config.Uintptr>))) (Const <config.Uintptr> [int64(len(s.(string)))]))
|
2015-06-06 16:03:33 -07:00
|
|
|
{
|
|
|
|
|
t := v.Type
|
|
|
|
|
s := v.Aux
|
|
|
|
|
if !(t.IsString()) {
|
2015-07-19 15:48:20 -07:00
|
|
|
goto endedcb8bd24122d6a47bdc9b752460c344
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
v.Op = OpStringMake
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
2015-06-11 21:29:25 -07:00
|
|
|
v0 := v.Block.NewValue0(v.Line, OpOffPtr, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.Type = TypeBytePtr
|
2015-07-19 15:48:20 -07:00
|
|
|
v0.AuxInt = 2 * config.PtrSize
|
2015-06-19 21:02:28 -07:00
|
|
|
v1 := v.Block.NewValue0(v.Line, OpAddr, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v1.Type = TypeBytePtr
|
|
|
|
|
v1.Aux = config.fe.StringSym(s.(string))
|
2015-06-19 21:02:28 -07:00
|
|
|
v2 := v.Block.NewValue0(v.Line, OpSB, TypeInvalid)
|
|
|
|
|
v2.Type = config.Uintptr
|
|
|
|
|
v1.AddArg(v2)
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.AddArg(v1)
|
|
|
|
|
v.AddArg(v0)
|
2015-06-19 21:02:28 -07:00
|
|
|
v3 := v.Block.NewValue0(v.Line, OpConst, TypeInvalid)
|
|
|
|
|
v3.Type = config.Uintptr
|
|
|
|
|
v3.AuxInt = int64(len(s.(string)))
|
|
|
|
|
v.AddArg(v3)
|
2015-06-06 16:03:33 -07:00
|
|
|
return true
|
|
|
|
|
}
|
2015-07-19 15:48:20 -07:00
|
|
|
goto endedcb8bd24122d6a47bdc9b752460c344
|
|
|
|
|
endedcb8bd24122d6a47bdc9b752460c344:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
|
|
|
|
case OpIsInBounds:
|
|
|
|
|
// match: (IsInBounds (Const [c]) (Const [d]))
|
|
|
|
|
// cond:
|
2015-06-11 21:29:25 -07:00
|
|
|
// result: (Const {inBounds(c,d)})
|
2015-06-06 16:03:33 -07:00
|
|
|
{
|
|
|
|
|
if v.Args[0].Op != OpConst {
|
2015-06-11 21:29:25 -07:00
|
|
|
goto enda96ccac78df2d17ae96c8baf2af2e189
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
2015-06-11 21:29:25 -07:00
|
|
|
c := v.Args[0].AuxInt
|
2015-06-06 16:03:33 -07:00
|
|
|
if v.Args[1].Op != OpConst {
|
2015-06-11 21:29:25 -07:00
|
|
|
goto enda96ccac78df2d17ae96c8baf2af2e189
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
2015-06-11 21:29:25 -07:00
|
|
|
d := v.Args[1].AuxInt
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Op = OpConst
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
2015-06-11 21:29:25 -07:00
|
|
|
v.Aux = inBounds(c, d)
|
2015-06-06 16:03:33 -07:00
|
|
|
return true
|
|
|
|
|
}
|
2015-06-11 21:29:25 -07:00
|
|
|
goto enda96ccac78df2d17ae96c8baf2af2e189
|
|
|
|
|
enda96ccac78df2d17ae96c8baf2af2e189:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
|
|
|
|
case OpLoad:
|
|
|
|
|
// match: (Load <t> ptr mem)
|
|
|
|
|
// cond: t.IsString()
|
2015-07-19 15:48:20 -07:00
|
|
|
// result: (StringMake (Load <TypeBytePtr> ptr mem) (Load <config.Uintptr> (OffPtr <TypeBytePtr> [config.PtrSize] ptr) mem))
|
2015-06-06 16:03:33 -07:00
|
|
|
{
|
|
|
|
|
t := v.Type
|
|
|
|
|
ptr := v.Args[0]
|
|
|
|
|
mem := v.Args[1]
|
|
|
|
|
if !(t.IsString()) {
|
2015-07-19 15:48:20 -07:00
|
|
|
goto endce3ba169a57b8a9f6b12751d49b4e23a
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
v.Op = OpStringMake
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
2015-06-11 21:29:25 -07:00
|
|
|
v0 := v.Block.NewValue0(v.Line, OpLoad, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.Type = TypeBytePtr
|
|
|
|
|
v0.AddArg(ptr)
|
|
|
|
|
v0.AddArg(mem)
|
|
|
|
|
v.AddArg(v0)
|
2015-06-11 21:29:25 -07:00
|
|
|
v1 := v.Block.NewValue0(v.Line, OpLoad, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v1.Type = config.Uintptr
|
2015-06-11 21:29:25 -07:00
|
|
|
v2 := v.Block.NewValue0(v.Line, OpOffPtr, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v2.Type = TypeBytePtr
|
2015-07-19 15:48:20 -07:00
|
|
|
v2.AuxInt = config.PtrSize
|
2015-06-06 16:03:33 -07:00
|
|
|
v2.AddArg(ptr)
|
|
|
|
|
v1.AddArg(v2)
|
|
|
|
|
v1.AddArg(mem)
|
|
|
|
|
v.AddArg(v1)
|
|
|
|
|
return true
|
|
|
|
|
}
|
2015-07-19 15:48:20 -07:00
|
|
|
goto endce3ba169a57b8a9f6b12751d49b4e23a
|
|
|
|
|
endce3ba169a57b8a9f6b12751d49b4e23a:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
|
|
|
|
case OpMul:
|
|
|
|
|
// match: (Mul <t> (Const [c]) (Const [d]))
|
|
|
|
|
// cond: is64BitInt(t)
|
2015-06-11 21:29:25 -07:00
|
|
|
// result: (Const [c*d])
|
2015-06-06 16:03:33 -07:00
|
|
|
{
|
|
|
|
|
t := v.Type
|
|
|
|
|
if v.Args[0].Op != OpConst {
|
2015-06-11 21:29:25 -07:00
|
|
|
goto endd82095c6a872974522d33aaff1ee07be
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
2015-06-11 21:29:25 -07:00
|
|
|
c := v.Args[0].AuxInt
|
2015-06-06 16:03:33 -07:00
|
|
|
if v.Args[1].Op != OpConst {
|
2015-06-11 21:29:25 -07:00
|
|
|
goto endd82095c6a872974522d33aaff1ee07be
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
2015-06-11 21:29:25 -07:00
|
|
|
d := v.Args[1].AuxInt
|
2015-06-06 16:03:33 -07:00
|
|
|
if !(is64BitInt(t)) {
|
2015-06-11 21:29:25 -07:00
|
|
|
goto endd82095c6a872974522d33aaff1ee07be
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
v.Op = OpConst
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = c * d
|
2015-06-06 16:03:33 -07:00
|
|
|
return true
|
|
|
|
|
}
|
2015-06-11 21:29:25 -07:00
|
|
|
goto endd82095c6a872974522d33aaff1ee07be
|
|
|
|
|
endd82095c6a872974522d33aaff1ee07be:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
|
|
|
|
case OpPtrIndex:
|
|
|
|
|
// match: (PtrIndex <t> ptr idx)
|
|
|
|
|
// cond:
|
2015-07-19 15:48:20 -07:00
|
|
|
// result: (AddPtr ptr (Mul <config.Uintptr> idx (Const <config.Uintptr> [t.Elem().Size()])))
|
2015-06-06 16:03:33 -07:00
|
|
|
{
|
|
|
|
|
t := v.Type
|
|
|
|
|
ptr := v.Args[0]
|
|
|
|
|
idx := v.Args[1]
|
2015-07-19 15:48:20 -07:00
|
|
|
v.Op = OpAddPtr
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
|
|
|
|
v.AddArg(ptr)
|
2015-06-11 21:29:25 -07:00
|
|
|
v0 := v.Block.NewValue0(v.Line, OpMul, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.Type = config.Uintptr
|
|
|
|
|
v0.AddArg(idx)
|
2015-06-11 21:29:25 -07:00
|
|
|
v1 := v.Block.NewValue0(v.Line, OpConst, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v1.Type = config.Uintptr
|
2015-06-11 21:29:25 -07:00
|
|
|
v1.AuxInt = t.Elem().Size()
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.AddArg(v1)
|
|
|
|
|
v.AddArg(v0)
|
|
|
|
|
return true
|
|
|
|
|
}
|
2015-07-19 15:48:20 -07:00
|
|
|
goto endc181347cd3c740e2a1da431a981fdd7e
|
|
|
|
|
endc181347cd3c740e2a1da431a981fdd7e:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
|
|
|
|
case OpSliceCap:
|
|
|
|
|
// match: (SliceCap (Load ptr mem))
|
|
|
|
|
// cond:
|
2015-07-19 15:48:20 -07:00
|
|
|
// result: (Load (AddPtr <ptr.Type> ptr (Const <config.Uintptr> [config.PtrSize*2])) mem)
|
2015-06-06 16:03:33 -07:00
|
|
|
{
|
|
|
|
|
if v.Args[0].Op != OpLoad {
|
2015-07-19 15:48:20 -07:00
|
|
|
goto end83c0ff7760465a4184bad9e4b47f7be8
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
ptr := v.Args[0].Args[0]
|
|
|
|
|
mem := v.Args[0].Args[1]
|
|
|
|
|
v.Op = OpLoad
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
2015-07-19 15:48:20 -07:00
|
|
|
v0 := v.Block.NewValue0(v.Line, OpAddPtr, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.Type = ptr.Type
|
|
|
|
|
v0.AddArg(ptr)
|
2015-06-11 21:29:25 -07:00
|
|
|
v1 := v.Block.NewValue0(v.Line, OpConst, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v1.Type = config.Uintptr
|
2015-07-19 15:48:20 -07:00
|
|
|
v1.AuxInt = config.PtrSize * 2
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.AddArg(v1)
|
|
|
|
|
v.AddArg(v0)
|
|
|
|
|
v.AddArg(mem)
|
|
|
|
|
return true
|
|
|
|
|
}
|
2015-07-19 15:48:20 -07:00
|
|
|
goto end83c0ff7760465a4184bad9e4b47f7be8
|
|
|
|
|
end83c0ff7760465a4184bad9e4b47f7be8:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
|
|
|
|
case OpSliceLen:
|
|
|
|
|
// match: (SliceLen (Load ptr mem))
|
|
|
|
|
// cond:
|
2015-07-19 15:48:20 -07:00
|
|
|
// result: (Load (AddPtr <ptr.Type> ptr (Const <config.Uintptr> [config.PtrSize])) mem)
|
2015-06-06 16:03:33 -07:00
|
|
|
{
|
|
|
|
|
if v.Args[0].Op != OpLoad {
|
2015-07-19 15:48:20 -07:00
|
|
|
goto end20579b262d017d875d579683996f0ef9
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
ptr := v.Args[0].Args[0]
|
|
|
|
|
mem := v.Args[0].Args[1]
|
|
|
|
|
v.Op = OpLoad
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
2015-07-19 15:48:20 -07:00
|
|
|
v0 := v.Block.NewValue0(v.Line, OpAddPtr, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.Type = ptr.Type
|
|
|
|
|
v0.AddArg(ptr)
|
2015-06-11 21:29:25 -07:00
|
|
|
v1 := v.Block.NewValue0(v.Line, OpConst, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v1.Type = config.Uintptr
|
2015-07-19 15:48:20 -07:00
|
|
|
v1.AuxInt = config.PtrSize
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.AddArg(v1)
|
|
|
|
|
v.AddArg(v0)
|
|
|
|
|
v.AddArg(mem)
|
|
|
|
|
return true
|
|
|
|
|
}
|
2015-07-19 15:48:20 -07:00
|
|
|
goto end20579b262d017d875d579683996f0ef9
|
|
|
|
|
end20579b262d017d875d579683996f0ef9:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
|
|
|
|
case OpSlicePtr:
|
|
|
|
|
// match: (SlicePtr (Load ptr mem))
|
|
|
|
|
// cond:
|
|
|
|
|
// result: (Load ptr mem)
|
|
|
|
|
{
|
|
|
|
|
if v.Args[0].Op != OpLoad {
|
|
|
|
|
goto end459613b83f95b65729d45c2ed663a153
|
|
|
|
|
}
|
|
|
|
|
ptr := v.Args[0].Args[0]
|
|
|
|
|
mem := v.Args[0].Args[1]
|
|
|
|
|
v.Op = OpLoad
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
|
|
|
|
v.AddArg(ptr)
|
|
|
|
|
v.AddArg(mem)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
goto end459613b83f95b65729d45c2ed663a153
|
|
|
|
|
end459613b83f95b65729d45c2ed663a153:
|
|
|
|
|
;
|
|
|
|
|
case OpStore:
|
|
|
|
|
// match: (Store dst (Load <t> src mem) mem)
|
|
|
|
|
// cond: t.Size() > 8
|
|
|
|
|
// result: (Move [t.Size()] dst src mem)
|
|
|
|
|
{
|
|
|
|
|
dst := v.Args[0]
|
|
|
|
|
if v.Args[1].Op != OpLoad {
|
|
|
|
|
goto end324ffb6d2771808da4267f62c854e9c8
|
|
|
|
|
}
|
|
|
|
|
t := v.Args[1].Type
|
|
|
|
|
src := v.Args[1].Args[0]
|
|
|
|
|
mem := v.Args[1].Args[1]
|
|
|
|
|
if v.Args[2] != v.Args[1].Args[1] {
|
|
|
|
|
goto end324ffb6d2771808da4267f62c854e9c8
|
|
|
|
|
}
|
|
|
|
|
if !(t.Size() > 8) {
|
|
|
|
|
goto end324ffb6d2771808da4267f62c854e9c8
|
|
|
|
|
}
|
|
|
|
|
v.Op = OpMove
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = t.Size()
|
2015-06-06 16:03:33 -07:00
|
|
|
v.AddArg(dst)
|
|
|
|
|
v.AddArg(src)
|
|
|
|
|
v.AddArg(mem)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
goto end324ffb6d2771808da4267f62c854e9c8
|
|
|
|
|
end324ffb6d2771808da4267f62c854e9c8:
|
|
|
|
|
;
|
|
|
|
|
// match: (Store dst str mem)
|
|
|
|
|
// cond: str.Type.IsString()
|
2015-07-19 15:48:20 -07:00
|
|
|
// result: (Store (OffPtr <TypeBytePtr> [config.PtrSize] dst) (StringLen <config.Uintptr> str) (Store <TypeMem> dst (StringPtr <TypeBytePtr> str) mem))
|
2015-06-06 16:03:33 -07:00
|
|
|
{
|
|
|
|
|
dst := v.Args[0]
|
|
|
|
|
str := v.Args[1]
|
|
|
|
|
mem := v.Args[2]
|
|
|
|
|
if !(str.Type.IsString()) {
|
2015-07-19 15:48:20 -07:00
|
|
|
goto endb47e037c1e5ac54c3a41d53163d8aef6
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
v.Op = OpStore
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = 0
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
2015-06-11 21:29:25 -07:00
|
|
|
v0 := v.Block.NewValue0(v.Line, OpOffPtr, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.Type = TypeBytePtr
|
2015-07-19 15:48:20 -07:00
|
|
|
v0.AuxInt = config.PtrSize
|
2015-06-06 16:03:33 -07:00
|
|
|
v0.AddArg(dst)
|
|
|
|
|
v.AddArg(v0)
|
2015-06-11 21:29:25 -07:00
|
|
|
v1 := v.Block.NewValue0(v.Line, OpStringLen, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v1.Type = config.Uintptr
|
|
|
|
|
v1.AddArg(str)
|
|
|
|
|
v.AddArg(v1)
|
2015-06-11 21:29:25 -07:00
|
|
|
v2 := v.Block.NewValue0(v.Line, OpStore, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v2.Type = TypeMem
|
|
|
|
|
v2.AddArg(dst)
|
2015-06-11 21:29:25 -07:00
|
|
|
v3 := v.Block.NewValue0(v.Line, OpStringPtr, TypeInvalid)
|
2015-06-06 16:03:33 -07:00
|
|
|
v3.Type = TypeBytePtr
|
|
|
|
|
v3.AddArg(str)
|
|
|
|
|
v2.AddArg(v3)
|
|
|
|
|
v2.AddArg(mem)
|
|
|
|
|
v.AddArg(v2)
|
|
|
|
|
return true
|
|
|
|
|
}
|
2015-07-19 15:48:20 -07:00
|
|
|
goto endb47e037c1e5ac54c3a41d53163d8aef6
|
|
|
|
|
endb47e037c1e5ac54c3a41d53163d8aef6:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
|
|
|
|
case OpStringLen:
|
|
|
|
|
// match: (StringLen (StringMake _ len))
|
|
|
|
|
// cond:
|
|
|
|
|
// result: len
|
|
|
|
|
{
|
|
|
|
|
if v.Args[0].Op != OpStringMake {
|
|
|
|
|
goto end0d922460b7e5ca88324034f4bd6c027c
|
|
|
|
|
}
|
|
|
|
|
len := v.Args[0].Args[1]
|
|
|
|
|
v.Op = len.Op
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = len.AuxInt
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = len.Aux
|
|
|
|
|
v.resetArgs()
|
|
|
|
|
v.AddArgs(len.Args...)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
goto end0d922460b7e5ca88324034f4bd6c027c
|
|
|
|
|
end0d922460b7e5ca88324034f4bd6c027c:
|
|
|
|
|
;
|
|
|
|
|
case OpStringPtr:
|
|
|
|
|
// match: (StringPtr (StringMake ptr _))
|
|
|
|
|
// cond:
|
|
|
|
|
// result: ptr
|
|
|
|
|
{
|
|
|
|
|
if v.Args[0].Op != OpStringMake {
|
|
|
|
|
goto end061edc5d85c73ad909089af2556d9380
|
|
|
|
|
}
|
|
|
|
|
ptr := v.Args[0].Args[0]
|
|
|
|
|
v.Op = ptr.Op
|
2015-06-11 21:29:25 -07:00
|
|
|
v.AuxInt = ptr.AuxInt
|
2015-06-06 16:03:33 -07:00
|
|
|
v.Aux = ptr.Aux
|
|
|
|
|
v.resetArgs()
|
|
|
|
|
v.AddArgs(ptr.Args...)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
goto end061edc5d85c73ad909089af2556d9380
|
|
|
|
|
end061edc5d85c73ad909089af2556d9380:
|
2015-07-15 21:33:49 -07:00
|
|
|
;
|
|
|
|
|
case OpStructSelect:
|
|
|
|
|
// match: (StructSelect [idx] (Load ptr mem))
|
|
|
|
|
// cond:
|
|
|
|
|
// result: (Load (OffPtr <v.Type.PtrTo()> [idx] ptr) mem)
|
|
|
|
|
{
|
|
|
|
|
idx := v.AuxInt
|
|
|
|
|
if v.Args[0].Op != OpLoad {
|
|
|
|
|
goto end16fdb45e1dd08feb36e3cc3fb5ed8935
|
|
|
|
|
}
|
|
|
|
|
ptr := v.Args[0].Args[0]
|
|
|
|
|
mem := v.Args[0].Args[1]
|
|
|
|
|
v.Op = OpLoad
|
|
|
|
|
v.AuxInt = 0
|
|
|
|
|
v.Aux = nil
|
|
|
|
|
v.resetArgs()
|
|
|
|
|
v0 := v.Block.NewValue0(v.Line, OpOffPtr, TypeInvalid)
|
|
|
|
|
v0.Type = v.Type.PtrTo()
|
|
|
|
|
v0.AuxInt = idx
|
|
|
|
|
v0.AddArg(ptr)
|
|
|
|
|
v.AddArg(v0)
|
|
|
|
|
v.AddArg(mem)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
goto end16fdb45e1dd08feb36e3cc3fb5ed8935
|
|
|
|
|
end16fdb45e1dd08feb36e3cc3fb5ed8935:
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
func rewriteBlockgeneric(b *Block) bool {
|
|
|
|
|
switch b.Kind {
|
|
|
|
|
case BlockIf:
|
2015-06-11 21:29:25 -07:00
|
|
|
// match: (If (Const {c}) yes no)
|
2015-06-06 16:03:33 -07:00
|
|
|
// cond: c.(bool)
|
|
|
|
|
// result: (Plain nil yes)
|
|
|
|
|
{
|
|
|
|
|
v := b.Control
|
|
|
|
|
if v.Op != OpConst {
|
2015-06-11 21:29:25 -07:00
|
|
|
goto end915e334b6388fed7d63e09aa69ecb05c
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
c := v.Aux
|
|
|
|
|
yes := b.Succs[0]
|
|
|
|
|
no := b.Succs[1]
|
|
|
|
|
if !(c.(bool)) {
|
2015-06-11 21:29:25 -07:00
|
|
|
goto end915e334b6388fed7d63e09aa69ecb05c
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
2015-07-06 14:13:17 -07:00
|
|
|
v.Block.Func.removePredecessor(b, no)
|
2015-06-06 16:03:33 -07:00
|
|
|
b.Kind = BlockPlain
|
|
|
|
|
b.Control = nil
|
|
|
|
|
b.Succs = b.Succs[:1]
|
|
|
|
|
b.Succs[0] = yes
|
|
|
|
|
return true
|
|
|
|
|
}
|
2015-06-11 21:29:25 -07:00
|
|
|
goto end915e334b6388fed7d63e09aa69ecb05c
|
|
|
|
|
end915e334b6388fed7d63e09aa69ecb05c:
|
2015-06-06 16:03:33 -07:00
|
|
|
;
|
2015-06-11 21:29:25 -07:00
|
|
|
// match: (If (Const {c}) yes no)
|
2015-06-06 16:03:33 -07:00
|
|
|
// cond: !c.(bool)
|
|
|
|
|
// result: (Plain nil no)
|
|
|
|
|
{
|
|
|
|
|
v := b.Control
|
|
|
|
|
if v.Op != OpConst {
|
2015-06-11 21:29:25 -07:00
|
|
|
goto end6452ee3a5bb02c708bddc3181c3ea3cb
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
c := v.Aux
|
|
|
|
|
yes := b.Succs[0]
|
|
|
|
|
no := b.Succs[1]
|
|
|
|
|
if !(!c.(bool)) {
|
2015-06-11 21:29:25 -07:00
|
|
|
goto end6452ee3a5bb02c708bddc3181c3ea3cb
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
2015-07-06 14:13:17 -07:00
|
|
|
v.Block.Func.removePredecessor(b, yes)
|
2015-06-06 16:03:33 -07:00
|
|
|
b.Kind = BlockPlain
|
|
|
|
|
b.Control = nil
|
|
|
|
|
b.Succs = b.Succs[:1]
|
|
|
|
|
b.Succs[0] = no
|
|
|
|
|
return true
|
|
|
|
|
}
|
2015-06-11 21:29:25 -07:00
|
|
|
goto end6452ee3a5bb02c708bddc3181c3ea3cb
|
|
|
|
|
end6452ee3a5bb02c708bddc3181c3ea3cb:
|
2015-06-06 16:03:33 -07:00
|
|
|
}
|
|
|
|
|
return false
|
|
|
|
|
}
|