Skip to content

Commit

Permalink
cmd/internal/obj/x86: use mov instead of lea to load the frame pointer
Browse files Browse the repository at this point in the history
This CL instructs the Go x86 compiler to load the frame pointer address
using a MOV instead of a LEA instruction, being MOV 1 byte shorter:

Before
  55            PUSHQ   BP
  48 8d 2c 24   LEAQ    0(SP), BP

After
  55            PUSHQ   BP
  48 89 e5      MOVQ    SP, BP

This reduces the size of the Go toolchain ~0.06%.

Updates golang#6853

Change-Id: I5557cf34c47e871d264ba0deda9b78338681a12c
Reviewed-on: https://go-review.googlesource.com/c/go/+/463845
Auto-Submit: Keith Randall <khr@google.com>
Reviewed-by: Keith Randall <khr@google.com>
Reviewed-by: Keith Randall <khr@golang.org>
Run-TryBot: Quim Muntal <quimmuntal@gmail.com>
Reviewed-by: Cherry Mui <cherryyz@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
  • Loading branch information
qmuntal authored and johanbrandhorst committed Feb 12, 2023
1 parent 307d62e commit 9a2c8fb
Showing 1 changed file with 2 additions and 4 deletions.
6 changes: 2 additions & 4 deletions src/cmd/internal/obj/x86/obj6.go
Original file line number Diff line number Diff line change
Expand Up @@ -695,11 +695,9 @@ func preprocess(ctxt *obj.Link, cursym *obj.LSym, newprog obj.ProgAlloc) {
// Move current frame to BP
p = obj.Appendp(p, newprog)

p.As = ALEAQ
p.From.Type = obj.TYPE_MEM
p.As = AMOVQ
p.From.Type = obj.TYPE_REG
p.From.Reg = REG_SP
p.From.Scale = 1
p.From.Offset = 0
p.To.Type = obj.TYPE_REG
p.To.Reg = REG_BP
}
Expand Down

0 comments on commit 9a2c8fb

Please sign in to comment.