FFmpeg 5.1.6
|
This struct is used for communicating QSV parameters between libavcodec and the caller. More...
#include <libavcodec/qsv.h>
Data Fields | |
mfxSession | session |
If non-NULL, the session to use for encoding or decoding. More... | |
int | iopattern |
The IO pattern to use. More... | |
mfxExtBuffer ** | ext_buffers |
Extra buffers to pass to encoder or decoder initialization. More... | |
int | nb_ext_buffers |
int | opaque_alloc |
Encoding only. More... | |
int | nb_opaque_surfaces |
Encoding only, and only if opaque_alloc is set to non-zero. More... | |
AVBufferRef * | opaque_surfaces |
Encoding only, and only if opaque_alloc is set to non-zero. More... | |
int | opaque_alloc_type |
Encoding only, and only if opaque_alloc is set to non-zero. More... | |
This struct is used for communicating QSV parameters between libavcodec and the caller.
It is managed by the caller and must be assigned to AVCodecContext.hwaccel_context.
mfxSession AVQSVContext::session |
mfxExtBuffer** AVQSVContext::ext_buffers |
int AVQSVContext::opaque_alloc |
Encoding only.
If this field is set to non-zero by the caller, libavcodec will create an mfxExtOpaqueSurfaceAlloc extended buffer and pass it to the encoder initialization. This only makes sense if iopattern is also set to MFX_IOPATTERN_IN_OPAQUE_MEMORY.
The number of allocated opaque surfaces will be the sum of the number required by the encoder and the user-provided value nb_opaque_surfaces. The array of the opaque surfaces will be exported to the caller through the opaque_surfaces field.
int AVQSVContext::nb_opaque_surfaces |
Encoding only, and only if opaque_alloc is set to non-zero.
Before calling avcodec_open2(), the caller should set this field to the number of extra opaque surfaces to allocate beyond what is required by the encoder.
On return from avcodec_open2(), this field will be set by libavcodec to the total number of allocated opaque surfaces.
AVBufferRef* AVQSVContext::opaque_surfaces |
Encoding only, and only if opaque_alloc is set to non-zero.
On return from avcodec_open2(), this field will be used by libavcodec to export the array of the allocated opaque surfaces to the caller, so they can be passed to other parts of the pipeline.
The buffer reference exported here is owned and managed by libavcodec, the callers should make their own reference with av_buffer_ref() and free it with av_buffer_unref() when it is no longer needed.
The buffer data is an nb_opaque_surfaces-sized array of mfxFrameSurface1.
int AVQSVContext::opaque_alloc_type |
Encoding only, and only if opaque_alloc is set to non-zero.
On return from avcodec_open2(), this field will be set to the surface type used in the opaque allocation request.