mirror of
				https://github.com/nyanmisaka/ffmpeg-rockchip.git
				synced 2025-10-31 04:26:37 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			138 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * 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
 | |
| 
 | |
| #include "libavutil/log.h"
 | |
| #include "libavutil/opt.h"
 | |
| 
 | |
| #include "bsf.h"
 | |
| #include "codec_id.h"
 | |
| #include "cbs.h"
 | |
| #include "packet.h"
 | |
| 
 | |
| 
 | |
| 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 */
 | 
