diff options
author | Lajos Molnar <lajos@google.com> | 2015-01-29 07:58:56 +0000 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2015-01-29 07:58:56 +0000 |
commit | 2a8dc00eedeb2b8a9fa3560d8afa4cfd7c17d395 (patch) | |
tree | 7da41e730feea3fd3b2803c01ab321f2170ba189 /media | |
parent | a6a01787fb657189202dec096c30b3d2f63197dc (diff) | |
parent | 8514766a0a388c3598eaa64709edc634f8edccb1 (diff) | |
download | frameworks_base-2a8dc00eedeb2b8a9fa3560d8afa4cfd7c17d395.zip frameworks_base-2a8dc00eedeb2b8a9fa3560d8afa4cfd7c17d395.tar.gz frameworks_base-2a8dc00eedeb2b8a9fa3560d8afa4cfd7c17d395.tar.bz2 |
Merge "ImageReader: add support for compatible flexYUV buffers" into lmp-mr1-dev
automerge: 8514766
* commit '8514766a0a388c3598eaa64709edc634f8edccb1':
ImageReader: add support for compatible flexYUV buffers
Diffstat (limited to 'media')
-rw-r--r-- | media/java/android/media/Image.java | 5 | ||||
-rw-r--r-- | media/jni/android_media_ImageReader.cpp | 25 |
2 files changed, 20 insertions, 10 deletions
diff --git a/media/java/android/media/Image.java b/media/java/android/media/Image.java index 0d6b91a..53ab264 100644 --- a/media/java/android/media/Image.java +++ b/media/java/android/media/Image.java @@ -214,6 +214,11 @@ public abstract class Image implements AutoCloseable { * the underlying data could be mapped as a pointer in JNI without doing * any copies with {@code GetDirectBufferAddress}.</p> * + * <p>For raw formats, each plane is only guaranteed to contain data + * up to the last pixel in the last row. In other words, the stride + * after the last row may not be mapped into the buffer. This is a + * necessary requirement for any interleaved format.</p> + * * @return the byte buffer containing the image data for this plane. */ public abstract ByteBuffer getBuffer(); diff --git a/media/jni/android_media_ImageReader.cpp b/media/jni/android_media_ImageReader.cpp index 3f4736d..890b039 100644 --- a/media/jni/android_media_ImageReader.cpp +++ b/media/jni/android_media_ImageReader.cpp @@ -351,7 +351,7 @@ static void Image_getLockedBufferInfo(JNIEnv* env, CpuConsumer::LockedBuffer* bu int bytesPerPixel = 0; dataSize = ySize = cSize = cStride = 0; - int32_t fmt = buffer->format; + int32_t fmt = buffer->flexFormat; bool usingRGBAOverride = usingRGBAToJpegOverride(fmt, readerFormat); fmt = applyFormatOverrides(fmt, readerFormat); @@ -363,18 +363,21 @@ static void Image_getLockedBufferInfo(JNIEnv* env, CpuConsumer::LockedBuffer* bu (idx == 1) ? buffer->dataCb : buffer->dataCr; + // only map until last pixel if (idx == 0) { - dataSize = buffer->stride * buffer->height; + dataSize = buffer->stride * (buffer->height - 1) + buffer->width; } else { - dataSize = buffer->chromaStride * buffer->height / 2; + dataSize = buffer->chromaStride * (buffer->height / 2 - 1) + + buffer->chromaStep * (buffer->width / 2 - 1) + 1; } break; // NV21 case HAL_PIXEL_FORMAT_YCrCb_420_SP: cr = buffer->data + (buffer->stride * buffer->height); cb = cr + 1; - ySize = buffer->width * buffer->height; - cSize = buffer->width * buffer->height / 2; + // only map until last pixel + ySize = buffer->width * (buffer->height - 1) + buffer->width; + cSize = buffer->width * (buffer->height / 2 - 1) + buffer->width - 1; pData = (idx == 0) ? @@ -488,7 +491,7 @@ static jint Image_imageGetPixelStride(JNIEnv* env, CpuConsumer::LockedBuffer* bu int pixelStride = 0; ALOG_ASSERT(buffer != NULL, "buffer is NULL"); - int32_t fmt = buffer->format; + int32_t fmt = buffer->flexFormat; fmt = applyFormatOverrides(fmt, readerFormat); @@ -549,7 +552,7 @@ static jint Image_imageGetRowStride(JNIEnv* env, CpuConsumer::LockedBuffer* buff int rowStride = 0; ALOG_ASSERT(buffer != NULL, "buffer is NULL"); - int32_t fmt = buffer->format; + int32_t fmt = buffer->flexFormat; fmt = applyFormatOverrides(fmt, readerFormat); @@ -797,7 +800,7 @@ static jint ImageReader_imageSetup(JNIEnv* env, jobject thiz, return ACQUIRE_NO_BUFFERS; } - if (buffer->format == HAL_PIXEL_FORMAT_YCrCb_420_SP) { + if (buffer->flexFormat == HAL_PIXEL_FORMAT_YCrCb_420_SP) { jniThrowException(env, "java/lang/UnsupportedOperationException", "NV21 format is not supported by ImageReader"); return -1; @@ -826,8 +829,10 @@ static jint ImageReader_imageSetup(JNIEnv* env, jobject thiz, } int bufFmt = buffer->format; + if (imgReaderFmt == HAL_PIXEL_FORMAT_YCbCr_420_888) { + bufFmt = buffer->flexFormat; + } if (imgReaderFmt != bufFmt) { - if (imgReaderFmt == HAL_PIXEL_FORMAT_YCbCr_420_888 && (bufFmt == HAL_PIXEL_FORMAT_YCrCb_420_SP || bufFmt == HAL_PIXEL_FORMAT_YV12)) { // Special casing for when producer switches to a format compatible with flexible YUV @@ -849,7 +854,7 @@ static jint ImageReader_imageSetup(JNIEnv* env, jobject thiz, String8 msg; msg.appendFormat("The producer output buffer format 0x%x doesn't " "match the ImageReader's configured buffer format 0x%x.", - buffer->format, ctx->getBufferFormat()); + bufFmt, ctx->getBufferFormat()); jniThrowException(env, "java/lang/UnsupportedOperationException", msg.string()); return -1; |