mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
in progress; doesn't fully work until they are also passed on register on the caller side. For #40724. Change-Id: I29a6680e60bdbe9d132782530214f2a2b51fb8f6 Reviewed-on: https://go-review.googlesource.com/c/go/+/293394 Trust: David Chase <drchase@google.com> Run-TryBot: David Chase <drchase@google.com> Reviewed-by: Cherry Zhang <cherryyz@google.com>
43 lines
1.4 KiB
Go
43 lines
1.4 KiB
Go
// Copyright 2015 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 ssa
|
|
|
|
// convert to machine-dependent ops
|
|
func lower(f *Func) {
|
|
// repeat rewrites until we find no more rewrites
|
|
applyRewrite(f, f.Config.lowerBlock, f.Config.lowerValue, removeDeadValues)
|
|
}
|
|
|
|
// checkLower checks for unlowered opcodes and fails if we find one.
|
|
func checkLower(f *Func) {
|
|
// Needs to be a separate phase because it must run after both
|
|
// lowering and a subsequent dead code elimination (because lowering
|
|
// rules may leave dead generic ops behind).
|
|
for _, b := range f.Blocks {
|
|
for _, v := range b.Values {
|
|
if !opcodeTable[v.Op].generic {
|
|
continue // lowered
|
|
}
|
|
switch v.Op {
|
|
case OpSP, OpSB, OpInitMem, OpArg, OpArgIntReg, OpArgFloatReg, OpPhi, OpVarDef, OpVarKill, OpVarLive, OpKeepAlive, OpSelect0, OpSelect1, OpSelectN, OpConvert, OpInlMark:
|
|
continue // ok not to lower
|
|
case OpMakeResult:
|
|
if len(b.Controls) == 1 && b.Controls[0] == v {
|
|
continue
|
|
}
|
|
case OpGetG:
|
|
if f.Config.hasGReg {
|
|
// has hardware g register, regalloc takes care of it
|
|
continue // ok not to lower
|
|
}
|
|
}
|
|
s := "not lowered: " + v.String() + ", " + v.Op.String() + " " + v.Type.SimpleString()
|
|
for _, a := range v.Args {
|
|
s += " " + a.Type.SimpleString()
|
|
}
|
|
f.Fatalf("%s", s)
|
|
}
|
|
}
|
|
}
|