| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 1 | /* | 
|  | 2 | * Copyright (C) 2013 The Android Open Source Project | 
|  | 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_STREAM_INTERFACE_H | 
|  | 18 | #define ANDROID_SERVERS_CAMERA3_STREAM_INTERFACE_H | 
|  | 19 |  | 
|  | 20 | #include <utils/RefBase.h> | 
|  | 21 | #include "Camera3StreamBufferListener.h" | 
| Yin-Chia Yeh | be83fa7 | 2017-03-30 13:35:36 -0700 | [diff] [blame] | 22 | #include "Camera3StreamBufferFreedListener.h" | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 23 |  | 
|  | 24 | struct camera3_stream_buffer; | 
|  | 25 |  | 
|  | 26 | namespace android { | 
|  | 27 |  | 
|  | 28 | namespace camera3 { | 
|  | 29 |  | 
| Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 30 | enum { | 
|  | 31 | /** | 
|  | 32 | * This stream set ID indicates that the set ID is invalid, and this stream doesn't intend to | 
|  | 33 | * share buffers with any other stream. It is illegal to register this kind of stream to | 
|  | 34 | * Camera3BufferManager. | 
|  | 35 | */ | 
|  | 36 | CAMERA3_STREAM_SET_ID_INVALID = -1, | 
|  | 37 |  | 
|  | 38 | /** | 
|  | 39 | * Invalid output stream ID. | 
|  | 40 | */ | 
|  | 41 | CAMERA3_STREAM_ID_INVALID = -1, | 
|  | 42 | }; | 
|  | 43 |  | 
| Eino-Ville Talvala | f1e98d8 | 2013-09-06 09:32:43 -0700 | [diff] [blame] | 44 | class StatusTracker; | 
|  | 45 |  | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 46 | /** | 
|  | 47 | * An interface for managing a single stream of input and/or output data from | 
|  | 48 | * the camera device. | 
|  | 49 | */ | 
|  | 50 | class Camera3StreamInterface : public virtual RefBase { | 
|  | 51 | public: | 
| Ruben Brunk | c78ac26 | 2015-08-13 17:58:46 -0700 | [diff] [blame] | 52 |  | 
|  | 53 | enum { | 
|  | 54 | ALLOCATE_PIPELINE_MAX = 0, // Allocate max buffers used by a given surface | 
|  | 55 | }; | 
|  | 56 |  | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 57 | /** | 
|  | 58 | * Get the stream's ID | 
|  | 59 | */ | 
|  | 60 | virtual int      getId() const = 0; | 
|  | 61 |  | 
|  | 62 | /** | 
| Zhijun He | 125684a | 2015-12-26 15:07:30 -0800 | [diff] [blame] | 63 | * Get the output stream set id. | 
|  | 64 | */ | 
|  | 65 | virtual int      getStreamSetId() const = 0; | 
|  | 66 |  | 
|  | 67 | /** | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 68 | * Get the stream's dimensions and format | 
|  | 69 | */ | 
|  | 70 | virtual uint32_t getWidth() const = 0; | 
|  | 71 | virtual uint32_t getHeight() const = 0; | 
|  | 72 | virtual int      getFormat() const = 0; | 
| Eino-Ville Talvala | d46a6b9 | 2015-05-14 17:26:24 -0700 | [diff] [blame] | 73 | virtual android_dataspace getDataSpace() const = 0; | 
| Emilian Peev | 710c142 | 2017-08-30 11:19:38 +0100 | [diff] [blame] | 74 | virtual void setFormatOverride(bool formatOverriden) = 0; | 
| Eino-Ville Talvala | 91cd3f8 | 2017-08-21 16:12:50 -0700 | [diff] [blame] | 75 | virtual bool isFormatOverridden() const = 0; | 
|  | 76 | virtual int getOriginalFormat() const = 0; | 
|  | 77 | virtual void setDataSpaceOverride(bool dataSpaceOverriden) = 0; | 
|  | 78 | virtual bool isDataSpaceOverridden() const = 0; | 
|  | 79 | virtual android_dataspace getOriginalDataSpace() const = 0; | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 80 |  | 
|  | 81 | /** | 
| Eino-Ville Talvala | 0b1cb14 | 2016-12-19 16:29:17 -0800 | [diff] [blame] | 82 | * Get a HAL3 handle for the stream, without starting stream configuration. | 
|  | 83 | */ | 
|  | 84 | virtual camera3_stream* asHalStream() = 0; | 
|  | 85 |  | 
|  | 86 | /** | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 87 | * Start the stream configuration process. Returns a handle to the stream's | 
|  | 88 | * information to be passed into the HAL device's configure_streams call. | 
|  | 89 | * | 
|  | 90 | * Until finishConfiguration() is called, no other methods on the stream may | 
|  | 91 | * be called. The usage and max_buffers fields of camera3_stream may be | 
|  | 92 | * modified between start/finishConfiguration, but may not be changed after | 
|  | 93 | * that. The priv field of camera3_stream may be modified at any time after | 
|  | 94 | * startConfiguration. | 
|  | 95 | * | 
|  | 96 | * Returns NULL in case of error starting configuration. | 
|  | 97 | */ | 
|  | 98 | virtual camera3_stream* startConfiguration() = 0; | 
|  | 99 |  | 
|  | 100 | /** | 
|  | 101 | * Check if the stream is mid-configuration (start has been called, but not | 
|  | 102 | * finish).  Used for lazy completion of configuration. | 
|  | 103 | */ | 
|  | 104 | virtual bool    isConfiguring() const = 0; | 
|  | 105 |  | 
|  | 106 | /** | 
|  | 107 | * Completes the stream configuration process. During this call, the stream | 
|  | 108 | * may call the device's register_stream_buffers() method. The stream | 
|  | 109 | * information structure returned by startConfiguration() may no longer be | 
|  | 110 | * modified after this call, but can still be read until the destruction of | 
|  | 111 | * the stream. | 
|  | 112 | * | 
|  | 113 | * Returns: | 
|  | 114 | *   OK on a successful configuration | 
|  | 115 | *   NO_INIT in case of a serious error from the HAL device | 
|  | 116 | *   NO_MEMORY in case of an error registering buffers | 
|  | 117 | *   INVALID_OPERATION in case connecting to the consumer failed | 
|  | 118 | */ | 
| Eino-Ville Talvala | 0b1cb14 | 2016-12-19 16:29:17 -0800 | [diff] [blame] | 119 | virtual status_t finishConfiguration() = 0; | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 120 |  | 
|  | 121 | /** | 
| Eino-Ville Talvala | 1754351 | 2014-08-06 14:32:02 -0700 | [diff] [blame] | 122 | * Cancels the stream configuration process. This returns the stream to the | 
|  | 123 | * initial state, allowing it to be configured again later. | 
|  | 124 | * This is done if the HAL rejects the proposed combined stream configuration | 
|  | 125 | */ | 
|  | 126 | virtual status_t cancelConfiguration() = 0; | 
|  | 127 |  | 
|  | 128 | /** | 
| Eino-Ville Talvala | 4d44cad | 2015-04-11 13:15:45 -0700 | [diff] [blame] | 129 | * Determine whether the stream has already become in-use (has received | 
|  | 130 | * a valid filled buffer), which determines if a stream can still have | 
|  | 131 | * prepareNextBuffer called on it. | 
|  | 132 | */ | 
|  | 133 | virtual bool     isUnpreparable() = 0; | 
|  | 134 |  | 
|  | 135 | /** | 
|  | 136 | * Start stream preparation. May only be called in the CONFIGURED state, | 
| Ruben Brunk | c78ac26 | 2015-08-13 17:58:46 -0700 | [diff] [blame] | 137 | * when no valid buffers have yet been returned to this stream. Prepares | 
|  | 138 | * up to maxCount buffers, or the maximum number of buffers needed by the | 
|  | 139 | * pipeline if maxCount is ALLOCATE_PIPELINE_MAX. | 
| Eino-Ville Talvala | 4d44cad | 2015-04-11 13:15:45 -0700 | [diff] [blame] | 140 | * | 
|  | 141 | * If no prepartion is necessary, returns OK and does not transition to | 
|  | 142 | * PREPARING state. Otherwise, returns NOT_ENOUGH_DATA and transitions | 
|  | 143 | * to PREPARING. | 
|  | 144 | * | 
|  | 145 | * Returns: | 
|  | 146 | *    OK if no more buffers need to be preallocated | 
|  | 147 | *    NOT_ENOUGH_DATA if calls to prepareNextBuffer are needed to finish | 
|  | 148 | *        buffer pre-allocation, and transitions to the PREPARING state. | 
|  | 149 | *    NO_INIT in case of a serious error from the HAL device | 
|  | 150 | *    INVALID_OPERATION if called when not in CONFIGURED state, or a | 
|  | 151 | *        valid buffer has already been returned to this stream. | 
|  | 152 | */ | 
| Ruben Brunk | c78ac26 | 2015-08-13 17:58:46 -0700 | [diff] [blame] | 153 | virtual status_t startPrepare(int maxCount) = 0; | 
| Eino-Ville Talvala | 4d44cad | 2015-04-11 13:15:45 -0700 | [diff] [blame] | 154 |  | 
|  | 155 | /** | 
|  | 156 | * Check if the stream is mid-preparing. | 
|  | 157 | */ | 
|  | 158 | virtual bool     isPreparing() const = 0; | 
|  | 159 |  | 
|  | 160 | /** | 
|  | 161 | * Continue stream buffer preparation by allocating the next | 
|  | 162 | * buffer for this stream.  May only be called in the PREPARED state. | 
|  | 163 | * | 
|  | 164 | * Returns OK and transitions to the CONFIGURED state if all buffers | 
|  | 165 | * are allocated after the call concludes. Otherwise returns NOT_ENOUGH_DATA. | 
|  | 166 | * | 
|  | 167 | * Returns: | 
|  | 168 | *    OK if no more buffers need to be preallocated, and transitions | 
|  | 169 | *        to the CONFIGURED state. | 
|  | 170 | *    NOT_ENOUGH_DATA if more calls to prepareNextBuffer are needed to finish | 
|  | 171 | *        buffer pre-allocation. | 
|  | 172 | *    NO_INIT in case of a serious error from the HAL device | 
|  | 173 | *    INVALID_OPERATION if called when not in CONFIGURED state, or a | 
|  | 174 | *        valid buffer has already been returned to this stream. | 
|  | 175 | */ | 
|  | 176 | virtual status_t prepareNextBuffer() = 0; | 
|  | 177 |  | 
|  | 178 | /** | 
|  | 179 | * Cancel stream preparation early. In case allocation needs to be | 
|  | 180 | * stopped, this method transitions the stream back to the CONFIGURED state. | 
|  | 181 | * Buffers that have been allocated with prepareNextBuffer remain that way, | 
|  | 182 | * but a later use of prepareNextBuffer will require just as many | 
|  | 183 | * calls as if the earlier prepare attempt had not existed. | 
|  | 184 | * | 
|  | 185 | * Returns: | 
|  | 186 | *    OK if cancellation succeeded, and transitions to the CONFIGURED state | 
|  | 187 | *    INVALID_OPERATION if not in the PREPARING state | 
|  | 188 | *    NO_INIT in case of a serious error from the HAL device | 
|  | 189 | */ | 
|  | 190 | virtual status_t cancelPrepare() = 0; | 
|  | 191 |  | 
|  | 192 | /** | 
| Eino-Ville Talvala | b25e3c8 | 2015-07-15 16:04:27 -0700 | [diff] [blame] | 193 | * Tear down memory for this stream. This frees all unused gralloc buffers | 
|  | 194 | * allocated for this stream, but leaves it ready for operation afterward. | 
|  | 195 | * | 
|  | 196 | * May only be called in the CONFIGURED state, and keeps the stream in | 
|  | 197 | * the CONFIGURED state. | 
|  | 198 | * | 
|  | 199 | * Returns: | 
|  | 200 | *    OK if teardown succeeded. | 
|  | 201 | *    INVALID_OPERATION if not in the CONFIGURED state | 
|  | 202 | *    NO_INIT in case of a serious error from the HAL device | 
|  | 203 | */ | 
|  | 204 | virtual status_t tearDown() = 0; | 
|  | 205 |  | 
|  | 206 | /** | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 207 | * Fill in the camera3_stream_buffer with the next valid buffer for this | 
|  | 208 | * stream, to hand over to the HAL. | 
|  | 209 | * | 
| Shuzhen Wang | bee0f0a | 2017-01-24 14:51:37 -0800 | [diff] [blame] | 210 | * Multiple surfaces could share the same HAL stream, but a request may | 
|  | 211 | * be only for a subset of surfaces. In this case, the | 
|  | 212 | * Camera3StreamInterface object needs the surface ID information to acquire | 
|  | 213 | * buffers for those surfaces. For the case of single surface for a HAL | 
|  | 214 | * stream, surface_ids parameter has no effect. | 
|  | 215 | * | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 216 | * This method may only be called once finishConfiguration has been called. | 
|  | 217 | * For bidirectional streams, this method applies to the output-side | 
|  | 218 | * buffers. | 
|  | 219 | * | 
|  | 220 | */ | 
| Shuzhen Wang | bee0f0a | 2017-01-24 14:51:37 -0800 | [diff] [blame] | 221 | virtual status_t getBuffer(camera3_stream_buffer *buffer, | 
|  | 222 | const std::vector<size_t>& surface_ids = std::vector<size_t>()) = 0; | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 223 |  | 
|  | 224 | /** | 
|  | 225 | * Return a buffer to the stream after use by the HAL. | 
|  | 226 | * | 
|  | 227 | * This method may only be called for buffers provided by getBuffer(). | 
|  | 228 | * For bidirectional streams, this method applies to the output-side buffers | 
|  | 229 | */ | 
|  | 230 | virtual status_t returnBuffer(const camera3_stream_buffer &buffer, | 
|  | 231 | nsecs_t timestamp) = 0; | 
|  | 232 |  | 
|  | 233 | /** | 
|  | 234 | * Fill in the camera3_stream_buffer with the next valid buffer for this | 
|  | 235 | * stream, to hand over to the HAL. | 
|  | 236 | * | 
|  | 237 | * This method may only be called once finishConfiguration has been called. | 
|  | 238 | * For bidirectional streams, this method applies to the input-side | 
|  | 239 | * buffers. | 
|  | 240 | * | 
| Eino-Ville Talvala | ba43525 | 2017-06-21 16:07:25 -0700 | [diff] [blame] | 241 | * Normally this call will block until the handed out buffer count is less than the stream | 
|  | 242 | * max buffer count; if respectHalLimit is set to false, this is ignored. | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 243 | */ | 
| Eino-Ville Talvala | ba43525 | 2017-06-21 16:07:25 -0700 | [diff] [blame] | 244 | virtual status_t getInputBuffer(camera3_stream_buffer *buffer, bool respectHalLimit = true) = 0; | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 245 |  | 
|  | 246 | /** | 
|  | 247 | * Return a buffer to the stream after use by the HAL. | 
|  | 248 | * | 
|  | 249 | * This method may only be called for buffers provided by getBuffer(). | 
|  | 250 | * For bidirectional streams, this method applies to the input-side buffers | 
|  | 251 | */ | 
|  | 252 | virtual status_t returnInputBuffer(const camera3_stream_buffer &buffer) = 0; | 
|  | 253 |  | 
|  | 254 | /** | 
| Chien-Yu Chen | 618ff8a | 2015-03-13 11:27:17 -0700 | [diff] [blame] | 255 | * Get the buffer producer of the input buffer queue. | 
|  | 256 | * | 
|  | 257 | * This method only applies to input streams. | 
|  | 258 | */ | 
|  | 259 | virtual status_t getInputBufferProducer(sp<IGraphicBufferProducer> *producer) = 0; | 
|  | 260 |  | 
|  | 261 | /** | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 262 | * Whether any of the stream's buffers are currently in use by the HAL, | 
|  | 263 | * including buffers that have been returned but not yet had their | 
|  | 264 | * release fence signaled. | 
|  | 265 | */ | 
|  | 266 | virtual bool     hasOutstandingBuffers() const = 0; | 
|  | 267 |  | 
|  | 268 | enum { | 
|  | 269 | TIMEOUT_NEVER = -1 | 
|  | 270 | }; | 
| Eino-Ville Talvala | f1e98d8 | 2013-09-06 09:32:43 -0700 | [diff] [blame] | 271 |  | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 272 | /** | 
| Eino-Ville Talvala | f1e98d8 | 2013-09-06 09:32:43 -0700 | [diff] [blame] | 273 | * Set the state tracker to use for signaling idle transitions. | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 274 | */ | 
| Eino-Ville Talvala | f1e98d8 | 2013-09-06 09:32:43 -0700 | [diff] [blame] | 275 | virtual status_t setStatusTracker(sp<StatusTracker> statusTracker) = 0; | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 276 |  | 
|  | 277 | /** | 
|  | 278 | * Disconnect stream from its non-HAL endpoint. After this, | 
|  | 279 | * start/finishConfiguration must be called before the stream can be used | 
|  | 280 | * again. This cannot be called if the stream has outstanding dequeued | 
|  | 281 | * buffers. | 
|  | 282 | */ | 
|  | 283 | virtual status_t disconnect() = 0; | 
|  | 284 |  | 
|  | 285 | /** | 
| Chien-Yu Chen | e8c535e | 2016-04-14 12:18:26 -0700 | [diff] [blame] | 286 | * Return if the buffer queue of the stream is abandoned. | 
|  | 287 | */ | 
|  | 288 | virtual bool isAbandoned() const = 0; | 
|  | 289 |  | 
|  | 290 | /** | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 291 | * Debug dump of the stream's state. | 
|  | 292 | */ | 
|  | 293 | virtual void     dump(int fd, const Vector<String16> &args) const = 0; | 
|  | 294 |  | 
|  | 295 | virtual void     addBufferListener( | 
|  | 296 | wp<Camera3StreamBufferListener> listener) = 0; | 
|  | 297 | virtual void     removeBufferListener( | 
|  | 298 | const sp<Camera3StreamBufferListener>& listener) = 0; | 
| Yin-Chia Yeh | be83fa7 | 2017-03-30 13:35:36 -0700 | [diff] [blame] | 299 |  | 
|  | 300 | /** | 
|  | 301 | * Setting listner will remove previous listener (if exists) | 
|  | 302 | * Only allow set listener during stream configuration because stream is guaranteed to be IDLE | 
|  | 303 | * at this state, so setBufferFreedListener won't collide with onBufferFreed callbacks. | 
|  | 304 | * Client is responsible to keep the listener object alive throughout the lifecycle of this | 
|  | 305 | * Camera3Stream. | 
|  | 306 | */ | 
| Yin-Chia Yeh | db1e864 | 2017-07-14 15:19:30 -0700 | [diff] [blame] | 307 | virtual void setBufferFreedListener(wp<Camera3StreamBufferFreedListener> listener) = 0; | 
| Igor Murashkin | ae500e5 | 2013-04-22 14:03:54 -0700 | [diff] [blame] | 308 | }; | 
|  | 309 |  | 
|  | 310 | } // namespace camera3 | 
|  | 311 |  | 
|  | 312 | } // namespace android | 
|  | 313 |  | 
|  | 314 | #endif |