move all libusb wrappers to libusb.go.

This commit is contained in:
Sebastian Zagrodzki
2017-02-23 10:25:02 +01:00
parent 6afb417224
commit cc135fe616
9 changed files with 88 additions and 320 deletions

View File

@@ -14,14 +14,6 @@
package usb
/*
#include <libusb.h>
int compact_iso_data(struct libusb_transfer *xfer, unsigned char *status);
int submit(struct libusb_transfer *xfer);
*/
import "C"
import (
"errors"
"fmt"
@@ -31,32 +23,8 @@ import (
"unsafe"
)
// libusb hooks used as injection points for tests.
var (
cCancel = func(t *libusbTransfer) usbError {
return usbError(C.libusb_cancel_transfer((*C.struct_libusb_transfer)(t)))
}
cSubmit = func(t *libusbTransfer) usbError {
return usbError(C.submit((*C.struct_libusb_transfer)(t)))
}
)
// because of a limitation of cgo, tests cannot import C.
type deviceHandle C.libusb_device_handle
type libusbTransfer C.struct_libusb_transfer
type libusbIso C.struct_libusb_iso_packet_descriptor
// also for tests
var (
libusbIsoSize = C.sizeof_struct_libusb_iso_packet_descriptor
libusbIsoOffset = unsafe.Offsetof(C.struct_libusb_transfer{}.iso_packet_desc)
)
//export xfer_callback
func xfer_callback(cptr unsafe.Pointer) {
ch := *(*chan struct{})(cptr)
close(ch)
}
// #include <libusb.h>
import "C"
type usbTransfer struct {
// mu protects the transfer state.
@@ -84,7 +52,7 @@ func (t *usbTransfer) submit() error {
}
t.done = make(chan struct{})
t.xfer.user_data = (unsafe.Pointer)(&t.done)
if err := cSubmit(t.xfer); err != SUCCESS {
if err := libusb.submit(t.xfer); err != nil {
return err
}
t.submitted = true
@@ -111,10 +79,9 @@ func (t *usbTransfer) wait() (n int, err error) {
var status TransferStatus
switch TransferType(t.xfer._type) {
case TRANSFER_TYPE_ISOCHRONOUS:
n = int(C.compact_iso_data((*C.struct_libusb_transfer)(t.xfer), (*C.uchar)(unsafe.Pointer(&status))))
n, status = libusb.compactIsoData(t.xfer)
default:
n = int(t.xfer.actual_length)
status = TransferStatus(t.xfer.status)
n, status = int(t.xfer.actual_length), TransferStatus(t.xfer.status)
}
if status != LIBUSB_TRANSFER_COMPLETED {
return n, status
@@ -130,15 +97,12 @@ func (t *usbTransfer) cancel() error {
if !t.submitted {
return nil
}
err := usbError(cCancel(t.xfer))
err := libusb.cancel(t.xfer)
if err == ERROR_NOT_FOUND {
// transfer already completed
err = SUCCESS
return nil
}
if err != SUCCESS {
return err
}
return nil
return err
}
// free releases the memory allocated for the transfer.
@@ -150,7 +114,7 @@ func (t *usbTransfer) free() error {
if t.submitted {
return errors.New("free() cannot be called on a submitted transfer until wait() returns")
}
C.libusb_free_transfer((*C.struct_libusb_transfer)(t.xfer))
libusb.free(t.xfer)
t.xfer = nil
t.buf = nil
t.done = nil
@@ -159,7 +123,7 @@ func (t *usbTransfer) free() error {
// newUSBTransfer allocates a new transfer structure for communication with a
// given device/endpoint, with buf as the underlying transfer buffer.
func newUSBTransfer(dev *deviceHandle, ei EndpointInfo, buf []byte, timeout time.Duration) (*usbTransfer, error) {
func newUSBTransfer(dev *libusbDevHandle, ei EndpointInfo, buf []byte, timeout time.Duration) (*usbTransfer, error) {
var isoPackets int
tt := ei.TransferType()
if tt == TRANSFER_TYPE_ISOCHRONOUS {
@@ -169,9 +133,9 @@ func newUSBTransfer(dev *deviceHandle, ei EndpointInfo, buf []byte, timeout time
}
}
xfer := C.libusb_alloc_transfer(C.int(isoPackets))
if xfer == nil {
return nil, fmt.Errorf("libusb_alloc_transfer(%d) failed", isoPackets)
xfer, err := libusb.alloc(isoPackets)
if err != nil {
return nil, err
}
xfer.dev_handle = (*C.struct_libusb_device_handle)(dev)
@@ -183,8 +147,7 @@ func newUSBTransfer(dev *deviceHandle, ei EndpointInfo, buf []byte, timeout time
xfer.length = C.int(len(buf))
if tt == TRANSFER_TYPE_ISOCHRONOUS {
xfer.num_iso_packets = C.int(isoPackets)
C.libusb_set_iso_packet_lengths(xfer, C.uint(ei.MaxIsoPacket))
libusb.setIsoPacketLengths(xfer, ei.MaxIsoPacket)
}
t := &usbTransfer{