|
|
|
@ -676,6 +676,26 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *got_frame, |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
break; |
|
|
|
|
case AV_PIX_FMT_YUV444P: |
|
|
|
|
for (i = 0; i < 3; i++) { |
|
|
|
|
ret = decode_plane(c, i, frame.f->data[i], 1, frame.f->linesize[i], |
|
|
|
|
avctx->width, avctx->height, |
|
|
|
|
plane_start[i], c->frame_pred == PRED_LEFT); |
|
|
|
|
if (ret) |
|
|
|
|
return ret; |
|
|
|
|
if (c->frame_pred == PRED_MEDIAN) { |
|
|
|
|
if (!c->interlaced) { |
|
|
|
|
restore_median(frame.f->data[i], 1, frame.f->linesize[i], |
|
|
|
|
avctx->width, avctx->height, |
|
|
|
|
c->slices, 0); |
|
|
|
|
} else { |
|
|
|
|
restore_median_il(frame.f->data[i], 1, frame.f->linesize[i], |
|
|
|
|
avctx->width, avctx->height, |
|
|
|
|
c->slices, 0); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
break; |
|
|
|
|
case AV_PIX_FMT_YUV422P10: |
|
|
|
|
for (i = 0; i < 3; i++) { |
|
|
|
|
ret = decode_plane10(c, i, (uint16_t *)frame.f->data[i], 1, frame.f->linesize[i] / 2, |
|
|
|
@ -757,6 +777,11 @@ static av_cold int decode_init(AVCodecContext *avctx) |
|
|
|
|
avctx->pix_fmt = AV_PIX_FMT_YUV422P; |
|
|
|
|
avctx->colorspace = AVCOL_SPC_BT470BG; |
|
|
|
|
break; |
|
|
|
|
case MKTAG('U', 'L', 'Y', '4'): |
|
|
|
|
c->planes = 3; |
|
|
|
|
avctx->pix_fmt = AV_PIX_FMT_YUV444P; |
|
|
|
|
avctx->colorspace = AVCOL_SPC_BT470BG; |
|
|
|
|
break; |
|
|
|
|
case MKTAG('U', 'Q', 'Y', '2'): |
|
|
|
|
c->planes = 3; |
|
|
|
|
avctx->pix_fmt = AV_PIX_FMT_YUV422P10; |
|
|
|
@ -779,6 +804,11 @@ static av_cold int decode_init(AVCodecContext *avctx) |
|
|
|
|
avctx->pix_fmt = AV_PIX_FMT_YUV422P; |
|
|
|
|
avctx->colorspace = AVCOL_SPC_BT709; |
|
|
|
|
break; |
|
|
|
|
case MKTAG('U', 'L', 'H', '4'): |
|
|
|
|
c->planes = 3; |
|
|
|
|
avctx->pix_fmt = AV_PIX_FMT_YUV444P; |
|
|
|
|
avctx->colorspace = AVCOL_SPC_BT709; |
|
|
|
|
break; |
|
|
|
|
default: |
|
|
|
|
av_log(avctx, AV_LOG_ERROR, "Unknown Ut Video FOURCC provided (%08X)\n", |
|
|
|
|
avctx->codec_tag); |
|
|
|
|