Loading camera/camera2/ICameraDeviceCallbacks.cpp +10 −5 Original line number Diff line number Diff line Loading @@ -57,11 +57,12 @@ public: data.writeNoException(); } void onResultReceived(int32_t frameId, const CameraMetadata& result) { void onResultReceived(int32_t requestId, const CameraMetadata& result) { ALOGV("onResultReceived"); Parcel data, reply; data.writeInterfaceToken(ICameraDeviceCallbacks::getInterfaceDescriptor()); data.writeInt32(frameId); data.writeInt32(requestId); data.writeInt32(1); // to mark presence of metadata object result.writeToParcel(&data); remote()->transact(RESULT_RECEIVED, data, &reply, IBinder::FLAG_ONEWAY); data.writeNoException(); Loading Loading @@ -91,10 +92,14 @@ status_t BnCameraDeviceCallbacks::onTransact( case RESULT_RECEIVED: { ALOGV("RESULT_RECEIVED"); CHECK_INTERFACE(ICameraDeviceCallbacks, data, reply); int32_t frameId = data.readInt32(); int32_t requestId = data.readInt32(); CameraMetadata result; if (data.readInt32() != 0) { result.readFromParcel(const_cast<Parcel*>(&data)); onResultReceived(frameId, result); } else { ALOGW("No metadata object is present in result"); } onResultReceived(requestId, result); data.readExceptionCode(); return NO_ERROR; break; Loading services/camera/libcameraservice/common/FrameProcessorBase.cpp +4 −4 Original line number Diff line number Diff line Loading @@ -143,7 +143,7 @@ status_t FrameProcessorBase::processListeners(const CameraMetadata &frame, __FUNCTION__, device->getId()); return BAD_VALUE; } int32_t frameId = entry.data.i32[0]; int32_t requestId = entry.data.i32[0]; List<sp<FilteredListener> > listeners; { Loading @@ -151,8 +151,8 @@ status_t FrameProcessorBase::processListeners(const CameraMetadata &frame, List<RangeListener>::iterator item = mRangeListeners.begin(); while (item != mRangeListeners.end()) { if (frameId >= item->minId && frameId < item->maxId) { if (requestId >= item->minId && requestId < item->maxId) { sp<FilteredListener> listener = item->listener.promote(); if (listener == 0) { item = mRangeListeners.erase(item); Loading @@ -167,7 +167,7 @@ status_t FrameProcessorBase::processListeners(const CameraMetadata &frame, ALOGV("Got %d range listeners out of %d", listeners.size(), mRangeListeners.size()); List<sp<FilteredListener> >::iterator item = listeners.begin(); for (; item != listeners.end(); item++) { (*item)->onFrameAvailable(frameId, frame); (*item)->onFrameAvailable(requestId, frame); } return OK; } Loading Loading
camera/camera2/ICameraDeviceCallbacks.cpp +10 −5 Original line number Diff line number Diff line Loading @@ -57,11 +57,12 @@ public: data.writeNoException(); } void onResultReceived(int32_t frameId, const CameraMetadata& result) { void onResultReceived(int32_t requestId, const CameraMetadata& result) { ALOGV("onResultReceived"); Parcel data, reply; data.writeInterfaceToken(ICameraDeviceCallbacks::getInterfaceDescriptor()); data.writeInt32(frameId); data.writeInt32(requestId); data.writeInt32(1); // to mark presence of metadata object result.writeToParcel(&data); remote()->transact(RESULT_RECEIVED, data, &reply, IBinder::FLAG_ONEWAY); data.writeNoException(); Loading Loading @@ -91,10 +92,14 @@ status_t BnCameraDeviceCallbacks::onTransact( case RESULT_RECEIVED: { ALOGV("RESULT_RECEIVED"); CHECK_INTERFACE(ICameraDeviceCallbacks, data, reply); int32_t frameId = data.readInt32(); int32_t requestId = data.readInt32(); CameraMetadata result; if (data.readInt32() != 0) { result.readFromParcel(const_cast<Parcel*>(&data)); onResultReceived(frameId, result); } else { ALOGW("No metadata object is present in result"); } onResultReceived(requestId, result); data.readExceptionCode(); return NO_ERROR; break; Loading
services/camera/libcameraservice/common/FrameProcessorBase.cpp +4 −4 Original line number Diff line number Diff line Loading @@ -143,7 +143,7 @@ status_t FrameProcessorBase::processListeners(const CameraMetadata &frame, __FUNCTION__, device->getId()); return BAD_VALUE; } int32_t frameId = entry.data.i32[0]; int32_t requestId = entry.data.i32[0]; List<sp<FilteredListener> > listeners; { Loading @@ -151,8 +151,8 @@ status_t FrameProcessorBase::processListeners(const CameraMetadata &frame, List<RangeListener>::iterator item = mRangeListeners.begin(); while (item != mRangeListeners.end()) { if (frameId >= item->minId && frameId < item->maxId) { if (requestId >= item->minId && requestId < item->maxId) { sp<FilteredListener> listener = item->listener.promote(); if (listener == 0) { item = mRangeListeners.erase(item); Loading @@ -167,7 +167,7 @@ status_t FrameProcessorBase::processListeners(const CameraMetadata &frame, ALOGV("Got %d range listeners out of %d", listeners.size(), mRangeListeners.size()); List<sp<FilteredListener> >::iterator item = listeners.begin(); for (; item != listeners.end(); item++) { (*item)->onFrameAvailable(frameId, frame); (*item)->onFrameAvailable(requestId, frame); } return OK; } Loading