Spaces:
Runtime error
Runtime error
/* | |
* Copyright (C) 2001-2002 Michael Niedermayer ([email protected]) | |
* | |
* This file is part of FFmpeg. | |
* | |
* FFmpeg is free software; you can redistribute it and/or modify | |
* it under the terms of the GNU General Public License as published by | |
* the Free Software Foundation; either version 2 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 General Public License for more details. | |
* | |
* You should have received a copy of the GNU 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 | |
*/ | |
/** | |
* @file | |
* internal API header. | |
*/ | |
// Experimental vertical filters | |
// Experimental horizontal filters | |
/// select between full y range (255-0) or standard one (234-16) | |
//Deinterlacing Filters | |
//use if you want a faster postprocessing code | |
//cannot differentiate between chroma & luma filters (both on or both off) | |
//obviously the -pp option on the command line has no effect except turning the here selected | |
//filters on | |
//#define COMPILE_TIME_MODE 0x77 | |
/** | |
* Postprocessing filter. | |
*/ | |
struct PPFilter{ | |
const char *shortName; | |
const char *longName; | |
int chromDefault; ///< is chrominance filtering on by default if this filter is manually activated | |
int minLumQuality; ///< minimum quality to turn luminance filtering on | |
int minChromQuality; ///< minimum quality to turn chrominance filtering on | |
int mask; ///< Bitmask to turn this filter on | |
}; | |
/** | |
* Postprocessing mode. | |
*/ | |
typedef struct PPMode{ | |
int lumMode; ///< activates filters for luminance | |
int chromMode; ///< activates filters for chrominance | |
int error; ///< non zero on error | |
int minAllowedY; ///< for brightness correction | |
int maxAllowedY; ///< for brightness correction | |
AVRational maxClippedThreshold; ///< amount of "black" you are willing to lose to get a brightness-corrected picture | |
int maxTmpNoise[3]; ///< for Temporal Noise Reducing filter (Maximal sum of abs differences) | |
int baseDcDiff; | |
int flatnessThreshold; | |
int forcedQuant; ///< quantizer if FORCE_QUANT is used | |
} PPMode; | |
/** | |
* postprocess context. | |
*/ | |
typedef struct PPContext{ | |
/** | |
* info on struct for av_log | |
*/ | |
const AVClass *av_class; | |
uint8_t *tempBlocks; ///<used for the horizontal code | |
/** | |
* luma histogram. | |
* we need 64bit here otherwise we'll going to have a problem | |
* after watching a black picture for 5 hours | |
*/ | |
uint64_t *yHistogram; | |
DECLARE_ALIGNED(8, uint64_t, packedYOffset); | |
DECLARE_ALIGNED(8, uint64_t, packedYScale); | |
/** Temporal noise reducing buffers */ | |
uint8_t *tempBlurred[3]; | |
int32_t *tempBlurredPast[3]; | |
/** Temporary buffers for handling the last row(s) */ | |
uint8_t *tempDst; | |
uint8_t *tempSrc; | |
uint8_t *deintTemp; | |
DECLARE_ALIGNED(8, uint64_t, pQPb); | |
DECLARE_ALIGNED(8, uint64_t, pQPb2); | |
DECLARE_ALIGNED(32, uint64_t, pQPb_block)[4]; | |
DECLARE_ALIGNED(32, uint64_t, pQPb2_block)[4]; | |
DECLARE_ALIGNED(32, uint64_t, mmxDcOffset)[64]; | |
DECLARE_ALIGNED(32, uint64_t, mmxDcThreshold)[64]; | |
int8_t *stdQPTable; ///< used to fix MPEG2 style qscale | |
int8_t *nonBQPTable; | |
int8_t *forcedQPTable; | |
int QP; | |
int nonBQP; | |
DECLARE_ALIGNED(32, int, QP_block)[4]; | |
DECLARE_ALIGNED(32, int, nonBQP_block)[4]; | |
int frameNum; | |
int cpuCaps; | |
int qpStride; ///<size of qp buffers (needed to realloc them if needed) | |
int stride; ///<size of some buffers (needed to realloc them if needed) | |
int hChromaSubSample; | |
int vChromaSubSample; | |
PPMode ppMode; | |
} PPContext; | |
static inline void linecpy(void *dest, const void *src, int lines, int stride) { | |
if (stride > 0) { | |
memcpy(dest, src, lines*stride); | |
} else { | |
memcpy((uint8_t*)dest+(lines-1)*stride, (const uint8_t*)src+(lines-1)*stride, -lines*stride); | |
} | |
} | |