blob: 2feca27ad217b692531c07f7bf17c25414d7cac0 [file] [log] [blame]
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -08001/*
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_OUTPUT_STREAM_H
18#define ANDROID_SERVERS_CAMERA3_OUTPUT_STREAM_H
19
20#include <utils/RefBase.h>
Zhijun He125684a2015-12-26 15:07:30 -080021#include <gui/IProducerListener.h>
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -080022#include <gui/Surface.h>
23
24#include "Camera3Stream.h"
Igor Murashkine3a9f962013-05-08 18:03:15 -070025#include "Camera3IOStreamBase.h"
Igor Murashkin2fba5842013-04-22 14:03:54 -070026#include "Camera3OutputStreamInterface.h"
Zhijun He125684a2015-12-26 15:07:30 -080027#include "Camera3BufferManager.h"
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -080028
29namespace android {
30
31namespace camera3 {
32
Zhijun He125684a2015-12-26 15:07:30 -080033class Camera3BufferManager;
34
35/**
36 * Stream info structure that holds the necessary stream info for buffer manager to use for
37 * buffer allocation and management.
38 */
39struct StreamInfo {
40 int streamId;
41 int streamSetId;
42 uint32_t width;
43 uint32_t height;
44 uint32_t format;
45 android_dataspace dataSpace;
46 uint32_t combinedUsage;
47 size_t totalBufferCount;
48 bool isConfigured;
49 StreamInfo(int id = CAMERA3_STREAM_ID_INVALID,
50 int setId = CAMERA3_STREAM_SET_ID_INVALID,
51 uint32_t w = 0,
52 uint32_t h = 0,
53 uint32_t fmt = 0,
54 android_dataspace ds = HAL_DATASPACE_UNKNOWN,
55 uint32_t usage = 0,
56 size_t bufferCount = 0,
57 bool configured = false) :
58 streamId(id),
59 streamSetId(setId),
60 width(w),
61 height(h),
62 format(fmt),
63 dataSpace(ds),
64 combinedUsage(usage),
65 totalBufferCount(bufferCount),
66 isConfigured(configured){}
67};
68
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -080069/**
70 * A class for managing a single stream of output data from the camera device.
71 */
Igor Murashkin2fba5842013-04-22 14:03:54 -070072class Camera3OutputStream :
Igor Murashkine3a9f962013-05-08 18:03:15 -070073 public Camera3IOStreamBase,
Igor Murashkin2fba5842013-04-22 14:03:54 -070074 public Camera3OutputStreamInterface {
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -080075 public:
76 /**
77 * Set up a stream for formats that have 2 dimensions, such as RAW and YUV.
Zhijun He125684a2015-12-26 15:07:30 -080078 * A valid stream set id needs to be set to support buffer sharing between multiple
79 * streams.
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -080080 */
Eino-Ville Talvala727d1722015-06-09 13:44:19 -070081 Camera3OutputStream(int id, sp<Surface> consumer,
Eino-Ville Talvala3d82c0d2015-02-23 15:19:19 -080082 uint32_t width, uint32_t height, int format,
Zhijun He125684a2015-12-26 15:07:30 -080083 android_dataspace dataSpace, camera3_stream_rotation_t rotation,
Shuzhen Wangc28dccc2016-02-11 23:48:46 -080084 nsecs_t timestampOffset, int setId = CAMERA3_STREAM_SET_ID_INVALID);
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -080085
86 /**
87 * Set up a stream for formats that have a variable buffer size for the same
88 * dimensions, such as compressed JPEG.
Zhijun He125684a2015-12-26 15:07:30 -080089 * A valid stream set id needs to be set to support buffer sharing between multiple
90 * streams.
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -080091 */
Eino-Ville Talvala727d1722015-06-09 13:44:19 -070092 Camera3OutputStream(int id, sp<Surface> consumer,
Eino-Ville Talvala3d82c0d2015-02-23 15:19:19 -080093 uint32_t width, uint32_t height, size_t maxSize, int format,
Zhijun He125684a2015-12-26 15:07:30 -080094 android_dataspace dataSpace, camera3_stream_rotation_t rotation,
Shuzhen Wangc28dccc2016-02-11 23:48:46 -080095 nsecs_t timestampOffset, int setId = CAMERA3_STREAM_SET_ID_INVALID);
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -080096
Zhijun He5d677d12016-05-29 16:52:39 -070097 /**
98 * Set up a stream with deferred consumer for formats that have 2 dimensions, such as
99 * RAW and YUV. The consumer must be set before using this stream for output. A valid
100 * stream set id needs to be set to support buffer sharing between multiple streams.
101 */
102 Camera3OutputStream(int id, uint32_t width, uint32_t height, int format,
103 uint32_t consumerUsage, android_dataspace dataSpace,
104 camera3_stream_rotation_t rotation, nsecs_t timestampOffset,
105 int setId = CAMERA3_STREAM_SET_ID_INVALID);
106
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -0800107 virtual ~Camera3OutputStream();
108
109 /**
110 * Camera3Stream interface
111 */
112
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -0800113 virtual void dump(int fd, const Vector<String16> &args) const;
114
115 /**
116 * Set the transform on the output stream; one of the
117 * HAL_TRANSFORM_* / NATIVE_WINDOW_TRANSFORM_* constants.
118 */
119 status_t setTransform(int transform);
120
Chien-Yu Chen85a64552015-08-28 15:46:12 -0700121 /**
122 * Return if this output stream is for video encoding.
123 */
124 bool isVideoStream() const;
Shuzhen Wang13a69632016-01-26 09:51:07 -0800125 /**
126 * Return if this output stream is consumed by hardware composer.
127 */
128 bool isConsumedByHWComposer() const;
Chien-Yu Chen85a64552015-08-28 15:46:12 -0700129
Zhijun He5d677d12016-05-29 16:52:39 -0700130 /**
131 * Return if the consumer configuration of this stream is deferred.
132 */
133 virtual bool isConsumerConfigurationDeferred() const;
134
135 /**
136 * Set the consumer surface to the output stream.
137 */
138 virtual status_t setConsumer(sp<Surface> consumer);
139
Zhijun He125684a2015-12-26 15:07:30 -0800140 class BufferReleasedListener : public BnProducerListener {
141 public:
142 BufferReleasedListener(wp<Camera3OutputStream> parent) : mParent(parent) {}
143
144 /**
145 * Implementation of IProducerListener, used to notify this stream that the consumer
146 * has returned a buffer and it is ready to return to Camera3BufferManager for reuse.
147 */
148 virtual void onBufferReleased();
149
150 private:
151 wp<Camera3OutputStream> mParent;
152 };
153
154 /**
155 * Set the graphic buffer manager to get/return the stream buffers.
156 *
157 * It is only legal to call this method when stream is in STATE_CONSTRUCTED state.
158 */
159 status_t setBufferManager(sp<Camera3BufferManager> bufferManager);
160
Igor Murashkine3a9f962013-05-08 18:03:15 -0700161 protected:
162 Camera3OutputStream(int id, camera3_stream_type_t type,
Eino-Ville Talvala3d82c0d2015-02-23 15:19:19 -0800163 uint32_t width, uint32_t height, int format,
Zhijun He125684a2015-12-26 15:07:30 -0800164 android_dataspace dataSpace, camera3_stream_rotation_t rotation,
165 int setId = CAMERA3_STREAM_SET_ID_INVALID);
Igor Murashkine3a9f962013-05-08 18:03:15 -0700166
Zhijun He124ccf42013-05-22 14:01:30 -0700167 /**
168 * Note that we release the lock briefly in this function
169 */
Igor Murashkine3a9f962013-05-08 18:03:15 -0700170 virtual status_t returnBufferCheckedLocked(
171 const camera3_stream_buffer &buffer,
172 nsecs_t timestamp,
173 bool output,
174 /*out*/
175 sp<Fence> *releaseFenceOut);
176
Zhijun He0a210512014-07-24 13:45:15 -0700177 virtual status_t disconnectLocked();
178
Eino-Ville Talvala727d1722015-06-09 13:44:19 -0700179 sp<Surface> mConsumer;
Zhijun He5d677d12016-05-29 16:52:39 -0700180
Igor Murashkine3a9f962013-05-08 18:03:15 -0700181 private:
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -0800182 int mTransform;
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -0800183
Igor Murashkine3a9f962013-05-08 18:03:15 -0700184 virtual status_t setTransformLocked(int transform);
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -0800185
Ruchit Sharmae0711f22014-08-18 13:48:24 -0400186 bool mTraceFirstBuffer;
187
Eino-Ville Talvala727d1722015-06-09 13:44:19 -0700188 // Name of Surface consumer
189 String8 mConsumerName;
190
Shuzhen Wangc28dccc2016-02-11 23:48:46 -0800191 // Whether consumer assumes MONOTONIC timestamp
192 bool mUseMonoTimestamp;
Shuzhen Wang13a69632016-01-26 09:51:07 -0800193
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -0800194 /**
Zhijun He125684a2015-12-26 15:07:30 -0800195 * GraphicBuffer manager this stream is registered to. Used to replace the buffer
196 * allocation/deallocation role of BufferQueue.
197 */
198 sp<Camera3BufferManager> mBufferManager;
199
200 /**
201 * Buffer released listener, used to notify the buffer manager that a buffer is released
202 * from consumer side.
203 */
204 sp<BufferReleasedListener> mBufferReleasedListener;
205
206 /**
207 * Flag indicating if the buffer manager is used to allocate the stream buffers
208 */
209 bool mUseBufferManager;
Shuzhen Wangc28dccc2016-02-11 23:48:46 -0800210
211 /**
212 * Timestamp offset for video and hardware composer consumed streams
213 */
214 nsecs_t mTimestampOffset;
215
Zhijun He125684a2015-12-26 15:07:30 -0800216 /**
Zhijun He5d677d12016-05-29 16:52:39 -0700217 * Consumer end point usage flag set by the constructor for the deferred
218 * consumer case.
219 */
220 uint32_t mConsumerUsage;
221
222 /**
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -0800223 * Internal Camera3Stream interface
224 */
225 virtual status_t getBufferLocked(camera3_stream_buffer *buffer);
226 virtual status_t returnBufferLocked(
227 const camera3_stream_buffer &buffer,
228 nsecs_t timestamp);
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -0800229
230 virtual status_t configureQueueLocked();
Eino-Ville Talvalab2f5b192013-07-30 14:36:03 -0700231
Eino-Ville Talvala4d44cad2015-04-11 13:15:45 -0700232 virtual status_t getEndpointUsage(uint32_t *usage) const;
Eino-Ville Talvalab2f5b192013-07-30 14:36:03 -0700233
Eino-Ville Talvalafd58f1a2013-03-06 16:20:06 -0800234}; // class Camera3OutputStream
235
236} // namespace camera3
237
238} // namespace android
239
240#endif