/* * 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_ENDPOINT_OBJECT_H__ #define ANDROID_USB_API_ADB_ENDPOINT_OBJECT_H__ /** \file This file consists of declaration of class AdbEndpointObject that encapsulates a handle opened to an endpoint on our device. */ #include "adb_interface.h" /** Class AdbEndpointObject encapsulates a handle opened to an endpoint on our device. This class implement functionality that is common for both, WinUsb and legacy APIs. */ class ADBWIN_API_CLASS AdbEndpointObject : public AdbObjectHandle { public: /** \brief Constructs the object @param[in] interface Parent interface for this object. Interface will be referenced in this object's constructur and released in the destructor. @param[in] endpoint_id Endpoint ID (endpoint address) on the device. @param[in] endpoint_index Zero-based endpoint index in the interface's array of endpoints. */ AdbEndpointObject(AdbInterfaceObject* parent_interf, UCHAR endpoint_id, UCHAR endpoint_index); 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 ~AdbEndpointObject(); // // Abstract // protected: /** \brief Common code for async read / write @param[in] is_read Read or write selector. @param[in,out] buffer Pointer to the buffer for read / write. @param[in] bytes_to_transfer Number of bytes to be read / written. @param[out] bytes_transferred Number of bytes read / written. Can be NULL. @param[in] event_handle Event handle that should be signaled when async I/O completes. Can be NULL. If it's not NULL this handle will be used to initialize OVERLAPPED structure for this I/O. @param[in] time_out A timeout (in milliseconds) required for this I/O to complete. Zero value in this parameter means that there is no timeout set for this I/O. @return A handle to IO completion object or NULL on failure. If NULL is returned GetLastError() provides extended error information. */ virtual ADBAPIHANDLE CommonAsyncReadWrite(bool is_read, void* buffer, ULONG bytes_to_transfer, ULONG* bytes_transferred, HANDLE event_handle, ULONG time_out) = 0; /** \brief Common code for sync read / write @param[in] is_read Read or write selector. @param[in,out] buffer Pointer to the buffer for read / write. @param[in] bytes_to_transfer Number of bytes to be read / written. @param[out] bytes_transferred Number of bytes read / written. Can be NULL. @param[in] time_out A timeout (in milliseconds) required for this I/O to complete. Zero value in this parameter means that there is no timeout set for this I/O. @return true on success, false on failure. If false is returned GetLastError() provides extended error information. */ virtual bool CommonSyncReadWrite(bool is_read, void* buffer, ULONG bytes_to_transfer, ULONG* bytes_transferred, ULONG time_out) = 0; // // Operations // public: /** \brief Gets information about this endpoint. @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. */ virtual bool GetEndpointInformation(AdbEndpointInformation* info); /** \brief Reads from opened I/O object asynchronously @param[out] buffer Pointer to the buffer that receives the data. @param[in] bytes_to_read Number of bytes to be read. @param[out] bytes_read Number of bytes read. Can be NULL. @param[in] event_handle Event handle that should be signaled when async I/O completes. Can be NULL. If it's not NULL this handle will be used to initialize OVERLAPPED structure for this I/O. @param[in] time_out A timeout (in milliseconds) required for this I/O to complete. Zero value in this parameter means that there is no timeout set for this I/O. @return A handle to IO completion object or NULL on failure. If NULL is returned GetLastError() provides extended error information. */ virtual ADBAPIHANDLE AsyncRead(void* buffer, ULONG bytes_to_read, ULONG* bytes_read, HANDLE event_handle, ULONG time_out); /** \brief Writes to opened I/O object asynchronously @param[in] buffer Pointer to the buffer containing the data to be written. @param[in] bytes_to_write Number of bytes to be written. @param[out] bytes_written Number of bytes written. Can be NULL. @param[in] event_handle Event handle that should be signaled when async I/O completes. Can be NULL. If it's not NULL this handle will be used to initialize OVERLAPPED structure for this I/O. @param[in] time_out A timeout (in milliseconds) required for this I/O to complete. Zero value in this parameter means that there is no timeout set for this I/O. @return A handle to IO completion object or NULL on failure. If NULL is returned GetLastError() provides extended error information. */ virtual ADBAPIHANDLE AsyncWrite(void* buffer, ULONG bytes_to_write, ULONG* bytes_written, HANDLE event_handle, ULONG time_out); /** \brief Reads from opened I/O object synchronously @param[out] buffer Pointer to the buffer that receives the data. @param[in] bytes_to_read Number of bytes to be read. @param[out] bytes_read Number of bytes read. Can be NULL. @param[in] time_out A timeout (in milliseconds) required for this I/O to complete. Zero value in this parameter means that there is no timeout set for this I/O. @return true on success and false on failure. If false is returned GetLastError() provides extended error information. */ virtual bool SyncRead(void* buffer, ULONG bytes_to_read, ULONG* bytes_read, ULONG time_out); /** \brief Writes to opened I/O object synchronously @param[in] buffer Pointer to the buffer containing the data to be written. @param[in] bytes_to_write Number of bytes to be written. @param[out] bytes_written Number of bytes written. Can be NULL. @param[in] time_out A timeout (in milliseconds) required for this I/O to complete. Zero value in this parameter means that there is no timeout set for this I/O. @return true on success and false on failure. If false is returned GetLastError() provides extended error information. */ virtual bool SyncWrite(void* buffer, ULONG bytes_to_write, ULONG* bytes_written, ULONG time_out); public: /// This is a helper for extracting object from the AdbObjectHandleMap static AdbObjectType Type() { return AdbObjectTypeEndpoint; } /// Gets parent interface AdbInterfaceObject* parent_interface() const { return parent_interface_; } /// Gets this endpoint ID UCHAR endpoint_id() const { return endpoint_id_; } /// Gets this endpoint index on the interface UCHAR endpoint_index() const { return endpoint_index_; } /// Gets parent interface handle ADBAPIHANDLE GetParentInterfaceHandle() const { return (NULL != parent_interface()) ? parent_interface()->adb_handle() : NULL; } protected: /// Parent interface AdbInterfaceObject* parent_interface_; /// This endpoint id UCHAR endpoint_id_; /// This endpoint index on the interface UCHAR endpoint_index_; }; #endif // ANDROID_USB_API_ADB_ENDPOINT_OBJECT_H__