diff options
| author | Junyang Shao <shaojunyang@google.com> | 2025-09-19 18:38:25 +0000 |
|---|---|---|
| committer | Junyang Shao <shaojunyang@google.com> | 2025-09-22 16:19:02 -0700 |
| commit | 63a09d6d3d68acedfc9e5fd2daf6febc35aca1d6 (patch) | |
| tree | bb70ba4f429251c384646298a6fdb335c7a09ac1 /src/cmd | |
| parent | 2ca96d218d2cbaad99ba807b3bddd90bbf6a5ba8 (diff) | |
| download | go-63a09d6d3d68acedfc9e5fd2daf6febc35aca1d6.tar.xz | |
[dev.simd] cmd/compile: fix SIMD const rematerialization condition
This CL fixes a condition for the previous fix CL 704056.
Change-Id: I1f1f8c6f72870403cb3dff14755c43385dc0c933
Reviewed-on: https://go-review.googlesource.com/c/go/+/705499
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Reviewed-by: Cherry Mui <cherryyz@google.com>
Diffstat (limited to 'src/cmd')
| -rw-r--r-- | src/cmd/compile/internal/ssa/regalloc.go | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/src/cmd/compile/internal/ssa/regalloc.go b/src/cmd/compile/internal/ssa/regalloc.go index fe30b89cdd..bcb5dec09d 100644 --- a/src/cmd/compile/internal/ssa/regalloc.go +++ b/src/cmd/compile/internal/ssa/regalloc.go @@ -2576,22 +2576,25 @@ func (e *edgeState) processDest(loc Location, vid ID, splice **Value, pos src.XP e.s.f.Fatalf("can't find source for %s->%s: %s\n", e.p, e.b, v.LongString()) } if dstReg { - // Handle incompatible registers. + // We want to rematerialize v into a register that is incompatible with v's op's register mask. + // Instead of setting the wrong register for the rematerialized v, we should find the right register + // for it and emit an additional copy to move to the desired register. // For #70451. - if e.s.regspec(v).outputs[0].regs®Mask(1<<register(loc.(*Register).num)) == 0 && c != nil { + if e.s.regspec(v).outputs[0].regs®Mask(1<<register(loc.(*Register).num)) == 0 { _, srcReg := src.(*Register) - if !srcReg { + if srcReg { + // It exists in a valid register already, so just copy it to the desired register + // If src is a Register, c must have already been set. + x = e.p.NewValue1(pos, OpCopy, c.Type, c) + } else { // We need a tmp register x = v.copyInto(e.p) r := e.findRegFor(x.Type) e.erase(r) - // Rematerialize to a tmp register + // Rematerialize to the tmp register e.set(r, vid, x, false, pos) // Copy from tmp to the desired register x = e.p.NewValue1(pos, OpCopy, x.Type, x) - } else { - // It exist in a valid register already, so just copy it to the desired register - x = e.p.NewValue1(pos, OpCopy, c.Type, c) } } else { x = v.copyInto(e.p) |
