|  | // Code generated from gen/dec.rules; DO NOT EDIT. | 
|  | // generated with: cd gen; go run *.go | 
|  |  | 
|  | package ssa | 
|  |  | 
|  | import "cmd/compile/internal/types" | 
|  |  | 
|  | func rewriteValuedec(v *Value) bool { | 
|  | switch v.Op { | 
|  | case OpComplexImag: | 
|  | return rewriteValuedec_OpComplexImag(v) | 
|  | case OpComplexReal: | 
|  | return rewriteValuedec_OpComplexReal(v) | 
|  | case OpIData: | 
|  | return rewriteValuedec_OpIData(v) | 
|  | case OpITab: | 
|  | return rewriteValuedec_OpITab(v) | 
|  | case OpLoad: | 
|  | return rewriteValuedec_OpLoad(v) | 
|  | case OpSliceCap: | 
|  | return rewriteValuedec_OpSliceCap(v) | 
|  | case OpSliceLen: | 
|  | return rewriteValuedec_OpSliceLen(v) | 
|  | case OpSlicePtr: | 
|  | return rewriteValuedec_OpSlicePtr(v) | 
|  | case OpSlicePtrUnchecked: | 
|  | return rewriteValuedec_OpSlicePtrUnchecked(v) | 
|  | case OpStore: | 
|  | return rewriteValuedec_OpStore(v) | 
|  | case OpStringLen: | 
|  | return rewriteValuedec_OpStringLen(v) | 
|  | case OpStringPtr: | 
|  | return rewriteValuedec_OpStringPtr(v) | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpComplexImag(v *Value) bool { | 
|  | v_0 := v.Args[0] | 
|  | // match: (ComplexImag (ComplexMake _ imag )) | 
|  | // result: imag | 
|  | for { | 
|  | if v_0.Op != OpComplexMake { | 
|  | break | 
|  | } | 
|  | imag := v_0.Args[1] | 
|  | v.copyOf(imag) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpComplexReal(v *Value) bool { | 
|  | v_0 := v.Args[0] | 
|  | // match: (ComplexReal (ComplexMake real _ )) | 
|  | // result: real | 
|  | for { | 
|  | if v_0.Op != OpComplexMake { | 
|  | break | 
|  | } | 
|  | real := v_0.Args[0] | 
|  | v.copyOf(real) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpIData(v *Value) bool { | 
|  | v_0 := v.Args[0] | 
|  | // match: (IData (IMake _ data)) | 
|  | // result: data | 
|  | for { | 
|  | if v_0.Op != OpIMake { | 
|  | break | 
|  | } | 
|  | data := v_0.Args[1] | 
|  | v.copyOf(data) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpITab(v *Value) bool { | 
|  | v_0 := v.Args[0] | 
|  | // match: (ITab (IMake itab _)) | 
|  | // result: itab | 
|  | for { | 
|  | if v_0.Op != OpIMake { | 
|  | break | 
|  | } | 
|  | itab := v_0.Args[0] | 
|  | v.copyOf(itab) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpLoad(v *Value) bool { | 
|  | v_1 := v.Args[1] | 
|  | v_0 := v.Args[0] | 
|  | b := v.Block | 
|  | config := b.Func.Config | 
|  | typ := &b.Func.Config.Types | 
|  | // match: (Load <t> ptr mem) | 
|  | // cond: t.IsComplex() && t.Size() == 8 | 
|  | // result: (ComplexMake (Load <typ.Float32> ptr mem) (Load <typ.Float32> (OffPtr <typ.Float32Ptr> [4] ptr) mem) ) | 
|  | for { | 
|  | t := v.Type | 
|  | ptr := v_0 | 
|  | mem := v_1 | 
|  | if !(t.IsComplex() && t.Size() == 8) { | 
|  | break | 
|  | } | 
|  | v.reset(OpComplexMake) | 
|  | v0 := b.NewValue0(v.Pos, OpLoad, typ.Float32) | 
|  | v0.AddArg2(ptr, mem) | 
|  | v1 := b.NewValue0(v.Pos, OpLoad, typ.Float32) | 
|  | v2 := b.NewValue0(v.Pos, OpOffPtr, typ.Float32Ptr) | 
|  | v2.AuxInt = int64ToAuxInt(4) | 
|  | v2.AddArg(ptr) | 
|  | v1.AddArg2(v2, mem) | 
|  | v.AddArg2(v0, v1) | 
|  | return true | 
|  | } | 
|  | // match: (Load <t> ptr mem) | 
|  | // cond: t.IsComplex() && t.Size() == 16 | 
|  | // result: (ComplexMake (Load <typ.Float64> ptr mem) (Load <typ.Float64> (OffPtr <typ.Float64Ptr> [8] ptr) mem) ) | 
|  | for { | 
|  | t := v.Type | 
|  | ptr := v_0 | 
|  | mem := v_1 | 
|  | if !(t.IsComplex() && t.Size() == 16) { | 
|  | break | 
|  | } | 
|  | v.reset(OpComplexMake) | 
|  | v0 := b.NewValue0(v.Pos, OpLoad, typ.Float64) | 
|  | v0.AddArg2(ptr, mem) | 
|  | v1 := b.NewValue0(v.Pos, OpLoad, typ.Float64) | 
|  | v2 := b.NewValue0(v.Pos, OpOffPtr, typ.Float64Ptr) | 
|  | v2.AuxInt = int64ToAuxInt(8) | 
|  | v2.AddArg(ptr) | 
|  | v1.AddArg2(v2, mem) | 
|  | v.AddArg2(v0, v1) | 
|  | return true | 
|  | } | 
|  | // match: (Load <t> ptr mem) | 
|  | // cond: t.IsString() | 
|  | // result: (StringMake (Load <typ.BytePtr> ptr mem) (Load <typ.Int> (OffPtr <typ.IntPtr> [config.PtrSize] ptr) mem)) | 
|  | for { | 
|  | t := v.Type | 
|  | ptr := v_0 | 
|  | mem := v_1 | 
|  | if !(t.IsString()) { | 
|  | break | 
|  | } | 
|  | v.reset(OpStringMake) | 
|  | v0 := b.NewValue0(v.Pos, OpLoad, typ.BytePtr) | 
|  | v0.AddArg2(ptr, mem) | 
|  | v1 := b.NewValue0(v.Pos, OpLoad, typ.Int) | 
|  | v2 := b.NewValue0(v.Pos, OpOffPtr, typ.IntPtr) | 
|  | v2.AuxInt = int64ToAuxInt(config.PtrSize) | 
|  | v2.AddArg(ptr) | 
|  | v1.AddArg2(v2, mem) | 
|  | v.AddArg2(v0, v1) | 
|  | return true | 
|  | } | 
|  | // match: (Load <t> ptr mem) | 
|  | // cond: t.IsSlice() | 
|  | // result: (SliceMake (Load <t.Elem().PtrTo()> ptr mem) (Load <typ.Int> (OffPtr <typ.IntPtr> [config.PtrSize] ptr) mem) (Load <typ.Int> (OffPtr <typ.IntPtr> [2*config.PtrSize] ptr) mem)) | 
|  | for { | 
|  | t := v.Type | 
|  | ptr := v_0 | 
|  | mem := v_1 | 
|  | if !(t.IsSlice()) { | 
|  | break | 
|  | } | 
|  | v.reset(OpSliceMake) | 
|  | v0 := b.NewValue0(v.Pos, OpLoad, t.Elem().PtrTo()) | 
|  | v0.AddArg2(ptr, mem) | 
|  | v1 := b.NewValue0(v.Pos, OpLoad, typ.Int) | 
|  | v2 := b.NewValue0(v.Pos, OpOffPtr, typ.IntPtr) | 
|  | v2.AuxInt = int64ToAuxInt(config.PtrSize) | 
|  | v2.AddArg(ptr) | 
|  | v1.AddArg2(v2, mem) | 
|  | v3 := b.NewValue0(v.Pos, OpLoad, typ.Int) | 
|  | v4 := b.NewValue0(v.Pos, OpOffPtr, typ.IntPtr) | 
|  | v4.AuxInt = int64ToAuxInt(2 * config.PtrSize) | 
|  | v4.AddArg(ptr) | 
|  | v3.AddArg2(v4, mem) | 
|  | v.AddArg3(v0, v1, v3) | 
|  | return true | 
|  | } | 
|  | // match: (Load <t> ptr mem) | 
|  | // cond: t.IsInterface() | 
|  | // result: (IMake (Load <typ.Uintptr> ptr mem) (Load <typ.BytePtr> (OffPtr <typ.BytePtrPtr> [config.PtrSize] ptr) mem)) | 
|  | for { | 
|  | t := v.Type | 
|  | ptr := v_0 | 
|  | mem := v_1 | 
|  | if !(t.IsInterface()) { | 
|  | break | 
|  | } | 
|  | v.reset(OpIMake) | 
|  | v0 := b.NewValue0(v.Pos, OpLoad, typ.Uintptr) | 
|  | v0.AddArg2(ptr, mem) | 
|  | v1 := b.NewValue0(v.Pos, OpLoad, typ.BytePtr) | 
|  | v2 := b.NewValue0(v.Pos, OpOffPtr, typ.BytePtrPtr) | 
|  | v2.AuxInt = int64ToAuxInt(config.PtrSize) | 
|  | v2.AddArg(ptr) | 
|  | v1.AddArg2(v2, mem) | 
|  | v.AddArg2(v0, v1) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpSliceCap(v *Value) bool { | 
|  | v_0 := v.Args[0] | 
|  | // match: (SliceCap (SliceMake _ _ cap)) | 
|  | // result: cap | 
|  | for { | 
|  | if v_0.Op != OpSliceMake { | 
|  | break | 
|  | } | 
|  | cap := v_0.Args[2] | 
|  | v.copyOf(cap) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpSliceLen(v *Value) bool { | 
|  | v_0 := v.Args[0] | 
|  | // match: (SliceLen (SliceMake _ len _)) | 
|  | // result: len | 
|  | for { | 
|  | if v_0.Op != OpSliceMake { | 
|  | break | 
|  | } | 
|  | len := v_0.Args[1] | 
|  | v.copyOf(len) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpSlicePtr(v *Value) bool { | 
|  | v_0 := v.Args[0] | 
|  | // match: (SlicePtr (SliceMake ptr _ _ )) | 
|  | // result: ptr | 
|  | for { | 
|  | if v_0.Op != OpSliceMake { | 
|  | break | 
|  | } | 
|  | ptr := v_0.Args[0] | 
|  | v.copyOf(ptr) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpSlicePtrUnchecked(v *Value) bool { | 
|  | v_0 := v.Args[0] | 
|  | // match: (SlicePtrUnchecked (SliceMake ptr _ _ )) | 
|  | // result: ptr | 
|  | for { | 
|  | if v_0.Op != OpSliceMake { | 
|  | break | 
|  | } | 
|  | ptr := v_0.Args[0] | 
|  | v.copyOf(ptr) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpStore(v *Value) bool { | 
|  | v_2 := v.Args[2] | 
|  | v_1 := v.Args[1] | 
|  | v_0 := v.Args[0] | 
|  | b := v.Block | 
|  | config := b.Func.Config | 
|  | typ := &b.Func.Config.Types | 
|  | // match: (Store {t} dst (ComplexMake real imag) mem) | 
|  | // cond: t.Size() == 8 | 
|  | // result: (Store {typ.Float32} (OffPtr <typ.Float32Ptr> [4] dst) imag (Store {typ.Float32} dst real mem)) | 
|  | for { | 
|  | t := auxToType(v.Aux) | 
|  | dst := v_0 | 
|  | if v_1.Op != OpComplexMake { | 
|  | break | 
|  | } | 
|  | imag := v_1.Args[1] | 
|  | real := v_1.Args[0] | 
|  | mem := v_2 | 
|  | if !(t.Size() == 8) { | 
|  | break | 
|  | } | 
|  | v.reset(OpStore) | 
|  | v.Aux = typeToAux(typ.Float32) | 
|  | v0 := b.NewValue0(v.Pos, OpOffPtr, typ.Float32Ptr) | 
|  | v0.AuxInt = int64ToAuxInt(4) | 
|  | v0.AddArg(dst) | 
|  | v1 := b.NewValue0(v.Pos, OpStore, types.TypeMem) | 
|  | v1.Aux = typeToAux(typ.Float32) | 
|  | v1.AddArg3(dst, real, mem) | 
|  | v.AddArg3(v0, imag, v1) | 
|  | return true | 
|  | } | 
|  | // match: (Store {t} dst (ComplexMake real imag) mem) | 
|  | // cond: t.Size() == 16 | 
|  | // result: (Store {typ.Float64} (OffPtr <typ.Float64Ptr> [8] dst) imag (Store {typ.Float64} dst real mem)) | 
|  | for { | 
|  | t := auxToType(v.Aux) | 
|  | dst := v_0 | 
|  | if v_1.Op != OpComplexMake { | 
|  | break | 
|  | } | 
|  | imag := v_1.Args[1] | 
|  | real := v_1.Args[0] | 
|  | mem := v_2 | 
|  | if !(t.Size() == 16) { | 
|  | break | 
|  | } | 
|  | v.reset(OpStore) | 
|  | v.Aux = typeToAux(typ.Float64) | 
|  | v0 := b.NewValue0(v.Pos, OpOffPtr, typ.Float64Ptr) | 
|  | v0.AuxInt = int64ToAuxInt(8) | 
|  | v0.AddArg(dst) | 
|  | v1 := b.NewValue0(v.Pos, OpStore, types.TypeMem) | 
|  | v1.Aux = typeToAux(typ.Float64) | 
|  | v1.AddArg3(dst, real, mem) | 
|  | v.AddArg3(v0, imag, v1) | 
|  | return true | 
|  | } | 
|  | // match: (Store dst (StringMake ptr len) mem) | 
|  | // result: (Store {typ.Int} (OffPtr <typ.IntPtr> [config.PtrSize] dst) len (Store {typ.BytePtr} dst ptr mem)) | 
|  | for { | 
|  | dst := v_0 | 
|  | if v_1.Op != OpStringMake { | 
|  | break | 
|  | } | 
|  | len := v_1.Args[1] | 
|  | ptr := v_1.Args[0] | 
|  | mem := v_2 | 
|  | v.reset(OpStore) | 
|  | v.Aux = typeToAux(typ.Int) | 
|  | v0 := b.NewValue0(v.Pos, OpOffPtr, typ.IntPtr) | 
|  | v0.AuxInt = int64ToAuxInt(config.PtrSize) | 
|  | v0.AddArg(dst) | 
|  | v1 := b.NewValue0(v.Pos, OpStore, types.TypeMem) | 
|  | v1.Aux = typeToAux(typ.BytePtr) | 
|  | v1.AddArg3(dst, ptr, mem) | 
|  | v.AddArg3(v0, len, v1) | 
|  | return true | 
|  | } | 
|  | // match: (Store {t} dst (SliceMake ptr len cap) mem) | 
|  | // result: (Store {typ.Int} (OffPtr <typ.IntPtr> [2*config.PtrSize] dst) cap (Store {typ.Int} (OffPtr <typ.IntPtr> [config.PtrSize] dst) len (Store {t.Elem().PtrTo()} dst ptr mem))) | 
|  | for { | 
|  | t := auxToType(v.Aux) | 
|  | dst := v_0 | 
|  | if v_1.Op != OpSliceMake { | 
|  | break | 
|  | } | 
|  | cap := v_1.Args[2] | 
|  | ptr := v_1.Args[0] | 
|  | len := v_1.Args[1] | 
|  | mem := v_2 | 
|  | v.reset(OpStore) | 
|  | v.Aux = typeToAux(typ.Int) | 
|  | v0 := b.NewValue0(v.Pos, OpOffPtr, typ.IntPtr) | 
|  | v0.AuxInt = int64ToAuxInt(2 * config.PtrSize) | 
|  | v0.AddArg(dst) | 
|  | v1 := b.NewValue0(v.Pos, OpStore, types.TypeMem) | 
|  | v1.Aux = typeToAux(typ.Int) | 
|  | v2 := b.NewValue0(v.Pos, OpOffPtr, typ.IntPtr) | 
|  | v2.AuxInt = int64ToAuxInt(config.PtrSize) | 
|  | v2.AddArg(dst) | 
|  | v3 := b.NewValue0(v.Pos, OpStore, types.TypeMem) | 
|  | v3.Aux = typeToAux(t.Elem().PtrTo()) | 
|  | v3.AddArg3(dst, ptr, mem) | 
|  | v1.AddArg3(v2, len, v3) | 
|  | v.AddArg3(v0, cap, v1) | 
|  | return true | 
|  | } | 
|  | // match: (Store dst (IMake itab data) mem) | 
|  | // result: (Store {typ.BytePtr} (OffPtr <typ.BytePtrPtr> [config.PtrSize] dst) data (Store {typ.Uintptr} dst itab mem)) | 
|  | for { | 
|  | dst := v_0 | 
|  | if v_1.Op != OpIMake { | 
|  | break | 
|  | } | 
|  | data := v_1.Args[1] | 
|  | itab := v_1.Args[0] | 
|  | mem := v_2 | 
|  | v.reset(OpStore) | 
|  | v.Aux = typeToAux(typ.BytePtr) | 
|  | v0 := b.NewValue0(v.Pos, OpOffPtr, typ.BytePtrPtr) | 
|  | v0.AuxInt = int64ToAuxInt(config.PtrSize) | 
|  | v0.AddArg(dst) | 
|  | v1 := b.NewValue0(v.Pos, OpStore, types.TypeMem) | 
|  | v1.Aux = typeToAux(typ.Uintptr) | 
|  | v1.AddArg3(dst, itab, mem) | 
|  | v.AddArg3(v0, data, v1) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpStringLen(v *Value) bool { | 
|  | v_0 := v.Args[0] | 
|  | // match: (StringLen (StringMake _ len)) | 
|  | // result: len | 
|  | for { | 
|  | if v_0.Op != OpStringMake { | 
|  | break | 
|  | } | 
|  | len := v_0.Args[1] | 
|  | v.copyOf(len) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteValuedec_OpStringPtr(v *Value) bool { | 
|  | v_0 := v.Args[0] | 
|  | // match: (StringPtr (StringMake ptr _)) | 
|  | // result: ptr | 
|  | for { | 
|  | if v_0.Op != OpStringMake { | 
|  | break | 
|  | } | 
|  | ptr := v_0.Args[0] | 
|  | v.copyOf(ptr) | 
|  | return true | 
|  | } | 
|  | return false | 
|  | } | 
|  | func rewriteBlockdec(b *Block) bool { | 
|  | return false | 
|  | } |