FFmpeg
|
This struct aggregates all the (hardware/vendor-specific) "high-level" state, i.e. More...
#include <hwcontext.h>
Data Fields | |
const AVClass * | av_class |
A class for logging. More... | |
AVHWDeviceInternal * | internal |
Private data used internally by libavutil. More... | |
enum AVHWDeviceType | type |
This field identifies the underlying API used for hardware access. More... | |
void * | hwctx |
The format-specific data, allocated and freed by libavutil along with this context. More... | |
void(* | free )(struct AVHWDeviceContext *ctx) |
This field may be set by the caller before calling av_hwdevice_ctx_init(). More... | |
void * | user_opaque |
Arbitrary user data, to be used e.g. More... | |
This struct aggregates all the (hardware/vendor-specific) "high-level" state, i.e.
state that is not tied to a concrete processing configuration. E.g., in an API that supports hardware-accelerated encoding and decoding, this struct will (if possible) wrap the state that is common to both encoding and decoding and from which specific instances of encoders or decoders can be derived.
This struct is reference-counted with the AVBuffer mechanism. The av_hwdevice_ctx_alloc() constructor yields a reference, whose data field points to the actual AVHWDeviceContext. Further objects derived from AVHWDeviceContext (such as AVHWFramesContext, describing a frame pool with specific properties) will hold an internal reference to it. After all the references are released, the AVHWDeviceContext itself will be freed, optionally invoking a user-specified callback for uninitializing the hardware state.
Definition at line 61 of file hwcontext.h.
const AVClass* AVHWDeviceContext::av_class |
AVHWDeviceInternal* AVHWDeviceContext::internal |
Private data used internally by libavutil.
Must not be accessed in any way by the caller.
Definition at line 71 of file hwcontext.h.
Referenced by av_hwdevice_ctx_create(), av_hwdevice_ctx_create_derived_opts(), av_hwframe_ctx_alloc(), create_exec_ctx(), free_exec_ctx(), opencl_check_extension(), opencl_device_init(), opencl_device_uninit(), opencl_frames_derive_to(), opencl_frames_init_command_queue(), opencl_map_to(), pixfmt_is_supported(), prepare_frame(), submit_exec_ctx(), transfer_image_buf(), try_export_flags(), vaapi_device_init(), vaapi_device_uninit(), vaapi_frames_get_constraints(), vaapi_get_image_format(), vaapi_transfer_get_formats(), vulkan_frame_free(), vulkan_frames_init(), vulkan_map_frame_to_mem(), vulkan_map_from(), vulkan_map_to(), vulkan_pool_alloc(), vulkan_transfer_data(), vulkan_transfer_data_from(), vulkan_transfer_data_to(), vulkan_unmap_frame(), and wait_start_exec_ctx().
enum AVHWDeviceType AVHWDeviceContext::type |
This field identifies the underlying API used for hardware access.
This field is set when this struct is allocated and never changed afterwards.
Definition at line 79 of file hwcontext.h.
Referenced by amf_init_context(), av_hwdevice_ctx_create_derived_opts(), avcodec_default_get_format(), cuda_device_derive(), ddagrab_config_props(), ff_decode_get_hw_frames_ctx(), ff_get_format(), ff_mediacodec_dec_init(), init_vulkan(), mediacodec_init(), nvenc_setup_device(), opencl_device_derive(), opencl_frames_derive_to(), qsv_device_derive(), qsv_device_derive_from_child(), qsv_frames_derive_from(), qsv_frames_derive_to(), qsv_init_child_ctx(), test_derivation(), test_device(), vaapi_device_derive(), and vulkan_device_derive().
void* AVHWDeviceContext::hwctx |
The format-specific data, allocated and freed by libavutil along with this context.
Should be cast by the user to the format-specific context defined in the corresponding header (hwcontext_*.h) and filled as described in the documentation before calling av_hwdevice_ctx_init().
After calling av_hwdevice_ctx_init() this struct should not be modified by the caller.
Definition at line 92 of file hwcontext.h.
Referenced by amf_init_context(), config_props(), create_exec_ctx(), cuda_bilateral_config_props(), cuda_buffer_free(), cuda_context_init(), cuda_device_create(), cuda_device_derive(), cuda_device_uninit(), cuda_frames_init(), cuda_pool_alloc(), cuda_transfer_data(), cudachromakey_config_props(), cudacolorspace_config_props(), cudascale_config_props(), cuvid_decode_end(), cuvid_decode_init(), cuvid_decode_packet(), cuvid_flush(), cuvid_output_frame(), d3d11va_device_init(), d3d11va_device_uninit(), ddagrab_config_props(), drm_device_create(), drm_device_free(), ff_dxva2_decode_init(), ff_dxva2_lock(), ff_dxva2_unlock(), ff_mediacodec_dec_init(), ff_qsv_init_session_device(), ff_vdpau_common_init(), free_exec_ctx(), get_mfx_version(), init_vpp_session(), init_vulkan(), mediacodec_init(), nppscale_filter_frame(), nppsharpen_filter_frame(), npptranspose_filter_frame(), nvenc_setup_device(), opencl_check_extension(), opencl_device_create_internal(), opencl_device_derive(), opencl_device_free(), opencl_device_init(), opencl_frames_get_constraints(), opencl_pool_alloc(), pixfmt_is_supported(), qsv_device_derive_from_child(), qsv_init_child_ctx(), submit_exec_ctx(), try_export_flags(), vaapi_buffer_free(), vaapi_decode_find_best_format(), vaapi_decode_make_config(), vaapi_device_derive(), vaapi_device_init(), vaapi_frames_get_constraints(), vaapi_frames_init(), vaapi_map_frame(), vaapi_pool_alloc(), vaapi_unmap_frame(), vulkan_device_derive(), vulkan_frame_free(), vulkan_frames_init(), vulkan_free_internal(), vulkan_map_frame_to_mem(), vulkan_unmap_frame(), and wait_start_exec_ctx().
void(* AVHWDeviceContext::free) (struct AVHWDeviceContext *ctx) |
This field may be set by the caller before calling av_hwdevice_ctx_init().
If non-NULL, this callback will be called when the last reference to this context is unreferenced, immediately before it is freed.
Definition at line 104 of file hwcontext.h.
Referenced by drm_device_create(), and opencl_device_create_internal().
void* AVHWDeviceContext::user_opaque |
Arbitrary user data, to be used e.g.
by the free() callback.
Definition at line 109 of file hwcontext.h.