diff options
author | Eino-Ville Talvala <etalvala@google.com> | 2014-09-26 13:09:54 -0700 |
---|---|---|
committer | Eino-Ville Talvala <etalvala@google.com> | 2014-09-28 12:06:41 -0700 |
commit | dc2e6ddc933e40632e79a866d9ece870db1a975e (patch) | |
tree | 882e16001c7e5bb3c5d259836b9962be16f9e72f /services/camera | |
parent | a67ced9746e6f0d4e03ff8007682091afea71f6c (diff) | |
download | frameworks_av-dc2e6ddc933e40632e79a866d9ece870db1a975e.zip frameworks_av-dc2e6ddc933e40632e79a866d9ece870db1a975e.tar.gz frameworks_av-dc2e6ddc933e40632e79a866d9ece870db1a975e.tar.bz2 |
Camera2Client: Revert HALv2 device behavior back to MR2
- Do not idle device before video snapshot stream configuration, to
avoid deadlock during waiting.
- Do not tear down ZSL stream
- Don't refresh ZSL stream after deletion was requested.
The v2 HAL implementations really don't like the ZSL stream being
touched ever.
Bug: 17634430
Bug: 17628507
Change-Id: I36b44a395e697be9802c4bd917a82b77c8d04be2
Diffstat (limited to 'services/camera')
-rw-r--r-- | services/camera/libcameraservice/api1/Camera2Client.cpp | 114 | ||||
-rw-r--r-- | services/camera/libcameraservice/api1/client2/ZslProcessor.cpp | 2 |
2 files changed, 69 insertions, 47 deletions
diff --git a/services/camera/libcameraservice/api1/Camera2Client.cpp b/services/camera/libcameraservice/api1/Camera2Client.cpp index 48ec730..3610362 100644 --- a/services/camera/libcameraservice/api1/Camera2Client.cpp +++ b/services/camera/libcameraservice/api1/Camera2Client.cpp @@ -1049,32 +1049,35 @@ status_t Camera2Client::startRecordingL(Parameters ¶ms, bool restart) { } } - if (mZslProcessor->getStreamId() != NO_STREAM) { - ALOGV("%s: Camera %d: Clearing out zsl stream before " - "creating recording stream", __FUNCTION__, mCameraId); - res = mStreamingProcessor->stopStream(); - if (res != OK) { - ALOGE("%s: Camera %d: Can't stop streaming to delete callback stream", - __FUNCTION__, mCameraId); - return res; - } - res = mDevice->waitUntilDrained(); - if (res != OK) { - ALOGE("%s: Camera %d: Waiting to stop streaming failed: %s (%d)", - __FUNCTION__, mCameraId, strerror(-res), res); - } - res = mZslProcessor->clearZslQueue(); - if (res != OK) { - ALOGE("%s: Camera %d: Can't clear zsl queue", - __FUNCTION__, mCameraId); - return res; - } - res = mZslProcessor->deleteStream(); - if (res != OK) { - ALOGE("%s: Camera %d: Unable to delete zsl stream before " - "record: %s (%d)", __FUNCTION__, mCameraId, - strerror(-res), res); - return res; + // On current HALs, clean up ZSL before transitioning into recording + if (mDeviceVersion != CAMERA_DEVICE_API_VERSION_2_0) { + if (mZslProcessor->getStreamId() != NO_STREAM) { + ALOGV("%s: Camera %d: Clearing out zsl stream before " + "creating recording stream", __FUNCTION__, mCameraId); + res = mStreamingProcessor->stopStream(); + if (res != OK) { + ALOGE("%s: Camera %d: Can't stop streaming to delete callback stream", + __FUNCTION__, mCameraId); + return res; + } + res = mDevice->waitUntilDrained(); + if (res != OK) { + ALOGE("%s: Camera %d: Waiting to stop streaming failed: %s (%d)", + __FUNCTION__, mCameraId, strerror(-res), res); + } + res = mZslProcessor->clearZslQueue(); + if (res != OK) { + ALOGE("%s: Camera %d: Can't clear zsl queue", + __FUNCTION__, mCameraId); + return res; + } + res = mZslProcessor->deleteStream(); + if (res != OK) { + ALOGE("%s: Camera %d: Unable to delete zsl stream before " + "record: %s (%d)", __FUNCTION__, mCameraId, + strerror(-res), res); + return res; + } } } @@ -1082,34 +1085,53 @@ status_t Camera2Client::startRecordingL(Parameters ¶ms, bool restart) { // and we can't fail record start without stagefright asserting. params.previewCallbackFlags = 0; - bool recordingStreamNeedsUpdate; - res = mStreamingProcessor->recordingStreamNeedsUpdate(params, &recordingStreamNeedsUpdate); - if (res != OK) { - ALOGE("%s: Camera %d: Can't query recording stream", - __FUNCTION__, mCameraId); - return res; - } - - if (recordingStreamNeedsUpdate) { - // Need to stop stream here so updateProcessorStream won't trigger configureStream - // Right now camera device cannot handle configureStream failure gracefully - // when device is streaming - res = mStreamingProcessor->stopStream(); + if (mDeviceVersion != CAMERA_DEVICE_API_VERSION_2_0) { + // For newer devices, may need to reconfigure video snapshot JPEG sizes + // during recording startup, so need a more complex sequence here to + // ensure an early stream reconfiguration doesn't happen + bool recordingStreamNeedsUpdate; + res = mStreamingProcessor->recordingStreamNeedsUpdate(params, &recordingStreamNeedsUpdate); if (res != OK) { - ALOGE("%s: Camera %d: Can't stop streaming to update record stream", + ALOGE("%s: Camera %d: Can't query recording stream", __FUNCTION__, mCameraId); return res; } - res = mDevice->waitUntilDrained(); - if (res != OK) { - ALOGE("%s: Camera %d: Waiting to stop streaming failed: %s (%d)", - __FUNCTION__, mCameraId, strerror(-res), res); + + if (recordingStreamNeedsUpdate) { + // Need to stop stream here so updateProcessorStream won't trigger configureStream + // Right now camera device cannot handle configureStream failure gracefully + // when device is streaming + res = mStreamingProcessor->stopStream(); + if (res != OK) { + ALOGE("%s: Camera %d: Can't stop streaming to update record " + "stream", __FUNCTION__, mCameraId); + return res; + } + res = mDevice->waitUntilDrained(); + if (res != OK) { + ALOGE("%s: Camera %d: Waiting to stop streaming failed: " + "%s (%d)", __FUNCTION__, mCameraId, + strerror(-res), res); + } + + res = updateProcessorStream< + StreamingProcessor, + &StreamingProcessor::updateRecordingStream>( + mStreamingProcessor, + params); + if (res != OK) { + ALOGE("%s: Camera %d: Unable to update recording stream: " + "%s (%d)", __FUNCTION__, mCameraId, + strerror(-res), res); + return res; + } } + } else { + // Maintain call sequencing for HALv2 devices. res = updateProcessorStream< StreamingProcessor, &StreamingProcessor::updateRecordingStream>(mStreamingProcessor, - params); - + params); if (res != OK) { ALOGE("%s: Camera %d: Unable to update recording stream: %s (%d)", __FUNCTION__, mCameraId, strerror(-res), res); diff --git a/services/camera/libcameraservice/api1/client2/ZslProcessor.cpp b/services/camera/libcameraservice/api1/client2/ZslProcessor.cpp index bb72206..8f78103 100644 --- a/services/camera/libcameraservice/api1/client2/ZslProcessor.cpp +++ b/services/camera/libcameraservice/api1/client2/ZslProcessor.cpp @@ -154,7 +154,7 @@ status_t ZslProcessor::updateStream(const Parameters ¶ms) { mId, strerror(-res), res); return res; } - if (mDeleted || currentWidth != (uint32_t)params.fastInfo.arrayWidth || + if (currentWidth != (uint32_t)params.fastInfo.arrayWidth || currentHeight != (uint32_t)params.fastInfo.arrayHeight) { res = device->deleteReprocessStream(mZslReprocessStreamId); if (res != OK) { |