Reduced number of register moves

This commit is contained in:
Eduard Urbach 2025-02-12 17:02:51 +01:00
parent b32df45289
commit 3fb05c382a
Signed by: akyoto
GPG Key ID: C874F672B1AF20C0
2 changed files with 19 additions and 2 deletions

View File

@ -18,7 +18,13 @@ func (f *Function) CompileReturn(node *ast.Return) error {
}
for i := len(node.Values) - 1; i >= 0; i-- {
for j := range i {
if f.UsesRegister(node.Values[j], f.CPU.Output[i]) {
f.SaveRegister(f.CPU.Output[i])
break
}
}
typ, err := f.ExpressionToRegister(node.Values[i], f.CPU.Output[i])
if err != nil {

View File

@ -4,14 +4,25 @@ import (
"git.akyoto.dev/cli/q/src/ast"
"git.akyoto.dev/cli/q/src/cpu"
"git.akyoto.dev/cli/q/src/expression"
"git.akyoto.dev/cli/q/src/token"
)
// UsesRegister returns true if evaluating the expression would write or read the given register.
func (f *Function) UsesRegister(expr *expression.Expression, register cpu.Register) bool {
if expr.IsLeaf() {
if expr.Token.Kind != token.Identifier {
return false
}
variable := f.VariableByName(expr.Token.Text(f.File.Bytes))
if variable == nil || variable.Register != register {
return false
}
return true
}
if ast.IsFunctionCall(expr) {
if register == f.CPU.Output[0] {
return true