move things around, to keep list of the devices at the beginning.
This commit is contained in:
@@ -21,74 +21,6 @@ import (
|
|||||||
"unsafe"
|
"unsafe"
|
||||||
)
|
)
|
||||||
|
|
||||||
type fakeTransfer struct {
|
|
||||||
// done is the channel that needs to be closed when the transfer has finished.
|
|
||||||
done chan struct{}
|
|
||||||
// buf is the slice for reading/writing data between the submit() and wait() returning.
|
|
||||||
buf []byte
|
|
||||||
// status will be returned by wait() on this transfer
|
|
||||||
status TransferStatus
|
|
||||||
// length is the number of bytes used from the buffer (write) or available
|
|
||||||
// in the buffer (read).
|
|
||||||
length int
|
|
||||||
}
|
|
||||||
|
|
||||||
type fakeLibusb struct {
|
|
||||||
libusbIntf
|
|
||||||
|
|
||||||
mu sync.Mutex
|
|
||||||
// ts has a map of all allocated transfers, indexed by the pointer of
|
|
||||||
// underlying libusbTransfer.
|
|
||||||
ts map[*libusbTransfer]*fakeTransfer
|
|
||||||
// submitted receives a fakeTransfers when submit() is called.
|
|
||||||
submitted chan *fakeTransfer
|
|
||||||
// handlers is a map of device handles pointing at opened devices.
|
|
||||||
handlers map[*libusbDevHandle]*libusbDevice
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *fakeLibusb) alloc(_ *libusbDevHandle, _ uint8, _ TransferType, _ time.Duration, _ int, buf []byte) (*libusbTransfer, error) {
|
|
||||||
f.mu.Lock()
|
|
||||||
defer f.mu.Unlock()
|
|
||||||
t := new(libusbTransfer)
|
|
||||||
f.ts[t] = &fakeTransfer{buf: buf}
|
|
||||||
return t, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *fakeLibusb) submit(t *libusbTransfer, done chan struct{}) error {
|
|
||||||
f.mu.Lock()
|
|
||||||
ft := f.ts[t]
|
|
||||||
f.mu.Unlock()
|
|
||||||
ft.done = done
|
|
||||||
f.submitted <- ft
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *fakeLibusb) cancel(t *libusbTransfer) error { return nil }
|
|
||||||
func (f *fakeLibusb) free(t *libusbTransfer) {
|
|
||||||
f.mu.Lock()
|
|
||||||
defer f.mu.Unlock()
|
|
||||||
delete(f.ts, t)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *fakeLibusb) data(t *libusbTransfer) (int, TransferStatus) {
|
|
||||||
f.mu.Lock()
|
|
||||||
defer f.mu.Unlock()
|
|
||||||
return f.ts[t].length, f.ts[t].status
|
|
||||||
}
|
|
||||||
|
|
||||||
func (f *fakeLibusb) waitForSubmitted() *fakeTransfer {
|
|
||||||
return <-f.submitted
|
|
||||||
}
|
|
||||||
|
|
||||||
func newFakeLibusb() *fakeLibusb {
|
|
||||||
return &fakeLibusb{
|
|
||||||
ts: make(map[*libusbTransfer]*fakeTransfer),
|
|
||||||
submitted: make(chan *fakeTransfer, 10),
|
|
||||||
handlers: make(map[*libusbDevHandle]*libusbDevice),
|
|
||||||
libusbIntf: libusbImpl{},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var (
|
var (
|
||||||
fakeDevices = map[*libusbDevice]*Descriptor{
|
fakeDevices = map[*libusbDevice]*Descriptor{
|
||||||
// Bus 001 Device 001: ID 9999:0001
|
// Bus 001 Device 001: ID 9999:0001
|
||||||
@@ -204,6 +136,65 @@ var (
|
|||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type fakeTransfer struct {
|
||||||
|
// done is the channel that needs to be closed when the transfer has finished.
|
||||||
|
done chan struct{}
|
||||||
|
// buf is the slice for reading/writing data between the submit() and wait() returning.
|
||||||
|
buf []byte
|
||||||
|
// status will be returned by wait() on this transfer
|
||||||
|
status TransferStatus
|
||||||
|
// length is the number of bytes used from the buffer (write) or available
|
||||||
|
// in the buffer (read).
|
||||||
|
length int
|
||||||
|
}
|
||||||
|
|
||||||
|
type fakeLibusb struct {
|
||||||
|
libusbIntf
|
||||||
|
|
||||||
|
mu sync.Mutex
|
||||||
|
// ts has a map of all allocated transfers, indexed by the pointer of
|
||||||
|
// underlying libusbTransfer.
|
||||||
|
ts map[*libusbTransfer]*fakeTransfer
|
||||||
|
// submitted receives a fakeTransfers when submit() is called.
|
||||||
|
submitted chan *fakeTransfer
|
||||||
|
// handlers is a map of device handles pointing at opened devices.
|
||||||
|
handlers map[*libusbDevHandle]*libusbDevice
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *fakeLibusb) alloc(_ *libusbDevHandle, _ uint8, _ TransferType, _ time.Duration, _ int, buf []byte) (*libusbTransfer, error) {
|
||||||
|
f.mu.Lock()
|
||||||
|
defer f.mu.Unlock()
|
||||||
|
t := new(libusbTransfer)
|
||||||
|
f.ts[t] = &fakeTransfer{buf: buf}
|
||||||
|
return t, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *fakeLibusb) submit(t *libusbTransfer, done chan struct{}) error {
|
||||||
|
f.mu.Lock()
|
||||||
|
ft := f.ts[t]
|
||||||
|
f.mu.Unlock()
|
||||||
|
ft.done = done
|
||||||
|
f.submitted <- ft
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *fakeLibusb) cancel(t *libusbTransfer) error { return nil }
|
||||||
|
func (f *fakeLibusb) free(t *libusbTransfer) {
|
||||||
|
f.mu.Lock()
|
||||||
|
defer f.mu.Unlock()
|
||||||
|
delete(f.ts, t)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *fakeLibusb) data(t *libusbTransfer) (int, TransferStatus) {
|
||||||
|
f.mu.Lock()
|
||||||
|
defer f.mu.Unlock()
|
||||||
|
return f.ts[t].length, f.ts[t].status
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *fakeLibusb) waitForSubmitted() *fakeTransfer {
|
||||||
|
return <-f.submitted
|
||||||
|
}
|
||||||
|
|
||||||
func (f *fakeLibusb) getDevices(*libusbContext) ([]*libusbDevice, error) {
|
func (f *fakeLibusb) getDevices(*libusbContext) ([]*libusbDevice, error) {
|
||||||
ret := make([]*libusbDevice, 0, len(fakeDevices))
|
ret := make([]*libusbDevice, 0, len(fakeDevices))
|
||||||
for d := range fakeDevices {
|
for d := range fakeDevices {
|
||||||
@@ -234,3 +225,12 @@ func (f *fakeLibusb) close(h *libusbDevHandle) {
|
|||||||
defer f.mu.Unlock()
|
defer f.mu.Unlock()
|
||||||
delete(f.handlers, h)
|
delete(f.handlers, h)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func newFakeLibusb() *fakeLibusb {
|
||||||
|
return &fakeLibusb{
|
||||||
|
ts: make(map[*libusbTransfer]*fakeTransfer),
|
||||||
|
submitted: make(chan *fakeTransfer, 10),
|
||||||
|
handlers: make(map[*libusbDevHandle]*libusbDevice),
|
||||||
|
libusbIntf: libusbImpl{},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user