diff options
| author | Junyang Shao <shaojunyang@google.com> | 2025-09-16 03:27:41 +0000 |
|---|---|---|
| committer | Junyang Shao <shaojunyang@google.com> | 2025-09-18 11:06:57 -0700 |
| commit | d9751166a6872e05afee5087cee2f360344bd2f9 (patch) | |
| tree | 7f8eb655b8817e05d8818ddd38d84e83b127c3d8 /src/cmd/compile/internal | |
| parent | 4eb5c6e07b56b75033d98941c8fadd3304ee4965 (diff) | |
| download | go-d9751166a6872e05afee5087cee2f360344bd2f9.tar.xz | |
[dev.simd] cmd/compile: handle rematerialized op for incompatible reg constraint
This CL fixes an issue raised by contributor dominikh@.
Change-Id: I941b330a6ba6f6c120c69951ddd24933f2f0b3ec
Reviewed-on: https://go-review.googlesource.com/c/go/+/704056
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Reviewed-by: David Chase <drchase@google.com>
Diffstat (limited to 'src/cmd/compile/internal')
| -rw-r--r-- | src/cmd/compile/internal/ssa/regalloc.go | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/src/cmd/compile/internal/ssa/regalloc.go b/src/cmd/compile/internal/ssa/regalloc.go index 7ed5bda28c..fe30b89cdd 100644 --- a/src/cmd/compile/internal/ssa/regalloc.go +++ b/src/cmd/compile/internal/ssa/regalloc.go @@ -2576,7 +2576,26 @@ 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 { - x = v.copyInto(e.p) + // Handle incompatible registers. + // For #70451. + if e.s.regspec(v).outputs[0].regs®Mask(1<<register(loc.(*Register).num)) == 0 && c != nil { + _, srcReg := src.(*Register) + if !srcReg { + // We need a tmp register + x = v.copyInto(e.p) + r := e.findRegFor(x.Type) + e.erase(r) + // Rematerialize to a 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) + } } else { // Rematerialize into stack slot. Need a free // register to accomplish this. |
