From: Ian Lance Taylor Date: Tue, 25 Oct 2016 19:59:36 +0000 (-0700) Subject: misc/cgo/errors: fix malloc test for dragonfly X-Git-Tag: go1.8beta1~634 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=e24ccfc6fc6289073cdbe6f47f8a915e798578e9;p=gostls13.git misc/cgo/errors: fix malloc test for dragonfly The Dragonfly libc returns a non-zero value for malloc(-1). Fixes #17585. Change-Id: Icfe68011ccbc75c676273ee3c3efdf24a520a004 Reviewed-on: https://go-review.googlesource.com/32050 Run-TryBot: Ian Lance Taylor TryBot-Result: Gobot Gobot Reviewed-by: Brad Fitzpatrick --- diff --git a/misc/cgo/errors/malloc.go b/misc/cgo/errors/malloc.go index 7a69736222..65da0208b9 100644 --- a/misc/cgo/errors/malloc.go +++ b/misc/cgo/errors/malloc.go @@ -11,10 +11,21 @@ import "C" import ( "fmt" + "runtime" ) func main() { - p := C.malloc(C.size_t(^uintptr(0))) + var size C.size_t + size-- + + // The Dragonfly libc succeeds when asked to allocate + // 0xffffffffffffffff bytes, so pass a different value that + // causes it to fail. + if runtime.GOOS == "dragonfly" { + size = C.size_t(0x7fffffff << (32 * (^uintptr(0) >> 63))) + } + + p := C.malloc(size) if p == nil { fmt.Println("malloc: C.malloc returned nil") // Just exit normally--the test script expects this diff --git a/misc/cgo/errors/test.bash b/misc/cgo/errors/test.bash index 8b892938fc..05261e9d76 100755 --- a/misc/cgo/errors/test.bash +++ b/misc/cgo/errors/test.bash @@ -62,7 +62,7 @@ fi # The malloc.go test should crash. rm -f malloc.out if go run malloc.go >malloc.out 2>&1; then - echo "`go run malloc.go` succeeded unexpectedly" + echo '`go run malloc.go` succeeded unexpectedly' cat malloc.out rm -f malloc.out exit 1