mirror of
https://github.com/golang/go
synced 2024-11-27 05:11:22 -07:00
reflect: fix func layout test for nacl build
This test code is ugly. There must be a better way. But for now, fix the build. Change-Id: I33064145ea37f11abf040ec97caa87669be1a9fa Reviewed-on: https://go-review.googlesource.com/2114 Reviewed-by: Ian Lance Taylor <iant@golang.org>
This commit is contained in:
parent
9371babdd8
commit
31f8310c45
@ -4085,8 +4085,10 @@ var funcLayoutTests []funcLayoutTest
|
||||
|
||||
func init() {
|
||||
var argAlign = PtrSize
|
||||
var naclExtra []byte
|
||||
if runtime.GOARCH == "amd64p32" {
|
||||
argAlign = 2 * PtrSize
|
||||
naclExtra = append(naclExtra, BitsScalar)
|
||||
}
|
||||
roundup := func(x uintptr, a uintptr) uintptr {
|
||||
return (x + a - 1) / a * a
|
||||
@ -4106,7 +4108,7 @@ func init() {
|
||||
var r, s []byte
|
||||
if PtrSize == 4 {
|
||||
r = []byte{BitsScalar, BitsScalar, BitsScalar, BitsPointer}
|
||||
s = []byte{BitsScalar, BitsScalar, BitsScalar, BitsPointer, BitsScalar}
|
||||
s = append([]byte{BitsScalar, BitsScalar, BitsScalar, BitsPointer, BitsScalar}, naclExtra...)
|
||||
} else {
|
||||
r = []byte{BitsScalar, BitsScalar, BitsPointer}
|
||||
s = []byte{BitsScalar, BitsScalar, BitsPointer, BitsScalar}
|
||||
@ -4156,24 +4158,24 @@ func init() {
|
||||
3 * PtrSize,
|
||||
roundup(3*PtrSize, argAlign),
|
||||
[]byte{BitsPointer, BitsScalar, BitsPointer},
|
||||
[]byte{BitsPointer, BitsScalar, BitsPointer},
|
||||
append([]byte{BitsPointer, BitsScalar, BitsPointer}, naclExtra...),
|
||||
})
|
||||
|
||||
funcLayoutTests = append(funcLayoutTests,
|
||||
funcLayoutTest{
|
||||
nil,
|
||||
ValueOf(func(a uintptr){}).Type(),
|
||||
PtrSize,
|
||||
PtrSize,
|
||||
ValueOf(func(a uintptr) {}).Type(),
|
||||
roundup(PtrSize, argAlign),
|
||||
PtrSize,
|
||||
roundup(PtrSize, argAlign),
|
||||
[]byte{},
|
||||
[]byte{BitsScalar},
|
||||
append([]byte{BitsScalar}, naclExtra...),
|
||||
})
|
||||
|
||||
funcLayoutTests = append(funcLayoutTests,
|
||||
funcLayoutTest{
|
||||
nil,
|
||||
ValueOf(func() uintptr{return 0}).Type(),
|
||||
ValueOf(func() uintptr { return 0 }).Type(),
|
||||
PtrSize,
|
||||
0,
|
||||
0,
|
||||
@ -4184,10 +4186,10 @@ func init() {
|
||||
funcLayoutTests = append(funcLayoutTests,
|
||||
funcLayoutTest{
|
||||
ValueOf(uintptr(0)).Type(),
|
||||
ValueOf(func(a uintptr){}).Type(),
|
||||
2*PtrSize,
|
||||
2*PtrSize,
|
||||
2*PtrSize,
|
||||
ValueOf(func(a uintptr) {}).Type(),
|
||||
2 * PtrSize,
|
||||
2 * PtrSize,
|
||||
2 * PtrSize,
|
||||
[]byte{BitsPointer},
|
||||
[]byte{BitsPointer, BitsScalar},
|
||||
// Note: this one is tricky, as the receiver is not a pointer. But we
|
||||
|
Loading…
Reference in New Issue
Block a user