Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 87579669 authored by Jamie Gennis's avatar Jamie Gennis Committed by Android (Google) Code Review
Browse files

Merge "Added a DummyConsumer for use with BufferQueue."

parents 99cd617b f71c4ae1
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -18,6 +18,7 @@
#define ANDROID_GUI_BUFFERQUEUE_H

#include <EGL/egl.h>
#include <EGL/eglext.h>

#include <gui/IGraphicBufferAlloc.h>
#include <gui/ISurfaceTexture.h>
+49 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2012 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef ANDROID_GUI_DUMMYCONSUMER_H
#define ANDROID_GUI_DUMMYCONSUMER_H

#include <gui/BufferQueue.h>

namespace android {
// ----------------------------------------------------------------------------


// The DummyConsumer does not keep a reference to BufferQueue
// unlike SurfaceTexture.  This prevents a circular reference from
// forming.  The BufferQueue indirectly keeps a DummyConsumer alive
// through the proxy ConsumerListener.
class DummyConsumer : public virtual RefBase,
        protected BufferQueue::ConsumerListener {
public:
    DummyConsumer(sp<BufferQueue> bufferQueue);
    virtual ~DummyConsumer();

protected:

    // Implementation of the BufferQueue::ConsumerListener interface.  These
    // calls are used to notify the SurfaceTexture of asynchronous events in the
    // BufferQueue.
    virtual void onFrameAvailable();
    virtual void onBuffersReleased();

};

// ----------------------------------------------------------------------------
}; // namespace android

#endif // ANDROID_GUI_DUMMYCONSUMER_H
+1 −0
Original line number Diff line number Diff line
@@ -21,6 +21,7 @@ LOCAL_SRC_FILES:= \
	LayerState.cpp \
	Surface.cpp \
	SurfaceComposerClient.cpp \
	DummyConsumer.cpp

LOCAL_SHARED_LIBRARIES := \
	libcutils \
+52 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2012 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#define LOG_TAG "DummyConsumer"
// #define LOG_NDEBUG 0

#include <gui/DummyConsumer.h>

#include <utils/Log.h>
#include <utils/String8.h>

namespace android {

DummyConsumer::DummyConsumer(sp<BufferQueue> bufferQueue) {
    wp<BufferQueue::ConsumerListener> listener;
    sp<BufferQueue::ConsumerListener> proxy;
    listener = static_cast<BufferQueue::ConsumerListener*>(this);
    proxy = new BufferQueue::ProxyConsumerListener(listener);

    status_t err = bufferQueue->consumerConnect(proxy);
    if (err != NO_ERROR) {
        ALOGE("DummyConsumer: error connecting to BufferQueue: %s (%d)",
                strerror(-err), err);
    }
}

DummyConsumer::~DummyConsumer() {
    ALOGV("~DummyConsumer");
}

void DummyConsumer::onFrameAvailable() {
    ALOGV("onFrameAvailable");
}

void DummyConsumer::onBuffersReleased() {
    ALOGV("onBuffersReleased");
}

}; // namespace android
+2 −0
Original line number Diff line number Diff line
@@ -575,6 +575,8 @@ void SurfaceTexture::onBuffersReleased() {
            freeBufferLocked(i);
        }
    }

    mCurrentTexture = BufferQueue::INVALID_BUFFER_SLOT;
}

void SurfaceTexture::dump(String8& result) const