FFmpeg  4.0
Files | Data Structures | Macros | Functions

AVBuffer is an API for reference-counted data buffers. More...

Files

file  buffer.h
 refcounted data buffer API
 

Data Structures

struct  AVBufferRef
 A reference to a data buffer. More...
 

Macros

#define AV_BUFFER_FLAG_READONLY   (1 << 0)
 Always treat the buffer as read-only, even when it has only one reference. More...
 

Functions

AVBufferRefav_buffer_alloc (int size)
 Allocate an AVBuffer of the given size using av_malloc(). More...
 
AVBufferRefav_buffer_allocz (int size)
 Same as av_buffer_alloc(), except the returned buffer will be initialized to zero. More...
 
AVBufferRefav_buffer_create (uint8_t *data, int size, void(*free)(void *opaque, uint8_t *data), void *opaque, int flags)
 Create an AVBuffer from an existing array. More...
 
void av_buffer_default_free (void *opaque, uint8_t *data)
 Default free callback, which calls av_free() on the buffer data. More...
 
AVBufferRefav_buffer_ref (AVBufferRef *buf)
 Create a new reference to an AVBuffer. More...
 
void av_buffer_unref (AVBufferRef **buf)
 Free a given reference and automatically free the buffer if there are no more references to it. More...
 
int av_buffer_is_writable (const AVBufferRef *buf)
 
voidav_buffer_get_opaque (const AVBufferRef *buf)
 
int av_buffer_get_ref_count (const AVBufferRef *buf)
 
int av_buffer_make_writable (AVBufferRef **buf)
 Create a writable reference from a given buffer reference, avoiding data copy if possible. More...
 
int av_buffer_realloc (AVBufferRef **buf, int size)
 Reallocate a given buffer. More...
 

Detailed Description

AVBuffer is an API for reference-counted data buffers.

There are two core objects in this API – AVBuffer and AVBufferRef. AVBuffer represents the data buffer itself; it is opaque and not meant to be accessed by the caller directly, but only through AVBufferRef. However, the caller may e.g. compare two AVBuffer pointers to check whether two different references are describing the same data buffer. AVBufferRef represents a single reference to an AVBuffer and it is the object that may be manipulated by the caller directly.

There are two functions provided for creating a new AVBuffer with a single reference – av_buffer_alloc() to just allocate a new buffer, and av_buffer_create() to wrap an existing array in an AVBuffer. From an existing reference, additional references may be created with av_buffer_ref(). Use av_buffer_unref() to free a reference (this will automatically free the data once all the references are freed).

The convention throughout this API and the rest of FFmpeg is such that the buffer is considered writable if there exists only one reference to it (and it has not been marked as read-only). The av_buffer_is_writable() function is provided to check whether this is true and av_buffer_make_writable() will automatically create a new writable buffer when necessary. Of course nothing prevents the calling code from violating this convention, however that is safe only when all the existing references are under its control.

Note
Referencing and unreferencing the buffers is thread-safe and thus may be done from multiple threads simultaneously without any need for additional locking.
Two different references to the same buffer can point to different parts of the buffer (i.e. their AVBufferRef.data will not be equal).

Macro Definition Documentation

◆ AV_BUFFER_FLAG_READONLY

#define AV_BUFFER_FLAG_READONLY   (1 << 0)

Function Documentation

◆ av_buffer_alloc()

AVBufferRef* av_buffer_alloc ( int  size)

◆ av_buffer_allocz()

AVBufferRef* av_buffer_allocz ( int  size)

◆ av_buffer_create()

