blob: 0b8c70525b9fbcf29aaa8de83968bc113851204b [file] [log] [blame]
Jamie Gennis8ba32fa2010-12-20 11:27:26 -08001/*
2 * Copyright (C) 2010 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#include <stdint.h>
18#include <sys/types.h>
19
20#include <utils/Errors.h>
Jesse Hall399184a2014-03-03 15:42:54 -080021#include <utils/NativeHandle.h>
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080022#include <utils/RefBase.h>
Brian Anderson175a7202016-10-10 16:52:56 -070023#include <utils/String8.h>
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080024#include <utils/Timers.h>
Jesse Hall399184a2014-03-03 15:42:54 -080025#include <utils/Vector.h>
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080026
27#include <binder/Parcel.h>
28#include <binder/IInterface.h>
29
Jiyong Parka75d3d62018-04-09 12:16:30 +090030#ifndef NO_BUFFERHUB
Jiwen 'Steve' Caic90a77f2018-01-14 15:42:29 -080031#include <gui/BufferHubProducer.h>
Jiyong Parka75d3d62018-04-09 12:16:30 +090032#endif
Pawin Vongmasae672cd02019-02-14 16:01:29 -080033
34#include <gui/bufferqueue/1.0/H2BGraphicBufferProducer.h>
35#include <gui/bufferqueue/2.0/H2BGraphicBufferProducer.h>
Chia-I Wuc79a2962017-05-15 10:32:27 -070036#include <gui/BufferQueueDefs.h>
Andy McFadden2adaf042012-12-18 09:49:45 -080037#include <gui/IGraphicBufferProducer.h>
Dan Stozaf0eaf252014-03-21 13:05:51 -070038#include <gui/IProducerListener.h>
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080039
40namespace android {
41// ----------------------------------------------------------------------------
42
Pawin Vongmasae672cd02019-02-14 16:01:29 -080043using H2BGraphicBufferProducerV1_0 =
44 ::android::hardware::graphics::bufferqueue::V1_0::utils::
45 H2BGraphicBufferProducer;
46using H2BGraphicBufferProducerV2_0 =
47 ::android::hardware::graphics::bufferqueue::V2_0::utils::
Pawin Vongmasa6e1193a2017-03-07 13:08:40 -080048 H2BGraphicBufferProducer;
49
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080050enum {
51 REQUEST_BUFFER = IBinder::FIRST_CALL_TRANSACTION,
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080052 DEQUEUE_BUFFER,
Dan Stoza9f3053d2014-03-06 15:14:33 -080053 DETACH_BUFFER,
Dan Stozad9822a32014-03-28 15:25:31 -070054 DETACH_NEXT_BUFFER,
Dan Stoza9f3053d2014-03-06 15:14:33 -080055 ATTACH_BUFFER,
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080056 QUEUE_BUFFER,
57 CANCEL_BUFFER,
Mathias Agopianeafabcd2011-04-20 14:20:59 -070058 QUERY,
Jamie Gennisfe0a87b2011-07-13 19:12:20 -070059 CONNECT,
60 DISCONNECT,
Jesse Hall399184a2014-03-03 15:42:54 -080061 SET_SIDEBAND_STREAM,
Dan Stoza29a3e902014-06-20 13:13:57 -070062 ALLOCATE_BUFFERS,
Dan Stoza9de72932015-04-16 17:28:43 -070063 ALLOW_ALLOCATION,
Dan Stoza812ed062015-06-02 15:45:22 -070064 SET_GENERATION_NUMBER,
Dan Stozac6f30bd2015-06-08 09:32:50 -070065 GET_CONSUMER_NAME,
Pablo Ceballosfa455352015-08-12 17:47:47 -070066 SET_MAX_DEQUEUED_BUFFER_COUNT,
Dan Stoza7dde5992015-05-22 09:51:44 -070067 SET_ASYNC_MODE,
Pablo Ceballos3559fbf2016-03-17 15:50:23 -070068 SET_SHARED_BUFFER_MODE,
Pablo Ceballosff95aab2016-01-13 17:09:58 -080069 SET_AUTO_REFRESH,
Dan Stoza127fc632015-06-30 13:43:32 -070070 SET_DEQUEUE_TIMEOUT,
Dan Stoza50101d02016-04-07 16:53:23 -070071 GET_LAST_QUEUED_BUFFER,
Pablo Ceballosfc352582016-06-30 17:22:20 -070072 GET_FRAME_TIMESTAMPS,
Chia-I Wue2786ea2017-08-07 10:36:08 -070073 GET_UNIQUE_ID,
74 GET_CONSUMER_USAGE,
Sungtak Lee3249fb62019-03-02 16:40:47 -080075 SET_LEGACY_BUFFER_DROP,
Yiwei Zhang538cedc2019-06-24 19:35:03 -070076 SET_AUTO_PREROTATION,
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080077};
78
Andy McFadden2adaf042012-12-18 09:49:45 -080079class BpGraphicBufferProducer : public BpInterface<IGraphicBufferProducer>
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080080{
81public:
Chih-Hung Hsiehe2347b72016-04-25 15:41:05 -070082 explicit BpGraphicBufferProducer(const sp<IBinder>& impl)
Andy McFadden2adaf042012-12-18 09:49:45 -080083 : BpInterface<IGraphicBufferProducer>(impl)
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080084 {
85 }
86
Yi Kongca038512017-05-02 16:55:24 -070087 ~BpGraphicBufferProducer() override;
Dan Stoza3be1c6b2014-11-18 10:24:03 -080088
Jamie Gennis7b305ff2011-07-19 12:08:33 -070089 virtual status_t requestBuffer(int bufferIdx, sp<GraphicBuffer>* buf) {
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080090 Parcel data, reply;
Andy McFadden2adaf042012-12-18 09:49:45 -080091 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080092 data.writeInt32(bufferIdx);
Jamie Gennis8a29ff22011-10-14 15:03:17 -070093 status_t result =remote()->transact(REQUEST_BUFFER, data, &reply);
94 if (result != NO_ERROR) {
95 return result;
96 }
Jamie Gennis8ba32fa2010-12-20 11:27:26 -080097 bool nonNull = reply.readInt32();
98 if (nonNull) {
Jamie Gennis7b305ff2011-07-19 12:08:33 -070099 *buf = new GraphicBuffer();
Lingyun Zhu2aff7022012-11-20 19:24:35 +0800100 result = reply.read(**buf);
101 if(result != NO_ERROR) {
102 (*buf).clear();
103 return result;
104 }
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800105 }
Jamie Gennis8a29ff22011-10-14 15:03:17 -0700106 result = reply.readInt32();
Jamie Gennis7b305ff2011-07-19 12:08:33 -0700107 return result;
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800108 }
109
Pablo Ceballosfa455352015-08-12 17:47:47 -0700110 virtual status_t setMaxDequeuedBufferCount(int maxDequeuedBuffers) {
111 Parcel data, reply;
112 data.writeInterfaceToken(
113 IGraphicBufferProducer::getInterfaceDescriptor());
114 data.writeInt32(maxDequeuedBuffers);
115 status_t result = remote()->transact(SET_MAX_DEQUEUED_BUFFER_COUNT,
116 data, &reply);
117 if (result != NO_ERROR) {
118 return result;
119 }
120 result = reply.readInt32();
121 return result;
122 }
123
124 virtual status_t setAsyncMode(bool async) {
125 Parcel data, reply;
126 data.writeInterfaceToken(
127 IGraphicBufferProducer::getInterfaceDescriptor());
128 data.writeInt32(async);
129 status_t result = remote()->transact(SET_ASYNC_MODE,
130 data, &reply);
131 if (result != NO_ERROR) {
132 return result;
133 }
134 result = reply.readInt32();
135 return result;
136 }
137
Ian Elliotta2eb34c2017-07-18 11:05:49 -0600138 virtual status_t dequeueBuffer(int* buf, sp<Fence>* fence, uint32_t width, uint32_t height,
139 PixelFormat format, uint64_t usage, uint64_t* outBufferAge,
140 FrameEventHistoryDelta* outTimestamps) {
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800141 Parcel data, reply;
Brian Anderson7c3ba8a2016-07-25 12:48:08 -0700142 bool getFrameTimestamps = (outTimestamps != nullptr);
Brian Andersonbaaad322016-07-22 15:55:13 -0700143
Andy McFadden2adaf042012-12-18 09:49:45 -0800144 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800145 data.writeUint32(width);
146 data.writeUint32(height);
147 data.writeInt32(static_cast<int32_t>(format));
Mathias Agopiancb496ac2017-05-22 14:21:00 -0700148 data.writeUint64(usage);
Brian Anderson7c3ba8a2016-07-25 12:48:08 -0700149 data.writeBool(getFrameTimestamps);
Brian Andersonbaaad322016-07-22 15:55:13 -0700150
Jamie Gennis8a29ff22011-10-14 15:03:17 -0700151 status_t result = remote()->transact(DEQUEUE_BUFFER, data, &reply);
152 if (result != NO_ERROR) {
153 return result;
154 }
Brian Andersonbaaad322016-07-22 15:55:13 -0700155
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800156 *buf = reply.readInt32();
Brian Andersonbaaad322016-07-22 15:55:13 -0700157 *fence = new Fence();
158 result = reply.read(**fence);
159 if (result != NO_ERROR) {
160 fence->clear();
161 return result;
Jesse Hallf7857542012-06-14 15:26:33 -0700162 }
Ian Elliotta2eb34c2017-07-18 11:05:49 -0600163 if (outBufferAge) {
164 result = reply.readUint64(outBufferAge);
165 } else {
166 // Read the value even if outBufferAge is nullptr:
167 uint64_t bufferAge;
168 result = reply.readUint64(&bufferAge);
169 }
170 if (result != NO_ERROR) {
171 ALOGE("IGBP::dequeueBuffer failed to read buffer age: %d", result);
172 return result;
173 }
Brian Anderson7c3ba8a2016-07-25 12:48:08 -0700174 if (getFrameTimestamps) {
175 result = reply.read(*outTimestamps);
176 if (result != NO_ERROR) {
177 ALOGE("IGBP::dequeueBuffer failed to read timestamps: %d",
178 result);
179 return result;
180 }
181 }
Jamie Gennis8a29ff22011-10-14 15:03:17 -0700182 result = reply.readInt32();
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800183 return result;
184 }
185
Dan Stoza9f3053d2014-03-06 15:14:33 -0800186 virtual status_t detachBuffer(int slot) {
187 Parcel data, reply;
188 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
189 data.writeInt32(slot);
190 status_t result = remote()->transact(DETACH_BUFFER, data, &reply);
191 if (result != NO_ERROR) {
192 return result;
193 }
194 result = reply.readInt32();
195 return result;
196 }
197
Dan Stozad9822a32014-03-28 15:25:31 -0700198 virtual status_t detachNextBuffer(sp<GraphicBuffer>* outBuffer,
199 sp<Fence>* outFence) {
Yi Kong48a619f2018-06-05 16:34:59 -0700200 if (outBuffer == nullptr) {
Dan Stozad9822a32014-03-28 15:25:31 -0700201 ALOGE("detachNextBuffer: outBuffer must not be NULL");
202 return BAD_VALUE;
Yi Kong48a619f2018-06-05 16:34:59 -0700203 } else if (outFence == nullptr) {
Dan Stozad9822a32014-03-28 15:25:31 -0700204 ALOGE("detachNextBuffer: outFence must not be NULL");
205 return BAD_VALUE;
206 }
207 Parcel data, reply;
208 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
209 status_t result = remote()->transact(DETACH_NEXT_BUFFER, data, &reply);
210 if (result != NO_ERROR) {
211 return result;
212 }
213 result = reply.readInt32();
214 if (result == NO_ERROR) {
215 bool nonNull = reply.readInt32();
216 if (nonNull) {
217 *outBuffer = new GraphicBuffer;
Pablo Ceballos70636b32016-07-06 15:24:54 -0700218 result = reply.read(**outBuffer);
219 if (result != NO_ERROR) {
220 outBuffer->clear();
221 return result;
222 }
Dan Stozad9822a32014-03-28 15:25:31 -0700223 }
224 nonNull = reply.readInt32();
225 if (nonNull) {
226 *outFence = new Fence;
Pablo Ceballos70636b32016-07-06 15:24:54 -0700227 result = reply.read(**outFence);
228 if (result != NO_ERROR) {
229 outBuffer->clear();
230 outFence->clear();
231 return result;
232 }
Dan Stozad9822a32014-03-28 15:25:31 -0700233 }
234 }
235 return result;
236 }
237
Dan Stoza9f3053d2014-03-06 15:14:33 -0800238 virtual status_t attachBuffer(int* slot, const sp<GraphicBuffer>& buffer) {
239 Parcel data, reply;
240 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
241 data.write(*buffer.get());
242 status_t result = remote()->transact(ATTACH_BUFFER, data, &reply);
243 if (result != NO_ERROR) {
244 return result;
245 }
Chia-I Wuc79a2962017-05-15 10:32:27 -0700246
Dan Stoza9f3053d2014-03-06 15:14:33 -0800247 *slot = reply.readInt32();
248 result = reply.readInt32();
Chia-I Wuc79a2962017-05-15 10:32:27 -0700249 if (result == NO_ERROR &&
250 (*slot < 0 || *slot >= BufferQueueDefs::NUM_BUFFER_SLOTS)) {
251 ALOGE("attachBuffer returned invalid slot %d", *slot);
252 android_errorWriteLog(0x534e4554, "37478824");
253 return UNKNOWN_ERROR;
254 }
255
Dan Stoza9f3053d2014-03-06 15:14:33 -0800256 return result;
257 }
258
Mathias Agopianf0bc2f12012-04-09 16:14:01 -0700259 virtual status_t queueBuffer(int buf,
260 const QueueBufferInput& input, QueueBufferOutput* output) {
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800261 Parcel data, reply;
Brian Andersonbaaad322016-07-22 15:55:13 -0700262
Andy McFadden2adaf042012-12-18 09:49:45 -0800263 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800264 data.writeInt32(buf);
Jesse Hallc777b0b2012-06-28 12:52:05 -0700265 data.write(input);
Brian Andersonbaaad322016-07-22 15:55:13 -0700266
Jamie Gennis8a29ff22011-10-14 15:03:17 -0700267 status_t result = remote()->transact(QUEUE_BUFFER, data, &reply);
268 if (result != NO_ERROR) {
269 return result;
270 }
Brian Andersonbaaad322016-07-22 15:55:13 -0700271
272 result = reply.read(*output);
273 if (result != NO_ERROR) {
274 return result;
275 }
276
Jamie Gennis8a29ff22011-10-14 15:03:17 -0700277 result = reply.readInt32();
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800278 return result;
279 }
280
Pablo Ceballos583b1b32015-09-03 18:23:52 -0700281 virtual status_t cancelBuffer(int buf, const sp<Fence>& fence) {
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800282 Parcel data, reply;
Andy McFadden2adaf042012-12-18 09:49:45 -0800283 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800284 data.writeInt32(buf);
Jamie Gennis1df8c342012-12-20 14:05:45 -0800285 data.write(*fence.get());
Pablo Ceballos583b1b32015-09-03 18:23:52 -0700286 status_t result = remote()->transact(CANCEL_BUFFER, data, &reply);
287 if (result != NO_ERROR) {
288 return result;
289 }
290 result = reply.readInt32();
291 return result;
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800292 }
293
Mathias Agopianeafabcd2011-04-20 14:20:59 -0700294 virtual int query(int what, int* value) {
295 Parcel data, reply;
Andy McFadden2adaf042012-12-18 09:49:45 -0800296 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
Mathias Agopianeafabcd2011-04-20 14:20:59 -0700297 data.writeInt32(what);
Jamie Gennis8a29ff22011-10-14 15:03:17 -0700298 status_t result = remote()->transact(QUERY, data, &reply);
299 if (result != NO_ERROR) {
300 return result;
301 }
Mathias Agopianeafabcd2011-04-20 14:20:59 -0700302 value[0] = reply.readInt32();
Jamie Gennis8a29ff22011-10-14 15:03:17 -0700303 result = reply.readInt32();
Mathias Agopianeafabcd2011-04-20 14:20:59 -0700304 return result;
305 }
306
Dan Stozaf0eaf252014-03-21 13:05:51 -0700307 virtual status_t connect(const sp<IProducerListener>& listener,
Mathias Agopian365857d2013-09-11 19:35:45 -0700308 int api, bool producerControlledByApp, QueueBufferOutput* output) {
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700309 Parcel data, reply;
Andy McFadden2adaf042012-12-18 09:49:45 -0800310 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
Yi Kong48a619f2018-06-05 16:34:59 -0700311 if (listener != nullptr) {
Dan Stozaf0eaf252014-03-21 13:05:51 -0700312 data.writeInt32(1);
Marco Nelissen097ca272014-11-14 08:01:01 -0800313 data.writeStrongBinder(IInterface::asBinder(listener));
Dan Stozaf0eaf252014-03-21 13:05:51 -0700314 } else {
315 data.writeInt32(0);
316 }
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700317 data.writeInt32(api);
Mathias Agopian595264f2013-07-16 22:56:09 -0700318 data.writeInt32(producerControlledByApp);
Jamie Gennis8a29ff22011-10-14 15:03:17 -0700319 status_t result = remote()->transact(CONNECT, data, &reply);
320 if (result != NO_ERROR) {
321 return result;
322 }
Brian Andersonbaaad322016-07-22 15:55:13 -0700323 reply.read(*output);
Jamie Gennis8a29ff22011-10-14 15:03:17 -0700324 result = reply.readInt32();
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700325 return result;
326 }
Mathias Agopian80727112011-05-02 19:51:12 -0700327
Robert Carr97b9c862016-09-08 13:54:35 -0700328 virtual status_t disconnect(int api, DisconnectMode mode) {
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700329 Parcel data, reply;
Andy McFadden2adaf042012-12-18 09:49:45 -0800330 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700331 data.writeInt32(api);
Robert Carr97b9c862016-09-08 13:54:35 -0700332 data.writeInt32(static_cast<int32_t>(mode));
Jamie Gennis8a29ff22011-10-14 15:03:17 -0700333 status_t result =remote()->transact(DISCONNECT, data, &reply);
334 if (result != NO_ERROR) {
335 return result;
336 }
337 result = reply.readInt32();
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700338 return result;
339 }
Jesse Hall399184a2014-03-03 15:42:54 -0800340
341 virtual status_t setSidebandStream(const sp<NativeHandle>& stream) {
342 Parcel data, reply;
343 status_t result;
344 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
345 if (stream.get()) {
346 data.writeInt32(true);
347 data.writeNativeHandle(stream->handle());
348 } else {
349 data.writeInt32(false);
350 }
351 if ((result = remote()->transact(SET_SIDEBAND_STREAM, data, &reply)) == NO_ERROR) {
352 result = reply.readInt32();
353 }
354 return result;
355 }
Dan Stoza29a3e902014-06-20 13:13:57 -0700356
Pablo Ceballos567dbbb2015-08-26 18:59:08 -0700357 virtual void allocateBuffers(uint32_t width, uint32_t height,
Mathias Agopiancb496ac2017-05-22 14:21:00 -0700358 PixelFormat format, uint64_t usage) {
Dan Stoza29a3e902014-06-20 13:13:57 -0700359 Parcel data, reply;
360 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800361 data.writeUint32(width);
362 data.writeUint32(height);
Dan Stoza29a3e902014-06-20 13:13:57 -0700363 data.writeInt32(static_cast<int32_t>(format));
Mathias Agopiancb496ac2017-05-22 14:21:00 -0700364 data.writeUint64(usage);
Steven Moreland366eb422019-04-01 19:22:32 -0700365 status_t result = remote()->transact(ALLOCATE_BUFFERS, data, &reply, IBinder::FLAG_ONEWAY);
Dan Stoza29a3e902014-06-20 13:13:57 -0700366 if (result != NO_ERROR) {
367 ALOGE("allocateBuffers failed to transact: %d", result);
368 }
369 }
Dan Stoza9de72932015-04-16 17:28:43 -0700370
371 virtual status_t allowAllocation(bool allow) {
372 Parcel data, reply;
373 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
374 data.writeInt32(static_cast<int32_t>(allow));
375 status_t result = remote()->transact(ALLOW_ALLOCATION, data, &reply);
376 if (result != NO_ERROR) {
377 return result;
378 }
379 result = reply.readInt32();
380 return result;
381 }
Dan Stoza812ed062015-06-02 15:45:22 -0700382
383 virtual status_t setGenerationNumber(uint32_t generationNumber) {
384 Parcel data, reply;
385 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
386 data.writeUint32(generationNumber);
387 status_t result = remote()->transact(SET_GENERATION_NUMBER, data, &reply);
388 if (result == NO_ERROR) {
389 result = reply.readInt32();
390 }
391 return result;
392 }
Dan Stozac6f30bd2015-06-08 09:32:50 -0700393
394 virtual String8 getConsumerName() const {
395 Parcel data, reply;
396 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
397 status_t result = remote()->transact(GET_CONSUMER_NAME, data, &reply);
398 if (result != NO_ERROR) {
399 ALOGE("getConsumerName failed to transact: %d", result);
400 return String8("TransactFailed");
401 }
402 return reply.readString8();
403 }
Dan Stoza7dde5992015-05-22 09:51:44 -0700404
Pablo Ceballos3559fbf2016-03-17 15:50:23 -0700405 virtual status_t setSharedBufferMode(bool sharedBufferMode) {
Pablo Ceballosccdfd602015-10-07 15:05:45 -0700406 Parcel data, reply;
407 data.writeInterfaceToken(
408 IGraphicBufferProducer::getInterfaceDescriptor());
Pablo Ceballos3559fbf2016-03-17 15:50:23 -0700409 data.writeInt32(sharedBufferMode);
410 status_t result = remote()->transact(SET_SHARED_BUFFER_MODE, data,
Pablo Ceballosccdfd602015-10-07 15:05:45 -0700411 &reply);
412 if (result == NO_ERROR) {
413 result = reply.readInt32();
414 }
415 return result;
416 }
Dan Stoza127fc632015-06-30 13:43:32 -0700417
Pablo Ceballosff95aab2016-01-13 17:09:58 -0800418 virtual status_t setAutoRefresh(bool autoRefresh) {
419 Parcel data, reply;
420 data.writeInterfaceToken(
421 IGraphicBufferProducer::getInterfaceDescriptor());
422 data.writeInt32(autoRefresh);
423 status_t result = remote()->transact(SET_AUTO_REFRESH, data, &reply);
424 if (result == NO_ERROR) {
425 result = reply.readInt32();
426 }
427 return result;
428 }
429
Dan Stoza127fc632015-06-30 13:43:32 -0700430 virtual status_t setDequeueTimeout(nsecs_t timeout) {
431 Parcel data, reply;
432 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
433 data.writeInt64(timeout);
434 status_t result = remote()->transact(SET_DEQUEUE_TIMEOUT, data, &reply);
435 if (result != NO_ERROR) {
436 ALOGE("setDequeueTimeout failed to transact: %d", result);
437 return result;
438 }
439 return reply.readInt32();
440 }
Dan Stoza50101d02016-04-07 16:53:23 -0700441
Sungtak Lee3249fb62019-03-02 16:40:47 -0800442 virtual status_t setLegacyBufferDrop(bool drop) {
443 Parcel data, reply;
444 data.writeInterfaceToken(
445 IGraphicBufferProducer::getInterfaceDescriptor());
446 data.writeInt32(drop);
447 status_t result = remote()->transact(SET_LEGACY_BUFFER_DROP,
448 data, &reply);
449 if (result != NO_ERROR) {
450 return result;
451 }
452 result = reply.readInt32();
453 return result;
454 }
455
Dan Stoza50101d02016-04-07 16:53:23 -0700456 virtual status_t getLastQueuedBuffer(sp<GraphicBuffer>* outBuffer,
John Reck1a61da52016-04-28 13:18:15 -0700457 sp<Fence>* outFence, float outTransformMatrix[16]) override {
Dan Stoza50101d02016-04-07 16:53:23 -0700458 Parcel data, reply;
459 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
460 status_t result = remote()->transact(GET_LAST_QUEUED_BUFFER, data,
461 &reply);
462 if (result != NO_ERROR) {
463 ALOGE("getLastQueuedBuffer failed to transact: %d", result);
464 return result;
465 }
466 result = reply.readInt32();
467 if (result != NO_ERROR) {
468 return result;
469 }
John Reckce8e5df2016-04-28 10:12:47 -0700470 bool hasBuffer = reply.readBool();
471 sp<GraphicBuffer> buffer;
472 if (hasBuffer) {
473 buffer = new GraphicBuffer();
474 result = reply.read(*buffer);
John Reck1a61da52016-04-28 13:18:15 -0700475 if (result == NO_ERROR) {
476 result = reply.read(outTransformMatrix, sizeof(float) * 16);
477 }
John Reckce8e5df2016-04-28 10:12:47 -0700478 }
Dan Stoza50101d02016-04-07 16:53:23 -0700479 if (result != NO_ERROR) {
480 ALOGE("getLastQueuedBuffer failed to read buffer: %d", result);
481 return result;
482 }
483 sp<Fence> fence(new Fence);
484 result = reply.read(*fence);
485 if (result != NO_ERROR) {
486 ALOGE("getLastQueuedBuffer failed to read fence: %d", result);
487 return result;
488 }
489 *outBuffer = buffer;
490 *outFence = fence;
491 return result;
492 }
Pablo Ceballosce796e72016-02-04 19:10:51 -0800493
Brian Anderson3890c392016-07-25 12:48:08 -0700494 virtual void getFrameTimestamps(FrameEventHistoryDelta* outDelta) {
Pablo Ceballosce796e72016-02-04 19:10:51 -0800495 Parcel data, reply;
496 status_t result = data.writeInterfaceToken(
497 IGraphicBufferProducer::getInterfaceDescriptor());
498 if (result != NO_ERROR) {
Brian Anderson3890c392016-07-25 12:48:08 -0700499 ALOGE("IGBP::getFrameTimestamps failed to write token: %d", result);
500 return;
Pablo Ceballosce796e72016-02-04 19:10:51 -0800501 }
502 result = remote()->transact(GET_FRAME_TIMESTAMPS, data, &reply);
503 if (result != NO_ERROR) {
Brian Anderson3890c392016-07-25 12:48:08 -0700504 ALOGE("IGBP::getFrameTimestamps failed to transact: %d", result);
505 return;
Pablo Ceballosce796e72016-02-04 19:10:51 -0800506 }
Brian Anderson3890c392016-07-25 12:48:08 -0700507 result = reply.read(*outDelta);
Pablo Ceballosce796e72016-02-04 19:10:51 -0800508 if (result != NO_ERROR) {
Brian Anderson3890c392016-07-25 12:48:08 -0700509 ALOGE("IGBP::getFrameTimestamps failed to read timestamps: %d",
510 result);
Pablo Ceballosce796e72016-02-04 19:10:51 -0800511 }
Pablo Ceballosce796e72016-02-04 19:10:51 -0800512 }
Pablo Ceballos6155b402016-06-30 17:01:49 -0700513
Pablo Ceballos8e3e92b2016-06-27 17:56:53 -0700514 virtual status_t getUniqueId(uint64_t* outId) const {
515 Parcel data, reply;
516 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
517 status_t result = remote()->transact(GET_UNIQUE_ID, data, &reply);
518 if (result != NO_ERROR) {
519 ALOGE("getUniqueId failed to transact: %d", result);
520 }
521 status_t actualResult = NO_ERROR;
522 result = reply.readInt32(&actualResult);
523 if (result != NO_ERROR) {
524 return result;
525 }
526 result = reply.readUint64(outId);
527 if (result != NO_ERROR) {
528 return result;
529 }
530 return actualResult;
531 }
Chia-I Wue2786ea2017-08-07 10:36:08 -0700532
533 virtual status_t getConsumerUsage(uint64_t* outUsage) const {
534 Parcel data, reply;
535 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
536 status_t result = remote()->transact(GET_CONSUMER_USAGE, data, &reply);
537 if (result != NO_ERROR) {
538 ALOGE("getConsumerUsage failed to transact: %d", result);
539 }
540 status_t actualResult = NO_ERROR;
541 result = reply.readInt32(&actualResult);
542 if (result != NO_ERROR) {
543 return result;
544 }
545 result = reply.readUint64(outUsage);
546 if (result != NO_ERROR) {
547 return result;
548 }
549 return actualResult;
550 }
Yiwei Zhang538cedc2019-06-24 19:35:03 -0700551
552 virtual status_t setAutoPrerotation(bool autoPrerotation) {
553 Parcel data, reply;
554 data.writeInterfaceToken(IGraphicBufferProducer::getInterfaceDescriptor());
555 data.writeBool(autoPrerotation);
556 status_t result = remote()->transact(SET_AUTO_PREROTATION, data, &reply);
557 if (result == NO_ERROR) {
558 result = reply.readInt32();
559 }
560 return result;
561 }
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800562};
563
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800564// Out-of-line virtual method definition to trigger vtable emission in this
565// translation unit (see clang warning -Wweak-vtables)
566BpGraphicBufferProducer::~BpGraphicBufferProducer() {}
567
Pawin Vongmasa6e1193a2017-03-07 13:08:40 -0800568class HpGraphicBufferProducer : public HpInterface<
Pawin Vongmasae672cd02019-02-14 16:01:29 -0800569 BpGraphicBufferProducer,
570 H2BGraphicBufferProducerV1_0,
571 H2BGraphicBufferProducerV2_0> {
Pawin Vongmasa6e1193a2017-03-07 13:08:40 -0800572public:
Chih-Hung Hsiehaaf62162018-12-20 15:45:04 -0800573 explicit HpGraphicBufferProducer(const sp<IBinder>& base) : PBase(base) {}
Pawin Vongmasa6e1193a2017-03-07 13:08:40 -0800574
575 status_t requestBuffer(int slot, sp<GraphicBuffer>* buf) override {
576 return mBase->requestBuffer(slot, buf);
577 }
578
579 status_t setMaxDequeuedBufferCount(int maxDequeuedBuffers) override {
580 return mBase->setMaxDequeuedBufferCount(maxDequeuedBuffers);
581 }
582
583 status_t setAsyncMode(bool async) override {
584 return mBase->setAsyncMode(async);
585 }
586
Ian Elliotta2eb34c2017-07-18 11:05:49 -0600587 status_t dequeueBuffer(int* slot, sp<Fence>* fence, uint32_t w, uint32_t h, PixelFormat format,
588 uint64_t usage, uint64_t* outBufferAge,
589 FrameEventHistoryDelta* outTimestamps) override {
590 return mBase->dequeueBuffer(slot, fence, w, h, format, usage, outBufferAge, outTimestamps);
Pawin Vongmasa6e1193a2017-03-07 13:08:40 -0800591 }
592
593 status_t detachBuffer(int slot) override {
594 return mBase->detachBuffer(slot);
595 }
596
597 status_t detachNextBuffer(
598 sp<GraphicBuffer>* outBuffer, sp<Fence>* outFence) override {
599 return mBase->detachNextBuffer(outBuffer, outFence);
600 }
601
602 status_t attachBuffer(
603 int* outSlot, const sp<GraphicBuffer>& buffer) override {
604 return mBase->attachBuffer(outSlot, buffer);
605 }
606
607 status_t queueBuffer(
608 int slot,
609 const QueueBufferInput& input,
610 QueueBufferOutput* output) override {
611 return mBase->queueBuffer(slot, input, output);
612 }
613
614 status_t cancelBuffer(int slot, const sp<Fence>& fence) override {
615 return mBase->cancelBuffer(slot, fence);
616 }
617
618 int query(int what, int* value) override {
619 return mBase->query(what, value);
620 }
621
622 status_t connect(
623 const sp<IProducerListener>& listener,
624 int api, bool producerControlledByApp,
625 QueueBufferOutput* output) override {
626 return mBase->connect(listener, api, producerControlledByApp, output);
627 }
628
629 status_t disconnect(
630 int api, DisconnectMode mode = DisconnectMode::Api) override {
631 return mBase->disconnect(api, mode);
632 }
633
634 status_t setSidebandStream(const sp<NativeHandle>& stream) override {
635 return mBase->setSidebandStream(stream);
636 }
637
638 void allocateBuffers(uint32_t width, uint32_t height,
Mathias Agopiancb496ac2017-05-22 14:21:00 -0700639 PixelFormat format, uint64_t usage) override {
Pawin Vongmasa6e1193a2017-03-07 13:08:40 -0800640 return mBase->allocateBuffers(width, height, format, usage);
641 }
642
643 status_t allowAllocation(bool allow) override {
644 return mBase->allowAllocation(allow);
645 }
646
647 status_t setGenerationNumber(uint32_t generationNumber) override {
648 return mBase->setGenerationNumber(generationNumber);
649 }
650
651 String8 getConsumerName() const override {
652 return mBase->getConsumerName();
653 }
654
655 status_t setSharedBufferMode(bool sharedBufferMode) override {
656 return mBase->setSharedBufferMode(sharedBufferMode);
657 }
658
659 status_t setAutoRefresh(bool autoRefresh) override {
660 return mBase->setAutoRefresh(autoRefresh);
661 }
662
663 status_t setDequeueTimeout(nsecs_t timeout) override {
664 return mBase->setDequeueTimeout(timeout);
665 }
666
Sungtak Lee3249fb62019-03-02 16:40:47 -0800667 status_t setLegacyBufferDrop(bool drop) override {
668 return mBase->setLegacyBufferDrop(drop);
669 }
670
Pawin Vongmasa6e1193a2017-03-07 13:08:40 -0800671 status_t getLastQueuedBuffer(
672 sp<GraphicBuffer>* outBuffer,
673 sp<Fence>* outFence,
674 float outTransformMatrix[16]) override {
675 return mBase->getLastQueuedBuffer(
676 outBuffer, outFence, outTransformMatrix);
677 }
678
679 void getFrameTimestamps(FrameEventHistoryDelta* outDelta) override {
680 return mBase->getFrameTimestamps(outDelta);
681 }
682
683 status_t getUniqueId(uint64_t* outId) const override {
684 return mBase->getUniqueId(outId);
685 }
Chia-I Wue2786ea2017-08-07 10:36:08 -0700686
687 status_t getConsumerUsage(uint64_t* outUsage) const override {
688 return mBase->getConsumerUsage(outUsage);
689 }
Yiwei Zhang538cedc2019-06-24 19:35:03 -0700690
691 status_t setAutoPrerotation(bool autoPrerotation) override {
692 return mBase->setAutoPrerotation(autoPrerotation);
693 }
Pawin Vongmasa6e1193a2017-03-07 13:08:40 -0800694};
695
Pawin Vongmasa338b81d2019-01-31 05:20:07 -0800696IMPLEMENT_HYBRID_META_INTERFACE(GraphicBufferProducer,
Pawin Vongmasa6e1193a2017-03-07 13:08:40 -0800697 "android.gui.IGraphicBufferProducer");
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800698
699// ----------------------------------------------------------------------
700
Sungtak Lee3249fb62019-03-02 16:40:47 -0800701status_t IGraphicBufferProducer::setLegacyBufferDrop(bool drop) {
702 // No-op for IGBP other than BufferQueue.
703 (void) drop;
704 return INVALID_OPERATION;
705}
706
Yiwei Zhang538cedc2019-06-24 19:35:03 -0700707status_t IGraphicBufferProducer::setAutoPrerotation(bool autoPrerotation) {
708 // No-op for IGBP other than BufferQueue.
709 (void)autoPrerotation;
710 return INVALID_OPERATION;
711}
712
Jiwen 'Steve' Caic90a77f2018-01-14 15:42:29 -0800713status_t IGraphicBufferProducer::exportToParcel(Parcel* parcel) {
714 status_t res = OK;
715 res = parcel->writeUint32(USE_BUFFER_QUEUE);
716 if (res != NO_ERROR) {
717 ALOGE("exportToParcel: Cannot write magic, res=%d.", res);
718 return res;
719 }
720
721 return parcel->writeStrongBinder(IInterface::asBinder(this));
722}
723
724/* static */
725status_t IGraphicBufferProducer::exportToParcel(const sp<IGraphicBufferProducer>& producer,
726 Parcel* parcel) {
727 if (parcel == nullptr) {
728 ALOGE("exportToParcel: Invalid parcel object.");
729 return BAD_VALUE;
730 }
731
732 if (producer == nullptr) {
733 status_t res = OK;
734 res = parcel->writeUint32(IGraphicBufferProducer::USE_BUFFER_QUEUE);
735 if (res != NO_ERROR) return res;
736 return parcel->writeStrongBinder(nullptr);
737 } else {
738 return producer->exportToParcel(parcel);
739 }
740}
741
742/* static */
743sp<IGraphicBufferProducer> IGraphicBufferProducer::createFromParcel(const Parcel* parcel) {
744 uint32_t outMagic = 0;
745 status_t res = NO_ERROR;
746
747 res = parcel->readUint32(&outMagic);
748 if (res != NO_ERROR) {
749 ALOGE("createFromParcel: Failed to read magic, error=%d.", res);
750 return nullptr;
751 }
752
753 switch (outMagic) {
754 case USE_BUFFER_QUEUE: {
755 sp<IBinder> binder;
756 res = parcel->readNullableStrongBinder(&binder);
757 if (res != NO_ERROR) {
758 ALOGE("createFromParcel: Can't read strong binder.");
759 return nullptr;
760 }
761 return interface_cast<IGraphicBufferProducer>(binder);
762 }
763 case USE_BUFFER_HUB: {
764 ALOGE("createFromParcel: BufferHub not implemented.");
Jiyong Parka75d3d62018-04-09 12:16:30 +0900765#ifndef NO_BUFFERHUB
Jiwen 'Steve' Caic90a77f2018-01-14 15:42:29 -0800766 dvr::ProducerQueueParcelable producerParcelable;
767 res = producerParcelable.readFromParcel(parcel);
768 if (res != NO_ERROR) {
769 ALOGE("createFromParcel: Failed to read from parcel, error=%d", res);
770 return nullptr;
771 }
772 return BufferHubProducer::Create(std::move(producerParcelable));
Jiyong Parka75d3d62018-04-09 12:16:30 +0900773#else
774 return nullptr;
775#endif
Jiwen 'Steve' Caic90a77f2018-01-14 15:42:29 -0800776 }
777 default: {
778 ALOGE("createFromParcel: Unexpected mgaic: 0x%x.", outMagic);
779 return nullptr;
780 }
781 }
782}
783
784// ----------------------------------------------------------------------------
785
Andy McFadden2adaf042012-12-18 09:49:45 -0800786status_t BnGraphicBufferProducer::onTransact(
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800787 uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags)
788{
789 switch(code) {
790 case REQUEST_BUFFER: {
Andy McFadden2adaf042012-12-18 09:49:45 -0800791 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800792 int bufferIdx = data.readInt32();
Jamie Gennis7b305ff2011-07-19 12:08:33 -0700793 sp<GraphicBuffer> buffer;
794 int result = requestBuffer(bufferIdx, &buffer);
Yi Kong48a619f2018-06-05 16:34:59 -0700795 reply->writeInt32(buffer != nullptr);
796 if (buffer != nullptr) {
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800797 reply->write(*buffer);
798 }
Jamie Gennis7b305ff2011-07-19 12:08:33 -0700799 reply->writeInt32(result);
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800800 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800801 }
Pablo Ceballosfa455352015-08-12 17:47:47 -0700802 case SET_MAX_DEQUEUED_BUFFER_COUNT: {
803 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
804 int maxDequeuedBuffers = data.readInt32();
805 int result = setMaxDequeuedBufferCount(maxDequeuedBuffers);
806 reply->writeInt32(result);
807 return NO_ERROR;
808 }
809 case SET_ASYNC_MODE: {
810 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
811 bool async = data.readInt32();
812 int result = setAsyncMode(async);
813 reply->writeInt32(result);
814 return NO_ERROR;
815 }
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800816 case DEQUEUE_BUFFER: {
Andy McFadden2adaf042012-12-18 09:49:45 -0800817 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800818 uint32_t width = data.readUint32();
819 uint32_t height = data.readUint32();
820 PixelFormat format = static_cast<PixelFormat>(data.readInt32());
Mathias Agopiancb496ac2017-05-22 14:21:00 -0700821 uint64_t usage = data.readUint64();
Ian Elliotta2eb34c2017-07-18 11:05:49 -0600822 uint64_t bufferAge = 0;
Brian Anderson7c3ba8a2016-07-25 12:48:08 -0700823 bool getTimestamps = data.readBool();
Brian Andersonbaaad322016-07-22 15:55:13 -0700824
Naveen Leekha12ba0f52015-09-21 17:28:04 -0700825 int buf = 0;
Brian Andersonbaaad322016-07-22 15:55:13 -0700826 sp<Fence> fence = Fence::NO_FENCE;
Brian Anderson7c3ba8a2016-07-25 12:48:08 -0700827 FrameEventHistoryDelta frameTimestamps;
Ian Elliotta2eb34c2017-07-18 11:05:49 -0600828 int result = dequeueBuffer(&buf, &fence, width, height, format, usage, &bufferAge,
829 getTimestamps ? &frameTimestamps : nullptr);
Brian Andersonbaaad322016-07-22 15:55:13 -0700830
Tobin Ehlis209e5fb2019-03-26 14:06:29 -0600831 if (fence == nullptr) {
832 ALOGE("dequeueBuffer returned a NULL fence, setting to Fence::NO_FENCE");
833 fence = Fence::NO_FENCE;
834 }
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800835 reply->writeInt32(buf);
Brian Andersonbaaad322016-07-22 15:55:13 -0700836 reply->write(*fence);
Ian Elliotta2eb34c2017-07-18 11:05:49 -0600837 reply->writeUint64(bufferAge);
Brian Anderson7c3ba8a2016-07-25 12:48:08 -0700838 if (getTimestamps) {
839 reply->write(frameTimestamps);
840 }
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800841 reply->writeInt32(result);
842 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800843 }
Dan Stoza9f3053d2014-03-06 15:14:33 -0800844 case DETACH_BUFFER: {
845 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
846 int slot = data.readInt32();
847 int result = detachBuffer(slot);
848 reply->writeInt32(result);
849 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800850 }
Dan Stozad9822a32014-03-28 15:25:31 -0700851 case DETACH_NEXT_BUFFER: {
852 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
853 sp<GraphicBuffer> buffer;
854 sp<Fence> fence;
855 int32_t result = detachNextBuffer(&buffer, &fence);
856 reply->writeInt32(result);
857 if (result == NO_ERROR) {
Yi Kong48a619f2018-06-05 16:34:59 -0700858 reply->writeInt32(buffer != nullptr);
859 if (buffer != nullptr) {
Dan Stozad9822a32014-03-28 15:25:31 -0700860 reply->write(*buffer);
861 }
Yi Kong48a619f2018-06-05 16:34:59 -0700862 reply->writeInt32(fence != nullptr);
863 if (fence != nullptr) {
Dan Stozad9822a32014-03-28 15:25:31 -0700864 reply->write(*fence);
865 }
866 }
867 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800868 }
Dan Stoza9f3053d2014-03-06 15:14:33 -0800869 case ATTACH_BUFFER: {
870 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
871 sp<GraphicBuffer> buffer = new GraphicBuffer();
Pablo Ceballos70636b32016-07-06 15:24:54 -0700872 status_t result = data.read(*buffer.get());
Naveen Leekha12ba0f52015-09-21 17:28:04 -0700873 int slot = 0;
Pablo Ceballos70636b32016-07-06 15:24:54 -0700874 if (result == NO_ERROR) {
875 result = attachBuffer(&slot, buffer);
876 }
Dan Stoza9f3053d2014-03-06 15:14:33 -0800877 reply->writeInt32(slot);
878 reply->writeInt32(result);
879 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800880 }
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800881 case QUEUE_BUFFER: {
Andy McFadden2adaf042012-12-18 09:49:45 -0800882 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
Brian Anderson7c3ba8a2016-07-25 12:48:08 -0700883
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800884 int buf = data.readInt32();
Jesse Hallc777b0b2012-06-28 12:52:05 -0700885 QueueBufferInput input(data);
Brian Andersonbaaad322016-07-22 15:55:13 -0700886 QueueBufferOutput output;
887 status_t result = queueBuffer(buf, input, &output);
Brian Andersonbaaad322016-07-22 15:55:13 -0700888 reply->write(output);
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800889 reply->writeInt32(result);
Brian Anderson7c3ba8a2016-07-25 12:48:08 -0700890
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800891 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800892 }
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800893 case CANCEL_BUFFER: {
Andy McFadden2adaf042012-12-18 09:49:45 -0800894 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800895 int buf = data.readInt32();
Jamie Gennis1df8c342012-12-20 14:05:45 -0800896 sp<Fence> fence = new Fence();
Pablo Ceballos70636b32016-07-06 15:24:54 -0700897 status_t result = data.read(*fence.get());
898 if (result == NO_ERROR) {
899 result = cancelBuffer(buf, fence);
900 }
Pablo Ceballos583b1b32015-09-03 18:23:52 -0700901 reply->writeInt32(result);
Jamie Gennis8ba32fa2010-12-20 11:27:26 -0800902 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800903 }
Mathias Agopianeafabcd2011-04-20 14:20:59 -0700904 case QUERY: {
Andy McFadden2adaf042012-12-18 09:49:45 -0800905 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
Naveen Leekha12ba0f52015-09-21 17:28:04 -0700906 int value = 0;
Mathias Agopianeafabcd2011-04-20 14:20:59 -0700907 int what = data.readInt32();
908 int res = query(what, &value);
909 reply->writeInt32(value);
910 reply->writeInt32(res);
911 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800912 }
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700913 case CONNECT: {
Andy McFadden2adaf042012-12-18 09:49:45 -0800914 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
Dan Stozaf0eaf252014-03-21 13:05:51 -0700915 sp<IProducerListener> listener;
916 if (data.readInt32() == 1) {
917 listener = IProducerListener::asInterface(data.readStrongBinder());
918 }
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700919 int api = data.readInt32();
Mathias Agopian595264f2013-07-16 22:56:09 -0700920 bool producerControlledByApp = data.readInt32();
Brian Andersonbaaad322016-07-22 15:55:13 -0700921 QueueBufferOutput output;
922 status_t res = connect(listener, api, producerControlledByApp, &output);
923 reply->write(output);
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700924 reply->writeInt32(res);
925 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800926 }
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700927 case DISCONNECT: {
Andy McFadden2adaf042012-12-18 09:49:45 -0800928 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700929 int api = data.readInt32();
Robert Carr97b9c862016-09-08 13:54:35 -0700930 DisconnectMode mode = static_cast<DisconnectMode>(data.readInt32());
931 status_t res = disconnect(api, mode);
Jamie Gennisfe0a87b2011-07-13 19:12:20 -0700932 reply->writeInt32(res);
933 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800934 }
Jesse Hall399184a2014-03-03 15:42:54 -0800935 case SET_SIDEBAND_STREAM: {
936 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
937 sp<NativeHandle> stream;
938 if (data.readInt32()) {
Wonsik Kim0ec54e12014-03-21 10:46:24 +0900939 stream = NativeHandle::create(data.readNativeHandle(), true);
Jesse Hall399184a2014-03-03 15:42:54 -0800940 }
941 status_t result = setSidebandStream(stream);
942 reply->writeInt32(result);
943 return NO_ERROR;
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800944 }
Dan Stoza9de72932015-04-16 17:28:43 -0700945 case ALLOCATE_BUFFERS: {
Dan Stoza29a3e902014-06-20 13:13:57 -0700946 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
Dan Stoza3be1c6b2014-11-18 10:24:03 -0800947 uint32_t width = data.readUint32();
948 uint32_t height = data.readUint32();
949 PixelFormat format = static_cast<PixelFormat>(data.readInt32());
Mathias Agopiancb496ac2017-05-22 14:21:00 -0700950 uint64_t usage = data.readUint64();
Pablo Ceballos567dbbb2015-08-26 18:59:08 -0700951 allocateBuffers(width, height, format, usage);
Dan Stoza29a3e902014-06-20 13:13:57 -0700952 return NO_ERROR;
Dan Stoza9de72932015-04-16 17:28:43 -0700953 }
954 case ALLOW_ALLOCATION: {
955 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
956 bool allow = static_cast<bool>(data.readInt32());
957 status_t result = allowAllocation(allow);
958 reply->writeInt32(result);
959 return NO_ERROR;
960 }
Dan Stoza812ed062015-06-02 15:45:22 -0700961 case SET_GENERATION_NUMBER: {
962 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
963 uint32_t generationNumber = data.readUint32();
964 status_t result = setGenerationNumber(generationNumber);
965 reply->writeInt32(result);
966 return NO_ERROR;
967 }
Dan Stozac6f30bd2015-06-08 09:32:50 -0700968 case GET_CONSUMER_NAME: {
969 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
970 reply->writeString8(getConsumerName());
971 return NO_ERROR;
972 }
Pablo Ceballos3559fbf2016-03-17 15:50:23 -0700973 case SET_SHARED_BUFFER_MODE: {
Pablo Ceballosccdfd602015-10-07 15:05:45 -0700974 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
Pablo Ceballos3559fbf2016-03-17 15:50:23 -0700975 bool sharedBufferMode = data.readInt32();
976 status_t result = setSharedBufferMode(sharedBufferMode);
Pablo Ceballosccdfd602015-10-07 15:05:45 -0700977 reply->writeInt32(result);
978 return NO_ERROR;
979 }
Pablo Ceballosff95aab2016-01-13 17:09:58 -0800980 case SET_AUTO_REFRESH: {
981 CHECK_INTERFACE(IGraphicBuffer, data, reply);
982 bool autoRefresh = data.readInt32();
983 status_t result = setAutoRefresh(autoRefresh);
984 reply->writeInt32(result);
985 return NO_ERROR;
986 }
Dan Stoza127fc632015-06-30 13:43:32 -0700987 case SET_DEQUEUE_TIMEOUT: {
988 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
989 nsecs_t timeout = data.readInt64();
990 status_t result = setDequeueTimeout(timeout);
991 reply->writeInt32(result);
992 return NO_ERROR;
993 }
Dan Stoza50101d02016-04-07 16:53:23 -0700994 case GET_LAST_QUEUED_BUFFER: {
995 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
996 sp<GraphicBuffer> buffer(nullptr);
997 sp<Fence> fence(Fence::NO_FENCE);
John Reck1a61da52016-04-28 13:18:15 -0700998 float transform[16] = {};
999 status_t result = getLastQueuedBuffer(&buffer, &fence, transform);
Dan Stoza50101d02016-04-07 16:53:23 -07001000 reply->writeInt32(result);
1001 if (result != NO_ERROR) {
1002 return result;
1003 }
John Reckce8e5df2016-04-28 10:12:47 -07001004 if (!buffer.get()) {
1005 reply->writeBool(false);
1006 } else {
1007 reply->writeBool(true);
1008 result = reply->write(*buffer);
John Reck1a61da52016-04-28 13:18:15 -07001009 if (result == NO_ERROR) {
1010 reply->write(transform, sizeof(float) * 16);
1011 }
John Reckce8e5df2016-04-28 10:12:47 -07001012 }
Dan Stoza50101d02016-04-07 16:53:23 -07001013 if (result != NO_ERROR) {
1014 ALOGE("getLastQueuedBuffer failed to write buffer: %d", result);
1015 return result;
1016 }
Tobin Ehlis209e5fb2019-03-26 14:06:29 -06001017 if (fence == nullptr) {
1018 ALOGE("getLastQueuedBuffer returned a NULL fence, setting to Fence::NO_FENCE");
1019 fence = Fence::NO_FENCE;
1020 }
Dan Stoza50101d02016-04-07 16:53:23 -07001021 result = reply->write(*fence);
1022 if (result != NO_ERROR) {
1023 ALOGE("getLastQueuedBuffer failed to write fence: %d", result);
1024 return result;
1025 }
1026 return NO_ERROR;
1027 }
Pablo Ceballosce796e72016-02-04 19:10:51 -08001028 case GET_FRAME_TIMESTAMPS: {
1029 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
Brian Anderson3890c392016-07-25 12:48:08 -07001030 FrameEventHistoryDelta frameTimestamps;
1031 getFrameTimestamps(&frameTimestamps);
1032 status_t result = reply->write(frameTimestamps);
Pablo Ceballosce796e72016-02-04 19:10:51 -08001033 if (result != NO_ERROR) {
Brian Anderson3890c392016-07-25 12:48:08 -07001034 ALOGE("BnGBP::GET_FRAME_TIMESTAMPS failed to write buffer: %d",
1035 result);
Pablo Ceballosce796e72016-02-04 19:10:51 -08001036 return result;
1037 }
Pablo Ceballosce796e72016-02-04 19:10:51 -08001038 return NO_ERROR;
1039 }
Pablo Ceballos8e3e92b2016-06-27 17:56:53 -07001040 case GET_UNIQUE_ID: {
1041 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
1042 uint64_t outId = 0;
1043 status_t actualResult = getUniqueId(&outId);
1044 status_t result = reply->writeInt32(actualResult);
1045 if (result != NO_ERROR) {
1046 return result;
1047 }
1048 result = reply->writeUint64(outId);
1049 if (result != NO_ERROR) {
1050 return result;
1051 }
1052 return NO_ERROR;
1053 }
Chia-I Wue2786ea2017-08-07 10:36:08 -07001054 case GET_CONSUMER_USAGE: {
1055 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
1056 uint64_t outUsage = 0;
1057 status_t actualResult = getConsumerUsage(&outUsage);
1058 status_t result = reply->writeInt32(actualResult);
1059 if (result != NO_ERROR) {
1060 return result;
1061 }
1062 result = reply->writeUint64(outUsage);
1063 if (result != NO_ERROR) {
1064 return result;
1065 }
1066 return NO_ERROR;
1067 }
Sungtak Lee3249fb62019-03-02 16:40:47 -08001068 case SET_LEGACY_BUFFER_DROP: {
1069 CHECK_INTERFACE(IGraphicBufferProducer, data, reply);
1070 bool drop = data.readInt32();
1071 int result = setLegacyBufferDrop(drop);
1072 reply->writeInt32(result);
1073 return NO_ERROR;
1074 }
Yiwei Zhang538cedc2019-06-24 19:35:03 -07001075 case SET_AUTO_PREROTATION: {
1076 CHECK_INTERFACE(IGraphicBuffer, data, reply);
1077 bool autoPrerotation = data.readBool();
1078 status_t result = setAutoPrerotation(autoPrerotation);
1079 reply->writeInt32(result);
1080 return NO_ERROR;
1081 }
Jamie Gennis8ba32fa2010-12-20 11:27:26 -08001082 }
1083 return BBinder::onTransact(code, data, reply, flags);
1084}
1085
1086// ----------------------------------------------------------------------------
1087
Andy McFadden2adaf042012-12-18 09:49:45 -08001088IGraphicBufferProducer::QueueBufferInput::QueueBufferInput(const Parcel& parcel) {
Jesse Hallc777b0b2012-06-28 12:52:05 -07001089 parcel.read(*this);
1090}
1091
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001092constexpr size_t IGraphicBufferProducer::QueueBufferInput::minFlattenedSize() {
1093 return sizeof(timestamp) +
1094 sizeof(isAutoTimestamp) +
1095 sizeof(dataSpace) +
1096 sizeof(crop) +
1097 sizeof(scalingMode) +
1098 sizeof(transform) +
1099 sizeof(stickyTransform) +
1100 sizeof(getFrameTimestamps);
1101}
1102
Mathias Agopiane1424282013-07-29 21:24:40 -07001103size_t IGraphicBufferProducer::QueueBufferInput::getFlattenedSize() const {
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001104 return minFlattenedSize() +
1105 fence->getFlattenedSize() +
Courtney Goeltzenleuchter9bad0d72017-12-19 12:34:34 -07001106 surfaceDamage.getFlattenedSize() +
1107 hdrMetadata.getFlattenedSize();
Jesse Hallc777b0b2012-06-28 12:52:05 -07001108}
1109
Mathias Agopiane1424282013-07-29 21:24:40 -07001110size_t IGraphicBufferProducer::QueueBufferInput::getFdCount() const {
Jamie Gennis1df8c342012-12-20 14:05:45 -08001111 return fence->getFdCount();
Jesse Hallc777b0b2012-06-28 12:52:05 -07001112}
1113
Mathias Agopiane1424282013-07-29 21:24:40 -07001114status_t IGraphicBufferProducer::QueueBufferInput::flatten(
1115 void*& buffer, size_t& size, int*& fds, size_t& count) const
Jesse Hallc777b0b2012-06-28 12:52:05 -07001116{
Mathias Agopiane1424282013-07-29 21:24:40 -07001117 if (size < getFlattenedSize()) {
1118 return NO_MEMORY;
1119 }
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001120
Mathias Agopiane1424282013-07-29 21:24:40 -07001121 FlattenableUtils::write(buffer, size, timestamp);
Andy McFadden3c256212013-08-16 14:55:39 -07001122 FlattenableUtils::write(buffer, size, isAutoTimestamp);
Eino-Ville Talvala82c6bcc2015-02-19 16:10:43 -08001123 FlattenableUtils::write(buffer, size, dataSpace);
Mathias Agopiane1424282013-07-29 21:24:40 -07001124 FlattenableUtils::write(buffer, size, crop);
1125 FlattenableUtils::write(buffer, size, scalingMode);
1126 FlattenableUtils::write(buffer, size, transform);
Ruben Brunk1681d952014-06-27 15:51:55 -07001127 FlattenableUtils::write(buffer, size, stickyTransform);
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001128 FlattenableUtils::write(buffer, size, getFrameTimestamps);
1129
Dan Stoza5065a552015-03-17 16:23:42 -07001130 status_t result = fence->flatten(buffer, size, fds, count);
1131 if (result != NO_ERROR) {
1132 return result;
1133 }
Courtney Goeltzenleuchter9bad0d72017-12-19 12:34:34 -07001134 result = surfaceDamage.flatten(buffer, size);
1135 if (result != NO_ERROR) {
1136 return result;
1137 }
1138 FlattenableUtils::advance(buffer, size, surfaceDamage.getFlattenedSize());
1139 return hdrMetadata.flatten(buffer, size);
Jesse Hallc777b0b2012-06-28 12:52:05 -07001140}
1141
Mathias Agopiane1424282013-07-29 21:24:40 -07001142status_t IGraphicBufferProducer::QueueBufferInput::unflatten(
1143 void const*& buffer, size_t& size, int const*& fds, size_t& count)
Jesse Hallc777b0b2012-06-28 12:52:05 -07001144{
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001145 if (size < minFlattenedSize()) {
Mathias Agopiane1424282013-07-29 21:24:40 -07001146 return NO_MEMORY;
1147 }
1148
1149 FlattenableUtils::read(buffer, size, timestamp);
Andy McFadden3c256212013-08-16 14:55:39 -07001150 FlattenableUtils::read(buffer, size, isAutoTimestamp);
Eino-Ville Talvala82c6bcc2015-02-19 16:10:43 -08001151 FlattenableUtils::read(buffer, size, dataSpace);
Mathias Agopiane1424282013-07-29 21:24:40 -07001152 FlattenableUtils::read(buffer, size, crop);
1153 FlattenableUtils::read(buffer, size, scalingMode);
1154 FlattenableUtils::read(buffer, size, transform);
Ruben Brunk1681d952014-06-27 15:51:55 -07001155 FlattenableUtils::read(buffer, size, stickyTransform);
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001156 FlattenableUtils::read(buffer, size, getFrameTimestamps);
Mathias Agopiane1424282013-07-29 21:24:40 -07001157
Jamie Gennis1df8c342012-12-20 14:05:45 -08001158 fence = new Fence();
Dan Stoza5065a552015-03-17 16:23:42 -07001159 status_t result = fence->unflatten(buffer, size, fds, count);
1160 if (result != NO_ERROR) {
1161 return result;
1162 }
Courtney Goeltzenleuchter9bad0d72017-12-19 12:34:34 -07001163 result = surfaceDamage.unflatten(buffer, size);
1164 if (result != NO_ERROR) {
1165 return result;
1166 }
1167 FlattenableUtils::advance(buffer, size, surfaceDamage.getFlattenedSize());
1168 return hdrMetadata.unflatten(buffer, size);
Jesse Hallc777b0b2012-06-28 12:52:05 -07001169}
1170
Brian Andersonbaaad322016-07-22 15:55:13 -07001171// ----------------------------------------------------------------------------
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001172constexpr size_t IGraphicBufferProducer::QueueBufferOutput::minFlattenedSize() {
1173 return sizeof(width) +
1174 sizeof(height) +
1175 sizeof(transformHint) +
1176 sizeof(numPendingBuffers) +
Shuzhen Wang22f842b2017-01-18 23:02:36 -08001177 sizeof(nextFrameNumber) +
1178 sizeof(bufferReplaced);
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001179}
Brian Andersonbaaad322016-07-22 15:55:13 -07001180
1181size_t IGraphicBufferProducer::QueueBufferOutput::getFlattenedSize() const {
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001182 return minFlattenedSize() + frameTimestamps.getFlattenedSize();
Brian Andersonbaaad322016-07-22 15:55:13 -07001183}
1184
1185size_t IGraphicBufferProducer::QueueBufferOutput::getFdCount() const {
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001186 return frameTimestamps.getFdCount();
Brian Andersonbaaad322016-07-22 15:55:13 -07001187}
1188
1189status_t IGraphicBufferProducer::QueueBufferOutput::flatten(
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001190 void*& buffer, size_t& size, int*& fds, size_t& count) const
Brian Andersonbaaad322016-07-22 15:55:13 -07001191{
1192 if (size < getFlattenedSize()) {
1193 return NO_MEMORY;
1194 }
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001195
Brian Andersonbaaad322016-07-22 15:55:13 -07001196 FlattenableUtils::write(buffer, size, width);
1197 FlattenableUtils::write(buffer, size, height);
1198 FlattenableUtils::write(buffer, size, transformHint);
1199 FlattenableUtils::write(buffer, size, numPendingBuffers);
1200 FlattenableUtils::write(buffer, size, nextFrameNumber);
Shuzhen Wang22f842b2017-01-18 23:02:36 -08001201 FlattenableUtils::write(buffer, size, bufferReplaced);
Brian Andersonbaaad322016-07-22 15:55:13 -07001202
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001203 return frameTimestamps.flatten(buffer, size, fds, count);
Brian Andersonbaaad322016-07-22 15:55:13 -07001204}
1205
1206status_t IGraphicBufferProducer::QueueBufferOutput::unflatten(
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001207 void const*& buffer, size_t& size, int const*& fds, size_t& count)
Brian Andersonbaaad322016-07-22 15:55:13 -07001208{
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001209 if (size < minFlattenedSize()) {
Brian Andersonbaaad322016-07-22 15:55:13 -07001210 return NO_MEMORY;
1211 }
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001212
Brian Andersonbaaad322016-07-22 15:55:13 -07001213 FlattenableUtils::read(buffer, size, width);
1214 FlattenableUtils::read(buffer, size, height);
1215 FlattenableUtils::read(buffer, size, transformHint);
1216 FlattenableUtils::read(buffer, size, numPendingBuffers);
1217 FlattenableUtils::read(buffer, size, nextFrameNumber);
Shuzhen Wang22f842b2017-01-18 23:02:36 -08001218 FlattenableUtils::read(buffer, size, bufferReplaced);
Brian Andersonbaaad322016-07-22 15:55:13 -07001219
Brian Anderson7c3ba8a2016-07-25 12:48:08 -07001220 return frameTimestamps.unflatten(buffer, size, fds, count);
Brian Andersonbaaad322016-07-22 15:55:13 -07001221}
1222
Jamie Gennis8ba32fa2010-12-20 11:27:26 -08001223}; // namespace android