Pin Chrome's shortcut to the Win10 Start menu on install and OS upgrade.
[chromium-blink-merge.git] / device / usb / usb_device_handle.h
blob2c59f2508b4d06e297b257c019b13277e4ce81ec
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_
8 #include <map>
9 #include <vector>
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"
18 namespace device {
20 class UsbDevice;
22 enum UsbTransferStatus {
23 USB_TRANSFER_COMPLETED = 0,
24 USB_TRANSFER_ERROR,
25 USB_TRANSFER_TIMEOUT,
26 USB_TRANSFER_CANCELLED,
27 USB_TRANSFER_STALLED,
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> {
35 public:
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
46 // flying transfers.
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;
63 // The transfer functions may be called from any thread. The provided callback
64 // will be run on the caller's thread.
65 virtual void ControlTransfer(UsbEndpointDirection direction,
66 TransferRequestType request_type,
67 TransferRecipient recipient,
68 uint8 request,
69 uint16 value,
70 uint16 index,
71 scoped_refptr<net::IOBuffer> buffer,
72 size_t length,
73 unsigned int timeout,
74 const TransferCallback& callback) = 0;
76 virtual void BulkTransfer(UsbEndpointDirection direction,
77 uint8 endpoint,
78 scoped_refptr<net::IOBuffer> buffer,
79 size_t length,
80 unsigned int timeout,
81 const TransferCallback& callback) = 0;
83 virtual void InterruptTransfer(UsbEndpointDirection direction,
84 uint8 endpoint,
85 scoped_refptr<net::IOBuffer> buffer,
86 size_t length,
87 unsigned int timeout,
88 const TransferCallback& callback) = 0;
90 virtual void IsochronousTransfer(UsbEndpointDirection direction,
91 uint8 endpoint,
92 scoped_refptr<net::IOBuffer> buffer,
93 size_t length,
94 unsigned int packets,
95 unsigned int packet_length,
96 unsigned int timeout,
97 const TransferCallback& callback) = 0;
99 protected:
100 friend class base::RefCountedThreadSafe<UsbDeviceHandle>;
102 UsbDeviceHandle() {};
104 virtual ~UsbDeviceHandle() {};
106 DISALLOW_COPY_AND_ASSIGN(UsbDeviceHandle);
109 } // namespace device
111 #endif // DEVICE_USB_USB_DEVICE_HANDLE_H_