AVBufferRef* av_buffer_create ( uint8_t data,
int  size,
void(*)(void *opaque, uint8_t *data free,
void opaque,
int  flags 
)

Create an AVBuffer from an existing array.

If this function is successful, data is owned by the AVBuffer. The caller may only access data through the returned AVBufferRef and references derived from it. If this function fails, data is left untouched.

Parameters
datadata array
sizesize of data in bytes
freea callback for freeing this buffer's data
opaqueparameter to be got for processing or passed to free
flagsa combination of AV_BUFFER_FLAG_*
Returns
an AVBufferRef referring to data on success, NULL on failure.

Definition at line 28 of file buffer.c.

Referenced by av_buffer_alloc(), av_buffer_pool_get(), av_buffer_realloc(), av_hwdevice_ctx_alloc(), av_hwframe_ctx_alloc(), av_packet_from_data(), bufref_wrap_interface(), cbs_h2645_assemble_fragment(), cuda_pool_alloc(), dxva2_pool_alloc(), ff_attach_decode_data(), ff_cbs_alloc_unit_content(), ff_cbs_h264_add_sei_message(), ff_cbs_insert_unit_data(), ff_hevc_decode_nal_pps(), ff_hwframe_map_create(), ff_stream_add_bitstream_filter(), ff_v4l2_m2m_create_context(), ff_videotoolbox_alloc_frame(), ffmmal_set_ref(), kmsgrab_read_packet(), matroska_parse_frame(), matroska_parse_tracks(), mediacodec_wrap_hw_buffer(), mmap_read_frame(), nvdec_decoder_create(), opencl_pool_alloc(), qsv_create_mids(), qsv_pool_alloc(), rkmpp_init_decoder(), rkmpp_retrieve_frame(), v4l2_buf_to_bufref(), vaapi_encode_alloc_output_buffer(), vaapi_pool_alloc(), vdpau_pool_alloc(), wrap_texture_buf(), and wrapped_avframe_encode().

◆ av_buffer_default_free()

void av_buffer_default_free ( void opaque,
uint8_t data 
)

Default free callback, which calls av_free() on the buffer data.

This function is meant to be passed to av_buffer_create(), not called directly.

Definition at line 62 of file buffer.c.

Referenced by av_buffer_alloc(), av_buffer_create(), av_buffer_realloc(), av_packet_from_data(), and ff_stream_add_bitstream_filter().

◆ av_buffer_ref()

AVBufferRef* av_buffer_ref ( AVBufferRef buf)

Create a new reference to an AVBuffer.

Returns
a new AVBufferRef referring to the same AVBuffer as buf or NULL on failure.

Definition at line 93 of file buffer.c.

Referenced by amf_init_context(), av_buffersrc_parameters_set(), av_frame_ref(), av_frame_set_qp_table(), av_hwdevice_ctx_create_derived(), av_hwframe_ctx_alloc(), av_hwframe_ctx_create_derived(), av_hwframe_get_buffer(), av_packet_ref(), avcodec_copy_context(), avfilter_config_links(), bitpacked_decode_uyvy422(), config_output(), config_props(), configure_filtergraph(), copy_packet_data(), cudaupload_config_output(), cuvid_decode_init(), cuvid_output_frame(), dec_enc(), do_streamcopy(), ff_cbs_insert_unit_content(), ff_cbs_insert_unit_data(), ff_cbs_read_packet(), ff_cbs_write_packet(), ff_h264_ref_picture(), ff_h264_update_thread_context(), ff_hwframe_map_create(), ff_mpeg_ref_picture(), ff_mpv_export_qp_table(), ff_nvdec_start_frame(), ff_thread_ref_frame(), ff_vaapi_encode_init(), ff_vaapi_vpp_config_input(), ff_vaapi_vpp_config_output(), ff_videotoolbox_uninit(), ffmmal_add_packet(), frame_add_buf(), frame_copy_props(), get_format(), h264_init_ps(), hevc_ref_frame(), hevc_update_thread_context(), hw_decoder_init(), hw_device_setup_for_decode(), hw_device_setup_for_encode(), hwdownload_config_input(), hwmap_config_output(), hwmap_filter_frame(), hwupload_config_output(), hwupload_query_formats(), ifilter_parameters_from_frame(), init_output_stream(), init_processing_chain(), kmsgrab_read_packet(), matroska_parse_frame(), nvdec_decoder_create(), open_input_file(), opencl_filter_set_device(), opt_sdp_file(), parse_nal_units(), parse_packet(), qsv_create_mids(), qsv_frame_lock(), qsv_init_session(), qsv_map_from(), qsv_setup_mids(), qsvdeint_config_props(), qsvenc_init_session(), raw_decode(), rkmpp_retrieve_frame(), set_hwframe_ctx(), try_push_frame(), update_context_from_thread(), v4l2_buf_to_bufref(), vp8_release_frame(), and vp9_frame_ref().

◆ av_buffer_unref()

void av_buffer_unref ( AVBufferRef **  buf)

Free a given reference and automatically free the buffer if there are no more references to it.

Parameters
bufthe reference to be freed. The pointer is set to NULL on return.

Definition at line 125 of file buffer.c.

Referenced by asf_parse_packet(), av_buffersrc_parameters_set(), av_frame_new_side_data(), av_frame_set_qp_table(), av_frame_unref(), av_free_packet(), av_hwdevice_ctx_create(), av_hwdevice_ctx_create_derived(), av_hwframe_ctx_alloc(), av_hwframe_ctx_create_derived(), av_hwframe_get_buffer(), av_packet_make_writable(), av_packet_unref(), avcodec_close(), avcodec_get_hw_frames_parameters(), avfilter_free(), bitpacked_decode_uyvy422(), cbs_h264_free_pps(), cbs_h264_free_sei_payload(), cbs_h264_free_slice(), cbs_h265_free_pps(), cbs_h265_free_slice(), cbs_h265_free_sps(), cbs_h265_free_vps(), cbs_mpeg2_free_slice(), cbs_mpeg2_free_user_data(), cbs_read_fragment_content(), cbs_unit_uninit(), copy_context_reset(), cudascale_uninit(), cudaupload_config_output(), cudaupload_uninit(), cuvid_decode_end(), cuvid_init(), cuvid_uninit(), decode_receive_frame_internal(), ebml_free(), ebml_read_binary(), extract_extradata_h2645(), ff_amf_encode_close(), ff_attach_decode_data(), ff_cbs_fragment_uninit(), ff_cbs_h264_add_sei_message(), ff_cbs_insert_unit_content(), ff_cbs_insert_unit_data(), ff_cbs_write_fragment_data(), ff_decode_get_hw_frames_ctx(), ff_dxva2_decode_uninit(), ff_er_frame_end(), ff_flac_parse_picture(), ff_frame_thread_free(), ff_free_picture_tables(), ff_h264_decode_picture_parameter_set(), ff_h264_decode_seq_parameter_set(), ff_h264_ps_uninit(), ff_h264_unref_picture(), ff_h264_update_thread_context(), ff_hevc_decode_nal_pps(), ff_hevc_decode_nal_sps(), ff_hevc_decode_nal_vps(), ff_hevc_ps_uninit(), ff_hevc_unref_frame(), ff_hwframe_map_create(), ff_hwframe_unmap(), ff_mpeg_unref_picture(), ff_nvdec_decode_uninit(), ff_opencl_filter_config_output(), ff_opencl_filter_uninit(), ff_qsv_decode_close(), ff_qsv_enc_close(), ff_qsv_init_session_frames(), ff_thread_release_buffer(), ff_v4l2_m2m_codec_end(), ff_vaapi_decode_uninit(), ff_vaapi_encode_close(), ff_vaapi_vpp_config_output(), ff_vaapi_vpp_ctx_uninit(), ff_vaapi_vpp_pipeline_uninit(), ff_videotoolbox_uninit(), ffmmal_add_packet(), ffmmal_fill_input_port(), ffmmal_stop_decoder(), ffmpeg_cleanup(), filter_frame(), frame_copy_props(), free_apic(), free_link(), free_picture(), free_side_data(), get_video_buffer(), h264_init_ps(), handle_packets(), hevc_update_thread_context(), hw_device_free_all(), hw_device_init_from_string(), hw_device_init_from_type(), hwaccel_uninit(), hwdevice_ctx_free(), hwdownload_config_input(), hwdownload_uninit(), hwframe_ctx_free(), hwmap_config_output(), hwmap_uninit(), hwupload_config_output(), hwupload_query_formats(), hwupload_uninit(), ifilter_parameters_from_frame(), init_stage(), init_vpp_session(), input_callback(), kmsgrab_read_close(), main(), matroska_parse_tracks(), mediacodec_wrap_hw_buffer(), mids_buf_free(), mpegts_close_filter(), nppscale_uninit(), nvdec_decoder_create(), nvdec_decoder_free(), nvdec_fdd_priv_free(), opencl_filter_set_device(), parse_nal_units(), pool_alloc_buffer(), qsv_create_mids(), qsv_device_free(), qsv_frame_alloc(), qsv_frame_free(), qsv_frames_uninit(), qsv_init(), qsv_init_child_ctx(), qsv_init_session(), qsv_setup_mids(), qsv_uninit(), qsvdeint_config_props(), qsvdeint_uninit(), qsvenc_init_session(), raw_close_decoder(), raw_decode(), remove_pps(), remove_sps(), remove_vps(), reset_pes_packet_state(), rkmpp_close_decoder(), rkmpp_release_decoder(), rkmpp_release_frame(), rkmpp_retrieve_frame(), set_hwframe_ctx(), thread_get_buffer_internal(), transcode(), uninit(), update_context_from_thread(), v4l2_buf_to_bufref(), v4l2_free_buffer(), vaapi_encode_discard(), vaapi_encode_issue(), vaapi_encode_output(), vaapi_frames_init(), vp8_alloc_frame(), vp8_release_frame(), and vp9_frame_unref().

◆ av_buffer_is_writable()

int av_buffer_is_writable ( const AVBufferRef buf)
Returns
1 if the caller may write to the data referred to by buf (which is true if and only if buf is the only reference to the underlying AVBuffer). Return 0 otherwise. A positive answer is valid until av_buffer_ref() is called on buf.

Definition at line 133 of file buffer.c.

Referenced by av_buffer_make_writable(), av_buffer_realloc(), av_frame_is_writable(), and av_packet_make_writable().

◆ av_buffer_get_opaque()

void* av_buffer_get_opaque ( const AVBufferRef buf)
Returns
the opaque parameter set by av_buffer_create.

Definition at line 141 of file buffer.c.

◆ av_buffer_get_ref_count()

int av_buffer_get_ref_count ( const AVBufferRef buf)

Definition at line 146 of file buffer.c.

Referenced by ff_h264_build_ref_list().

◆ av_buffer_make_writable()

int av_buffer_make_writable ( AVBufferRef **  buf)

Create a writable reference from a given buffer reference, avoiding data copy if possible.

Parameters
bufbuffer reference to make writable. On success, buf is either left untouched, or it is unreferenced and a new writable AVBufferRef is written in its place. On failure, buf is left untouched.
Returns
0 on success, a negative AVERROR on failure.

Definition at line 151 of file buffer.c.

Referenced by raw_decode().

◆ av_buffer_realloc()

int av_buffer_realloc ( AVBufferRef **  buf,
int  size 
)

Reallocate a given buffer.

Parameters
bufa buffer reference to reallocate. On success, buf will be unreferenced and a new reference with the required size will be written in its place. On failure buf will be left untouched. *buf may be NULL, then a new buffer is allocated.
sizerequired new buffer size.
Returns
0 on success, a negative AVERROR on failure.
Note
the buffer is actually reallocated with av_realloc() only if it was initially allocated through av_buffer_realloc(NULL) and there is only one reference to it (i.e. the one passed to this function). In all other cases a new buffer is allocated and the data is copied.

Definition at line 169 of file buffer.c.

Referenced by av_buffer_realloc(), av_grow_packet(), avcodec_encode_audio2(), avcodec_encode_video2(), ebml_read_binary(), get_qt_codec(), and packet_alloc().