1 /*
2 * Copyright 2014 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 // TODO(b/129481165): remove the #pragma below and fix conversion issues
18 #pragma clang diagnostic push
19 #pragma clang diagnostic ignored "-Wconversion"
20
21 #include "MonitoredProducer.h"
22 #include "Layer.h"
23 #include "SurfaceFlinger.h"
24
25 #include "Scheduler/MessageQueue.h"
26
27 namespace android {
28
MonitoredProducer(const sp<IGraphicBufferProducer> & producer,const sp<SurfaceFlinger> & flinger,const wp<Layer> & layer)29 MonitoredProducer::MonitoredProducer(const sp<IGraphicBufferProducer>& producer,
30 const sp<SurfaceFlinger>& flinger,
31 const wp<Layer>& layer) :
32 mProducer(producer),
33 mFlinger(flinger),
34 mLayer(layer) {}
35
~MonitoredProducer()36 MonitoredProducer::~MonitoredProducer() {
37 // Remove ourselves from SurfaceFlinger's list. We do this asynchronously
38 // because we don't know where this destructor is called from. It could be
39 // called with the mStateLock held, leading to a dead-lock (it actually
40 // happens).
41 mFlinger->removeGraphicBufferProducerAsync(onAsBinder());
42 }
43
requestBuffer(int slot,sp<GraphicBuffer> * buf)44 status_t MonitoredProducer::requestBuffer(int slot, sp<GraphicBuffer>* buf) {
45 return mProducer->requestBuffer(slot, buf);
46 }
47
setMaxDequeuedBufferCount(int maxDequeuedBuffers)48 status_t MonitoredProducer::setMaxDequeuedBufferCount(
49 int maxDequeuedBuffers) {
50 return mProducer->setMaxDequeuedBufferCount(maxDequeuedBuffers);
51 }
52
setAsyncMode(bool async)53 status_t MonitoredProducer::setAsyncMode(bool async) {
54 return mProducer->setAsyncMode(async);
55 }
56
dequeueBuffer(int * slot,sp<Fence> * fence,uint32_t w,uint32_t h,PixelFormat format,uint64_t usage,uint64_t * outBufferAge,FrameEventHistoryDelta * outTimestamps)57 status_t MonitoredProducer::dequeueBuffer(int* slot, sp<Fence>* fence, uint32_t w, uint32_t h,
58 PixelFormat format, uint64_t usage,
59 uint64_t* outBufferAge,
60 FrameEventHistoryDelta* outTimestamps) {
61 return mProducer->dequeueBuffer(slot, fence, w, h, format, usage, outBufferAge, outTimestamps);
62 }
63
detachBuffer(int slot)64 status_t MonitoredProducer::detachBuffer(int slot) {
65 return mProducer->detachBuffer(slot);
66 }
67
detachNextBuffer(sp<GraphicBuffer> * outBuffer,sp<Fence> * outFence)68 status_t MonitoredProducer::detachNextBuffer(sp<GraphicBuffer>* outBuffer,
69 sp<Fence>* outFence) {
70 return mProducer->detachNextBuffer(outBuffer, outFence);
71 }
72
attachBuffer(int * outSlot,const sp<GraphicBuffer> & buffer)73 status_t MonitoredProducer::attachBuffer(int* outSlot,
74 const sp<GraphicBuffer>& buffer) {
75 return mProducer->attachBuffer(outSlot, buffer);
76 }
77
queueBuffer(int slot,const QueueBufferInput & input,QueueBufferOutput * output)78 status_t MonitoredProducer::queueBuffer(int slot, const QueueBufferInput& input,
79 QueueBufferOutput* output) {
80 return mProducer->queueBuffer(slot, input, output);
81 }
82
cancelBuffer(int slot,const sp<Fence> & fence)83 status_t MonitoredProducer::cancelBuffer(int slot, const sp<Fence>& fence) {
84 return mProducer->cancelBuffer(slot, fence);
85 }
86
query(int what,int * value)87 int MonitoredProducer::query(int what, int* value) {
88 return mProducer->query(what, value);
89 }
90
connect(const sp<IProducerListener> & listener,int api,bool producerControlledByApp,QueueBufferOutput * output)91 status_t MonitoredProducer::connect(const sp<IProducerListener>& listener,
92 int api, bool producerControlledByApp, QueueBufferOutput* output) {
93 return mProducer->connect(listener, api, producerControlledByApp, output);
94 }
95
disconnect(int api,DisconnectMode mode)96 status_t MonitoredProducer::disconnect(int api, DisconnectMode mode) {
97 return mProducer->disconnect(api, mode);
98 }
99
setSidebandStream(const sp<NativeHandle> & stream)100 status_t MonitoredProducer::setSidebandStream(const sp<NativeHandle>& stream) {
101 return mProducer->setSidebandStream(stream);
102 }
103
allocateBuffers(uint32_t width,uint32_t height,PixelFormat format,uint64_t usage)104 void MonitoredProducer::allocateBuffers(uint32_t width, uint32_t height,
105 PixelFormat format, uint64_t usage) {
106 mProducer->allocateBuffers(width, height, format, usage);
107 }
108
allowAllocation(bool allow)109 status_t MonitoredProducer::allowAllocation(bool allow) {
110 return mProducer->allowAllocation(allow);
111 }
112
setGenerationNumber(uint32_t generationNumber)113 status_t MonitoredProducer::setGenerationNumber(uint32_t generationNumber) {
114 return mProducer->setGenerationNumber(generationNumber);
115 }
116
getConsumerName() const117 String8 MonitoredProducer::getConsumerName() const {
118 return mProducer->getConsumerName();
119 }
120
setSharedBufferMode(bool sharedBufferMode)121 status_t MonitoredProducer::setSharedBufferMode(bool sharedBufferMode) {
122 return mProducer->setSharedBufferMode(sharedBufferMode);
123 }
124
setAutoRefresh(bool autoRefresh)125 status_t MonitoredProducer::setAutoRefresh(bool autoRefresh) {
126 return mProducer->setAutoRefresh(autoRefresh);
127 }
128
setDequeueTimeout(nsecs_t timeout)129 status_t MonitoredProducer::setDequeueTimeout(nsecs_t timeout) {
130 return mProducer->setDequeueTimeout(timeout);
131 }
132
setLegacyBufferDrop(bool drop)133 status_t MonitoredProducer::setLegacyBufferDrop(bool drop) {
134 return mProducer->setLegacyBufferDrop(drop);
135 }
136
getLastQueuedBuffer(sp<GraphicBuffer> * outBuffer,sp<Fence> * outFence,float outTransformMatrix[16])137 status_t MonitoredProducer::getLastQueuedBuffer(sp<GraphicBuffer>* outBuffer,
138 sp<Fence>* outFence, float outTransformMatrix[16]) {
139 return mProducer->getLastQueuedBuffer(outBuffer, outFence,
140 outTransformMatrix);
141 }
142
getLastQueuedBuffer(sp<GraphicBuffer> * outBuffer,sp<Fence> * outFence,Rect * outRect,uint32_t * outTransform)143 status_t MonitoredProducer::getLastQueuedBuffer(sp<GraphicBuffer>* outBuffer, sp<Fence>* outFence,
144 Rect* outRect, uint32_t* outTransform) {
145 return mProducer->getLastQueuedBuffer(outBuffer, outFence, outRect, outTransform);
146 }
147
getFrameTimestamps(FrameEventHistoryDelta * outDelta)148 void MonitoredProducer::getFrameTimestamps(FrameEventHistoryDelta* outDelta) {
149 mProducer->getFrameTimestamps(outDelta);
150 }
151
getUniqueId(uint64_t * outId) const152 status_t MonitoredProducer::getUniqueId(uint64_t* outId) const {
153 return mProducer->getUniqueId(outId);
154 }
155
getConsumerUsage(uint64_t * outUsage) const156 status_t MonitoredProducer::getConsumerUsage(uint64_t* outUsage) const {
157 return mProducer->getConsumerUsage(outUsage);
158 }
159
setAutoPrerotation(bool autoPrerotation)160 status_t MonitoredProducer::setAutoPrerotation(bool autoPrerotation) {
161 return mProducer->setAutoPrerotation(autoPrerotation);
162 }
163
onAsBinder()164 IBinder* MonitoredProducer::onAsBinder() {
165 return this;
166 }
167
getLayer() const168 sp<Layer> MonitoredProducer::getLayer() const {
169 return mLayer.promote();
170 }
171
172 // ---------------------------------------------------------------------------
173 }; // namespace android
174
175 // TODO(b/129481165): remove the #pragma below and fix conversion issues
176 #pragma clang diagnostic pop // ignored "-Wconversion"
177