Sebastian Zagrodzki
eed6d08423
Re-use the same done channel for every callback of a single transfer.
2017-04-26 21:35:26 +02:00
Sebastian Zagrodzki
c1009ed25d
Call back to Go function directly, it will know how to deal with an xfer
...
pointer.
2017-04-26 21:33:45 +02:00
Sebastian Zagrodzki
550fe8d1f2
Introduce xferMap, avoid passing Go pointer into the C code.
...
Weirdness with memory barriers.
2017-04-26 21:32:49 +02:00
Sebastian Zagrodzki
dacae32d83
Tests for read transfers, starting on write transfers.
2017-04-23 22:58:30 +02:00
Sebastian Zagrodzki
b50bc8761f
First version of streaming transfers.
2017-04-23 10:45:04 +02:00
Sebastian Zagrodzki
d92ea14c33
Add a test to catch invalud endpoint info.
2017-04-10 03:25:32 +02:00
Sebastian Zagrodzki
9cecdec977
Fix a bug where EndpointInfo would always be picked from the last
...
alternative setting.
When looking up matching EndpointInfo and InterfaceSetting for
an endpoint, a reference to range variable is stored. If range is
allowed to continue, the value of this variable will be updated.
It's a trick to allow use of "nil" pointer as a "found" variable, but it
requires a careful management of the range iterations.
2017-04-10 03:16:59 +02:00
Sebastian Zagrodzki
b0d5519c67
Change the iso packet size if the buffer is very small.
...
Previously number of iso packets could have amounted to a transfer
buffer larger than passed buffer, which could lead to overflow.
Now the number of bytes requested from device is always smaller or equal
to the buffer size.
In theory, it could lead to inefficiencies in transfer: if max packet
size is 1024 and user request 2046 bytes of data, transfer will return at most
1024 bytes, while it could use a more efficient 2 packets of 1023 bytes.
But at least it's correct now. It seems that for efficiency the user would
always use the reported max packet size anyway.
The device could still send more data than requested, but libusb takes
care of it.
2017-04-10 02:45:16 +02:00
Sebastian Zagrodzki
5efb68e45e
iota used on the second line of const block starts from 1, not from 0...
2017-04-10 01:41:36 +02:00
Sebastian Zagrodzki
5150242633
Set slice length, since we don't use append.
2017-04-10 01:41:12 +02:00
Sebastian Zagrodzki
453e3832b2
Add tests for failed open. Add tests for OutEndpoint.Write
2017-04-10 01:28:21 +02:00
Sebastian Zagrodzki
b6794b7d45
Add a test for InEndpoint.Read. Use ID for vid/pid in OpenDevice...
2017-04-10 01:25:51 +02:00
Sebastian Zagrodzki
b1dcaa1195
Add Device.OutEndpoint, simplify endpoint test.
2017-04-10 01:11:38 +02:00
Sebastian Zagrodzki
57b10f0dd3
Remove OpenEndpoint, add InEndpoint for Read transfers.
2017-04-10 01:00:53 +02:00
Sebastian Zagrodzki
dd405348e9
move tests around
2017-04-09 20:55:37 +02:00
Sebastian Zagrodzki
128c206986
Move EndpointInfo to endpoint.go
2017-04-09 20:51:47 +02:00
Sebastian Zagrodzki
aaef575b06
rename Setups to AltSettings
2017-04-09 20:45:35 +02:00
Sebastian Zagrodzki
188fd8382d
more comments
2017-04-09 20:27:37 +02:00
Sebastian Zagrodzki
56162d0105
Remove BCD.Int, add BCD.Major/Minor. Remove USB spec versions
...
- I don't expect them to get much use, and reuse of BCD for USB spec
version and device revision makes it somewhat confusing.
2017-04-09 20:25:16 +02:00
Sebastian Zagrodzki
a5c4de3a29
more comments. Rename USBError to just Error.
2017-04-09 19:41:44 +02:00
Sebastian Zagrodzki
87c7a873e9
Go naming for error codes. Export USBError type.
2017-04-09 19:27:33 +02:00
Sebastian Zagrodzki
54aed557d8
more comments
2017-04-09 19:18:11 +02:00
Sebastian Zagrodzki
b09de1cf09
more comments
2017-04-09 19:17:13 +02:00
Sebastian Zagrodzki
f668df87df
OpenEndpoint for now takes an address - a device can have two endpoints
...
with the same number...
2017-04-09 19:08:42 +02:00
Sebastian Zagrodzki
f58798160d
make addr() part of EndpointInfo
2017-04-09 18:55:41 +02:00
Sebastian Zagrodzki
13f4e95f2f
Unexport bitmasks, they are only used internally. All values present
...
in exported structs are meaningful and the users should not need to use
bitmasks.
2017-04-09 18:53:49 +02:00
Sebastian Zagrodzki
3d62929e05
Replace EndpointDirection with a bool
2017-04-09 18:51:51 +02:00
Sebastian Zagrodzki
168b501d53
Rename IfClass/IfSubClass/IfProtocol to Class/SubClass/Protocol, these
...
fields occur within an interface descriptor.
2017-04-09 18:44:32 +02:00
Sebastian Zagrodzki
f91d53931a
Use Protocol type for USB interface protocol.
2017-04-09 18:42:04 +02:00
Sebastian Zagrodzki
d3428d9b35
Use Class for classes in usbid.
2017-04-09 18:29:16 +02:00
Sebastian Zagrodzki
af00028b97
more comments, add Milliamperes type.
2017-04-09 18:15:48 +02:00
Sebastian Zagrodzki
c437b39ef7
comments for endpointinfo type fields
2017-04-09 16:56:36 +02:00
Sebastian Zagrodzki
3e59eeac6c
replace class/subclass with Class type
2017-04-09 16:41:38 +02:00
Sebastian Zagrodzki
83302ae558
add test for an interrupt endpoint.
2017-04-09 00:22:11 +02:00
Sebastian Zagrodzki
ab6b612d1b
String of the endpoint should use EndpointInfo, not the default mapping
...
from InterfaceInfo.
2017-04-09 00:18:54 +02:00
Sebastian Zagrodzki
ca02c03241
since this is the only usecase, return a *libusbDevice for a new
...
pointer.
2017-04-09 00:12:39 +02:00
Sebastian Zagrodzki
3ec748db4c
An invalid pointer triggers a runtime failure when passed as argument in
...
Go1.7:
runtime: bad pointer in frame
github.com/kylelemons/gousb/usb.(*fakeLibusb).open at 0xc420045ce0: 0x1
fatal error: invalid stack pointer
Use an arbitrary C-allocated pointer instead.
2017-04-09 00:10:15 +02:00
Sebastian Zagrodzki
e0f30623b3
Modify EndpointInfo to provide meaningful data rather than raw USB
...
descriptor values. E.g. for the user, the distinction between
MaxIsoPkt and MaxPktSize is irrelevant, only the calculated max packet
size matters.
2017-04-08 23:49:10 +02:00
Sebastian Zagrodzki
d982ef5a37
Add constants for device speed.
2017-03-27 23:01:02 +02:00
Sebastian Zagrodzki
f3b2f37e3a
Rename the rest of the constants.
2017-03-27 22:33:29 +02:00
Sebastian Zagrodzki
36241e869e
more constants
2017-03-27 22:29:24 +02:00
Sebastian Zagrodzki
b70848cf73
start renaming the constants to Go-style.
2017-03-27 22:23:47 +02:00
Sebastian Zagrodzki
341fde410e
replace Endpoint interface with a real Endpoint struct.
2017-03-27 22:15:45 +02:00
Sebastian Zagrodzki
0a7fc9fb53
Merge branch 'master' of https://github.com/kylelemons/gousb into libusb_wrappers_tests
2017-03-26 17:46:12 +02:00
Sebastian Zagrodzki
1f977a94aa
Update the comment - there's no way to create a new pointer to struct
...
libusb_device, since the struct is not defined in libusb headers (only
name is declared), as such the compiler doesn't know the size of the
struct to allocate.
2017-03-26 17:44:25 +02:00
Sebastian Zagrodzki
4c5589cffb
Moar comments.
2017-03-23 18:07:55 +01:00
Sebastian Zagrodzki
fc41761879
Remove the alloc test that used real libusb allocation.
2017-03-10 09:25:57 -05:00
Sebastian Zagrodzki
81f2998055
Merge branch 'coverage' into libusb_wrappers_tests
2017-03-10 08:55:45 -05:00
Sebastian Zagrodzki
389ae4e2b3
EndpointInfo tests
2017-03-10 08:48:21 -05:00
Sebastian Zagrodzki
a221bef905
ensure the vid/pid match
2017-03-10 08:36:00 -05:00