[FFmpeg-devel] [PATCH 1/5] lavc/amfenc: HWConfig for amf encoder.
Mark Thompson
sw at jkqxz.net
Thu Oct 29 01:21:41 EET 2020
On 15/10/2020 01:16, OvchinnikovDmitrii wrote:
> ---
> libavcodec/amfenc.c | 12 ++++++++++++
> libavcodec/amfenc.h | 4 +++-
> libavcodec/amfenc_h264.c | 1 +
> libavcodec/amfenc_hevc.c | 1 +
> 4 files changed, 17 insertions(+), 1 deletion(-)
>
> diff --git a/libavcodec/amfenc.c b/libavcodec/amfenc.c
> index da0652943d..33f97dd582 100644
> --- a/libavcodec/amfenc.c
> +++ b/libavcodec/amfenc.c
> @@ -782,3 +782,15 @@ int ff_amf_receive_packet(AVCodecContext *avctx, AVPacket *avpkt)
> }
> return ret;
> }
> +
> +const AVCodecHWConfigInternal *ff_amfenc_hw_configs[] = {
> +#if CONFIG_D3D11VA
> + HW_CONFIG_ENCODER_FRAMES(D3D11, D3D11VA),
> + HW_CONFIG_ENCODER_DEVICE(NONE, D3D11VA),
> +#endif
> +#if CONFIG_DXVA2
> + HW_CONFIG_ENCODER_FRAMES(DXVA2_VLD, DXVA2),
> + HW_CONFIG_ENCODER_DEVICE(NONE, DXVA2),
> +#endif
> + NULL,
> +};
> \ No newline at end of file
Your git client has left a review comment for you.
> diff --git a/libavcodec/amfenc.h b/libavcodec/amfenc.h
> index 80658c6b2a..06994da543 100644
> --- a/libavcodec/amfenc.h
> +++ b/libavcodec/amfenc.h
> @@ -27,7 +27,7 @@
> #include "libavutil/fifo.h"
>
> #include "avcodec.h"
> -
> +#include "hwconfig.h"
>
> /**
> * AMF trace writer callback class
> @@ -117,6 +117,8 @@ typedef struct AmfContext {
> int tier;
> } AmfContext;
>
> +extern const AVCodecHWConfigInternal *ff_amfenc_hw_configs[];
> +
> /**
> * Common encoder initization function
> */
> diff --git a/libavcodec/amfenc_h264.c b/libavcodec/amfenc_h264.c
> index 7a8029f3b7..622ee85946 100644
> --- a/libavcodec/amfenc_h264.c
> +++ b/libavcodec/amfenc_h264.c
> @@ -392,4 +392,5 @@ AVCodec ff_h264_amf_encoder = {
> .caps_internal = FF_CODEC_CAP_INIT_CLEANUP,
> .pix_fmts = ff_amf_pix_fmts,
> .wrapper_name = "amf",
> + .hw_configs = ff_amfenc_hw_configs,
> };
> diff --git a/libavcodec/amfenc_hevc.c b/libavcodec/amfenc_hevc.c
> index fa12a3a3f6..bb224c5fec 100644
> --- a/libavcodec/amfenc_hevc.c
> +++ b/libavcodec/amfenc_hevc.c
> @@ -322,4 +322,5 @@ AVCodec ff_hevc_amf_encoder = {
> .caps_internal = FF_CODEC_CAP_INIT_CLEANUP,
> .pix_fmts = ff_amf_pix_fmts,
> .wrapper_name = "amf",
> + .hw_configs = ff_amfenc_hw_configs,
> };
>
This looks right, but can you clarify the intent behind the hw config cases? (Do you have an ffmpeg command line or other example which is improved by them?)
Thanks,
- Mark
More information about the ffmpeg-devel
mailing list