Skip to content

Commit

Permalink
runtime: change functype's in and out fields to []*_type
Browse files Browse the repository at this point in the history
Allows removing a few gratuitous unsafe.Pointer conversions and
parallels the type of reflect.funcType's in and out fields ([]*rtype).

Change-Id: Ie5ca230a94407301a854dfd8782a3180d5054bc4
Reviewed-on: https://go-review.googlesource.com/16163
Run-TryBot: Matthew Dempsky <[email protected]>
TryBot-Result: Gobot Gobot <[email protected]>
Reviewed-by: Ian Lance Taylor <[email protected]>
  • Loading branch information
mdempsky committed Oct 21, 2015
1 parent 163653e commit c279250
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 10 deletions.
7 changes: 3 additions & 4 deletions src/runtime/mfinal.go
Original file line number Diff line number Diff line change
Expand Up @@ -327,11 +327,10 @@ func SetFinalizer(obj interface{}, finalizer interface{}) {
throw("runtime.SetFinalizer: second argument is " + *ftyp._string + ", not a function")
}
ft := (*functype)(unsafe.Pointer(ftyp))
ins := *(*[]*_type)(unsafe.Pointer(&ft.in))
if ft.dotdotdot || len(ins) != 1 {
if ft.dotdotdot || len(ft.in) != 1 {
throw("runtime.SetFinalizer: cannot pass " + *etyp._string + " to finalizer " + *ftyp._string)
}
fint := ins[0]
fint := ft.in[0]
switch {
case fint == etyp:
// ok - same type
Expand All @@ -356,7 +355,7 @@ func SetFinalizer(obj interface{}, finalizer interface{}) {
okarg:
// compute size needed for return parameters
nret := uintptr(0)
for _, t := range *(*[]*_type)(unsafe.Pointer(&ft.out)) {
for _, t := range ft.out {
nret = round(nret, uintptr(t.align)) + uintptr(t.size)
}
nret = round(nret, ptrSize)
Expand Down
8 changes: 4 additions & 4 deletions src/runtime/syscall_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,16 +45,16 @@ func compileCallback(fn eface, cleanstack bool) (code uintptr) {
panic("compileCallback: not a function")
}
ft := (*functype)(unsafe.Pointer(fn._type))
if ft.out.len != 1 {
if len(ft.out) != 1 {
panic("compileCallback: function must have one output parameter")
}
uintptrSize := unsafe.Sizeof(uintptr(0))
if t := (**_type)(unsafe.Pointer(ft.out.array)); (*t).size != uintptrSize {
if ft.out[0].size != uintptrSize {
panic("compileCallback: output parameter size is wrong")
}
argsize := uintptr(0)
for _, t := range (*[1024](*_type))(unsafe.Pointer(ft.in.array))[:ft.in.len] {
if (*t).size > uintptrSize {
for _, t := range ft.in {
if t.size > uintptrSize {
panic("compileCallback: input parameter size is wrong")
}
argsize += uintptrSize
Expand Down
4 changes: 2 additions & 2 deletions src/runtime/type.go
Original file line number Diff line number Diff line change
Expand Up @@ -84,8 +84,8 @@ type slicetype struct {
type functype struct {
typ _type
dotdotdot bool
in slice
out slice
in []*_type
out []*_type
}

type ptrtype struct {
Expand Down

0 comments on commit c279250

Please sign in to comment.