Go to the documentation of this file.
25 #define SCALE_FUNC(filter_n, from_bpc, to_bpc, opt) \
26 void ff_hscale ## from_bpc ## to ## to_bpc ## _ ## filter_n ## _ ## opt( \
27 SwsContext *c, int16_t *data, \
28 int dstW, const uint8_t *src, \
29 const int16_t *filter, \
30 const int32_t *filterPos, int filterSize)
31 #define SCALE_FUNCS(filter_n, opt) \
32 SCALE_FUNC(filter_n, 8, 15, opt);
33 #define ALL_SCALE_FUNCS(opt) \
34 SCALE_FUNCS(4, opt); \
40 const int16_t **
src, uint8_t *dest,
int dstW,
43 #define ASSIGN_SCALE_FUNC2(hscalefn, filtersize, opt) do { \
44 if (c->srcBpc == 8 && c->dstBpc <= 14) { \
46 ff_hscale8to15_ ## filtersize ## _ ## opt; \
50 #define ASSIGN_SCALE_FUNC(hscalefn, filtersize, opt) \
51 switch (filtersize) { \
52 case 4: ASSIGN_SCALE_FUNC2(hscalefn, 4, opt); break; \
53 default: if (filtersize % 8 == 0) \
54 ASSIGN_SCALE_FUNC2(hscalefn, X8, opt); \
void ff_yuv2planeX_8_neon(const int16_t *filter, int filterSize, const int16_t **src, uint8_t *dest, int dstW, const uint8_t *dither, int offset)
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
int av_get_cpu_flags(void)
Return the flags which specify extensions supported by the CPU.
static atomic_int cpu_flags
av_cold void ff_sws_init_swscale_aarch64(SwsContext *c)
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
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 ASSIGN_SCALE_FUNC(hscalefn, filtersize, opt)
#define ALL_SCALE_FUNCS(opt)
static const uint8_t dither[8][8]