summaryrefslogtreecommitdiffstats
path: root/media/mtp/MtpDevice.cpp
diff options
context:
space:
mode:
authorMike Lockwood <lockwood@android.com>2010-12-09 18:34:18 -0800
committerMike Lockwood <lockwood@android.com>2010-12-09 18:34:18 -0800
commitf7454622eaac287d20ab43013d7015fe42b894f8 (patch)
tree1bbc63dbaf849ed5226194e933f2de3c9bdb22e0 /media/mtp/MtpDevice.cpp
parent424c6cbfa75da5f4f889ab6517dfee4dd024ba2d (diff)
downloadframeworks_av-f7454622eaac287d20ab43013d7015fe42b894f8.zip
frameworks_av-f7454622eaac287d20ab43013d7015fe42b894f8.tar.gz
frameworks_av-f7454622eaac287d20ab43013d7015fe42b894f8.tar.bz2
MTP host: Handle receiving a response packet instead of data packet.
This will happen if the device needs to report an error rather than returning the data. Change-Id: I477512b3676c2f0518a85a4135832ed4475fbc2d Signed-off-by: Mike Lockwood <lockwood@android.com>
Diffstat (limited to 'media/mtp/MtpDevice.cpp')
-rw-r--r--media/mtp/MtpDevice.cpp19
1 files changed, 16 insertions, 3 deletions
diff --git a/media/mtp/MtpDevice.cpp b/media/mtp/MtpDevice.cpp
index 8ad39dc..e058a5a 100644
--- a/media/mtp/MtpDevice.cpp
+++ b/media/mtp/MtpDevice.cpp
@@ -49,7 +49,8 @@ MtpDevice::MtpDevice(struct usb_device* device, int interface,
mDeviceInfo(NULL),
mID(usb_device_get_unique_id(device)),
mSessionID(0),
- mTransactionID(0)
+ mTransactionID(0),
+ mReceivedResponse(false)
{
}
@@ -513,6 +514,7 @@ fail:
bool MtpDevice::sendRequest(MtpOperationCode operation) {
LOGV("sendRequest: %s\n", MtpDebug::getOperationCodeName(operation));
+ mReceivedResponse = false;
mRequest.setOperationCode(operation);
if (mTransactionID > 0)
mRequest.setTransactionID(mTransactionID++);
@@ -535,6 +537,14 @@ bool MtpDevice::readData() {
int ret = mData.read(mEndpointIn);
LOGV("readData returned %d\n", ret);
if (ret >= MTP_CONTAINER_HEADER_SIZE) {
+ if (mData.getContainerType() == MTP_CONTAINER_TYPE_RESPONSE) {
+ LOGD("got response packet instead of data packet");
+ // we got a response packet rather than data
+ // copy it to mResponse
+ mResponse.copyFrom(mData);
+ mReceivedResponse = true;
+ return false;
+ }
mData.dump();
return true;
}
@@ -552,12 +562,15 @@ bool MtpDevice::writeDataHeader(MtpOperationCode operation, int dataLength) {
MtpResponseCode MtpDevice::readResponse() {
LOGV("readResponse\n");
+ if (mReceivedResponse) {
+ mReceivedResponse = false;
+ return mResponse.getResponseCode();
+ }
int ret = mResponse.read(mEndpointIn);
if (ret >= MTP_CONTAINER_HEADER_SIZE) {
mResponse.dump();
return mResponse.getResponseCode();
- }
- else {
+ } else {
LOGD("readResponse failed\n");
return -1;
}