More C.CBytes() preparatory work.
This commit is contained in:
parent
53722b5b08
commit
42d273bea8
14
util.go
14
util.go
|
@ -13,8 +13,22 @@ import "C"
|
||||||
|
|
||||||
// TODO move this to C.CBytes() when switching to Go 1.7
|
// TODO move this to C.CBytes() when switching to Go 1.7
|
||||||
|
|
||||||
|
// We want Go itself to complain when we're out of memory.
|
||||||
|
// The allocators in cgo *should* do this, but there isn't a
|
||||||
|
// C.CMalloc(). There *is* a C.CBytes(), however, for transferring
|
||||||
|
// binary blobs from Go to C. If we pass this an arbitrary slice
|
||||||
|
// of the desired length, we get our C.CMalloc(). Using a slice
|
||||||
|
// that's always initialized to zero gives us the ZeroMemory()
|
||||||
|
// for free.
|
||||||
|
var uimallocBytes = make([]byte, 1024) // 1024 bytes first
|
||||||
|
|
||||||
//export uimalloc
|
//export uimalloc
|
||||||
func uimalloc(n C.size_t) unsafe.Pointer {
|
func uimalloc(n C.size_t) unsafe.Pointer {
|
||||||
|
if n > C.size_t(len(uimallocBytes)) {
|
||||||
|
// TODO round n up to a multiple of a power of 2?
|
||||||
|
// for instance 0x1234 bytes -> 0x1800 bytes
|
||||||
|
uimallocBytes = make([]byte, n)
|
||||||
|
}
|
||||||
p := C.malloc(n)
|
p := C.malloc(n)
|
||||||
if p == nil {
|
if p == nil {
|
||||||
panic("out of memory in uimalloc()")
|
panic("out of memory in uimalloc()")
|
||||||
|
|
Loading…
Reference in New Issue