FFmpeg
|
#include "config.h"
#include "version.h"
#include "libavutil/avassert.h"
#include "libavutil/avutil.h"
#include "libavutil/common.h"
#include "libavutil/intreadwrite.h"
#include "libavutil/log.h"
#include "libavutil/pixfmt.h"
#include "libavutil/pixdesc.h"
#include "libavutil/ppc/util_altivec.h"
Go to the source code of this file.
Data Structures | |
struct | SwsContext |
struct | SwsPlane |
Slice plane. More... | |
struct | SwsSlice |
Struct which defines a slice of an image to be scaled or an output for a scaled slice. More... | |
struct | SwsFilterDescriptor |
Struct which holds all necessary data for processing a slice. More... | |
Macros | |
#define | STR(s) AV_TOSTRING(s) |
#define | YUVRGB_TABLE_HEADROOM 512 |
#define | YUVRGB_TABLE_LUMA_HEADROOM 512 |
#define | MAX_FILTER_SIZE SWS_MAX_FILTER_SIZE |
#define | DITHER1XBPP |
#define | ALT32_CORR 1 |
#define | APCK_PTR2 4 |
#define | APCK_COEF 8 |
#define | APCK_SIZE 16 |
#define | RETCODE_USE_CASCADE -12345 |
#define | FILL(wfunc) |
#define | FILL(wfunc) |
#define | MAX_SLICE_PLANES 4 |
#define | MAX_LINES_AHEAD 4 |
Horizontal and vertical filters. | |
To better understand the following fields, here is a pseudo-code of their usage in filtering a horizontal line: | |
#define | RY_IDX 0 |
#define | GY_IDX 1 |
#define | BY_IDX 2 |
#define | RU_IDX 3 |
#define | GU_IDX 4 |
#define | BU_IDX 5 |
#define | RV_IDX 6 |
#define | GV_IDX 7 |
#define | BV_IDX 8 |
#define | RGB2YUV_SHIFT 15 |
#define | RED_DITHER "0*8" |
#define | GREEN_DITHER "1*8" |
#define | BLUE_DITHER "2*8" |
#define | Y_COEFF "3*8" |
#define | VR_COEFF "4*8" |
#define | UB_COEFF "5*8" |
#define | VG_COEFF "6*8" |
#define | UG_COEFF "7*8" |
#define | Y_OFFSET "8*8" |
#define | U_OFFSET "9*8" |
#define | V_OFFSET "10*8" |
#define | LUM_MMX_FILTER_OFFSET "11*8" |
#define | CHR_MMX_FILTER_OFFSET "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE) |
#define | DSTW_OFFSET "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2" |
#define | ESP_OFFSET "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+8" |
#define | VROUNDER_OFFSET "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+16" |
#define | U_TEMP "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+24" |
#define | V_TEMP "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+32" |
#define | Y_TEMP "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+40" |
#define | ALP_MMX_FILTER_OFFSET "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+48" |
#define | UV_OFF_PX "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*3+48" |
#define | UV_OFF_BYTE "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*3+56" |
#define | DITHER16 "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*3+64" |
#define | DITHER32 "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*3+80" |
#define | DITHER32_INT (11*8+4*4*MAX_FILTER_SIZE*3+80) |
#define | XYZ_GAMMA (2.6f) |
#define | RGB_GAMMA (2.2f) |
Typedefs | |
typedef int(* | SwsFunc) (struct SwsContext *context, const uint8_t *src[], int srcStride[], int srcSliceY, int srcSliceH, uint8_t *dst[], int dstStride[]) |
typedef void(* | yuv2planar1_fn) (const int16_t *src, uint8_t *dest, int dstW, const uint8_t *dither, int offset) |
Write one line of horizontally scaled data to planar output without any additional vertical scaling (or point-scaling). More... | |
typedef void(* | yuv2planarX_fn) (const int16_t *filter, int filterSize, const int16_t **src, uint8_t *dest, int dstW, const uint8_t *dither, int offset) |
Write one line of horizontally scaled data to planar output with multi-point vertical scaling between input pixels. More... | |
typedef void(* | yuv2interleavedX_fn) (struct SwsContext *c, const int16_t *chrFilter, int chrFilterSize, const int16_t **chrUSrc, const int16_t **chrVSrc, uint8_t *dest, int dstW) |
Write one line of horizontally scaled chroma to interleaved output with multi-point vertical scaling between input pixels. More... | |
typedef void(* | yuv2packed1_fn) (struct SwsContext *c, const int16_t *lumSrc, const int16_t *chrUSrc[2], const int16_t *chrVSrc[2], const int16_t *alpSrc, uint8_t *dest, int dstW, int uvalpha, int y) |
Write one line of horizontally scaled Y/U/V/A to packed-pixel YUV/RGB output without any additional vertical scaling (or point-scaling). More... | |
typedef void(* | yuv2packed2_fn) (struct SwsContext *c, const int16_t *lumSrc[2], const int16_t *chrUSrc[2], const int16_t *chrVSrc[2], const int16_t *alpSrc[2], uint8_t *dest, int dstW, int yalpha, int uvalpha, int y) |
Write one line of horizontally scaled Y/U/V/A to packed-pixel YUV/RGB output by doing bilinear scaling between two input lines. More... | |
typedef void(* | yuv2packedX_fn) (struct SwsContext *c, const int16_t *lumFilter, const int16_t **lumSrc, int lumFilterSize, const int16_t *chrFilter, const int16_t **chrUSrc, const int16_t **chrVSrc, int chrFilterSize, const int16_t **alpSrc, uint8_t *dest, int dstW, int y) |
Write one line of horizontally scaled Y/U/V/A to packed-pixel YUV/RGB output by doing multi-point vertical scaling between input pixels. More... | |
typedef void(* | yuv2anyX_fn) (struct SwsContext *c, const int16_t *lumFilter, const int16_t **lumSrc, int lumFilterSize, const int16_t *chrFilter, const int16_t **chrUSrc, const int16_t **chrVSrc, int chrFilterSize, const int16_t **alpSrc, uint8_t **dest, int dstW, int y) |
Write one line of horizontally scaled Y/U/V/A to YUV/RGB output by doing multi-point vertical scaling between input pixels. More... | |
Enumerations | |
enum | SwsDither { SWS_DITHER_NONE = 0, SWS_DITHER_AUTO, SWS_DITHER_BAYER, SWS_DITHER_ED, SWS_DITHER_A_DITHER, SWS_DITHER_X_DITHER, NB_SWS_DITHER } |
enum | SwsAlphaBlend { SWS_ALPHA_BLEND_NONE = 0, SWS_ALPHA_BLEND_UNIFORM, SWS_ALPHA_BLEND_CHECKERBOARD, SWS_ALPHA_BLEND_NB } |
Variables | |
const uint64_t | ff_dither4 [2] |
const uint64_t | ff_dither8 [2] |
const uint8_t | ff_dither_2x2_4 [3][8] |
const uint8_t | ff_dither_2x2_8 [3][8] |
const uint8_t | ff_dither_4x4_16 [5][8] |
const uint8_t | ff_dither_8x8_32 [9][8] |
const uint8_t | ff_dither_8x8_73 [9][8] |
const uint8_t | ff_dither_8x8_128 [9][8] |
const uint8_t | ff_dither_8x8_220 [9][8] |
const int32_t | ff_yuv2rgb_coeffs [11][4] |
const AVClass | ff_sws_context_class |
#define STR | ( | s | ) | AV_TOSTRING(s) |
Definition at line 36 of file swscale_internal.h.
#define YUVRGB_TABLE_HEADROOM 512 |
Definition at line 38 of file swscale_internal.h.
#define YUVRGB_TABLE_LUMA_HEADROOM 512 |
Definition at line 39 of file swscale_internal.h.
#define MAX_FILTER_SIZE SWS_MAX_FILTER_SIZE |
Definition at line 41 of file swscale_internal.h.
#define DITHER1XBPP |
Definition at line 43 of file swscale_internal.h.
#define ALT32_CORR 1 |
Definition at line 48 of file swscale_internal.h.
#define APCK_PTR2 4 |
Definition at line 56 of file swscale_internal.h.
#define APCK_COEF 8 |
Definition at line 57 of file swscale_internal.h.
#define APCK_SIZE 16 |
Definition at line 58 of file swscale_internal.h.
#define RETCODE_USE_CASCADE -12345 |
Definition at line 61 of file swscale_internal.h.
#define RY_IDX 0 |
Definition at line 404 of file swscale_internal.h.
#define GY_IDX 1 |
Definition at line 405 of file swscale_internal.h.
#define BY_IDX 2 |
Definition at line 406 of file swscale_internal.h.
#define RU_IDX 3 |
Definition at line 407 of file swscale_internal.h.
#define GU_IDX 4 |
Definition at line 408 of file swscale_internal.h.
#define BU_IDX 5 |
Definition at line 409 of file swscale_internal.h.
#define RV_IDX 6 |
Definition at line 410 of file swscale_internal.h.
#define GV_IDX 7 |
Definition at line 411 of file swscale_internal.h.
#define BV_IDX 8 |
Definition at line 412 of file swscale_internal.h.
#define RGB2YUV_SHIFT 15 |
Definition at line 413 of file swscale_internal.h.
#define RED_DITHER "0*8" |
Definition at line 438 of file swscale_internal.h.
#define GREEN_DITHER "1*8" |
Definition at line 439 of file swscale_internal.h.
#define BLUE_DITHER "2*8" |
Definition at line 440 of file swscale_internal.h.
#define Y_COEFF "3*8" |
Definition at line 441 of file swscale_internal.h.
#define VR_COEFF "4*8" |
Definition at line 442 of file swscale_internal.h.
#define UB_COEFF "5*8" |
Definition at line 443 of file swscale_internal.h.
#define VG_COEFF "6*8" |
Definition at line 444 of file swscale_internal.h.
#define UG_COEFF "7*8" |
Definition at line 445 of file swscale_internal.h.
#define Y_OFFSET "8*8" |
Definition at line 446 of file swscale_internal.h.
#define U_OFFSET "9*8" |
Definition at line 447 of file swscale_internal.h.
#define V_OFFSET "10*8" |
Definition at line 448 of file swscale_internal.h.
#define LUM_MMX_FILTER_OFFSET "11*8" |
Definition at line 449 of file swscale_internal.h.
#define CHR_MMX_FILTER_OFFSET "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE) |
Definition at line 450 of file swscale_internal.h.
#define DSTW_OFFSET "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2" |
Definition at line 451 of file swscale_internal.h.
#define ESP_OFFSET "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+8" |
Definition at line 452 of file swscale_internal.h.
#define VROUNDER_OFFSET "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+16" |
Definition at line 453 of file swscale_internal.h.
#define U_TEMP "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+24" |
Definition at line 454 of file swscale_internal.h.
#define V_TEMP "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+32" |
Definition at line 455 of file swscale_internal.h.
#define Y_TEMP "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+40" |
Definition at line 456 of file swscale_internal.h.
#define ALP_MMX_FILTER_OFFSET "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*2+48" |
Definition at line 457 of file swscale_internal.h.
#define UV_OFF_PX "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*3+48" |
Definition at line 458 of file swscale_internal.h.
#define UV_OFF_BYTE "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*3+56" |
Definition at line 459 of file swscale_internal.h.
#define DITHER16 "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*3+64" |
Definition at line 460 of file swscale_internal.h.
#define DITHER32 "11*8+4*4*"AV_STRINGIFY(MAX_FILTER_SIZE)"*3+80" |
Definition at line 461 of file swscale_internal.h.
#define DITHER32_INT (11*8+4*4*MAX_FILTER_SIZE*3+80) |
Definition at line 462 of file swscale_internal.h.
#define XYZ_GAMMA (2.6f) |
Definition at line 509 of file swscale_internal.h.
#define RGB_GAMMA (2.2f) |
Definition at line 510 of file swscale_internal.h.
#define FILL | ( | wfunc | ) |
#define FILL | ( | wfunc | ) |
#define MAX_SLICE_PLANES 4 |
Definition at line 959 of file swscale_internal.h.
#define MAX_LINES_AHEAD 4 |
Definition at line 1047 of file swscale_internal.h.
typedef int(* SwsFunc) (struct SwsContext *context, const uint8_t *src[], int srcStride[], int srcSliceY, int srcSliceH, uint8_t *dst[], int dstStride[]) |
Definition at line 82 of file swscale_internal.h.
typedef void(* yuv2planar1_fn) (const int16_t *src, uint8_t *dest, int dstW, const uint8_t *dither, int offset) |
Write one line of horizontally scaled data to planar output without any additional vertical scaling (or point-scaling).
src | scaled source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
dest | pointer to the output plane. For >8-bit output, this is in uint16_t |
dstW | width of destination in pixels |
dither | ordered dither array of type int16_t and size 8 |
offset | Dither offset |
Definition at line 98 of file swscale_internal.h.
typedef void(* yuv2planarX_fn) (const int16_t *filter, int filterSize, const int16_t **src, uint8_t *dest, int dstW, const uint8_t *dither, int offset) |
Write one line of horizontally scaled data to planar output with multi-point vertical scaling between input pixels.
filter | vertical luma/alpha scaling coefficients, 12 bits [0,4096] |
src | scaled luma (Y) or alpha (A) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
filterSize | number of vertical input lines to scale |
dest | pointer to output plane. For >8-bit output, this is in uint16_t |
dstW | width of destination pixels |
offset | Dither offset |
Definition at line 114 of file swscale_internal.h.
typedef void(* yuv2interleavedX_fn) (struct SwsContext *c, const int16_t *chrFilter, int chrFilterSize, const int16_t **chrUSrc, const int16_t **chrVSrc, uint8_t *dest, int dstW) |
Write one line of horizontally scaled chroma to interleaved output with multi-point vertical scaling between input pixels.
c | SWS scaling context |
chrFilter | vertical chroma scaling coefficients, 12 bits [0,4096] |
chrUSrc | scaled chroma (U) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
chrVSrc | scaled chroma (V) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
chrFilterSize | number of vertical chroma input lines to scale |
dest | pointer to the output plane. For >8-bit output, this is in uint16_t |
dstW | width of chroma planes |
Definition at line 133 of file swscale_internal.h.
typedef void(* yuv2packed1_fn) (struct SwsContext *c, const int16_t *lumSrc, const int16_t *chrUSrc[2], const int16_t *chrVSrc[2], const int16_t *alpSrc, uint8_t *dest, int dstW, int uvalpha, int y) |
Write one line of horizontally scaled Y/U/V/A to packed-pixel YUV/RGB output without any additional vertical scaling (or point-scaling).
Note that this function may do chroma scaling, see the "uvalpha" argument.
c | SWS scaling context |
lumSrc | scaled luma (Y) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
chrUSrc | scaled chroma (U) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
chrVSrc | scaled chroma (V) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
alpSrc | scaled alpha (A) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
dest | pointer to the output plane. For 16-bit output, this is uint16_t |
dstW | width of lumSrc and alpSrc in pixels, number of pixels to write into dest[] |
uvalpha | chroma scaling coefficient for the second line of chroma pixels, either 2048 or 0. If 0, one chroma input is used for 2 output pixels (or if the SWS_FLAG_FULL_CHR_INT flag is set, it generates 1 output pixel). If 2048, two chroma input pixels should be averaged for 2 output pixels (this only happens if SWS_FLAG_FULL_CHR_INT is not set) |
y | vertical line number for this output. This does not need to be used to calculate the offset in the destination, but can be used to generate comfort noise using dithering for some output formats. |
Definition at line 169 of file swscale_internal.h.
typedef void(* yuv2packed2_fn) (struct SwsContext *c, const int16_t *lumSrc[2], const int16_t *chrUSrc[2], const int16_t *chrVSrc[2], const int16_t *alpSrc[2], uint8_t *dest, int dstW, int yalpha, int uvalpha, int y) |
Write one line of horizontally scaled Y/U/V/A to packed-pixel YUV/RGB output by doing bilinear scaling between two input lines.
c | SWS scaling context |
lumSrc | scaled luma (Y) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
chrUSrc | scaled chroma (U) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
chrVSrc | scaled chroma (V) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
alpSrc | scaled alpha (A) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
dest | pointer to the output plane. For 16-bit output, this is uint16_t |
dstW | width of lumSrc and alpSrc in pixels, number of pixels to write into dest[] |
yalpha | luma/alpha scaling coefficients for the second input line. The first line's coefficients can be calculated by using 4096 - yalpha |
uvalpha | chroma scaling coefficient for the second input line. The first line's coefficients can be calculated by using 4096 - uvalpha |
y | vertical line number for this output. This does not need to be used to calculate the offset in the destination, but can be used to generate comfort noise using dithering for some output formats. |
Definition at line 202 of file swscale_internal.h.
typedef void(* yuv2packedX_fn) (struct SwsContext *c, const int16_t *lumFilter, const int16_t **lumSrc, int lumFilterSize, const int16_t *chrFilter, const int16_t **chrUSrc, const int16_t **chrVSrc, int chrFilterSize, const int16_t **alpSrc, uint8_t *dest, int dstW, int y) |
Write one line of horizontally scaled Y/U/V/A to packed-pixel YUV/RGB output by doing multi-point vertical scaling between input pixels.
c | SWS scaling context |
lumFilter | vertical luma/alpha scaling coefficients, 12 bits [0,4096] |
lumSrc | scaled luma (Y) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
lumFilterSize | number of vertical luma/alpha input lines to scale |
chrFilter | vertical chroma scaling coefficients, 12 bits [0,4096] |
chrUSrc | scaled chroma (U) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
chrVSrc | scaled chroma (V) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
chrFilterSize | number of vertical chroma input lines to scale |
alpSrc | scaled alpha (A) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
dest | pointer to the output plane. For 16-bit output, this is uint16_t |
dstW | width of lumSrc and alpSrc in pixels, number of pixels to write into dest[] |
y | vertical line number for this output. This does not need to be used to calculate the offset in the destination, but can be used to generate comfort noise using dithering or some output formats. |
Definition at line 234 of file swscale_internal.h.
typedef void(* yuv2anyX_fn) (struct SwsContext *c, const int16_t *lumFilter, const int16_t **lumSrc, int lumFilterSize, const int16_t *chrFilter, const int16_t **chrUSrc, const int16_t **chrVSrc, int chrFilterSize, const int16_t **alpSrc, uint8_t **dest, int dstW, int y) |
Write one line of horizontally scaled Y/U/V/A to YUV/RGB output by doing multi-point vertical scaling between input pixels.
c | SWS scaling context |
lumFilter | vertical luma/alpha scaling coefficients, 12 bits [0,4096] |
lumSrc | scaled luma (Y) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
lumFilterSize | number of vertical luma/alpha input lines to scale |
chrFilter | vertical chroma scaling coefficients, 12 bits [0,4096] |
chrUSrc | scaled chroma (U) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
chrVSrc | scaled chroma (V) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
chrFilterSize | number of vertical chroma input lines to scale |
alpSrc | scaled alpha (A) source data, 15 bits for 8-10-bit output, 19 bits for 16-bit output (in int32_t) |
dest | pointer to the output planes. For 16-bit output, this is uint16_t |
dstW | width of lumSrc and alpSrc in pixels, number of pixels to write into dest[] |
y | vertical line number for this output. This does not need to be used to calculate the offset in the destination, but can be used to generate comfort noise using dithering or some output formats. |
Definition at line 268 of file swscale_internal.h.
enum SwsDither |
Enumerator | |
---|---|
SWS_DITHER_NONE | |
SWS_DITHER_AUTO | |
SWS_DITHER_BAYER | |
SWS_DITHER_ED | |
SWS_DITHER_A_DITHER | |
SWS_DITHER_X_DITHER | |
NB_SWS_DITHER |
Definition at line 65 of file swscale_internal.h.
enum SwsAlphaBlend |
Enumerator | |
---|---|
SWS_ALPHA_BLEND_NONE | |
SWS_ALPHA_BLEND_UNIFORM | |
SWS_ALPHA_BLEND_CHECKERBOARD | |
SWS_ALPHA_BLEND_NB |
Definition at line 75 of file swscale_internal.h.
SwsFunc ff_yuv2rgb_get_func_ptr | ( | SwsContext * | c | ) |
Definition at line 679 of file yuv2rgb.c.
Referenced by ff_get_unscaled_swscale().
int ff_yuv2rgb_c_init_tables | ( | SwsContext * | c, |
const int | inv_table[4], | ||
int | fullRange, | ||
int | brightness, | ||
int | contrast, | ||
int | saturation | ||
) |
Definition at line 774 of file yuv2rgb.c.
Referenced by sws_setColorspaceDetails().
void ff_yuv2rgb_init_tables_ppc | ( | SwsContext * | c, |
const int | inv_table[4], | ||
int | brightness, | ||
int | contrast, | ||
int | saturation | ||
) |
Definition at line 587 of file yuv2rgb_altivec.c.
Referenced by sws_setColorspaceDetails().
void ff_updateMMXDitherTables | ( | SwsContext * | c, |
int | dstY | ||
) |
Referenced by swscale().
av_cold void ff_sws_init_range_convert | ( | SwsContext * | c | ) |
Definition at line 526 of file swscale.c.
Referenced by sws_init_swscale(), and sws_setColorspaceDetails().
SwsFunc ff_yuv2rgb_init_x86 | ( | SwsContext * | c | ) |
Definition at line 81 of file yuv2rgb.c.
Referenced by ff_yuv2rgb_get_func_ptr().
SwsFunc ff_yuv2rgb_init_ppc | ( | SwsContext * | c | ) |
Definition at line 524 of file yuv2rgb_altivec.c.
Referenced by ff_yuv2rgb_get_func_ptr().
|
static |
Definition at line 643 of file swscale_internal.h.
Referenced by ff_sws_init_output_funcs(), ff_sws_init_swscale_ppc(), ff_sws_init_swscale_vsx(), planarCopyWrapper(), rgb9plus_planar_funcs(), sws_init_context(), sws_init_swscale_TMPL(), sws_setColorspaceDetails(), and swscale().
|
static |
Definition at line 650 of file swscale_internal.h.
Referenced by swscale().
|
static |
Definition at line 657 of file swscale_internal.h.
Referenced by ff_sws_init_output_funcs(), ff_sws_init_swscale_ppc(), ff_sws_init_swscale_vsx(), planarCopyWrapper(), rgb9plus_planar_funcs(), sws_init_context(), sws_init_swscale_TMPL(), sws_setColorspaceDetails(), and swscale().
|
static |
Definition at line 664 of file swscale_internal.h.
Referenced by ff_sws_alphablendaway(), ff_sws_init_output_funcs(), ff_sws_init_swscale_vsx(), ff_sws_init_swscale_x86(), planarCopyWrapper(), rgb9plus_planar_funcs(), swscale(), yuv2gbrp16_full_X_c(), yuv2gbrp_full_X_c(), and yuv2gbrpf32_full_X_c().
|
static |
Definition at line 671 of file swscale_internal.h.
Referenced by isPlanarYUV(), and sws_setColorspaceDetails().
|
static |
Definition at line 678 of file swscale_internal.h.
Referenced by isSemiPlanarYUV().
|
static |
Definition at line 689 of file swscale_internal.h.
Referenced by ff_get_unscaled_swscale(), ff_sws_init_swscale_ppc(), ff_sws_init_swscale_vsx(), and sws_init_swscale_TMPL().
|
static |
Definition at line 696 of file swscale_internal.h.
|
static |
Definition at line 703 of file swscale_internal.h.
|
static |
Definition at line 714 of file swscale_internal.h.
Referenced by findRgbConvFn().
|
static |
Definition at line 736 of file swscale_internal.h.
Referenced by findRgbConvFn().
|
static |
Definition at line 758 of file swscale_internal.h.
Referenced by ff_get_unscaled_swscale(), sws_init_context(), and sws_scale().
|
static |
Definition at line 765 of file swscale_internal.h.
Referenced by ff_get_unscaled_swscale(), ff_sws_init_range_convert(), hScale16To15_c(), hScale16To19_c(), and sws_init_context().
|
static |
Definition at line 773 of file swscale_internal.h.
Referenced by ff_get_unscaled_swscale(), planarCopyWrapper(), and sws_init_context().
|
static |
Definition at line 780 of file swscale_internal.h.
|
static |
Definition at line 789 of file swscale_internal.h.
Referenced by ff_get_unscaled_swscale(), and swscale().
|
static |
Definition at line 798 of file swscale_internal.h.
Referenced by ff_get_unscaled_swscale(), ff_yuv2rgb_c_init_tables(), reset_ptr(), and swscale().
|
static |
Definition at line 805 of file swscale_internal.h.
Referenced by ff_get_unscaled_swscale().
|
static |
Definition at line 812 of file swscale_internal.h.
Referenced by sws_init_context().
|
static |
Definition at line 820 of file swscale_internal.h.
Referenced by ff_get_unscaled_swscale(), ff_init_filters(), palToRgbWrapper(), reset_ptr(), and sws_scale().
void ff_get_unscaled_swscale | ( | SwsContext * | c | ) |
Set c->swscale to an unscaled converter if one exists for the specific source and destination formats, bit depths, flags, etc.
Definition at line 1927 of file swscale_unscaled.c.
Referenced by sws_init_context().
void ff_get_unscaled_swscale_ppc | ( | SwsContext * | c | ) |
Definition at line 187 of file yuv2yuv_altivec.c.
Referenced by ff_get_unscaled_swscale().
void ff_get_unscaled_swscale_arm | ( | SwsContext * | c | ) |
Definition at line 183 of file swscale_unscaled.c.
Referenced by ff_get_unscaled_swscale().
void ff_get_unscaled_swscale_aarch64 | ( | SwsContext * | c | ) |
Definition at line 127 of file swscale_unscaled.c.
Referenced by ff_get_unscaled_swscale().
SwsFunc ff_getSwsFunc | ( | SwsContext * | c | ) |
Return function pointer to fastest main scaler path function depending on architecture and available optimizations.
Definition at line 583 of file swscale.c.
Referenced by check_hscale(), and sws_init_context().
void ff_sws_init_input_funcs | ( | SwsContext * | c | ) |
Referenced by sws_init_swscale().
void ff_sws_init_output_funcs | ( | SwsContext * | c, |
yuv2planar1_fn * | yuv2plane1, | ||
yuv2planarX_fn * | yuv2planeX, | ||
yuv2interleavedX_fn * | yuv2nv12cX, | ||
yuv2packed1_fn * | yuv2packed1, | ||
yuv2packed2_fn * | yuv2packed2, | ||
yuv2packedX_fn * | yuv2packedX, | ||
yuv2anyX_fn * | yuv2anyX | ||
) |
Definition at line 2533 of file output.c.
Referenced by sws_init_swscale(), and swscale().
void ff_sws_init_swscale_ppc | ( | SwsContext * | c | ) |
Definition at line 238 of file swscale_altivec.c.
Referenced by ff_getSwsFunc().
void ff_sws_init_swscale_vsx | ( | SwsContext * | c | ) |
Definition at line 2076 of file swscale_vsx.c.
Referenced by ff_sws_init_swscale_ppc().
void ff_sws_init_swscale_x86 | ( | SwsContext * | c | ) |
Definition at line 383 of file swscale.c.
Referenced by ff_getSwsFunc().
void ff_sws_init_swscale_aarch64 | ( | SwsContext * | c | ) |
Definition at line 32 of file swscale.c.
Referenced by ff_getSwsFunc().
void ff_sws_init_swscale_arm | ( | SwsContext * | c | ) |
Definition at line 32 of file swscale.c.
Referenced by ff_getSwsFunc().
void ff_hyscale_fast_c | ( | SwsContext * | c, |
int16_t * | dst, | ||
int | dstWidth, | ||
const uint8_t * | src, | ||
int | srcW, | ||
int | xInc | ||
) |
Definition at line 23 of file hscale_fast_bilinear.c.
Referenced by sws_init_swscale().
void ff_hcscale_fast_c | ( | SwsContext * | c, |
int16_t * | dst1, | ||
int16_t * | dst2, | ||
int | dstWidth, | ||
const uint8_t * | src1, | ||
const uint8_t * | src2, | ||
int | srcW, | ||
int | xInc | ||
) |
Definition at line 38 of file hscale_fast_bilinear.c.
Referenced by sws_init_swscale().
int ff_init_hscaler_mmxext | ( | int | dstW, |
int | xInc, | ||
uint8_t * | filterCode, | ||
int16_t * | filter, | ||
int32_t * | filterPos, | ||
int | numSplits | ||
) |
Referenced by sws_init_context().
void ff_hyscale_fast_mmxext | ( | SwsContext * | c, |
int16_t * | dst, | ||
int | dstWidth, | ||
const uint8_t * | src, | ||
int | srcW, | ||
int | xInc | ||
) |
Referenced by sws_init_swscale_TMPL().
void ff_hcscale_fast_mmxext | ( | SwsContext * | c, |
int16_t * | dst1, | ||
int16_t * | dst2, | ||
int | dstWidth, | ||
const uint8_t * | src1, | ||
const uint8_t * | src2, | ||
int | srcW, | ||
int | xInc | ||
) |
Referenced by sws_init_swscale_TMPL().
struct SwsContext* sws_alloc_set_opts | ( | int | srcW, |
int | srcH, | ||
enum AVPixelFormat | srcFormat, | ||
int | dstW, | ||
int | dstH, | ||
enum AVPixelFormat | dstFormat, | ||
int | flags, | ||
const double * | param | ||
) |
Allocate and return an SwsContext.
This is like sws_getContext() but does not perform the init step, allowing the user to set additional AVOptions.
Definition at line 1874 of file utils.c.
Referenced by sws_getContext(), sws_init_context(), and sws_setColorspaceDetails().
int ff_sws_alphablendaway | ( | SwsContext * | c, |
const uint8_t * | src[], | ||
int | srcStride[], | ||
int | srcSliceY, | ||
int | srcSliceH, | ||
uint8_t * | dst[], | ||
int | dstStride[] | ||
) |
Definition at line 23 of file alphablend.c.
Referenced by sws_init_context().
|
inlinestatic |
Definition at line 910 of file swscale_internal.h.
Referenced by planarCopyWrapper(), and swscale().
|
inlinestatic |
Definition at line 931 of file swscale_internal.h.
Referenced by swscale().
int ff_init_filters | ( | SwsContext * | c | ) |
Definition at line 252 of file slice.c.
Referenced by sws_init_context().
int ff_free_filters | ( | SwsContext * | c | ) |
Definition at line 386 of file slice.c.
Referenced by ff_init_filters(), sws_freeContext(), and sws_init_context().
int ff_init_gamma_convert | ( | SwsFilterDescriptor * | desc, |
SwsSlice * | src, | ||
uint16_t * | table | ||
) |
initializes gamma conversion descriptor
Definition at line 58 of file gamma.c.
Referenced by ff_init_filters().
int ff_init_desc_fmt_convert | ( | SwsFilterDescriptor * | desc, |
SwsSlice * | src, | ||
SwsSlice * | dst, | ||
uint32_t * | pal | ||
) |
initializes lum pixel format conversion descriptor
Definition at line 127 of file hscale.c.
Referenced by ff_init_filters().
int ff_init_desc_hscale | ( | SwsFilterDescriptor * | desc, |
SwsSlice * | src, | ||
SwsSlice * | dst, | ||
uint16_t * | filter, | ||
int * | filter_pos, | ||
int | filter_size, | ||
int | xInc | ||
) |
initializes lum horizontal scaling descriptor
Definition at line 144 of file hscale.c.
Referenced by ff_init_filters().
int ff_init_desc_cfmt_convert | ( | SwsFilterDescriptor * | desc, |
SwsSlice * | src, | ||
SwsSlice * | dst, | ||
uint32_t * | pal | ||
) |
initializes chr pixel format conversion descriptor
Definition at line 235 of file hscale.c.
Referenced by ff_init_filters().
int ff_init_desc_chscale | ( | SwsFilterDescriptor * | desc, |
SwsSlice * | src, | ||
SwsSlice * | dst, | ||
uint16_t * | filter, | ||
int * | filter_pos, | ||
int | filter_size, | ||
int | xInc | ||
) |
initializes chr horizontal scaling descriptor
Definition at line 250 of file hscale.c.
Referenced by ff_init_filters().
int ff_init_desc_no_chr | ( | SwsFilterDescriptor * | desc, |
SwsSlice * | src, | ||
SwsSlice * | dst | ||
) |
Definition at line 281 of file hscale.c.
Referenced by ff_init_filters().
int ff_init_vscale | ( | SwsContext * | c, |
SwsFilterDescriptor * | desc, | ||
SwsSlice * | src, | ||
SwsSlice * | dst | ||
) |
initializes vertical scaling descriptors
Definition at line 213 of file vscale.c.
Referenced by ff_init_filters().
void ff_init_vscale_pfn | ( | SwsContext * | c, |
yuv2planar1_fn | yuv2plane1, | ||
yuv2planarX_fn | yuv2planeX, | ||
yuv2interleavedX_fn | yuv2nv12cX, | ||
yuv2packed1_fn | yuv2packed1, | ||
yuv2packed2_fn | yuv2packed2, | ||
yuv2packedX_fn | yuv2packedX, | ||
yuv2anyX_fn | yuv2anyX, | ||
int | use_mmx | ||
) |
setup vertical scaler functions
Definition at line 257 of file vscale.c.
Referenced by ff_init_vscale(), and swscale().
const uint64_t ff_dither4[2] |
Definition at line 32 of file swscale.c.
Referenced by yuv420_rgb16_TMPL().
const uint64_t ff_dither8[2] |
Definition at line 36 of file swscale.c.
Referenced by yuv420_rgb15_TMPL(), and yuv420_rgb16_TMPL().
const uint8_t ff_dither_2x2_4[3][8] |
Definition at line 39 of file output.c.
Referenced by yuv2rgb_write().
const uint8_t ff_dither_2x2_8[3][8] |
Definition at line 45 of file output.c.
Referenced by yuv2rgb_write().
const uint8_t ff_dither_4x4_16[5][8] |
Definition at line 51 of file output.c.
Referenced by yuv2rgb_write().
const uint8_t ff_dither_8x8_32[9][8] |
Definition at line 59 of file output.c.
Referenced by yuv2rgb_write().
const uint8_t ff_dither_8x8_73[9][8] |
Definition at line 71 of file output.c.
Referenced by yuv2rgb_write().
const uint8_t ff_dither_8x8_128[9][8] |
const uint8_t ff_dither_8x8_220[9][8] |
Definition at line 84 of file output.c.
Referenced by yuv2mono_1_c_template(), yuv2mono_2_c_template(), yuv2mono_X_c_template(), and yuv2rgb_write().
const int32_t ff_yuv2rgb_coeffs[11][4] |
Definition at line 49 of file yuv2rgb.c.
Referenced by sws_getCoefficients(), and sws_init_context().
const AVClass ff_sws_context_class |
Definition at line 87 of file options.c.
Referenced by sws_alloc_context(), and sws_get_class().