Go to the documentation of this file.
32 #define randomize_buffers(buf, size) \
35 for (j = 0; j < size; j+=4) \
36 AV_WN32(buf + j, rnd()); \
46 d = ((filterSize - 1) * 8 +
dither[0]) >> 4;
47 for (
i = 0;
i < dstW;
i++) {
54 for (j = 0; j < filterSize; j++){
65 int fsi, osi, isi,
i, j;
67 #define LARGEST_FILTER 16
68 #define FILTER_SIZES 4
69 static const int filter_sizes[
FILTER_SIZES] = {1, 4, 8, 16};
70 #define LARGEST_INPUT_SIZE 512
72 static const int input_sizes[
INPUT_SIZES] = {8, 24, 128, 144, 256, 512};
75 int filterSize,
const int16_t **
src,
uint8_t *dest,
98 dstW = input_sizes[isi];
99 for(osi = 0; osi < 64; osi += 16){
102 vFilterData =
av_malloc((filter_sizes[fsi] + 2) *
sizeof(
union VFilterData));
103 memset(vFilterData, 0, (filter_sizes[fsi] + 2) *
sizeof(
union VFilterData));
104 for(
i = 0;
i < filter_sizes[fsi]; ++
i){
106 vFilterData[
i].src =
src[
i];
107 for(j = 0; j < 4; ++j)
108 vFilterData[
i].
coeff[j + 4] = filter_coeff[
i];
110 if (
check_func(
ctx->yuv2planeX,
"yuv2yuvX_%d_%d_%d", filter_sizes[fsi], osi, dstW)){
120 if(
ctx->use_mmx_vfilter){
121 call_new((
const int16_t*)vFilterData, filter_sizes[fsi],
src, dst1, dstW - osi,
dither, osi);
125 bench_new((
const int16_t*)vFilterData, filter_sizes[fsi],
src, dst1, dstW - osi,
dither, osi);
138 #define SRC_PIXELS 128
142 #define MAX_FILTER_WIDTH 40
143 #define FILTER_SIZES 5
144 static const int filter_sizes[
FILTER_SIZES] = { 4, 8, 16, 32, 40 };
146 #define HSCALE_PAIRS 2
152 int i, j, fsi, hpi,
width;
168 const int32_t *filterPos,
int filterSize);
178 width = filter_sizes[fsi];
180 ctx->srcBpc = hscale_pairs[hpi][0];
181 ctx->dstBpc = hscale_pairs[hpi][1];
200 for (j = 0; j <
width; j++) {
216 memset(dst0, 0,
SRC_PIXELS *
sizeof(dst0[0]));
217 memset(dst1, 0,
SRC_PIXELS *
sizeof(dst1[0]));
221 if (memcmp(dst0, dst1,
SRC_PIXELS *
sizeof(dst0[0])))
#define declare_func_emms(cpu_flags, ret,...)
int dstW
Width of destination luma/alpha planes.
static void check_yuv2yuvX(void)
#define check_func(func,...)
filter_frame For filters that do not use the this method is called when a frame is pushed to the filter s input It can be called at any time except in a reentrant way If the input frame is enough to produce then the filter should push the output frames on the output link immediately As an exception to the previous rule if the input frame is enough to produce several output frames then the filter needs output only at least one per link The additional frames can be left buffered in the filter
static double val(void *priv, double ch)
static void check_hscale(void)
#define LOCAL_ALIGNED_8(t, v,...)
#define LOCAL_ALIGNED_32(t, v,...)
struct SwsContext * sws_alloc_context(void)
Allocate an empty SwsContext.
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
SwsFunc ff_getSwsFunc(SwsContext *c)
Return function pointer to fastest main scaler path function depending on architecture and available ...
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf offset
#define LARGEST_INPUT_SIZE
#define randomize_buffers(buf, size)
av_warn_unused_result int sws_init_context(struct SwsContext *sws_context, SwsFilter *srcFilter, SwsFilter *dstFilter)
Initialize the swscaler context sws_context.
#define AV_CPU_FLAG_MMX
standard MMX
void sws_freeContext(struct SwsContext *swsContext)
Free the swscaler context swsContext.
static void ref_function(const int16_t *filter, int filterSize, const int16_t **src, uint8_t *dest, int dstW, const uint8_t *dither, int offset)
static const double coeff[2][5]
void checkasm_check_sw_scale(void)
static const uint8_t dither[8][8]