They are also frequently used in libavformat. This change does not cause any breakage as avcodec.h includes defs.h. Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
		
			
				
	
	
		
			193 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			193 lines
		
	
	
		
			6.6 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_DEFS_H
 | 
						|
#define AVCODEC_DEFS_H
 | 
						|
 | 
						|
/**
 | 
						|
 * @file
 | 
						|
 * @ingroup libavc
 | 
						|
 * Misc types and constants that do not belong anywhere else.
 | 
						|
 */
 | 
						|
 | 
						|
#include <stdint.h>
 | 
						|
#include <stdlib.h>
 | 
						|
 | 
						|
/**
 | 
						|
 * @ingroup lavc_decoding
 | 
						|
 * Required number of additionally allocated bytes at the end of the input bitstream for decoding.
 | 
						|
 * This is mainly needed because some optimized bitstream readers read
 | 
						|
 * 32 or 64 bit at once and could read over the end.<br>
 | 
						|
 * Note: If the first 23 bits of the additional bytes are not 0, then damaged
 | 
						|
 * MPEG bitstreams could cause overread and segfault.
 | 
						|
 */
 | 
						|
#define AV_INPUT_BUFFER_PADDING_SIZE 64
 | 
						|
 | 
						|
/**
 | 
						|
 * Verify checksums embedded in the bitstream (could be of either encoded or
 | 
						|
 * decoded data, depending on the format) and print an error message on mismatch.
 | 
						|
 * If AV_EF_EXPLODE is also set, a mismatching checksum will result in the
 | 
						|
 * decoder/demuxer returning an error.
 | 
						|
 */
 | 
						|
#define AV_EF_CRCCHECK       (1<<0)
 | 
						|
#define AV_EF_BITSTREAM      (1<<1)   ///< detect bitstream specification deviations
 | 
						|
#define AV_EF_BUFFER         (1<<2)   ///< detect improper bitstream length
 | 
						|
#define AV_EF_EXPLODE        (1<<3)   ///< abort decoding on minor error detection
 | 
						|
 | 
						|
#define AV_EF_IGNORE_ERR     (1<<15)  ///< ignore errors and continue
 | 
						|
#define AV_EF_CAREFUL        (1<<16)  ///< consider things that violate the spec, are fast to calculate and have not been seen in the wild as errors
 | 
						|
#define AV_EF_COMPLIANT      (1<<17)  ///< consider all spec non compliances as errors
 | 
						|
#define AV_EF_AGGRESSIVE     (1<<18)  ///< consider things that a sane encoder/muxer should not do as an error
 | 
						|
 | 
						|
#define FF_COMPLIANCE_VERY_STRICT   2 ///< Strictly conform to an older more strict version of the spec or reference software.
 | 
						|
#define FF_COMPLIANCE_STRICT        1 ///< Strictly conform to all the things in the spec no matter what consequences.
 | 
						|
#define FF_COMPLIANCE_NORMAL        0
 | 
						|
#define FF_COMPLIANCE_UNOFFICIAL   -1 ///< Allow unofficial extensions
 | 
						|
#define FF_COMPLIANCE_EXPERIMENTAL -2 ///< Allow nonstandardized experimental things.
 | 
						|
 | 
						|
/**
 | 
						|
 * @ingroup lavc_decoding
 | 
						|
 */
 | 
						|
enum AVDiscard{
 | 
						|
    /* We leave some space between them for extensions (drop some
 | 
						|
     * keyframes for intra-only or drop just some bidir frames). */
 | 
						|
    AVDISCARD_NONE    =-16, ///< discard nothing
 | 
						|
    AVDISCARD_DEFAULT =  0, ///< discard useless packets like 0 size packets in avi
 | 
						|
    AVDISCARD_NONREF  =  8, ///< discard all non reference
 | 
						|
    AVDISCARD_BIDIR   = 16, ///< discard all bidirectional frames
 | 
						|
    AVDISCARD_NONINTRA= 24, ///< discard all non intra frames
 | 
						|
    AVDISCARD_NONKEY  = 32, ///< discard all frames except keyframes
 | 
						|
    AVDISCARD_ALL     = 48, ///< discard all
 | 
						|
};
 | 
						|
 | 
						|
