aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/github.com/karalabe/gousb/usb/endpoint.go
diff options
context:
space:
mode:
authorNick Johnson <arachnid@notdot.net>2017-02-20 00:19:40 +0800
committerGitHub <noreply@github.com>2017-02-20 00:19:40 +0800
commite51f65af1f440aa4b221568e4a546455b7fe0964 (patch)
tree41a823398466c725f5072e052ef5fefe6326dcef /vendor/github.com/karalabe/gousb/usb/endpoint.go
parent037c8b9ae9abe7b8739943838c91255abc2dd3b5 (diff)
parent6ec81352560e3e4268855115eda9d78f6e27875f (diff)
downloadgo-tangerine-e51f65af1f440aa4b221568e4a546455b7fe0964.tar
go-tangerine-e51f65af1f440aa4b221568e4a546455b7fe0964.tar.gz
go-tangerine-e51f65af1f440aa4b221568e4a546455b7fe0964.tar.bz2
go-tangerine-e51f65af1f440aa4b221568e4a546455b7fe0964.tar.lz
go-tangerine-e51f65af1f440aa4b221568e4a546455b7fe0964.tar.xz
go-tangerine-e51f65af1f440aa4b221568e4a546455b7fe0964.tar.zst
go-tangerine-e51f65af1f440aa4b221568e4a546455b7fe0964.zip
Merge pull request #3681 from karalabe/usb-hidapi
accounts/usbwallet: swap karalabe/gousb to karalabe/hid
Diffstat (limited to 'vendor/github.com/karalabe/gousb/usb/endpoint.go')
-rw-r--r--vendor/github.com/karalabe/gousb/usb/endpoint.go100
1 files changed, 0 insertions, 100 deletions
diff --git a/vendor/github.com/karalabe/gousb/usb/endpoint.go b/vendor/github.com/karalabe/gousb/usb/endpoint.go
deleted file mode 100644
index 12b4ccf95..000000000
--- a/vendor/github.com/karalabe/gousb/usb/endpoint.go
+++ /dev/null
@@ -1,100 +0,0 @@
-// Copyright 2013 Google Inc. All rights reserved.
-//
-// Licensed under the Apache License, Version 2.0 (the "License");
-// you may not use this file except in compliance with the License.
-// You may obtain a copy of the License at
-//
-// http://www.apache.org/licenses/LICENSE-2.0
-//
-// Unless required by applicable law or agreed to in writing, software
-// distributed under the License is distributed on an "AS IS" BASIS,
-// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-// See the License for the specific language governing permissions and
-// limitations under the License.
-
-package usb
-
-// #include "libusb.h"
-import "C"
-
-import (
- "fmt"
- "reflect"
- "time"
- "unsafe"
-)
-
-type Endpoint interface {
- Read(b []byte) (int, error)
- Write(b []byte) (int, error)
- Interface() InterfaceSetup
- Info() EndpointInfo
-}
-
-type endpoint struct {
- *Device
- InterfaceSetup
- EndpointInfo
- xfer func(*endpoint, []byte, time.Duration) (int, error)
-}
-
-func (e *endpoint) Read(buf []byte) (int, error) {
- if EndpointDirection(e.Address)&ENDPOINT_DIR_MASK != ENDPOINT_DIR_IN {
- return 0, fmt.Errorf("usb: read: not an IN endpoint")
- }
-
- return e.xfer(e, buf, e.ReadTimeout)
-}
-
-func (e *endpoint) Write(buf []byte) (int, error) {
- if EndpointDirection(e.Address)&ENDPOINT_DIR_MASK != ENDPOINT_DIR_OUT {
- return 0, fmt.Errorf("usb: write: not an OUT endpoint")
- }
-
- return e.xfer(e, buf, e.WriteTimeout)
-}
-
-func (e *endpoint) Interface() InterfaceSetup { return e.InterfaceSetup }
-func (e *endpoint) Info() EndpointInfo { return e.EndpointInfo }
-
-// TODO(kevlar): (*Endpoint).Close
-
-func bulk_xfer(e *endpoint, buf []byte, timeout time.Duration) (int, error) {
- if len(buf) == 0 {
- return 0, nil
- }
-
- data := (*reflect.SliceHeader)(unsafe.Pointer(&buf)).Data
-
- var cnt C.int
- if errno := C.libusb_bulk_transfer(
- e.handle,
- C.uchar(e.Address),
- (*C.uchar)(unsafe.Pointer(data)),
- C.int(len(buf)),
- &cnt,
- C.uint(timeout/time.Millisecond)); errno < 0 {
- return 0, usbError(errno)
- }
- return int(cnt), nil
-}
-
-func interrupt_xfer(e *endpoint, buf []byte, timeout time.Duration) (int, error) {
- if len(buf) == 0 {
- return 0, nil
- }
-
- data := (*reflect.SliceHeader)(unsafe.Pointer(&buf)).Data
-
- var cnt C.int
- if errno := C.libusb_interrupt_transfer(
- e.handle,
- C.uchar(e.Address),
- (*C.uchar)(unsafe.Pointer(data)),
- C.int(len(buf)),
- &cnt,
- C.uint(timeout/time.Millisecond)); errno < 0 {
- return 0, usbError(errno)
- }
- return int(cnt), nil
-}