diff mbox series

[FFmpeg-devel] lavc/videotoolbox: drop HEVC cropping from start_frame rather than end_frame

Message ID 20240723073720.28871-1-anton@khirnov.net
State New
Headers show
Series [FFmpeg-devel] lavc/videotoolbox: drop HEVC cropping from start_frame rather than end_frame | expand

Checks

Context Check Description
andriy/make_x86 success Make finished
andriy/make_fate_x86 success Make fate finished

Commit Message

Anton Khirnov July 23, 2024, 7:36 a.m. UTC
HEVCContext.output_frame will be removed in following commits.

Reported-By: Max Bykov
---
Untested, testing welcome.

Cf. '[PATCH 37/39] lavc/hevcdec: use a ContainerFifo to hold frames
scheduled for output' currently on ML.
---
 libavcodec/videotoolbox.c | 13 ++++++++-----
 1 file changed, 8 insertions(+), 5 deletions(-)

Comments

Marvin Scholz July 23, 2024, 10:42 a.m. UTC | #1
On 23 Jul 2024, at 9:36, Anton Khirnov wrote:

> HEVCContext.output_frame will be removed in following commits.
>
> Reported-By: Max Bykov
> ---
> Untested, testing welcome.

Tested with fate-hevc-conformance-CONFWIN_A_Sony_1 and works.

LGTM

>
> Cf. '[PATCH 37/39] lavc/hevcdec: use a ContainerFifo to hold frames
> scheduled for output' currently on ML.
> ---
>  libavcodec/videotoolbox.c | 13 ++++++++-----
>  1 file changed, 8 insertions(+), 5 deletions(-)
>
> diff --git a/libavcodec/videotoolbox.c b/libavcodec/videotoolbox.c
> index 3dd804bb0c..505483ef66 100644
> --- a/libavcodec/videotoolbox.c
> +++ b/libavcodec/videotoolbox.c
> @@ -1053,6 +1053,14 @@ static int videotoolbox_hevc_start_frame(AVCodecContext *avctx,
>                                           const uint8_t *buffer,
>                                           uint32_t size)
>  {
> +    HEVCContext *h = avctx->priv_data;
> +    AVFrame *frame = h->cur_frame->f;
> +
> +    frame->crop_right  = 0;
> +    frame->crop_left   = 0;
> +    frame->crop_top    = 0;
> +    frame->crop_bottom = 0;
> +
>      return 0;
>  }
>
> @@ -1079,11 +1087,6 @@ static int videotoolbox_hevc_end_frame(AVCodecContext *avctx)
>      VTContext *vtctx = avctx->internal->hwaccel_priv_data;
>      int ret;
>
> -    h->output_frame->crop_right = 0;
> -    h->output_frame->crop_left = 0;
> -    h->output_frame->crop_top = 0;
> -    h->output_frame->crop_bottom = 0;
> -
>      ret = ff_videotoolbox_common_end_frame(avctx, frame);
>      vtctx->bitstream_size = 0;
>      return ret;
> -- 
> 2.43.0
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel@ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
diff mbox series

Patch

diff --git a/libavcodec/videotoolbox.c b/libavcodec/videotoolbox.c
index 3dd804bb0c..505483ef66 100644
--- a/libavcodec/videotoolbox.c
+++ b/libavcodec/videotoolbox.c
@@ -1053,6 +1053,14 @@  static int videotoolbox_hevc_start_frame(AVCodecContext *avctx,
                                          const uint8_t *buffer,
                                          uint32_t size)
 {
+    HEVCContext *h = avctx->priv_data;
+    AVFrame *frame = h->cur_frame->f;
+
+    frame->crop_right  = 0;
+    frame->crop_left   = 0;
+    frame->crop_top    = 0;
+    frame->crop_bottom = 0;
+
     return 0;
 }
 
@@ -1079,11 +1087,6 @@  static int videotoolbox_hevc_end_frame(AVCodecContext *avctx)
     VTContext *vtctx = avctx->internal->hwaccel_priv_data;
     int ret;
 
-    h->output_frame->crop_right = 0;
-    h->output_frame->crop_left = 0;
-    h->output_frame->crop_top = 0;
-    h->output_frame->crop_bottom = 0;
-
     ret = ff_videotoolbox_common_end_frame(avctx, frame);
     vtctx->bitstream_size = 0;
     return ret;