summaryrefslogtreecommitdiffstats
path: root/media
diff options
context:
space:
mode:
authorEino-Ville Talvala <etalvala@google.com>2015-06-11 19:36:15 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2015-06-11 19:36:17 +0000
commitcd17a84a860769049806c8a7fe80d274edcd950d (patch)
treee61afbeda7322d4e11e31aa18d7e162426c1a818 /media
parentdb6ac98ec375f388d4815fe405201e9649a003f8 (diff)
parentef9db7d81b0ce1093944b9e3d5efb6ab756f5cbc (diff)
downloadframeworks_base-cd17a84a860769049806c8a7fe80d274edcd950d.zip
frameworks_base-cd17a84a860769049806c8a7fe80d274edcd950d.tar.gz
frameworks_base-cd17a84a860769049806c8a7fe80d274edcd950d.tar.bz2
Merge "Add more specific consumer names for common buffer queue endpoints." into mnc-dev
Diffstat (limited to 'media')
-rw-r--r--media/jni/android_media_ImageReader.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/media/jni/android_media_ImageReader.cpp b/media/jni/android_media_ImageReader.cpp
index 49614bd..635fa11 100644
--- a/media/jni/android_media_ImageReader.cpp
+++ b/media/jni/android_media_ImageReader.cpp
@@ -72,6 +72,12 @@ static struct {
jmethodID ctor;
} gSurfacePlaneClassInfo;
+// Get an ID that's unique within this process.
+static int32_t createProcessUniqueId() {
+ static volatile int32_t globalCounter = 0;
+ return android_atomic_inc(&globalCounter);
+}
+
// ----------------------------------------------------------------------------
class JNIImageReaderContext : public ConsumerBase::FrameAvailableListener
@@ -808,6 +814,9 @@ static void ImageReader_init(JNIEnv* env, jobject thiz, jobject weakThiz,
sp<ConsumerBase> consumer;
sp<CpuConsumer> cpuConsumer;
sp<BufferItemConsumer> opaqueConsumer;
+ String8 consumerName = String8::format("ImageReader-%dx%df%xm%d-%d-%d",
+ width, height, format, maxImages, getpid(),
+ createProcessUniqueId());
if (isFormatOpaque(nativeFormat)) {
// Use the SW_READ_NEVER usage to tell producer that this format is not for preview or video
// encoding. The only possibility will be ZSL output.
@@ -819,6 +828,7 @@ static void ImageReader_init(JNIEnv* env, jobject thiz, jobject weakThiz,
return;
}
ctx->setOpaqueConsumer(opaqueConsumer);
+ opaqueConsumer->setName(consumerName);
consumer = opaqueConsumer;
} else {
cpuConsumer = new CpuConsumer(gbConsumer, maxImages, /*controlledByApp*/true);
@@ -828,6 +838,7 @@ static void ImageReader_init(JNIEnv* env, jobject thiz, jobject weakThiz,
return;
}
ctx->setCpuConsumer(cpuConsumer);
+ cpuConsumer->setName(consumerName);
consumer = cpuConsumer;
}