Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

cmd/compile: internal compiler error with zero-size types [1.22 backport] #68594

Closed
gopherbot opened this issue Jul 25, 2024 · 3 comments
Closed
Labels
CherryPickApproved Used during the release process for point releases compiler/runtime Issues related to the Go compiler and/or runtime.
Milestone

Comments

@gopherbot
Copy link
Contributor

@dr2chase requested issue #65808 to be considered for backport to the next 1.22 minor release.

@gopherbot please consider this for backport to 1.22; it is likely a regression from the expand_calls cleanup.

I tested the backport already, the fix is targeted, low risk, and applies clean.

@gopherbot gopherbot added the CherryPickCandidate Used during the release process for point releases label Jul 25, 2024
@gopherbot gopherbot added the compiler/runtime Issues related to the Go compiler and/or runtime. label Jul 25, 2024
@gopherbot gopherbot added this to the Go1.22.6 milestone Jul 25, 2024
@dr2chase
Copy link
Contributor

This IS a regression from 1.21, and does not need to be backported to 1.21 also.

@gopherbot
Copy link
Contributor Author

gopherbot commented Jul 25, 2024

Change https://go.dev/cl/601195 mentions this issue: [release-branch.go1.22] cmd/compile: add 0-sized-value simplification to copyelim

@mknyszek mknyszek added the CherryPickApproved Used during the release process for point releases label Jul 31, 2024
@gopherbot gopherbot removed the CherryPickCandidate Used during the release process for point releases label Jul 31, 2024
gopherbot pushed a commit that referenced this issue Jul 31, 2024
… to copyelim

The problem was caused by faulty handling of unSSA-able
operations on zero-sized data in expand calls, but there
is no point to operations on zero-sized data.  This CL adds
a simplify step to the first place in SSA where all values
are processed and replaces anything producing a 0-sized
struct/array with the corresponding Struct/Array Make0
operation (of the appropriate type).

I attempted not generating them in ssagen, but that was a
larger change, and also had bugs. This is simple and obvious.
The only question is whether it would be worthwhile to do it
earlier (in numberlines or phielem).

Fixes #68594.
Fixes #68585.

Change-Id: I0a596b3d272798015e7bb6b1a20411241759fe0e
Reviewed-on: https://go-review.googlesource.com/c/go/+/568258
Reviewed-by: Cuong Manh Le <[email protected]>
Reviewed-by: Keith Randall <[email protected]>
Reviewed-by: Keith Randall <[email protected]>
LUCI-TryBot-Result: Go LUCI <[email protected]>
(cherry picked from commit 6f5d774)
Reviewed-on: https://go-review.googlesource.com/c/go/+/601195
@gopherbot
Copy link
Contributor Author

Closed by merging CL 601195 (commit 8c8adff) to release-branch.go1.22.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
CherryPickApproved Used during the release process for point releases compiler/runtime Issues related to the Go compiler and/or runtime.
Projects
None yet
Development

No branches or pull requests

3 participants