forked from Dadido3/blackcl
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuffer.go
72 lines (67 loc) · 1.45 KB
/
buffer.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
package highCL
import (
"errors"
constants "github.com/opencl-pure/constantsCL"
pure "github.com/opencl-pure/pureCL"
"log"
"unsafe"
)
// buffer memory buffer on the device
type buffer struct {
memobj pure.Buffer
size pure.Size
device *Device
}
// newBuffer creates new buffer with specified size
func newBuffer(d *Device, size int) (*buffer, error) {
var ret pure.Status
clBuffer := pure.CreateBuffer(d.ctx, constants.CL_MEM_READ_WRITE, pure.Size(size), nil, &ret)
if err := pure.StatusToErr(ret); err != nil {
return nil, err
}
if clBuffer == pure.Buffer(0) {
return nil, ErrUnknown
}
return &buffer{
memobj: clBuffer,
size: pure.Size(size),
device: d,
}, nil
}
// Release releases the buffer on the device
func (b *buffer) Release() error {
return pure.StatusToErr(pure.ReleaseMemObject(b.memobj))
}
func (b *buffer) copy(size int, ptr unsafe.Pointer) <-chan error {
ch := make(chan error, 1)
if b.size != pure.Size(size) {
ch <- errors.New("buffer size not equal to data len")
return ch
}
var event pure.Event
err := pure.StatusToErr(pure.EnqueueWriteBuffer(
b.device.queue,
b.memobj,
false,
0,
pure.Size(size),
ptr,
0,
nil,
&event,
))
if err != nil {
ch <- err
return ch
}
go func() {
list := []pure.Event{event}
defer func() {
if err2 := pure.StatusToErr(pure.ReleaseEvent(event)); err2 != nil {
log.Println(err2)
}
}()
ch <- pure.StatusToErr(pure.WaitForEvents(1, list))
}()
return ch
}