2021-01-01 21:35:17 +00:00
|
|
|
/*
|
|
|
|
* This file is part of FFmpeg.
|
|
|
|
*
|
|
|
|
* FFmpeg is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* FFmpeg is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with FFmpeg; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef AVCODEC_CBS_BSF_H
|
|
|
|
#define AVCODEC_CBS_BSF_H
|
|
|
|
|
2021-03-02 10:53:50 +01:00
|
|
|
#include "libavutil/log.h"
|
|
|
|
#include "libavutil/opt.h"
|
|
|
|
|
|
|
|
#include "bsf.h"
|
|
|
|
#include "codec_id.h"
|
2021-01-01 21:35:17 +00:00
|
|
|
#include "cbs.h"
|
2021-03-02 10:53:50 +01:00
|
|
|
#include "packet.h"
|
2021-01-01 21:35:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
typedef struct CBSBSFType {
|
|
|
|
enum AVCodecID codec_id;
|
|
|
|
|
|
|
|
// Name of a frame fragment in this codec (e.g. "access unit",
|
|
|
|
// "temporal unit").
|
|
|
|
const char *fragment_name;
|
|
|
|
|
|
|
|
// Name of a unit for this BSF, for use in error messages (e.g.
|
|
|
|
// "NAL unit", "OBU").
|
|
|
|
const char *unit_name;
|
|
|
|
|
|
|
|
// Update the content of a fragment with whatever metadata changes
|
|
|
|
// are desired. The associated AVPacket is provided so that any side
|
|
|
|
// data associated with the fragment can be inspected or edited. If
|
|
|
|
// pkt is NULL, then an extradata header fragment is being updated.
|
|
|
|
int (*update_fragment)(AVBSFContext *bsf, AVPacket *pkt,
|
|
|
|
CodedBitstreamFragment *frag);
|
|
|
|
} CBSBSFType;
|
|
|
|
|
|
|
|
// Common structure for all generic CBS BSF users. An instance of this
|
|
|
|
// structure must be the first member of the BSF private context (to be
|
|
|
|
// pointed to by AVBSFContext.priv_data).
|
|
|
|
typedef struct CBSBSFContext {
|
|
|
|
const AVClass *class;
|
|
|
|
const CBSBSFType *type;
|
|
|
|
|
|
|
|
CodedBitstreamContext *input;
|
|
|
|
CodedBitstreamContext *output;
|
|
|
|
CodedBitstreamFragment fragment;
|
|
|
|
} CBSBSFContext;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialise generic CBS BSF setup.
|
|
|
|
*
|
|
|
|
* Creates the input and output CBS instances, and applies the filter to
|
|
|
|
* the extradata on the input codecpar if any is present.
|
|
|
|
*
|
|
|
|
* Since it calls the update_fragment() function immediately to deal with
|
|
|
|
* extradata, this should be called after any codec-specific setup is done
|
|
|
|
* (probably at the end of the AVBitStreamFilter.init function).
|
|
|
|
*/
|
|
|
|
int ff_cbs_bsf_generic_init(AVBSFContext *bsf, const CBSBSFType *type);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Close a generic CBS BSF instance.
|
|
|
|
*
|
|
|
|
* If no other deinitialisation is required then this function can be used
|
|
|
|
* directly as AVBitStreamFilter.close.
|
|
|
|
*/
|
|
|
|
void ff_cbs_bsf_generic_close(AVBSFContext *bsf);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Filter operation for CBS BSF.
|
|
|
|
*
|
|
|
|
* Reads the input packet into a CBS fragment, calls update_fragment() on
|
|
|
|
* it, then writes the result to an output packet. If the input packet
|
|
|
|
* has AV_PKT_DATA_NEW_EXTRADATA side-data associated with it then it does
|
|
|
|
* the same thing to that new extradata to form the output side-data first.
|
|
|
|
*
|
|
|
|
* If the BSF does not do anything else then this function can be used
|
|
|
|
* directly as AVBitStreamFilter.filter.
|
|
|
|
*/
|
|
|
|
int ff_cbs_bsf_generic_filter(AVBSFContext *bsf, AVPacket *pkt);
|
|
|
|
|
|
|
|
|
|
|
|
// Options for element manipulation.
|
|
|
|
enum {
|
|
|
|
// Pass this element through unchanged.
|
|
|
|
BSF_ELEMENT_PASS,
|
|
|
|
// Insert this element, replacing any existing instances of it.
|
|
|
|
// Associated values may be provided explicitly (as addtional options)
|
|
|
|
// or implicitly (either as side data or deduced from other parts of
|
|
|
|
// the stream).
|
|
|
|
BSF_ELEMENT_INSERT,
|
|
|
|
// Remove this element if it appears in the stream.
|
|
|
|
BSF_ELEMENT_REMOVE,
|
|
|
|
// Extract this element to side data, so that further manipulation
|
|
|
|
// can happen elsewhere.
|
|
|
|
BSF_ELEMENT_EXTRACT,
|
|
|
|
};
|
|
|
|
|
|
|
|
#define BSF_ELEMENT_OPTIONS_PIR(name, help, field, opt_flags) \
|
|
|
|
{ name, help, OFFSET(field), AV_OPT_TYPE_INT, \
|
|
|
|
{ .i64 = BSF_ELEMENT_PASS }, \
|
|
|
|
BSF_ELEMENT_PASS, BSF_ELEMENT_REMOVE, opt_flags, name }, \
|
|
|
|
{ "pass", NULL, 0, AV_OPT_TYPE_CONST, \
|
|
|
|
{ .i64 = BSF_ELEMENT_PASS }, .flags = opt_flags, .unit = name }, \
|
|
|
|
{ "insert", NULL, 0, AV_OPT_TYPE_CONST, \
|
|
|
|
{ .i64 = BSF_ELEMENT_INSERT }, .flags = opt_flags, .unit = name }, \
|
|
|
|
{ "remove", NULL, 0, AV_OPT_TYPE_CONST, \
|
|
|
|
{ .i64 = BSF_ELEMENT_REMOVE }, .flags = opt_flags, .unit = name }
|
|
|
|
|
|
|
|
#define BSF_ELEMENT_OPTIONS_PIRE(name, help, field, opt_flags) \
|
|
|
|
{ name, help, OFFSET(field), AV_OPT_TYPE_INT, \
|
|
|
|
{ .i64 = BSF_ELEMENT_PASS }, \
|
|
|
|
BSF_ELEMENT_PASS, BSF_ELEMENT_EXTRACT, opt_flags, name }, \
|
|
|
|
{ "pass", NULL, 0, AV_OPT_TYPE_CONST, \
|
|
|
|
{ .i64 = BSF_ELEMENT_PASS }, .flags = opt_flags, .unit = name }, \
|
|
|
|
{ "insert", NULL, 0, AV_OPT_TYPE_CONST, \
|
|
|
|
{ .i64 = BSF_ELEMENT_INSERT }, .flags = opt_flags, .unit = name }, \
|
|
|
|
{ "remove", NULL, 0, AV_OPT_TYPE_CONST, \
|
|
|
|
{ .i64 = BSF_ELEMENT_REMOVE }, .flags = opt_flags, .unit = name }, \
|
|
|
|
{ "extract", NULL, 0, AV_OPT_TYPE_CONST, \
|
|
|
|
{ .i64 = BSF_ELEMENT_EXTRACT }, .flags = opt_flags, .unit = name } \
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* AVCODEC_CBS_BSF_H */
|