Commit 05f9b369 authored by Jeet Parekh's avatar Jeet Parekh Committed by Austin Clements

syscall: improve NewCallback documentation and panic message

Fixes #26138

Change-Id: If77b2839bccc600223735df42438a19131cd051c
GitHub-Last-Rev: 64ceaea9f1cb7afb3d552dce0223b818bac1faf9
GitHub-Pull-Request: golang/go#26617
Reviewed-on: https://go-review.googlesource.com/126035Reviewed-by: default avatarAustin Clements <austin@google.com>
Run-TryBot: Austin Clements <austin@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent ead59f4b
...@@ -42,20 +42,20 @@ func callbackasmAddr(i int) uintptr { ...@@ -42,20 +42,20 @@ func callbackasmAddr(i int) uintptr {
//go:linkname compileCallback syscall.compileCallback //go:linkname compileCallback syscall.compileCallback
func compileCallback(fn eface, cleanstack bool) (code uintptr) { func compileCallback(fn eface, cleanstack bool) (code uintptr) {
if fn._type == nil || (fn._type.kind&kindMask) != kindFunc { if fn._type == nil || (fn._type.kind&kindMask) != kindFunc {
panic("compileCallback: not a function") panic("compileCallback: expected function with one uintptr-sized result")
} }
ft := (*functype)(unsafe.Pointer(fn._type)) ft := (*functype)(unsafe.Pointer(fn._type))
if len(ft.out()) != 1 { if len(ft.out()) != 1 {
panic("compileCallback: function must have one output parameter") panic("compileCallback: expected function with one uintptr-sized result")
} }
uintptrSize := unsafe.Sizeof(uintptr(0)) uintptrSize := unsafe.Sizeof(uintptr(0))
if ft.out()[0].size != uintptrSize { if ft.out()[0].size != uintptrSize {
panic("compileCallback: output parameter size is wrong") panic("compileCallback: expected function with one uintptr-sized result")
} }
argsize := uintptr(0) argsize := uintptr(0)
for _, t := range ft.in() { for _, t := range ft.in() {
if t.size > uintptrSize { if t.size > uintptrSize {
panic("compileCallback: input parameter size is wrong") panic("compileCallback: argument size is larger than uintptr")
} }
argsize += uintptrSize argsize += uintptrSize
} }
......
...@@ -120,16 +120,16 @@ func (e Errno) Timeout() bool { ...@@ -120,16 +120,16 @@ func (e Errno) Timeout() bool {
// Implemented in runtime/syscall_windows.go. // Implemented in runtime/syscall_windows.go.
func compileCallback(fn interface{}, cleanstack bool) uintptr func compileCallback(fn interface{}, cleanstack bool) uintptr
// Converts a Go function to a function pointer conforming // NewCallback converts a Go function to a function pointer conforming to the stdcall calling convention.
// to the stdcall calling convention. This is useful when // This is useful when interoperating with Windows code requiring callbacks.
// interoperating with Windows code requiring callbacks. // The argument is expected to be a function with with one uintptr-sized result. The function must not have arguments with size larger than the size of uintptr.
func NewCallback(fn interface{}) uintptr { func NewCallback(fn interface{}) uintptr {
return compileCallback(fn, true) return compileCallback(fn, true)
} }
// Converts a Go function to a function pointer conforming // NewCallbackCDecl converts a Go function to a function pointer conforming to the cdecl calling convention.
// to the cdecl calling convention. This is useful when // This is useful when interoperating with Windows code requiring callbacks.
// interoperating with Windows code requiring callbacks. // The argument is expected to be a function with with one uintptr-sized result. The function must not have arguments with size larger than the size of uintptr.
func NewCallbackCDecl(fn interface{}) uintptr { func NewCallbackCDecl(fn interface{}) uintptr {
return compileCallback(fn, false) return compileCallback(fn, false)
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment