blob: 1188837456a1a456b24bea2020d353a9cdbae278 [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 Stozae0d58622014-04-22 14:12:55 -070020#include <gui/BufferQueueDefs.h>
21#include <gui/IGraphicBufferConsumer.h>
22#include <gui/IGraphicBufferProducer.h>
Dan Stoza3e96f192014-03-03 10:16:19 -080023#include <gui/IConsumerListener.h>
24
25// These are only required to keep other parts of the framework with incomplete
26// dependencies building successfully
27#include <gui/IGraphicBufferAlloc.h>
Daniel Lam6b091c52012-01-22 15:26:27 -080028
Daniel Lam6b091c52012-01-22 15:26:27 -080029namespace android {
Daniel Lam6b091c52012-01-22 15:26:27 -080030
Dan Stozae0d58622014-04-22 14:12:55 -070031class BufferQueue {
Daniel Lam6b091c52012-01-22 15:26:27 -080032public:
Igor Murashkin7d2d1602013-11-12 18:02:20 -080033 // BufferQueue will keep track of at most this value of buffers.
34 // Attempts at runtime to increase the number of buffers past this will fail.
Dan Stozafebd4f42014-04-09 16:14:51 -070035 enum { NUM_BUFFER_SLOTS = BufferQueueDefs::NUM_BUFFER_SLOTS };
Igor Murashkin7d2d1602013-11-12 18:02:20 -080036 // Used as a placeholder slot# when the value isn't pointing to an existing buffer.
37 enum { INVALID_BUFFER_SLOT = IGraphicBufferConsumer::BufferItem::INVALID_BUFFER_SLOT };
38 // Alias to <IGraphicBufferConsumer.h> -- please scope from there in future code!
39 enum {
40 NO_BUFFER_AVAILABLE = IGraphicBufferConsumer::NO_BUFFER_AVAILABLE,
41 PRESENT_LATER = IGraphicBufferConsumer::PRESENT_LATER,
42 };
Daniel Lam6b091c52012-01-22 15:26:27 -080043
Jamie Gennisc68f2ec2012-08-30 18:36:22 -070044 // When in async mode we reserve two slots in order to guarantee that the
45 // producer and consumer can run asynchronously.
46 enum { MAX_MAX_ACQUIRED_BUFFERS = NUM_BUFFER_SLOTS - 2 };
47
Mathias Agopiana4e19522013-07-31 20:09:53 -070048 // for backward source compatibility
49 typedef ::android::ConsumerListener ConsumerListener;
Dan Stozae0d58622014-04-22 14:12:55 -070050 typedef IGraphicBufferConsumer::BufferItem BufferItem;
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 Stoza8dc55392014-11-04 11:37:46 -080065 virtual void onFrameAvailable(const android::BufferItem& item);
Jamie Gennisfa5b40e2012-03-15 14:01:24 -070066 virtual void onBuffersReleased();
Jesse Hall399184a2014-03-03 15:42:54 -080067 virtual void onSidebandStreamChanged();
Jamie Gennisfa5b40e2012-03-15 14:01:24 -070068 private:
Mathias Agopiana4e19522013-07-31 20:09:53 -070069 // mConsumerListener is a weak reference to the IConsumerListener. This is
Jamie Gennisfa5b40e2012-03-15 14:01:24 -070070 // the raison d'etre of ProxyConsumerListener.
Mathias Agopiana4e19522013-07-31 20:09:53 -070071 wp<ConsumerListener> mConsumerListener;
Jamie Gennisfa5b40e2012-03-15 14:01:24 -070072 };
73
Jamie Gennis72f096f2012-08-27 18:48:37 -070074 // BufferQueue manages a pool of gralloc memory slots to be used by
Mathias Agopian595264f2013-07-16 22:56:09 -070075 // producers and consumers. allocator is used to allocate all the
76 // needed gralloc buffers.
Dan Stozaf522af72014-03-12 10:17:20 -070077 static void createBufferQueue(sp<IGraphicBufferProducer>* outProducer,
78 sp<IGraphicBufferConsumer>* outConsumer,
79 const sp<IGraphicBufferAlloc>& allocator = NULL);
80
Daniel Lameae59d22012-01-22 15:26:27 -080081private:
Dan Stozae0d58622014-04-22 14:12:55 -070082 BufferQueue(); // Create through createBufferQueue
Daniel Lam6b091c52012-01-22 15:26:27 -080083};
84
85// ----------------------------------------------------------------------------
86}; // namespace android
87
88#endif // ANDROID_GUI_BUFFERQUEUE_H