Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 1 | /* |
Shuzhen Wang | c28189a | 2017-11-27 23:05:10 -0800 | [diff] [blame] | 2 | * Copyright (C) 2013-2018 The Android Open Source Project |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
| 17 | #ifndef ANDROID_SERVERS_CAMERA3_OUTPUT_STREAM_H |
| 18 | #define ANDROID_SERVERS_CAMERA3_OUTPUT_STREAM_H |
| 19 | |
Yin-Chia Yeh | 14ef48d | 2020-02-10 15:06:37 -0800 | [diff] [blame] | 20 | #include <mutex> |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 21 | #include <utils/RefBase.h> |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 22 | #include <gui/IProducerListener.h> |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 23 | #include <gui/Surface.h> |
| 24 | |
Shuzhen Wang | 686f644 | 2017-06-20 16:16:04 -0700 | [diff] [blame] | 25 | #include "utils/LatencyHistogram.h" |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 26 | #include "Camera3Stream.h" |
Igor Murashkin | e3a9f96 | 2013-05-08 18:03:15 -0700 | [diff] [blame] | 27 | #include "Camera3IOStreamBase.h" |
Igor Murashkin | 2fba584 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 28 | #include "Camera3OutputStreamInterface.h" |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 29 | #include "Camera3BufferManager.h" |
Shuzhen Wang | e4adddb | 2021-09-21 15:24:44 -0700 | [diff] [blame] | 30 | #include "PreviewFrameScheduler.h" |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 31 | |
| 32 | namespace android { |
| 33 | |
| 34 | namespace camera3 { |
| 35 | |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 36 | class Camera3BufferManager; |
| 37 | |
| 38 | /** |
| 39 | * Stream info structure that holds the necessary stream info for buffer manager to use for |
| 40 | * buffer allocation and management. |
| 41 | */ |
| 42 | struct StreamInfo { |
| 43 | int streamId; |
| 44 | int streamSetId; |
| 45 | uint32_t width; |
| 46 | uint32_t height; |
| 47 | uint32_t format; |
| 48 | android_dataspace dataSpace; |
Emilian Peev | 050f5dc | 2017-05-18 14:43:56 +0100 | [diff] [blame] | 49 | uint64_t combinedUsage; |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 50 | size_t totalBufferCount; |
| 51 | bool isConfigured; |
Shuzhen Wang | 83bff12 | 2020-11-20 15:51:39 -0800 | [diff] [blame] | 52 | bool isMultiRes; |
Chih-Hung Hsieh | d19d994 | 2016-08-29 14:21:14 -0700 | [diff] [blame] | 53 | explicit StreamInfo(int id = CAMERA3_STREAM_ID_INVALID, |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 54 | int setId = CAMERA3_STREAM_SET_ID_INVALID, |
| 55 | uint32_t w = 0, |
| 56 | uint32_t h = 0, |
| 57 | uint32_t fmt = 0, |
| 58 | android_dataspace ds = HAL_DATASPACE_UNKNOWN, |
Emilian Peev | 050f5dc | 2017-05-18 14:43:56 +0100 | [diff] [blame] | 59 | uint64_t usage = 0, |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 60 | size_t bufferCount = 0, |
Shuzhen Wang | 83bff12 | 2020-11-20 15:51:39 -0800 | [diff] [blame] | 61 | bool configured = false, |
| 62 | bool multiRes = false) : |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 63 | streamId(id), |
| 64 | streamSetId(setId), |
| 65 | width(w), |
| 66 | height(h), |
| 67 | format(fmt), |
| 68 | dataSpace(ds), |
| 69 | combinedUsage(usage), |
| 70 | totalBufferCount(bufferCount), |
Shuzhen Wang | 83bff12 | 2020-11-20 15:51:39 -0800 | [diff] [blame] | 71 | isConfigured(configured), |
| 72 | isMultiRes(multiRes) {} |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 73 | }; |
| 74 | |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 75 | /** |
| 76 | * A class for managing a single stream of output data from the camera device. |
| 77 | */ |
Igor Murashkin | 2fba584 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 78 | class Camera3OutputStream : |
Igor Murashkin | e3a9f96 | 2013-05-08 18:03:15 -0700 | [diff] [blame] | 79 | public Camera3IOStreamBase, |
Igor Murashkin | 2fba584 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 80 | public Camera3OutputStreamInterface { |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 81 | public: |
| 82 | /** |
| 83 | * Set up a stream for formats that have 2 dimensions, such as RAW and YUV. |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 84 | * A valid stream set id needs to be set to support buffer sharing between multiple |
| 85 | * streams. |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 86 | */ |
Eino-Ville Talvala | 727d172 | 2015-06-09 13:44:19 -0700 | [diff] [blame] | 87 | Camera3OutputStream(int id, sp<Surface> consumer, |
Eino-Ville Talvala | 3d82c0d | 2015-02-23 15:19:19 -0800 | [diff] [blame] | 88 | uint32_t width, uint32_t height, int format, |
Emilian Peev | f481670 | 2020-04-03 15:44:51 -0700 | [diff] [blame] | 89 | android_dataspace dataSpace, camera_stream_rotation_t rotation, |
Shuzhen Wang | c28189a | 2017-11-27 23:05:10 -0800 | [diff] [blame] | 90 | nsecs_t timestampOffset, const String8& physicalCameraId, |
Jayant Chowdhary | 13f9b2f | 2020-12-02 22:46:15 -0800 | [diff] [blame] | 91 | const std::unordered_set<int32_t> &sensorPixelModesUsed, |
Emilian Peev | 2295df7 | 2021-11-12 18:14:10 -0800 | [diff] [blame^] | 92 | int setId = CAMERA3_STREAM_SET_ID_INVALID, bool isMultiResolution = false, |
| 93 | int dynamicProfile = ANDROID_REQUEST_AVAILABLE_DYNAMIC_RANGE_PROFILES_MAP_STANDARD); |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 94 | /** |
| 95 | * Set up a stream for formats that have a variable buffer size for the same |
| 96 | * dimensions, such as compressed JPEG. |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 97 | * A valid stream set id needs to be set to support buffer sharing between multiple |
| 98 | * streams. |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 99 | */ |
Eino-Ville Talvala | 727d172 | 2015-06-09 13:44:19 -0700 | [diff] [blame] | 100 | Camera3OutputStream(int id, sp<Surface> consumer, |
Eino-Ville Talvala | 3d82c0d | 2015-02-23 15:19:19 -0800 | [diff] [blame] | 101 | uint32_t width, uint32_t height, size_t maxSize, int format, |
Emilian Peev | f481670 | 2020-04-03 15:44:51 -0700 | [diff] [blame] | 102 | android_dataspace dataSpace, camera_stream_rotation_t rotation, |
Shuzhen Wang | c28189a | 2017-11-27 23:05:10 -0800 | [diff] [blame] | 103 | nsecs_t timestampOffset, const String8& physicalCameraId, |
Jayant Chowdhary | 13f9b2f | 2020-12-02 22:46:15 -0800 | [diff] [blame] | 104 | const std::unordered_set<int32_t> &sensorPixelModesUsed, |
Emilian Peev | 2295df7 | 2021-11-12 18:14:10 -0800 | [diff] [blame^] | 105 | int setId = CAMERA3_STREAM_SET_ID_INVALID, bool isMultiResolution = false, |
| 106 | int dynamicProfile = ANDROID_REQUEST_AVAILABLE_DYNAMIC_RANGE_PROFILES_MAP_STANDARD); |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 107 | /** |
| 108 | * Set up a stream with deferred consumer for formats that have 2 dimensions, such as |
| 109 | * RAW and YUV. The consumer must be set before using this stream for output. A valid |
| 110 | * stream set id needs to be set to support buffer sharing between multiple streams. |
| 111 | */ |
| 112 | Camera3OutputStream(int id, uint32_t width, uint32_t height, int format, |
Emilian Peev | 050f5dc | 2017-05-18 14:43:56 +0100 | [diff] [blame] | 113 | uint64_t consumerUsage, android_dataspace dataSpace, |
Emilian Peev | f481670 | 2020-04-03 15:44:51 -0700 | [diff] [blame] | 114 | camera_stream_rotation_t rotation, nsecs_t timestampOffset, |
Shuzhen Wang | c28189a | 2017-11-27 23:05:10 -0800 | [diff] [blame] | 115 | const String8& physicalCameraId, |
Jayant Chowdhary | 13f9b2f | 2020-12-02 22:46:15 -0800 | [diff] [blame] | 116 | const std::unordered_set<int32_t> &sensorPixelModesUsed, |
Emilian Peev | 2295df7 | 2021-11-12 18:14:10 -0800 | [diff] [blame^] | 117 | int setId = CAMERA3_STREAM_SET_ID_INVALID, bool isMultiResolution = false, |
| 118 | int dynamicProfile = ANDROID_REQUEST_AVAILABLE_DYNAMIC_RANGE_PROFILES_MAP_STANDARD); |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 119 | |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 120 | virtual ~Camera3OutputStream(); |
| 121 | |
| 122 | /** |
| 123 | * Camera3Stream interface |
| 124 | */ |
| 125 | |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 126 | virtual void dump(int fd, const Vector<String16> &args) const; |
| 127 | |
| 128 | /** |
| 129 | * Set the transform on the output stream; one of the |
| 130 | * HAL_TRANSFORM_* / NATIVE_WINDOW_TRANSFORM_* constants. |
| 131 | */ |
| 132 | status_t setTransform(int transform); |
| 133 | |
Chien-Yu Chen | 85a6455 | 2015-08-28 15:46:12 -0700 | [diff] [blame] | 134 | /** |
| 135 | * Return if this output stream is for video encoding. |
| 136 | */ |
| 137 | bool isVideoStream() const; |
Shuzhen Wang | 13a6963 | 2016-01-26 09:51:07 -0800 | [diff] [blame] | 138 | /** |
| 139 | * Return if this output stream is consumed by hardware composer. |
| 140 | */ |
| 141 | bool isConsumedByHWComposer() const; |
Chien-Yu Chen | 85a6455 | 2015-08-28 15:46:12 -0700 | [diff] [blame] | 142 | |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 143 | /** |
Zhijun He | f0645c1 | 2016-08-02 00:58:11 -0700 | [diff] [blame] | 144 | * Return if this output stream is consumed by hardware texture. |
| 145 | */ |
| 146 | bool isConsumedByHWTexture() const; |
| 147 | |
| 148 | /** |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 149 | * Return if the consumer configuration of this stream is deferred. |
| 150 | */ |
Shuzhen Wang | 0129d52 | 2016-10-30 22:43:41 -0700 | [diff] [blame] | 151 | virtual bool isConsumerConfigurationDeferred(size_t surface_id) const; |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 152 | |
| 153 | /** |
Shuzhen Wang | 758c215 | 2017-01-10 18:26:18 -0800 | [diff] [blame] | 154 | * Set the consumer surfaces to the output stream. |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 155 | */ |
Shuzhen Wang | 758c215 | 2017-01-10 18:26:18 -0800 | [diff] [blame] | 156 | virtual status_t setConsumers(const std::vector<sp<Surface>>& consumers); |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 157 | |
Shuzhen Wang | 0160ddd | 2019-08-15 09:11:56 -0700 | [diff] [blame] | 158 | class BufferProducerListener : public SurfaceListener { |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 159 | public: |
Shuzhen Wang | 0160ddd | 2019-08-15 09:11:56 -0700 | [diff] [blame] | 160 | BufferProducerListener(wp<Camera3OutputStream> parent, bool needsReleaseNotify) |
| 161 | : mParent(parent), mNeedsReleaseNotify(needsReleaseNotify) {} |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 162 | |
Shuzhen Wang | 0160ddd | 2019-08-15 09:11:56 -0700 | [diff] [blame] | 163 | /** |
| 164 | * Implementation of IProducerListener, used to notify this stream that the consumer |
| 165 | * has returned a buffer and it is ready to return to Camera3BufferManager for reuse. |
| 166 | */ |
| 167 | virtual void onBufferReleased(); |
| 168 | virtual bool needsReleaseNotify() { return mNeedsReleaseNotify; } |
| 169 | virtual void onBuffersDiscarded(const std::vector<sp<GraphicBuffer>>& buffers); |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 170 | |
| 171 | private: |
Shuzhen Wang | 0160ddd | 2019-08-15 09:11:56 -0700 | [diff] [blame] | 172 | wp<Camera3OutputStream> mParent; |
| 173 | bool mNeedsReleaseNotify; |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 174 | }; |
| 175 | |
Eino-Ville Talvala | 77c1a35 | 2016-06-13 12:32:43 -0700 | [diff] [blame] | 176 | virtual status_t detachBuffer(sp<GraphicBuffer>* buffer, int* fenceFd); |
| 177 | |
Shuzhen Wang | bee0f0a | 2017-01-24 14:51:37 -0800 | [diff] [blame] | 178 | /** |
| 179 | * Notify that the buffer is being released to the buffer queue instead of |
| 180 | * being queued to the consumer. |
| 181 | */ |
| 182 | virtual status_t notifyBufferReleased(ANativeWindowBuffer *anwBuffer); |
Shuzhen Wang | 0129d52 | 2016-10-30 22:43:41 -0700 | [diff] [blame] | 183 | |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 184 | /** |
Chien-Yu Chen | a936ac2 | 2017-10-23 15:59:49 -0700 | [diff] [blame] | 185 | * Drop buffers if dropping is true. If dropping is false, do not drop buffers. |
| 186 | */ |
| 187 | virtual status_t dropBuffers(bool dropping) override; |
| 188 | |
| 189 | /** |
Shuzhen Wang | 5c22c15 | 2017-12-31 17:12:25 -0800 | [diff] [blame] | 190 | * Query the physical camera id for the output stream. |
| 191 | */ |
| 192 | virtual const String8& getPhysicalCameraId() const override; |
| 193 | |
| 194 | /** |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 195 | * Set the graphic buffer manager to get/return the stream buffers. |
| 196 | * |
| 197 | * It is only legal to call this method when stream is in STATE_CONSTRUCTED state. |
| 198 | */ |
| 199 | status_t setBufferManager(sp<Camera3BufferManager> bufferManager); |
| 200 | |
Emilian Peev | 40ead60 | 2017-09-26 15:46:36 +0100 | [diff] [blame] | 201 | /** |
| 202 | * Query the ouput surface id. |
| 203 | */ |
| 204 | virtual ssize_t getSurfaceId(const sp<Surface> &/*surface*/) { return 0; } |
| 205 | |
Yin-Chia Yeh | 58b1b4e | 2018-10-15 12:18:36 -0700 | [diff] [blame] | 206 | virtual status_t getUniqueSurfaceIds(const std::vector<size_t>&, |
| 207 | /*out*/std::vector<size_t>*) { return INVALID_OPERATION; }; |
| 208 | |
Emilian Peev | 40ead60 | 2017-09-26 15:46:36 +0100 | [diff] [blame] | 209 | /** |
| 210 | * Update the stream output surfaces. |
| 211 | */ |
| 212 | virtual status_t updateStream(const std::vector<sp<Surface>> &outputSurfaces, |
| 213 | const std::vector<OutputStreamInfo> &outputInfo, |
| 214 | const std::vector<size_t> &removedSurfaceIds, |
| 215 | KeyedVector<sp<Surface>, size_t> *outputMap/*out*/); |
| 216 | |
Emilian Peev | 35ae826 | 2018-11-08 13:11:32 +0000 | [diff] [blame] | 217 | /** |
Yin-Chia Yeh | 14ef48d | 2020-02-10 15:06:37 -0800 | [diff] [blame] | 218 | * Set the batch size for buffer operations. The output stream will request |
| 219 | * buffers from buffer queue on a batch basis. Currently only video streams |
| 220 | * are allowed to set the batch size. Also if the stream is managed by |
| 221 | * buffer manager (Surface group in Java API) then batching is also not |
| 222 | * supported. Changing batch size on the fly while there is already batched |
| 223 | * buffers in the stream is also not supported. |
| 224 | * If the batch size is larger than the max dequeue count set |
| 225 | * by the camera HAL, the batch size will be set to the max dequeue count |
| 226 | * instead. |
| 227 | */ |
| 228 | virtual status_t setBatchSize(size_t batchSize = 1) override; |
| 229 | |
| 230 | /** |
Emilian Peev | 35ae826 | 2018-11-08 13:11:32 +0000 | [diff] [blame] | 231 | * Apply ZSL related consumer usage quirk. |
| 232 | */ |
| 233 | static void applyZSLUsageQuirk(int format, uint64_t *consumerUsage /*inout*/); |
| 234 | |
Shuzhen Wang | abbcb6b | 2020-12-09 22:32:44 -0800 | [diff] [blame] | 235 | void setImageDumpMask(int mask) { mImageDumpMask = mask; } |
Shuzhen Wang | e4adddb | 2021-09-21 15:24:44 -0700 | [diff] [blame] | 236 | bool shouldLogError(status_t res); |
Shuzhen Wang | abbcb6b | 2020-12-09 22:32:44 -0800 | [diff] [blame] | 237 | |
Igor Murashkin | e3a9f96 | 2013-05-08 18:03:15 -0700 | [diff] [blame] | 238 | protected: |
Emilian Peev | f481670 | 2020-04-03 15:44:51 -0700 | [diff] [blame] | 239 | Camera3OutputStream(int id, camera_stream_type_t type, |
Eino-Ville Talvala | 3d82c0d | 2015-02-23 15:19:19 -0800 | [diff] [blame] | 240 | uint32_t width, uint32_t height, int format, |
Emilian Peev | f481670 | 2020-04-03 15:44:51 -0700 | [diff] [blame] | 241 | android_dataspace dataSpace, camera_stream_rotation_t rotation, |
Shuzhen Wang | c28189a | 2017-11-27 23:05:10 -0800 | [diff] [blame] | 242 | const String8& physicalCameraId, |
Jayant Chowdhary | 13f9b2f | 2020-12-02 22:46:15 -0800 | [diff] [blame] | 243 | const std::unordered_set<int32_t> &sensorPixelModesUsed, |
Emilian Peev | 050f5dc | 2017-05-18 14:43:56 +0100 | [diff] [blame] | 244 | uint64_t consumerUsage = 0, nsecs_t timestampOffset = 0, |
Emilian Peev | 2295df7 | 2021-11-12 18:14:10 -0800 | [diff] [blame^] | 245 | int setId = CAMERA3_STREAM_SET_ID_INVALID, bool isMultiResolution = false, |
| 246 | int dynamicProfile = ANDROID_REQUEST_AVAILABLE_DYNAMIC_RANGE_PROFILES_MAP_STANDARD); |
Igor Murashkin | e3a9f96 | 2013-05-08 18:03:15 -0700 | [diff] [blame] | 247 | |
Zhijun He | 124ccf4 | 2013-05-22 14:01:30 -0700 | [diff] [blame] | 248 | /** |
| 249 | * Note that we release the lock briefly in this function |
| 250 | */ |
Igor Murashkin | e3a9f96 | 2013-05-08 18:03:15 -0700 | [diff] [blame] | 251 | virtual status_t returnBufferCheckedLocked( |
Emilian Peev | f481670 | 2020-04-03 15:44:51 -0700 | [diff] [blame] | 252 | const camera_stream_buffer &buffer, |
Igor Murashkin | e3a9f96 | 2013-05-08 18:03:15 -0700 | [diff] [blame] | 253 | nsecs_t timestamp, |
Shuzhen Wang | 90708ea | 2021-11-04 11:40:49 -0700 | [diff] [blame] | 254 | nsecs_t readoutTimestamp, |
Igor Murashkin | e3a9f96 | 2013-05-08 18:03:15 -0700 | [diff] [blame] | 255 | bool output, |
Emilian Peev | 5104fe9 | 2021-10-21 14:27:09 -0700 | [diff] [blame] | 256 | int32_t transform, |
Yin-Chia Yeh | 58b1b4e | 2018-10-15 12:18:36 -0700 | [diff] [blame] | 257 | const std::vector<size_t>& surface_ids, |
Igor Murashkin | e3a9f96 | 2013-05-08 18:03:15 -0700 | [diff] [blame] | 258 | /*out*/ |
| 259 | sp<Fence> *releaseFenceOut); |
| 260 | |
Zhijun He | 0a21051 | 2014-07-24 13:45:15 -0700 | [diff] [blame] | 261 | virtual status_t disconnectLocked(); |
| 262 | |
Emilian Peev | 050f5dc | 2017-05-18 14:43:56 +0100 | [diff] [blame] | 263 | status_t getEndpointUsageForSurface(uint64_t *usage, |
Shuzhen Wang | 0129d52 | 2016-10-30 22:43:41 -0700 | [diff] [blame] | 264 | const sp<Surface>& surface) const; |
Shuzhen Wang | e4adddb | 2021-09-21 15:24:44 -0700 | [diff] [blame] | 265 | status_t configureConsumerQueueLocked(bool allowPreviewScheduler); |
Shuzhen Wang | 0129d52 | 2016-10-30 22:43:41 -0700 | [diff] [blame] | 266 | |
| 267 | // Consumer as the output of camera HAL |
Eino-Ville Talvala | 727d172 | 2015-06-09 13:44:19 -0700 | [diff] [blame] | 268 | sp<Surface> mConsumer; |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 269 | |
Emilian Peev | 050f5dc | 2017-05-18 14:43:56 +0100 | [diff] [blame] | 270 | uint64_t getPresetConsumerUsage() const { return mConsumerUsage; } |
Zhijun He | f0645c1 | 2016-08-02 00:58:11 -0700 | [diff] [blame] | 271 | |
| 272 | static const nsecs_t kDequeueBufferTimeout = 1000000000; // 1 sec |
| 273 | |
Shuzhen Wang | bee0f0a | 2017-01-24 14:51:37 -0800 | [diff] [blame] | 274 | status_t getBufferLockedCommon(ANativeWindowBuffer** anb, int* fenceFd); |
| 275 | |
| 276 | |
Shuzhen Wang | 0129d52 | 2016-10-30 22:43:41 -0700 | [diff] [blame] | 277 | private: |
| 278 | |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 279 | int mTransform; |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 280 | |
Igor Murashkin | e3a9f96 | 2013-05-08 18:03:15 -0700 | [diff] [blame] | 281 | virtual status_t setTransformLocked(int transform); |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 282 | |
Ruchit Sharma | e0711f2 | 2014-08-18 13:48:24 -0400 | [diff] [blame] | 283 | bool mTraceFirstBuffer; |
| 284 | |
Eino-Ville Talvala | 727d172 | 2015-06-09 13:44:19 -0700 | [diff] [blame] | 285 | // Name of Surface consumer |
| 286 | String8 mConsumerName; |
| 287 | |
Shuzhen Wang | c28dccc | 2016-02-11 23:48:46 -0800 | [diff] [blame] | 288 | // Whether consumer assumes MONOTONIC timestamp |
| 289 | bool mUseMonoTimestamp; |
Shuzhen Wang | 13a6963 | 2016-01-26 09:51:07 -0800 | [diff] [blame] | 290 | |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 291 | /** |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 292 | * GraphicBuffer manager this stream is registered to. Used to replace the buffer |
| 293 | * allocation/deallocation role of BufferQueue. |
| 294 | */ |
| 295 | sp<Camera3BufferManager> mBufferManager; |
| 296 | |
| 297 | /** |
Shuzhen Wang | 0160ddd | 2019-08-15 09:11:56 -0700 | [diff] [blame] | 298 | * Buffer producer listener, used to handle notification when a buffer is released |
| 299 | * from consumer side, or a set of buffers are discarded by the consumer. |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 300 | */ |
Shuzhen Wang | 0160ddd | 2019-08-15 09:11:56 -0700 | [diff] [blame] | 301 | sp<BufferProducerListener> mBufferProducerListener; |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 302 | |
| 303 | /** |
| 304 | * Flag indicating if the buffer manager is used to allocate the stream buffers |
| 305 | */ |
| 306 | bool mUseBufferManager; |
Shuzhen Wang | c28dccc | 2016-02-11 23:48:46 -0800 | [diff] [blame] | 307 | |
| 308 | /** |
| 309 | * Timestamp offset for video and hardware composer consumed streams |
| 310 | */ |
| 311 | nsecs_t mTimestampOffset; |
| 312 | |
Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 313 | /** |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 314 | * Consumer end point usage flag set by the constructor for the deferred |
| 315 | * consumer case. |
| 316 | */ |
Emilian Peev | 050f5dc | 2017-05-18 14:43:56 +0100 | [diff] [blame] | 317 | uint64_t mConsumerUsage; |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 318 | |
Chien-Yu Chen | a936ac2 | 2017-10-23 15:59:49 -0700 | [diff] [blame] | 319 | // Whether to drop valid buffers. |
| 320 | bool mDropBuffers; |
| 321 | |
Yin-Chia Yeh | 14ef48d | 2020-02-10 15:06:37 -0800 | [diff] [blame] | 322 | |
Yin-Chia Yeh | 14ef48d | 2020-02-10 15:06:37 -0800 | [diff] [blame] | 323 | |
| 324 | // The batch size for buffer operation |
Shuzhen Wang | c762946 | 2021-07-12 15:02:58 -0700 | [diff] [blame] | 325 | std::atomic_size_t mBatchSize = 1; |
Yin-Chia Yeh | 14ef48d | 2020-02-10 15:06:37 -0800 | [diff] [blame] | 326 | |
Shuzhen Wang | c762946 | 2021-07-12 15:02:58 -0700 | [diff] [blame] | 327 | // Protecting batch states below, must be acquired after mLock |
| 328 | std::mutex mBatchLock; |
Yin-Chia Yeh | 14ef48d | 2020-02-10 15:06:37 -0800 | [diff] [blame] | 329 | // Prefetched buffers (ready to be handed to client) |
| 330 | std::vector<Surface::BatchBuffer> mBatchedBuffers; |
Yin-Chia Yeh | 14ef48d | 2020-02-10 15:06:37 -0800 | [diff] [blame] | 331 | // ---- End of mBatchLock protected scope ---- |
| 332 | |
Zhijun He | 5d677d1 | 2016-05-29 16:52:39 -0700 | [diff] [blame] | 333 | /** |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 334 | * Internal Camera3Stream interface |
| 335 | */ |
Emilian Peev | f481670 | 2020-04-03 15:44:51 -0700 | [diff] [blame] | 336 | virtual status_t getBufferLocked(camera_stream_buffer *buffer, |
Shuzhen Wang | bee0f0a | 2017-01-24 14:51:37 -0800 | [diff] [blame] | 337 | const std::vector<size_t>& surface_ids); |
| 338 | |
Yin-Chia Yeh | 14ef48d | 2020-02-10 15:06:37 -0800 | [diff] [blame] | 339 | virtual status_t getBuffersLocked(/*out*/std::vector<OutstandingBuffer>* buffers) override; |
| 340 | |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 341 | virtual status_t returnBufferLocked( |
Emilian Peev | f481670 | 2020-04-03 15:44:51 -0700 | [diff] [blame] | 342 | const camera_stream_buffer &buffer, |
Shuzhen Wang | 90708ea | 2021-11-04 11:40:49 -0700 | [diff] [blame] | 343 | nsecs_t timestamp, nsecs_t readoutTimestamp, |
| 344 | int32_t transform, const std::vector<size_t>& surface_ids); |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 345 | |
Shuzhen Wang | bee0f0a | 2017-01-24 14:51:37 -0800 | [diff] [blame] | 346 | virtual status_t queueBufferToConsumer(sp<ANativeWindow>& consumer, |
Yin-Chia Yeh | 58b1b4e | 2018-10-15 12:18:36 -0700 | [diff] [blame] | 347 | ANativeWindowBuffer* buffer, int anwReleaseFence, |
| 348 | const std::vector<size_t>& surface_ids); |
Shuzhen Wang | bee0f0a | 2017-01-24 14:51:37 -0800 | [diff] [blame] | 349 | |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 350 | virtual status_t configureQueueLocked(); |
Eino-Ville Talvala | b2f5b19 | 2013-07-30 14:36:03 -0700 | [diff] [blame] | 351 | |
Emilian Peev | 050f5dc | 2017-05-18 14:43:56 +0100 | [diff] [blame] | 352 | virtual status_t getEndpointUsage(uint64_t *usage) const; |
Eino-Ville Talvala | b2f5b19 | 2013-07-30 14:36:03 -0700 | [diff] [blame] | 353 | |
Yin-Chia Yeh | 89954d9 | 2017-05-21 17:28:53 -0700 | [diff] [blame] | 354 | /** |
| 355 | * Private methods |
| 356 | */ |
Yin-Chia Yeh | 017d49c | 2017-03-31 19:11:00 -0700 | [diff] [blame] | 357 | void onBuffersRemovedLocked(const std::vector<sp<GraphicBuffer>>&); |
Yin-Chia Yeh | 89954d9 | 2017-05-21 17:28:53 -0700 | [diff] [blame] | 358 | status_t detachBufferLocked(sp<GraphicBuffer>* buffer, int* fenceFd); |
Yin-Chia Yeh | bf1b8b9 | 2019-03-06 14:56:08 -0800 | [diff] [blame] | 359 | // Call this after each dequeueBuffer/attachBuffer/detachNextBuffer call to get update on |
| 360 | // removed buffers. Set notifyBufferManager to false when the call is initiated by buffer |
| 361 | // manager so buffer manager doesn't need to be notified. |
| 362 | void checkRemovedBuffersLocked(bool notifyBufferManager = true); |
| 363 | |
| 364 | // Check return status of IGBP calls and set abandoned state accordingly |
| 365 | void checkRetAndSetAbandonedLocked(status_t res); |
Yin-Chia Yeh | 017d49c | 2017-03-31 19:11:00 -0700 | [diff] [blame] | 366 | |
Yin-Chia Yeh | a1b56c8 | 2019-03-27 15:50:39 -0700 | [diff] [blame] | 367 | // If the status indicates abandonded stream, only log when state hasn't been updated to |
| 368 | // STATE_ABANDONED |
| 369 | static bool shouldLogError(status_t res, StreamState state); |
| 370 | |
Shuzhen Wang | abbcb6b | 2020-12-09 22:32:44 -0800 | [diff] [blame] | 371 | // Dump images to disk before returning to consumer |
| 372 | void dumpImageToDisk(nsecs_t timestamp, ANativeWindowBuffer* anwBuffer, int fence); |
| 373 | |
Yin-Chia Yeh | 14ef48d | 2020-02-10 15:06:37 -0800 | [diff] [blame] | 374 | void returnPrefetchedBuffersLocked(); |
| 375 | |
Shuzhen Wang | 686f644 | 2017-06-20 16:16:04 -0700 | [diff] [blame] | 376 | static const int32_t kDequeueLatencyBinSize = 5; // in ms |
| 377 | CameraLatencyHistogram mDequeueBufferLatency; |
| 378 | |
Shuzhen Wang | abbcb6b | 2020-12-09 22:32:44 -0800 | [diff] [blame] | 379 | int mImageDumpMask = 0; |
| 380 | |
Shuzhen Wang | e4adddb | 2021-09-21 15:24:44 -0700 | [diff] [blame] | 381 | // The preview stream scheduler for re-timing frames |
| 382 | std::unique_ptr<PreviewFrameScheduler> mPreviewFrameScheduler; |
Eino-Ville Talvala | fd58f1a | 2013-03-06 16:20:06 -0800 | [diff] [blame] | 383 | }; // class Camera3OutputStream |
| 384 | |
| 385 | } // namespace camera3 |
| 386 | |
| 387 | } // namespace android |
| 388 | |
| 389 | #endif |