Previously, adb was assuming a fixed maximum packet size of 1024 bytes
(the value for an endpoint connected via USB 3.0). When connected to an
endpoint that has an actual maximum packet size of 512 bytes (i.e.
every single device over USB 2.0), the following could occur:
device sends amessage with 512 byte payload
client reads amessage
client tries to read payload with a length of 1024
In this scenario, the kernel will block, waiting for an additional
packet which won't arrive until something else gets sent across the
wire, which will result in the previous read failing, and the new
packet being dropped.
Bug: http://b/37783561
Test: python test_device.py on linux/darwin, with native/libusb
Change-Id: I556f5344945e22dd1533b076f662a97eea24628e
56 lines
2.1 KiB
C++
56 lines
2.1 KiB
C++
/*
|
|
* Copyright (C) 2017 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.
|
|
*/
|
|
|
|
#include <android-base/logging.h>
|
|
#include "usb.h"
|
|
|
|
void usb_init() {
|
|
if (should_use_libusb()) {
|
|
LOG(DEBUG) << "using libusb backend";
|
|
libusb::usb_init();
|
|
} else {
|
|
LOG(DEBUG) << "using native backend";
|
|
native::usb_init();
|
|
}
|
|
}
|
|
|
|
int usb_write(usb_handle* h, const void* data, int len) {
|
|
return should_use_libusb()
|
|
? libusb::usb_write(reinterpret_cast<libusb::usb_handle*>(h), data, len)
|
|
: native::usb_write(reinterpret_cast<native::usb_handle*>(h), data, len);
|
|
}
|
|
|
|
int usb_read(usb_handle* h, void* data, int len) {
|
|
return should_use_libusb()
|
|
? libusb::usb_read(reinterpret_cast<libusb::usb_handle*>(h), data, len)
|
|
: native::usb_read(reinterpret_cast<native::usb_handle*>(h), data, len);
|
|
}
|
|
|
|
int usb_close(usb_handle* h) {
|
|
return should_use_libusb() ? libusb::usb_close(reinterpret_cast<libusb::usb_handle*>(h))
|
|
: native::usb_close(reinterpret_cast<native::usb_handle*>(h));
|
|
}
|
|
|
|
void usb_kick(usb_handle* h) {
|
|
should_use_libusb() ? libusb::usb_kick(reinterpret_cast<libusb::usb_handle*>(h))
|
|
: native::usb_kick(reinterpret_cast<native::usb_handle*>(h));
|
|
}
|
|
|
|
size_t usb_get_max_packet_size(usb_handle* h) {
|
|
return should_use_libusb()
|
|
? libusb::usb_get_max_packet_size(reinterpret_cast<libusb::usb_handle*>(h))
|
|
: native::usb_get_max_packet_size(reinterpret_cast<native::usb_handle*>(h));
|
|
}
|