/* | |
* Copyright (C) 2006 The Android Open Source Project | |
* | |
* 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. | |
*/ | |
#ifndef ANDROID_USB_API_ADB_INTERFACE_H__ | |
#define ANDROID_USB_API_ADB_INTERFACE_H__ | |
/** \file | |
This file consists of declaration of class AdbInterfaceObject that | |
encapsulates an interface on our USB device. | |
*/ | |
#include "adb_object_handle.h" | |
/** \brief Encapsulates an interface on our USB device. | |
*/ | |
class AdbInterfaceObject : public AdbObjectHandle { | |
public: | |
/** \brief Constructs the object. | |
@param[in] interf_name Name of the interface | |
*/ | |
explicit AdbInterfaceObject(const wchar_t* interf_name); | |
protected: | |
/** \brief Destructs the object. | |
We hide destructor in order to prevent ourseves from accidentaly allocating | |
instances on the stack. If such attemp occur, compiler will error. | |
*/ | |
virtual ~AdbInterfaceObject(); | |
public: | |
/** \brief Creates handle to this object. | |
In this call a handle for this object is generated and object is added | |
to the AdbObjectHandleMap. We override this method in order to verify that | |
interface indeed exists and gather device, interface and pipe properties. | |
If this step succeeds then and only then AdbObjectHandle::CreateHandle | |
will be called. Note that in this method we will open a handle to the | |
USB device (saved in usb_device_handle_). The handle will be opened for | |
read and write access, and for read and write sharing mode. The handle | |
will be closed in CloseHandle method of this class. | |
@return A handle to this object on success or NULL on an error. | |
If NULL is returned GetLastError() provides extended error | |
information. ERROR_GEN_FAILURE is set if an attempt was | |
made to create already opened object. | |
*/ | |
virtual ADBAPIHANDLE CreateHandle(); | |
/** \brief This method is called when handle to this object gets closed. | |
In this call object is deleted from the AdbObjectHandleMap. We override | |
this method in order close device and WinUsb handles created in | |
CreateHandle method of this class. | |
@return true on success or false if object is already closed. If | |
false is returned GetLastError() provides extended error | |
information. | |
*/ | |
virtual bool CloseHandle(); | |
/** \brief Gets interface device name. | |
@param[out] buffer Buffer for the name. Can be NULL in which case | |
buffer_char_size will contain number of characters required to fit | |
the name. | |
@param[in,out] buffer_char_size On the way in supplies size (in characters) | |
of the buffer. On the way out if method failed and GetLastError | |
reports ERROR_INSUFFICIENT_BUFFER will contain number of characters | |
required to fit the name. | |
@param[in] ansi If true the name will be returned as single character | |
string. Otherwise name will be returned as wide character string. | |
@return true on success, false on failure. If false is returned | |
GetLastError() provides extended error information. | |
*/ | |
bool GetInterfaceName(void* buffer, | |
unsigned long* buffer_char_size, | |
bool ansi); | |
/** \brief Gets serial number for interface's device. | |
@param[out] buffer Buffer for the serail number string. Can be NULL in | |
which case buffer_char_size will contain number of characters | |
required for the string. | |
@param[in,out] buffer_char_size On the way in supplies size (in characters) | |
of the buffer. On the way out, if method failed and GetLastError | |
reports ERROR_INSUFFICIENT_BUFFER, will contain number of characters | |
required for the name. | |
@param[in] ansi If true the name will be returned as single character | |
string. Otherwise name will be returned as wide character string. | |
@return true on success, false on failure. If false is returned | |
GetLastError() provides extended error information. | |
*/ | |
bool GetSerialNumber(void* buffer, | |
unsigned long* buffer_char_size, | |
bool ansi); | |
/** \brief Gets device descriptor for the USB device associated with | |
this interface. | |
@param[out] desc Upon successful completion will have usb device | |
descriptor. | |
@return true on success, false on failure. If false is returned | |
GetLastError() provides extended error information. | |
*/ | |
bool GetUsbDeviceDescriptor(USB_DEVICE_DESCRIPTOR* desc); | |
/** \brief Gets descriptor for the selected USB device configuration. | |
@param[out] desc Upon successful completion will have usb device | |
configuration descriptor. | |
@return true on success, false on failure. If false is returned | |
GetLastError() provides extended error information. | |
*/ | |
bool GetUsbConfigurationDescriptor(USB_CONFIGURATION_DESCRIPTOR* desc); | |
/** \brief Gets descriptor for this interface. | |
@param[out] desc Upon successful completion will have interface | |
descriptor. | |
@return true on success, false on failure. If false is returned | |
GetLastError() provides extended error information. | |
*/ | |
bool GetUsbInterfaceDescriptor(USB_INTERFACE_DESCRIPTOR* desc); | |
/** \brief Gets information about an endpoint on this interface. | |
@param[in] endpoint_index Zero-based endpoint index. There are two | |
shortcuts for this parameter: ADB_QUERY_BULK_WRITE_ENDPOINT_INDEX | |
and ADB_QUERY_BULK_READ_ENDPOINT_INDEX that provide infor about | |
(default?) bulk write and read endpoints respectively. | |
@param[out] info Upon successful completion will have endpoint information. | |
@return true on success, false on failure. If false is returned | |
GetLastError() provides extended error information. | |
*/ | |
bool GetEndpointInformation(UCHAR endpoint_index, | |
AdbEndpointInformation* info); | |
/** \brief Opens an endpoint on this interface. | |
@param[in] endpoint_index Zero-based endpoint index. There are two | |
shortcuts for this parameter: ADB_QUERY_BULK_WRITE_ENDPOINT_INDEX | |
and ADB_QUERY_BULK_READ_ENDPOINT_INDEX that provide infor about | |
(default?) bulk write and read endpoints respectively. | |
@param[in] access_type Desired access type. In the current implementation | |
this parameter has no effect on the way endpoint is opened. It's | |
always read / write access. | |
@param[in] sharing_mode Desired share mode. In the current implementation | |
this parameter has no effect on the way endpoint is opened. It's | |
always shared for read / write. | |
@return Handle to the opened endpoint object or NULL on failure. | |
If NULL is returned GetLastError() provides extended information | |
about the error that occurred. | |
*/ | |
ADBAPIHANDLE OpenEndpoint(UCHAR endpoint_index, | |
AdbOpenAccessType access_type, | |
AdbOpenSharingMode sharing_mode); | |
/** \brief Opens an endpoint on this interface. | |
@param[in] endpoint_id Endpoint (pipe) address on the device. | |
@param[in] endpoint_index Zero-based endpoint index. | |
@return Handle to the opened endpoint object or NULL on failure. | |
If NULL is returned GetLastError() provides extended information | |
about the error that occurred. | |
*/ | |
ADBAPIHANDLE OpenEndpoint(UCHAR endpoint_id, UCHAR endpoint_index); | |
public: | |
/// Gets name of the USB interface (device name) for this object | |
const std::wstring& interface_name() const { | |
return interface_name_; | |
} | |
/// This is a helper for extracting object from the AdbObjectHandleMap | |
static AdbObjectType Type() { | |
return AdbObjectTypeInterface; | |
} | |
/// Gets cached usb device descriptor | |
const USB_DEVICE_DESCRIPTOR* usb_device_descriptor() const { | |
return &usb_device_descriptor_; | |
} | |
/// Gets cached usb configuration descriptor | |
const USB_CONFIGURATION_DESCRIPTOR* usb_config_descriptor() const { | |
return &usb_config_descriptor_; | |
} | |
/// Gets cached usb interface descriptor | |
const USB_INTERFACE_DESCRIPTOR* usb_interface_descriptor() const { | |
return &usb_interface_descriptor_; | |
} | |
/// Gets handle to the USB device | |
HANDLE usb_device_handle() const { | |
return usb_device_handle_; | |
} | |
/// Gets interface handle used by WinUSB API | |
WINUSB_INTERFACE_HANDLE winusb_handle() const { | |
return winusb_handle_; | |
} | |
/// Gets current interface number. | |
UCHAR interface_number() const { | |
return interface_number_; | |
} | |
private: | |
/// Name of the USB interface (device name) for this object | |
std::wstring interface_name_; | |
/// Cached usb device descriptor | |
USB_DEVICE_DESCRIPTOR usb_device_descriptor_; | |
/// Cached usb configuration descriptor | |
USB_CONFIGURATION_DESCRIPTOR usb_config_descriptor_; | |
/// Cached usb interface descriptor | |
USB_INTERFACE_DESCRIPTOR usb_interface_descriptor_; | |
/// Handle to the USB device | |
HANDLE usb_device_handle_; | |
/// Interface handle used by WinUSB API | |
WINUSB_INTERFACE_HANDLE winusb_handle_; | |
/// Current interface number. This value is obtained via call to | |
/// WinUsb_GetCurrentAlternateSetting and is used in WinUsb_Xxx | |
/// calls that require interface number. | |
UCHAR interface_number_; | |
/// Index for the default bulk read endpoint | |
UCHAR def_read_endpoint_; | |
/// ID for the default bulk read endpoint | |
UCHAR read_endpoint_id_; | |
/// Index for the default bulk write endpoint | |
UCHAR def_write_endpoint_; | |
/// ID for the default bulk write endpoint | |
UCHAR write_endpoint_id_; | |
}; | |
#endif // ANDROID_USB_API_ADB_INTERFACE_H__ |