mirror of
https://github.com/ceph/go-ceph
synced 2025-01-28 17:12:54 +00:00
430dea5b7f
In order to be able to swich on and off PtrGuard usage, SyncBuffer implements a typical usage pattern of PtrGuard, that is a data buffer referenced from inside a C allocated struct, in two ways: 1) using a PtrGuard to dierctly store a pointer to the Go buffer in C memory, or 2) allocating a C buffer of same size and syncing data back with C.memcpy(). The implementation can be chosen with the with_ptrguard build tag. Signed-off-by: Sven Anderson <sven@redhat.com>
38 lines
758 B
Go
38 lines
758 B
Go
// +build !ptrguard
|
|
|
|
package cutil
|
|
|
|
// SyncBuffer is a C buffer connected to a data slice
|
|
type SyncBuffer struct {
|
|
data []byte
|
|
cPtr *CPtr
|
|
}
|
|
|
|
// NewSyncBuffer creates a C buffer from a data slice and stores it at CPtr
|
|
func NewSyncBuffer(cPtr CPtr, data []byte) *SyncBuffer {
|
|
var v SyncBuffer
|
|
v.data = data
|
|
v.cPtr = (*CPtr)(cPtr)
|
|
*v.cPtr = CBytes(data)
|
|
return &v
|
|
}
|
|
|
|
// Release releases the C buffer and nulls its stored pointer
|
|
func (v *SyncBuffer) Release() {
|
|
if v.cPtr != nil {
|
|
Free(*v.cPtr)
|
|
*v.cPtr = nil
|
|
v.cPtr = nil
|
|
}
|
|
v.data = nil
|
|
}
|
|
|
|
// Sync asserts that changes in the C buffer are available in the data
|
|
// slice
|
|
func (v *SyncBuffer) Sync() {
|
|
if v.cPtr == nil {
|
|
return
|
|
}
|
|
Memcpy(CPtr(&v.data[0]), CPtr(*v.cPtr), SizeT(len(v.data)))
|
|
}
|