| Index: core/fxcodec/codec/fx_codec_jpx_opj.cpp
|
| diff --git a/core/fxcodec/codec/fx_codec_jpx_opj.cpp b/core/fxcodec/codec/fx_codec_jpx_opj.cpp
|
| index 486cb929b8a83ae430dbb42a47da0d6c55217550..aaa89388b806b8d7ba46d3cf076835b4aa7abc36 100644
|
| --- a/core/fxcodec/codec/fx_codec_jpx_opj.cpp
|
| +++ b/core/fxcodec/codec/fx_codec_jpx_opj.cpp
|
| @@ -201,14 +201,30 @@ static void sycc444_to_rgb(opj_image_t* img) {
|
| FX_Free(img->comps[2].data);
|
| img->comps[2].data = d2;
|
| }
|
| +static bool sycc420_422_size_is_valid(opj_image_t* img) {
|
| + return (img && img->comps[0].w != std::numeric_limits<OPJ_UINT32>::max() &&
|
| + (img->comps[0].w + 1) / 2 == img->comps[1].w &&
|
| + img->comps[1].w == img->comps[2].w &&
|
| + img->comps[1].h == img->comps[2].h);
|
| +}
|
| +static bool sycc420_size_is_valid(opj_image_t* img) {
|
| + return (sycc420_422_size_is_valid(img) &&
|
| + img->comps[0].h != std::numeric_limits<OPJ_UINT32>::max() &&
|
| + (img->comps[0].h + 1) / 2 == img->comps[1].h);
|
| +}
|
| +static bool sycc422_size_is_valid(opj_image_t* img) {
|
| + return (sycc420_422_size_is_valid(img) && img->comps[0].h == img->comps[1].h);
|
| +}
|
| static void sycc422_to_rgb(opj_image_t* img) {
|
| + if (!sycc422_size_is_valid(img))
|
| + return;
|
| +
|
| int prec = img->comps[0].prec;
|
| int offset = 1 << (prec - 1);
|
| int upb = (1 << prec) - 1;
|
| - OPJ_UINT32 maxw =
|
| - std::min(std::min(img->comps[0].w, img->comps[1].w), img->comps[2].w);
|
| - OPJ_UINT32 maxh =
|
| - std::min(std::min(img->comps[0].h, img->comps[1].h), img->comps[2].h);
|
| +
|
| + OPJ_UINT32 maxw = img->comps[0].w;
|
| + OPJ_UINT32 maxh = img->comps[0].h;
|
| FX_SAFE_SIZE_T max_size = maxw;
|
| max_size *= maxh;
|
| if (!max_size.IsValid())
|
| @@ -262,16 +278,13 @@ static void sycc422_to_rgb(opj_image_t* img) {
|
| img->comps[1].dy = img->comps[0].dy;
|
| img->comps[2].dy = img->comps[0].dy;
|
| }
|
| -static bool sycc420_size_is_valid(OPJ_UINT32 y, OPJ_UINT32 cbcr) {
|
| - if (!y || !cbcr)
|
| - return false;
|
| -
|
| - return (cbcr == y / 2) || ((y & 1) && (cbcr == y / 2 + 1));
|
| -}
|
| static bool sycc420_must_extend_cbcr(OPJ_UINT32 y, OPJ_UINT32 cbcr) {
|
| return (y & 1) && (cbcr == y / 2);
|
| }
|
| void sycc420_to_rgb(opj_image_t* img) {
|
| + if (!sycc420_size_is_valid(img))
|
| + return;
|
| +
|
| OPJ_UINT32 prec = img->comps[0].prec;
|
| if (!prec)
|
| return;
|
| @@ -282,11 +295,6 @@ void sycc420_to_rgb(opj_image_t* img) {
|
| OPJ_UINT32 cbw = img->comps[1].w;
|
| OPJ_UINT32 cbh = img->comps[1].h;
|
| OPJ_UINT32 crw = img->comps[2].w;
|
| - OPJ_UINT32 crh = img->comps[2].h;
|
| - if (cbw != crw || cbh != crh)
|
| - return;
|
| - if (!sycc420_size_is_valid(yw, cbw) || !sycc420_size_is_valid(yh, cbh))
|
| - return;
|
| bool extw = sycc420_must_extend_cbcr(yw, cbw);
|
| bool exth = sycc420_must_extend_cbcr(yh, cbh);
|
| FX_SAFE_DWORD safeSize = yw;
|
|
|