move newUSBTransfer as a vanilla function to transfer.go.
Initialize all static params at new.
This commit is contained in:
@@ -41,8 +41,15 @@ type usbTransfer struct {
|
|||||||
buf []byte
|
buf []byte
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *usbTransfer) submit(timeout time.Duration) error {
|
type deviceHandle *C.libusb_device_handle
|
||||||
t.xfer.timeout = C.uint(timeout / time.Millisecond)
|
|
||||||
|
func (t *usbTransfer) attach(dev deviceHandle) {
|
||||||
|
t.xfer.dev_handle = dev
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *usbTransfer) submit() error {
|
||||||
|
done := make(chan struct{}, 1)
|
||||||
|
t.xfer.user_data = (unsafe.Pointer)(&done)
|
||||||
if errno := C.submit(t.xfer); errno < 0 {
|
if errno := C.submit(t.xfer); errno < 0 {
|
||||||
return usbError(errno)
|
return usbError(errno)
|
||||||
}
|
}
|
||||||
@@ -73,3 +80,33 @@ func (t *usbTransfer) free() error {
|
|||||||
C.libusb_free_transfer(t.xfer)
|
C.libusb_free_transfer(t.xfer)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func newUSBTransfer(ei EndpointInfo, buf []byte, timeout time.Duration) (*usbTransfer, error) {
|
||||||
|
var isoPackets int
|
||||||
|
tt := ei.TransferType()
|
||||||
|
if tt == TRANSFER_TYPE_ISOCHRONOUS {
|
||||||
|
isoPackets = len(buf) / int(ei.MaxIsoPacket)
|
||||||
|
}
|
||||||
|
|
||||||
|
xfer := C.libusb_alloc_transfer(C.int(isoPackets))
|
||||||
|
if xfer == nil {
|
||||||
|
return nil, fmt.Errorf("libusb_alloc_transfer(%d) failed", isoPackets)
|
||||||
|
}
|
||||||
|
|
||||||
|
xfer.timeout = C.uint(timeout / time.Millisecond)
|
||||||
|
xfer.endpoint = C.uchar(ei.Address)
|
||||||
|
xfer._type = C.uchar(tt)
|
||||||
|
|
||||||
|
xfer.buffer = (*C.uchar)((unsafe.Pointer)(&buf[0]))
|
||||||
|
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))
|
||||||
|
}
|
||||||
|
|
||||||
|
return &usbTransfer{
|
||||||
|
xfer: xfer,
|
||||||
|
buf: buf,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user