1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef DEVICE_USB_USB_DEVICE_HANDLE_H_
6 #define DEVICE_USB_USB_DEVICE_HANDLE_H_
11 #include "base/callback.h"
12 #include "base/memory/ref_counted.h"
13 #include "base/strings/string16.h"
14 #include "base/threading/thread_checker.h"
15 #include "device/usb/usb_descriptors.h"
16 #include "net/base/io_buffer.h"
22 enum UsbTransferStatus
{
23 USB_TRANSFER_COMPLETED
= 0,
26 USB_TRANSFER_CANCELLED
,
28 USB_TRANSFER_DISCONNECT
,
29 USB_TRANSFER_OVERFLOW
,
30 USB_TRANSFER_LENGTH_SHORT
,
33 // UsbDeviceHandle class provides basic I/O related functionalities.
34 class UsbDeviceHandle
: public base::RefCountedThreadSafe
<UsbDeviceHandle
> {
36 using ResultCallback
= base::Callback
<void(bool)>;
37 using TransferCallback
= base::Callback
<
38 void(UsbTransferStatus
, scoped_refptr
<net::IOBuffer
>, size_t)>;
40 enum TransferRequestType
{ STANDARD
, CLASS
, VENDOR
, RESERVED
};
41 enum TransferRecipient
{ DEVICE
, INTERFACE
, ENDPOINT
, OTHER
};
43 virtual scoped_refptr
<UsbDevice
> GetDevice() const = 0;
45 // Notifies UsbDevice to drop the reference of this object; cancels all the
47 // It is possible that the object has no other reference after this call. So
48 // if it is called using a raw pointer, it could be invalidated.
49 // The platform device handle will be closed when UsbDeviceHandle destructs.
50 virtual void Close() = 0;
52 // Device manipulation operations.
53 virtual void SetConfiguration(int configuration_value
,
54 const ResultCallback
& callback
) = 0;
55 virtual void ClaimInterface(int interface_number
,
56 const ResultCallback
& callback
) = 0;
57 virtual bool ReleaseInterface(int interface_number
) = 0;
58 virtual void SetInterfaceAlternateSetting(int interface_number
,
59 int alternate_setting
,
60 const ResultCallback
& callback
) = 0;
61 virtual void ResetDevice(const ResultCallback
& callback
) = 0;
62 virtual void ClearHalt(uint8 endpoint
, const ResultCallback
& callback
) = 0;
64 // The transfer functions may be called from any thread. The provided callback
65 // will be run on the caller's thread.
66 virtual void ControlTransfer(UsbEndpointDirection direction
,
67 TransferRequestType request_type
,
68 TransferRecipient recipient
,
72 scoped_refptr
<net::IOBuffer
> buffer
,
75 const TransferCallback
& callback
) = 0;
77 virtual void BulkTransfer(UsbEndpointDirection direction
,
79 scoped_refptr
<net::IOBuffer
> buffer
,
82 const TransferCallback
& callback
) = 0;
84 virtual void InterruptTransfer(UsbEndpointDirection direction
,
86 scoped_refptr
<net::IOBuffer
> buffer
,
89 const TransferCallback
& callback
) = 0;
91 virtual void IsochronousTransfer(UsbEndpointDirection direction
,
93 scoped_refptr
<net::IOBuffer
> buffer
,
96 unsigned int packet_length
,
98 const TransferCallback
& callback
) = 0;
101 friend class base::RefCountedThreadSafe
<UsbDeviceHandle
>;
103 UsbDeviceHandle() {};
105 virtual ~UsbDeviceHandle() {};
107 DISALLOW_COPY_AND_ASSIGN(UsbDeviceHandle
);
110 } // namespace device
112 #endif // DEVICE_USB_USB_DEVICE_HANDLE_H_