-
Notifications
You must be signed in to change notification settings - Fork 18.4k
cmd/cgo: use the export'ed file/line in error messages #76118
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
base: master
Are you sure you want to change the base?
Conversation
|
This PR (HEAD: 956aa4b) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/go/+/716441. Important tips:
|
|
Message from Gopher Robot: Patch Set 1: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Ariel Otilibili Anieli: Patch Set 1: (2 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from t hepudds: Patch Set 1: Commit-Queue+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Go LUCI: Patch Set 1: Dry run: CV is trying the patch. Bot data: {"action":"start","triggered_at":"2025-10-30T13:06:19Z","revision":"5eb0a3d78893485106a8837e76486d73857acc9d"} Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from t hepudds: Patch Set 1: -Commit-Queue Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Go LUCI: Patch Set 1: This CL has passed the run Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Go LUCI: Patch Set 1: LUCI-TryBot-Result+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from t hepudds: Patch Set 1: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
956aa4b to
eb376d9
Compare
|
This PR (HEAD: eb376d9) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/go/+/716441. Important tips:
|
|
Message from Ariel Otilibili Anieli: Patch Set 1: (2 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
eb376d9 to
533628d
Compare
|
This PR (HEAD: 533628d) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/go/+/716441. Important tips:
|
|
Message from Ariel Otilibili Anieli: Patch Set 2: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from t hepudds: Patch Set 3: Commit-Queue+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Go LUCI: Patch Set 3: Dry run: CV is trying the patch. Bot data: {"action":"start","triggered_at":"2025-10-31T11:47:32Z","revision":"e71bc4cc4a690279b5aa53d26fd4d0ee80946042"} Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from t hepudds: Patch Set 3: -Commit-Queue Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Go LUCI: Patch Set 3: This CL has passed the run Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Go LUCI: Patch Set 3: LUCI-TryBot-Result+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from t hepudds: Patch Set 3: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Keith Randall: Patch Set 3: Code-Review+2 (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
When an unpinned Go pointer (or a pointer to an unpinned Go pointer) is
returned from Go to C,
1 package main
2
3 import (
4 "C"
5 )
6
7 //export foo
8 func foo(CLine *C.char) string {
9 return C.GoString(CLine)
10 }
11
12
13 func main() {
14 }
The error message mentions the file/line of the cgo wrapper,
panic: runtime error: cgo result is unpinned Go pointer or points to unpinned Go pointer
goroutine 17 [running, locked to thread]:
panic({0x798f2341a4c0?, 0xc000112000?})
/usr/lib/go/src/runtime/panic.go:802 +0x168
runtime.cgoCheckArg(0x798f23417e20, 0xc000066e50, 0x0?, 0x0, {0x798f233f5a62, 0x42})
/usr/lib/go/src/runtime/cgocall.go:679 +0x35b
runtime.cgoCheckResult({0x798f23417e20, 0xc000066e50})
/usr/lib/go/src/runtime/cgocall.go:795 +0x4b
_cgoexp_3c910ddb72c4_foo(0x7ffc9fa9bfa0)
_cgo_gotypes.go:65 +0x5d
runtime.cgocallbackg1(0x798f233ec780, 0x7ffc9fa9bfa0, 0x0)
/usr/lib/go/src/runtime/cgocall.go:446 +0x289
runtime.cgocallbackg(0x798f233ec780, 0x7ffc9fa9bfa0, 0x0)
/usr/lib/go/src/runtime/cgocall.go:350 +0x132
runtime.cgocallbackg(0x798f233ec780, 0x7ffc9fa9bfa0, 0x0)
<autogenerated>:1 +0x2b
runtime.cgocallback(0x0, 0x0, 0x0)
/usr/lib/go/src/runtime/asm_amd64.s:1082 +0xcd
runtime.goexit({})
/usr/lib/go/src/runtime/asm_amd64.s:1693 +0x1
The cgo wrapper (_cgoexp_3c910ddb72c4_foo) is located in a temporary
build artifact (_cgo_gotypes.go)
$ go tool cgo -objdir objdir parse.go
$ cat -n objdir/_cgo_gotypes.go | sed -n '55,70p'
55 //go:cgo_export_dynamic foo
56 //go:linkname _cgoexp_d48770e267d1_foo _cgoexp_d48770e267d1_foo
57 //go:cgo_export_static _cgoexp_d48770e267d1_foo
58 func _cgoexp_d48770e267d1_foo(a *struct {
59 p0 *_Ctype_char
60 r0 string
61 }) {
62 a.r0 = foo(a.p0)
63 _cgoCheckResult(a.r0)
64 }
The file/line of the export'ed function is expected in the error message.
Use it in error messages.
panic: runtime error: cgo result is unpinned Go pointer or points to unpinned Go pointer
goroutine 17 [running, locked to thread]:
panic({0x7df72b1d8ae0?, 0x3ec8a1790030?})
/mnt/go/src/runtime/panic.go:877 +0x16f
runtime.cgoCheckArg(0x7df72b1d62c0, 0x3ec8a16eee50, 0x68?, 0x0, {0x7df72b1ad44c, 0x42})
/mnt/go/src/runtime/cgocall.go:679 +0x35b
runtime.cgoCheckResult({0x7df72b1d62c0, 0x3ec8a16eee50})
/mnt/go/src/runtime/cgocall.go:795 +0x4b
_cgoexp_3c910ddb72c4_foo(0x7ffca1b21020)
/mnt/tmp/parse.go:8 +0x5d
runtime.cgocallbackg1(0x7df72b1a4360, 0x7ffca1b21020, 0x0)
/mnt/go/src/runtime/cgocall.go:446 +0x289
runtime.cgocallbackg(0x7df72b1a4360, 0x7ffca1b21020, 0x0)
/mnt/go/src/runtime/cgocall.go:350 +0x132
runtime.cgocallbackg(0x7df72b1a4360, 0x7ffca1b21020, 0x0)
<autogenerated>:1 +0x2b
runtime.cgocallback(0x0, 0x0, 0x0)
/mnt/go/src/runtime/asm_amd64.s:1101 +0xcd
runtime.goexit({})
/mnt/go/src/runtime/asm_amd64.s:1712 +0x1
So doing, fix typos in comments.
Link: https://web.archive.org/web/20251008114504/https://dave.cheney.net/2018/01/08/gos-hidden-pragmas
Suggested-by: Keith Randall <khr@golang.org>
For golang#75856
533628d to
e65839c
Compare
|
This PR (HEAD: e65839c) has been imported to Gerrit for code review. Please visit Gerrit at https://go-review.googlesource.com/c/go/+/716441. Important tips:
|
|
Message from Ariel Otilibili Anieli: Patch Set 3: (3 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from t hepudds: Patch Set 4: Commit-Queue+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Go LUCI: Patch Set 4: Dry run: CV is trying the patch. Bot data: {"action":"start","triggered_at":"2025-11-01T10:15:00Z","revision":"b2752e45b40b29b0f19a56c4a2fb3f2588000e62"} Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from t hepudds: Patch Set 4: -Commit-Queue Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Go LUCI: Patch Set 4: This CL has passed the run Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Go LUCI: Patch Set 4: LUCI-TryBot-Result+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from t hepudds: Patch Set 4: (1 comment) Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Florian Lehner: Patch Set 4: Code-Review+1 Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
|
Message from Ariel Otilibili Anieli: Patch Set 5: (2 comments) Please don’t reply on this GitHub thread. Visit golang.org/cl/716441. |
When an unpinned Go pointer (or a pointer to an unpinned Go pointer) is
returned from Go to C,
The error message mentions the file/line of the cgo wrapper,
The cgo wrapper (_cgoexp_3c910ddb72c4_foo) is located in a temporary
build artifact (_cgo_gotypes.go)
The file/line of the export'ed function is expected in the error message.
Use it in error messages.
So doing, fix typos in comments.
Link: https://web.archive.org/web/20251008114504/https://dave.cheney.net/2018/01/08/gos-hidden-pragmas
Suggested-by: Keith Randall khr@golang.org
For #75856