-
Notifications
You must be signed in to change notification settings - Fork 17.9k
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/link: panic on riscv64 with CGO enabled due to empty container symbol #72840
Comments
cc @golang/riscv64 |
When you say "handling of certain symbols", is it possible to be more specific? |
@golang/compiler |
Reading the error message, it looks like the error is from loading a symbol from an empty section in a C object. Perhaps we should just ignore it, especially that it is not a loadable section. Perhaps we can ignore the entire debug sections from C object? @thanm do you know if we use the debug info from C objects in internal linking mode? I think we probably don't. (It may be a good thing to do for the future. But that needs a good amount of effort beyond just loading the symbols. If currently we load the symbols but not doing anything with them, we may as well not load them at all.) |
From looking at the code, it does appear that we're loading up |
I attempted the following build process and still failed with the same reason: git clone https://github.com/golang/go
cd go
git checkout go1.24.1
cd src
./all.bash It is worth noting that I am using the following versions of gcc --version
# gcc (GCC) 15.0.1 20250114 (Red Hat 15.0.1-0)
ar --version
# GNU ar version 2.43.50.20250106 Please let me know if any additional details are required. |
Go version
go version go1.24.1 linux/riscv64
Output of
go env
in your module/workspace:What did you do?
Built Go (version 1.24.1) on a riscv64 system on Fedora 42 with CGO enabled. Ran the full Go check suite and also attempted a minimal reproduction by isolating tests in the
internal/poll
directory. In the minimal test setup, I removed others test files ininternal/poll
and only the test fileserror_linux_test.go
,error_stub_test.go
, anderror_test.go
remained. Furthermore, I experimented with a workaround by commenting out the following code inerror_test.go
:and trying to run
cd /builddir/build/BUILD/golang-1.24.1-build/go/src ./run.bash --no-rebuild -v -v -v -k internal/poll
What did you see happen?
The build fails during the linking phase with a panic. Key parts of the error log include:
This panic in the linker (
cmd/link/internal/loader.(*Loader).AddInteriorSym
) prevents the test suite from completing. The workaround of commenting out the code inerror_test.go
allowed the tests to pass, indicating that the issue might be related to the handling of certain symbols.And I also tried with CGO disabled(by set CGO_ENABLED=0), test complete successfully without panics.
full build log: http://openkoji.iscas.ac.cn/kojifiles/work/tasks/8787/7038787/build.log
golang spec file: https://src.fedoraproject.org/rpms/golang/blob/rawhide/f/golang.spec
What did you expect to see?
I expected the Go build and test suite to complete successfully without panics, even with CGO enabled on the riscv64 platform. The behavior should be consistent with other architectures where the build passes without the need to modify test files.
The text was updated successfully, but these errors were encountered: