blob: 09300a20c96fd0df50611cad42809ada2d1327bf [file] [log] [blame]
Daniel Lam6b091c52012-01-22 15:26:27 -08001/*
2 * Copyright (C) 2012 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_GUI_BUFFERQUEUE_H
18#define ANDROID_GUI_BUFFERQUEUE_H
19
Dan Stoza54716312015-03-13 14:40:34 -070020#include <gui/BufferItem.h>
Dan Stozae0d58622014-04-22 14:12:55 -070021#include <gui/BufferQueueDefs.h>
22#include <gui/IGraphicBufferConsumer.h>
23#include <gui/IGraphicBufferProducer.h>
Dan Stoza3e96f192014-03-03 10:16:19 -080024#include <gui/IConsumerListener.h>
25
26// These are only required to keep other parts of the framework with incomplete
27// dependencies building successfully
28#include <gui/IGraphicBufferAlloc.h>
Daniel Lam6b091c52012-01-22 15:26:27 -080029
Daniel Lam6b091c52012-01-22 15:26:27 -080030namespace android {
Daniel Lam6b091c52012-01-22 15:26:27 -080031
Dan Stozae0d58622014-04-22 14:12:55 -070032class BufferQueue {
Daniel Lam6b091c52012-01-22 15:26:27 -080033public:
Igor Murashkin7d2d1602013-11-12 18:02:20 -080034 // BufferQueue will keep track of at most this value of buffers.
35 // Attempts at runtime to increase the number of buffers past this will fail.
Dan Stozafebd4f42014-04-09 16:14:51 -070036 enum { NUM_BUFFER_SLOTS = BufferQueueDefs::NUM_BUFFER_SLOTS };
Igor Murashkin7d2d1602013-11-12 18:02:20 -080037 // Used as a placeholder slot# when the value isn't pointing to an existing buffer.
Dan Stoza54716312015-03-13 14:40:34 -070038 enum { INVALID_BUFFER_SLOT = BufferItem::INVALID_BUFFER_SLOT };
Igor Murashkin7d2d1602013-11-12 18:02:20 -080039 // Alias to <IGraphicBufferConsumer.h> -- please scope from there in future code!
40 enum {
41 NO_BUFFER_AVAILABLE = IGraphicBufferConsumer::NO_BUFFER_AVAILABLE,
42 PRESENT_LATER = IGraphicBufferConsumer::PRESENT_LATER,
43 };
Daniel Lam6b091c52012-01-22 15:26:27 -080044
Jamie Gennisc68f2ec2012-08-30 18:36:22 -070045 // When in async mode we reserve two slots in order to guarantee that the
46 // producer and consumer can run asynchronously.
47 enum { MAX_MAX_ACQUIRED_BUFFERS = NUM_BUFFER_SLOTS - 2 };
48
Mathias Agopiana4e19522013-07-31 20:09:53 -070049 // for backward source compatibility
50 typedef ::android::ConsumerListener ConsumerListener;
Daniel Lam6b091c52012-01-22 15:26:27 -080051
Jamie Gennisfa5b40e2012-03-15 14:01:24 -070052 // ProxyConsumerListener is a ConsumerListener implementation that keeps a weak
53 // reference to the actual consumer object. It forwards all calls to that
54 // consumer object so long as it exists.
55 //
56 // This class exists to avoid having a circular reference between the
57 // BufferQueue object and the consumer object. The reason this can't be a weak
58 // reference in the BufferQueue class is because we're planning to expose the
59 // consumer side of a BufferQueue as a binder interface, which doesn't support
60 // weak references.
Mathias Agopiana4e19522013-07-31 20:09:53 -070061 class ProxyConsumerListener : public BnConsumerListener {
Jamie Gennisfa5b40e2012-03-15 14:01:24 -070062 public:
Mathias Agopiana4e19522013-07-31 20:09:53 -070063 ProxyConsumerListener(const wp<ConsumerListener>& consumerListener);
Jamie Gennisfa5b40e2012-03-15 14:01:24 -070064 virtual ~ProxyConsumerListener();
Dan Stozadc13c5b2015-05-11 15:33:01 -070065 virtual void onFrameAvailable(const BufferItem& item) override;
66 virtual void onFrameReplaced(const BufferItem& item) override;
67 virtual void onBuffersReleased() override;
68 virtual void onSidebandStreamChanged() override;
Jamie Gennisfa5b40e2012-03-15 14:01:24 -070069 private:
Mathias Agopiana4e19522013-07-31 20:09:53 -070070 // mConsumerListener is a weak reference to the IConsumerListener. This is
Jamie Gennisfa5b40e2012-03-15 14:01:24 -070071 // the raison d'etre of ProxyConsumerListener.
Mathias Agopiana4e19522013-07-31 20:09:53 -070072 wp<ConsumerListener> mConsumerListener;
Jamie Gennisfa5b40e2012-03-15 14:01:24 -070073 };
74
Jamie Gennis72f096f2012-08-27 18:48:37 -070075 // BufferQueue manages a pool of gralloc memory slots to be used by
Mathias Agopian595264f2013-07-16 22:56:09 -070076 // producers and consumers. allocator is used to allocate all the
77 // needed gralloc buffers.
Dan Stozaf522af72014-03-12 10:17:20 -070078 static void createBufferQueue(sp<IGraphicBufferProducer>* outProducer,
79 sp<IGraphicBufferConsumer>* outConsumer,
80 const sp<IGraphicBufferAlloc>& allocator = NULL);
81
Daniel Lameae59d22012-01-22 15:26:27 -080082private:
Dan Stozae0d58622014-04-22 14:12:55 -070083 BufferQueue(); // Create through createBufferQueue
Daniel Lam6b091c52012-01-22 15:26:27 -080084};
85
86// ----------------------------------------------------------------------------
87}; // namespace android
88
89#endif // ANDROID_GUI_BUFFERQUEUE_H