bsf: add a flushing mechanism to AVBSFContext
Meant to reset the internal bsf state without the need to reinitialize it. Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
@@ -13,6 +13,9 @@ libavutil: 2017-03-23
|
|||||||
|
|
||||||
API changes, most recent first:
|
API changes, most recent first:
|
||||||
|
|
||||||
|
2018-xx-xx - xxxxxxx - lavc 58.10.0 - avcodec.h
|
||||||
|
Add av_bsf_flush().
|
||||||
|
|
||||||
2018-02-xx - xxxxxxx - lavfi 7.1.0 - avfilter.h
|
2018-02-xx - xxxxxxx - lavfi 7.1.0 - avfilter.h
|
||||||
Add AVFilterContext.extra_hw_frames.
|
Add AVFilterContext.extra_hw_frames.
|
||||||
|
|
||||||
|
|||||||
@@ -4927,6 +4927,7 @@ typedef struct AVBitStreamFilter {
|
|||||||
int (*init)(AVBSFContext *ctx);
|
int (*init)(AVBSFContext *ctx);
|
||||||
int (*filter)(AVBSFContext *ctx, AVPacket *pkt);
|
int (*filter)(AVBSFContext *ctx, AVPacket *pkt);
|
||||||
void (*close)(AVBSFContext *ctx);
|
void (*close)(AVBSFContext *ctx);
|
||||||
|
void (*flush)(AVBSFContext *ctx);
|
||||||
} AVBitStreamFilter;
|
} AVBitStreamFilter;
|
||||||
|
|
||||||
#if FF_API_OLD_BSF
|
#if FF_API_OLD_BSF
|
||||||
@@ -5029,6 +5030,11 @@ int av_bsf_send_packet(AVBSFContext *ctx, AVPacket *pkt);
|
|||||||
*/
|
*/
|
||||||
int av_bsf_receive_packet(AVBSFContext *ctx, AVPacket *pkt);
|
int av_bsf_receive_packet(AVBSFContext *ctx, AVPacket *pkt);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reset the internal bitstream filter state / flush internal buffers.
|
||||||
|
*/
|
||||||
|
void av_bsf_flush(AVBSFContext *ctx);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Free a bitstream filter context and everything associated with it; write NULL
|
* Free a bitstream filter context and everything associated with it; write NULL
|
||||||
* into the supplied pointer.
|
* into the supplied pointer.
|
||||||
|
|||||||
@@ -170,6 +170,16 @@ int av_bsf_init(AVBSFContext *ctx)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void av_bsf_flush(AVBSFContext *ctx)
|
||||||
|
{
|
||||||
|
ctx->internal->eof = 0;
|
||||||
|
|
||||||
|
av_packet_unref(ctx->internal->buffer_pkt);
|
||||||
|
|
||||||
|
if (ctx->filter->flush)
|
||||||
|
ctx->filter->flush(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
int av_bsf_send_packet(AVBSFContext *ctx, AVPacket *pkt)
|
int av_bsf_send_packet(AVBSFContext *ctx, AVPacket *pkt)
|
||||||
{
|
{
|
||||||
if (!pkt || !pkt->data) {
|
if (!pkt || !pkt->data) {
|
||||||
|
|||||||
@@ -28,7 +28,7 @@
|
|||||||
#include "libavutil/version.h"
|
#include "libavutil/version.h"
|
||||||
|
|
||||||
#define LIBAVCODEC_VERSION_MAJOR 58
|
#define LIBAVCODEC_VERSION_MAJOR 58
|
||||||
#define LIBAVCODEC_VERSION_MINOR 9
|
#define LIBAVCODEC_VERSION_MINOR 10
|
||||||
#define LIBAVCODEC_VERSION_MICRO 0
|
#define LIBAVCODEC_VERSION_MICRO 0
|
||||||
|
|
||||||
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
||||||
|
|||||||
Reference in New Issue
Block a user