enum AVAudioServiceType {
 | 
						|
    AV_AUDIO_SERVICE_TYPE_MAIN              = 0,
 | 
						|
    AV_AUDIO_SERVICE_TYPE_EFFECTS           = 1,
 | 
						|
    AV_AUDIO_SERVICE_TYPE_VISUALLY_IMPAIRED = 2,
 | 
						|
    AV_AUDIO_SERVICE_TYPE_HEARING_IMPAIRED  = 3,
 | 
						|
    AV_AUDIO_SERVICE_TYPE_DIALOGUE          = 4,
 | 
						|
    AV_AUDIO_SERVICE_TYPE_COMMENTARY        = 5,
 | 
						|
    AV_AUDIO_SERVICE_TYPE_EMERGENCY         = 6,
 | 
						|
    AV_AUDIO_SERVICE_TYPE_VOICE_OVER        = 7,
 | 
						|
    AV_AUDIO_SERVICE_TYPE_KARAOKE           = 8,
 | 
						|
    AV_AUDIO_SERVICE_TYPE_NB                   , ///< Not part of ABI
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
 * Pan Scan area.
 | 
						|
 * This specifies the area which should be displayed.
 | 
						|
 * Note there may be multiple such areas for one frame.
 | 
						|
 */
 | 
						|
typedef struct AVPanScan {
 | 
						|
    /**
 | 
						|
     * id
 | 
						|
     * - encoding: Set by user.
 | 
						|
     * - decoding: Set by libavcodec.
 | 
						|
     */
 | 
						|
    int id;
 | 
						|
 | 
						|
    /**
 | 
						|
     * width and height in 1/16 pel
 | 
						|
     * - encoding: Set by user.
 | 
						|
     * - decoding: Set by libavcodec.
 | 
						|
     */
 | 
						|
    int width;
 | 
						|
    int height;
 | 
						|
 | 
						|
    /**
 | 
						|
     * position of the top left corner in 1/16 pel for up to 3 fields/frames
 | 
						|
     * - encoding: Set by user.
 | 
						|
     * - decoding: Set by libavcodec.
 | 
						|
     */
 | 
						|
    int16_t position[3][2];
 | 
						|
} AVPanScan;
 | 
						|
 | 
						|
/**
 | 
						|
 * This structure describes the bitrate properties of an encoded bitstream. It
 | 
						|
 * roughly corresponds to a subset the VBV parameters for MPEG-2 or HRD
 | 
						|
 * parameters for H.264/HEVC.
 | 
						|
 */
 | 
						|
typedef struct AVCPBProperties {
 | 
						|
    /**
 | 
						|
     * Maximum bitrate of the stream, in bits per second.
 | 
						|
     * Zero if unknown or unspecified.
 | 
						|
     */
 | 
						|
    int64_t max_bitrate;
 | 
						|
    /**
 | 
						|
     * Minimum bitrate of the stream, in bits per second.
 | 
						|
     * Zero if unknown or unspecified.
 | 
						|
     */
 | 
						|
    int64_t min_bitrate;
 | 
						|
    /**
 | 
						|
     * Average bitrate of the stream, in bits per second.
 | 
						|
     * Zero if unknown or unspecified.
 | 
						|
     */
 | 
						|
    int64_t avg_bitrate;
 | 
						|
 | 
						|
    /**
 | 
						|
     * The size of the buffer to which the ratecontrol is applied, in bits.
 | 
						|
     * Zero if unknown or unspecified.
 | 
						|
     */
 | 
						|
    int64_t buffer_size;
 | 
						|
 | 
						|
    /**
 | 
						|
     * The delay between the time the packet this structure is associated with
 | 
						|
     * is received and the time when it should be decoded, in periods of a 27MHz
 | 
						|
     * clock.
 | 
						|
     *
 | 
						|
     * UINT64_MAX when unknown or unspecified.
 | 
						|
     */
 | 
						|
    uint64_t vbv_delay;
 | 
						|
} AVCPBProperties;
 | 
						|
 | 
						|
/**
 | 
						|
 * Allocate a CPB properties structure and initialize its fields to default
 | 
						|
 * values.
 | 
						|
 *
 | 
						|
 * @param size if non-NULL, the size of the allocated struct will be written
 | 
						|
 *             here. This is useful for embedding it in side data.
 | 
						|
 *
 | 
						|
 * @return the newly allocated struct or NULL on failure
 | 
						|
 */
 | 
						|
AVCPBProperties *av_cpb_properties_alloc(size_t *size);
 | 
						|
 | 
						|
/**
 | 
						|
 * This structure supplies correlation between a packet timestamp and a wall clock
 | 
						|
 * production time. The definition follows the Producer Reference Time ('prft')
 | 
						|
 * as defined in ISO/IEC 14496-12
 | 
						|
 */
 | 
						|
typedef struct AVProducerReferenceTime {
 | 
						|
    /**
 | 
						|
     * A UTC timestamp, in microseconds, since Unix epoch (e.g, av_gettime()).
 | 
						|
     */
 | 
						|
    int64_t wallclock;
 | 
						|
    int flags;
 | 
						|
} AVProducerReferenceTime;
 | 
						|
 | 
						|
/**
 | 
						|
 * Encode extradata length to a buffer. Used by xiph codecs.
 | 
						|
 *
 | 
						|
 * @param s buffer to write to; must be at least (v/255+1) bytes long
 | 
						|
 * @param v size of extradata in bytes
 | 
						|
 * @return number of bytes written to the buffer.
 | 
						|
 */
 | 
						|
unsigned int av_xiphlacing(unsigned char *s, unsigned int v);
 | 
						|
 | 
						|
#endif // AVCODEC_DEFS_H
 |