| Index: src/codec/SkCodecImageGenerator.cpp | 
| diff --git a/src/codec/SkCodecImageGenerator.cpp b/src/codec/SkCodecImageGenerator.cpp | 
| index 2fef381ec1ffa332f5d62c8eb30d6b7eebcbe909..e6e164ef6137ba358b2b769a928f5af98ade8bab 100644 | 
| --- a/src/codec/SkCodecImageGenerator.cpp | 
| +++ b/src/codec/SkCodecImageGenerator.cpp | 
| @@ -16,10 +16,21 @@ SkImageGenerator* SkCodecImageGenerator::NewFromEncodedCodec(SkData* data) { | 
| return new SkCodecImageGenerator(codec, data); | 
| } | 
|  | 
| +static SkImageInfo make_premul(const SkImageInfo& info) { | 
| +    if (kUnpremul_SkAlphaType == info.alphaType()) { | 
| +        return info.makeAlphaType(kPremul_SkAlphaType); | 
| +    } | 
| + | 
| +    return info; | 
| +} | 
| + | 
| SkCodecImageGenerator::SkCodecImageGenerator(SkCodec* codec, SkData* data) | 
| -    : INHERITED(codec->getInfo()) | 
| +    : INHERITED(make_premul(codec->getInfo())) | 
| , fCodec(codec) | 
| , fData(SkRef(data)) | 
| +    , fYWidth(0) | 
| +    , fUWidth(0) | 
| +    , fVWidth(0) | 
| {} | 
|  | 
| SkData* SkCodecImageGenerator::onRefEncodedData(SK_REFENCODEDDATA_CTXPARAM) { | 
| @@ -42,5 +53,51 @@ bool SkCodecImageGenerator::onGetPixels(const SkImageInfo& info, void* pixels, s | 
|  | 
| bool SkCodecImageGenerator::onGetYUV8Planes(SkISize sizes[3], void* planes[3], size_t rowBytes[3], | 
| SkYUVColorSpace* colorSpace) { | 
| -    return false; | 
| +    // TODO (msarett): Change the YUV API in ImageGenerator to match SkCodec. | 
| +    //                 This function is currently a hack to match the implementation | 
| +    //                 in SkCodec with the old API. | 
| +    SkCodec::YUVSizeInfo sizeInfo; | 
| + | 
| +    // If planes is NULL, we just need to return the size. | 
| +    if (nullptr == planes) { | 
| +        bool result = fCodec->queryYUV8(&sizeInfo, colorSpace); | 
| +        if (result) { | 
| +            // Save the true widths | 
| +            fYWidth = sizeInfo.fYSize.width(); | 
| +            fUWidth = sizeInfo.fUSize.width(); | 
| +            fVWidth = sizeInfo.fVSize.width(); | 
| + | 
| +            // Set the sizes so that the client allocates enough memory | 
| +            sizes[0].fWidth = (int) sizeInfo.fYWidthBytes; | 
| +            sizes[0].fHeight = sizeInfo.fYSize.height(); | 
| +            sizes[1].fWidth = (int) sizeInfo.fUWidthBytes; | 
| +            sizes[1].fHeight = sizeInfo.fUSize.height(); | 
| +            sizes[2].fWidth = (int) sizeInfo.fVWidthBytes; | 
| +            sizes[2].fHeight = sizeInfo.fVSize.height(); | 
| +        } | 
| +        return result; | 
| +    } | 
| + | 
| +    // Set the sizeInfo with the true widths and heights | 
| +    SkASSERT(fYWidth != 0 && fUWidth != 0 && fVWidth != 0); | 
| +    sizeInfo.fYSize.set(fYWidth, sizes[0].height()); | 
| +    sizeInfo.fUSize.set(fUWidth, sizes[1].height()); | 
| +    sizeInfo.fVSize.set(fVWidth, sizes[2].height()); | 
| + | 
| +    // Set the sizeInfo with the allocated widths | 
| +    sizeInfo.fYWidthBytes = sizes[0].width(); | 
| +    sizeInfo.fUWidthBytes = sizes[1].width(); | 
| +    sizeInfo.fVWidthBytes = sizes[2].width(); | 
| +    SkCodec::Result result = fCodec->getYUV8Planes(sizeInfo, planes); | 
| +    if ((result == SkCodec::kSuccess || result == SkCodec::kIncompleteInput) && colorSpace) { | 
| +        *colorSpace = kJPEG_SkYUVColorSpace; | 
| +    } | 
| + | 
| +    switch (result) { | 
| +        case SkCodec::kSuccess: | 
| +        case SkCodec::kIncompleteInput: | 
| +            return true; | 
| +        default: | 
| +            return false; | 
| +    } | 
| } | 
|  |