// Code generated from _gen/dec.rules; DO NOT EDIT. // generated with: cd _gen; go run . 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 ptr mem) // cond: t.IsComplex() && t.Size() == 8 // result: (ComplexMake (Load ptr mem) (Load (OffPtr [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 ptr mem) // cond: t.IsComplex() && t.Size() == 16 // result: (ComplexMake (Load ptr mem) (Load (OffPtr [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 ptr mem) // cond: t.IsString() // result: (StringMake (Load ptr mem) (Load (OffPtr [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 ptr mem) // cond: t.IsSlice() // result: (SliceMake (Load ptr mem) (Load (OffPtr [config.PtrSize] ptr) mem) (Load (OffPtr [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 ptr mem) // cond: t.IsInterface() // result: (IMake (Load ptr mem) (Load (OffPtr [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 [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 [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 [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 [2*config.PtrSize] dst) cap (Store {typ.Int} (OffPtr [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 [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 }