Commit fc1e6915 authored by Josh Bleecher Snyder's avatar Josh Bleecher Snyder

cmd/internal/obj/x86: minor clean-up in span6

* Reduce the scope of q.
* Remove duplicate handling of AADJSP.
* Move ab declaration closer to use.
* Collapse nested if statements.
* Change declaration of n for increased readability in context.
* Simplify AADJSP handling.

Passes toolstash-check.

Change-Id: I046369477db567f2f7c4a9c8d400ec9dd9c32f3f
Reviewed-on: https://go-review.googlesource.com/c/go/+/168342
Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
parent e608ffda
...@@ -1857,63 +1857,38 @@ func span6(ctxt *obj.Link, s *obj.LSym, newprog obj.ProgAlloc) { ...@@ -1857,63 +1857,38 @@ func span6(ctxt *obj.Link, s *obj.LSym, newprog obj.ProgAlloc) {
ctxt.Diag("x86 tables not initialized, call x86.instinit first") ctxt.Diag("x86 tables not initialized, call x86.instinit first")
} }
var ab AsmBuf
for p := s.Func.Text; p != nil; p = p.Link { for p := s.Func.Text; p != nil; p = p.Link {
if p.To.Type == obj.TYPE_BRANCH { if p.To.Type == obj.TYPE_BRANCH && p.Pcond == nil {
if p.Pcond == nil {
p.Pcond = p p.Pcond = p
} }
}
if p.As == AADJSP { if p.As == AADJSP {
p.To.Type = obj.TYPE_REG p.To.Type = obj.TYPE_REG
p.To.Reg = REG_SP p.To.Reg = REG_SP
v := int32(-p.From.Offset) switch v := p.From.Offset; {
p.From.Offset = int64(v) case v == 0:
p.As = obj.ANOP
case v < 0:
p.As = spadjop(ctxt, AADDL, AADDQ) p.As = spadjop(ctxt, AADDL, AADDQ)
if v < 0 { p.From.Offset *= -1
default:
p.As = spadjop(ctxt, ASUBL, ASUBQ) p.As = spadjop(ctxt, ASUBL, ASUBQ)
v = -v
p.From.Offset = int64(v)
}
if v == 0 {
p.As = obj.ANOP
} }
} }
} }
var q *obj.Prog
var count int64 // rough count of number of instructions var count int64 // rough count of number of instructions
for p := s.Func.Text; p != nil; p = p.Link { for p := s.Func.Text; p != nil; p = p.Link {
count++ count++
p.Back = branchShort // use short branches first time through p.Back = branchShort // use short branches first time through
q = p.Pcond if q := p.Pcond; q != nil && (q.Back&branchShort != 0) {
if q != nil && (q.Back&branchShort != 0) {
p.Back |= branchBackwards p.Back |= branchBackwards
q.Back |= branchLoopHead q.Back |= branchLoopHead
} }
if p.As == AADJSP {
p.To.Type = obj.TYPE_REG
p.To.Reg = REG_SP
v := int32(-p.From.Offset)
p.From.Offset = int64(v)
p.As = spadjop(ctxt, AADDL, AADDQ)
if v < 0 {
p.As = spadjop(ctxt, ASUBL, ASUBQ)
v = -v
p.From.Offset = int64(v)
}
if v == 0 {
p.As = obj.ANOP
}
}
} }
s.GrowCap(count * 5) // preallocate roughly 5 bytes per instruction s.GrowCap(count * 5) // preallocate roughly 5 bytes per instruction
n := 0 var ab AsmBuf
var n int
var c int32 var c int32
errors := ctxt.Errors errors := ctxt.Errors
for { for {
...@@ -1975,7 +1950,7 @@ func span6(ctxt *obj.Link, s *obj.LSym, newprog obj.ProgAlloc) { ...@@ -1975,7 +1950,7 @@ func span6(ctxt *obj.Link, s *obj.LSym, newprog obj.ProgAlloc) {
p.Pc = int64(c) p.Pc = int64(c)
// process forward jumps to p // process forward jumps to p
for q = p.Rel; q != nil; q = q.Forwd { for q := p.Rel; q != nil; q = q.Forwd {
v := int32(p.Pc - (q.Pc + int64(q.Isize))) v := int32(p.Pc - (q.Pc + int64(q.Isize)))
if q.Back&branchShort != 0 { if q.Back&branchShort != 0 {
if v > 127 { if v > 127 {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment