FFmpeg
Data Fields
SwsInternal Struct Reference

#include <swscale_internal.h>

Data Fields

SwsContext opts
 
SwsContextparent
 
AVSliceThreadslicethread
 
SwsContext ** slice_ctx
 
int * slice_err
 
int nb_slice_ctx
 
SwsGraphgraph [2]
 
int dst_slice_start
 
int dst_slice_height
 
SwsFunc convert_unscaled
 Note that src, dst, srcStride, dstStride will be copied in the sws_scale() wrapper so they can be freely modified here. More...
 
int chrSrcW
 Width of source chroma planes. More...
 
int chrSrcH
 Height of source chroma planes. More...
 
int chrDstW
 Width of destination chroma planes. More...
 
int chrDstH
 Height of destination chroma planes. More...
 
int lumXInc
 
int chrXInc
 
int lumYInc
 
int chrYInc
 
int dstFormatBpp
 Number of bits per pixel of the destination pixel format. More...
 
int srcFormatBpp
 Number of bits per pixel of the source pixel format. More...
 
int dstBpc
 
int srcBpc
 
int chrSrcHSubSample
 Binary logarithm of horizontal subsampling factor between luma/alpha and chroma planes in source image. More...
 
int chrSrcVSubSample
 Binary logarithm of vertical subsampling factor between luma/alpha and chroma planes in source image. More...
 
int chrDstHSubSample
 Binary logarithm of horizontal subsampling factor between luma/alpha and chroma planes in destination image. More...
 
int chrDstVSubSample
 Binary logarithm of vertical subsampling factor between luma/alpha and chroma planes in destination image. More...
 
int vChrDrop
 Binary logarithm of extra vertical subsampling factor in source image chroma planes specified by user. More...
 
int sliceDir
 Direction that slices are fed to the scaler (1 = top-to-bottom, -1 = bottom-to-top). More...
 
AVFrameframe_src
 
AVFrameframe_dst
 
RangeList src_ranges
 
SwsContextcascaded_context [3]
 
int cascaded_tmpStride [2][4]
 
uint8_t * cascaded_tmp [2][4]
 
int cascaded_mainindex
 
double gamma_value
 
int is_internal_gamma
 
uint16_t * gamma
 
uint16_t * inv_gamma
 
int numDesc
 
int descIndex [2]
 
int numSlice
 
struct SwsSliceslice
 
struct SwsFilterDescriptordesc
 
uint32_t pal_yuv [256]
 
uint32_t pal_rgb [256]
 
float uint2float_lut [256]
 
uint32_t lumConvertRange_coeff
 
uint32_t chrConvertRange_coeff
 
int64_t lumConvertRange_offset
 
int64_t chrConvertRange_offset
 
int needs_hcscale
 Set if there are chroma planes to be converted. More...
 
uint8_t * rgb0_scratch
 
unsigned int rgb0_scratch_allocated
 
uint8_t * xyz_scratch
 
unsigned int xyz_scratch_allocated
 
unsigned int dst_slice_align
 
atomic_int stride_unaligned_warned
 
atomic_int data_unaligned_warned
 
int color_conversion_warned
 
Half2FloatTablesh2f_tables
 
Scaled horizontal lines ring buffer.

The horizontal scaler keeps just enough scaled lines in a ring buffer so they may be passed to the vertical scaler.

The pointers to the allocated buffers for each line are duplicated in sequence in the ring buffer to simplify indexing and avoid wrapping around between lines inside the vertical scaler code. The wrapping is done before the vertical scaler is called.

int lastInLumBuf
 Last scaled horizontal luma/alpha line from source in the ring buffer. More...
 
int lastInChrBuf
 Last scaled horizontal chroma line from source in the ring buffer. More...
 
uint8_t * formatConvBuffer
 
int needAlpha
 
Horizontal and vertical filters.

To better understand the following fields, here is a pseudo-code of their usage in filtering a horizontal line:

for (i = 0; i < width; i++) {
dst[i] = 0;
for (j = 0; j < filterSize; j++)
dst[i] += src[ filterPos[i] + j ] * filter[ filterSize * i + j ];
dst[i] >>= FRAC_BITS; // The actual implementation is fixed-point.
}
int16_t * hLumFilter
 Array of horizontal filter coefficients for luma/alpha planes. More...
 
int16_t * hChrFilter
 Array of horizontal filter coefficients for chroma planes. More...
 
int16_t * vLumFilter
 Array of vertical filter coefficients for luma/alpha planes. More...
 
int16_t * vChrFilter
 Array of vertical filter coefficients for chroma planes. More...
 
int32_thLumFilterPos
 Array of horizontal filter starting positions for each dst[i] for luma/alpha planes. More...
 
int32_thChrFilterPos
 Array of horizontal filter starting positions for each dst[i] for chroma planes. More...
 
int32_tvLumFilterPos
 Array of vertical filter starting positions for each dst[i] for luma/alpha planes. More...
 
int32_tvChrFilterPos
 Array of vertical filter starting positions for each dst[i] for chroma planes. More...
 
int hLumFilterSize
 Horizontal filter size for luma/alpha pixels. More...
 
int hChrFilterSize
 Horizontal filter size for chroma pixels. More...
 
int vLumFilterSize
 Vertical filter size for luma/alpha pixels. More...
 
int vChrFilterSize
 Vertical filter size for chroma pixels. More...
 
int lumMmxextFilterCodeSize
 Runtime-generated MMXEXT horizontal fast bilinear scaler code size for luma/alpha planes. More...
 
int chrMmxextFilterCodeSize
 Runtime-generated MMXEXT horizontal fast bilinear scaler code size for chroma planes. More...
 
uint8_t * lumMmxextFilterCode
 Runtime-generated MMXEXT horizontal fast bilinear scaler code for luma/alpha planes. More...
 
uint8_t * chrMmxextFilterCode
 Runtime-generated MMXEXT horizontal fast bilinear scaler code for chroma planes. More...
 
int canMMXEXTBeUsed
 
int warned_unuseable_bilinear
 
int dstY
 Last destination vertical line output from last slice. More...
 
void * yuvTable
 
int table_gV [256+2 *YUVRGB_TABLE_HEADROOM]
 
uint8_t * table_rV [256+2 *YUVRGB_TABLE_HEADROOM]
 
uint8_t * table_gU [256+2 *YUVRGB_TABLE_HEADROOM]
 
uint8_t * table_bU [256+2 *YUVRGB_TABLE_HEADROOM]
 
int32_t input_rgb2yuv_table [16+40 *4]
 
int * dither_error [4]
 
int contrast
 
int brightness
 
int saturation
 
int srcColorspaceTable [4]
 
int dstColorspaceTable [4]
 
int src0Alpha
 
int dst0Alpha
 
int srcXYZ
 
int dstXYZ
 
int yuv2rgb_y_offset
 
int yuv2rgb_y_coeff
 
int yuv2rgb_v2r_coeff
 
int yuv2rgb_v2g_coeff
 
int yuv2rgb_u2g_coeff
 
int yuv2rgb_u2b_coeff
 
uint64_t redDither
 
uint64_t greenDither
 
uint64_t blueDither
 
uint64_t yCoeff
 
uint64_t vrCoeff
 
uint64_t ubCoeff
 
uint64_t vgCoeff
 
uint64_t ugCoeff
 
uint64_t yOffset
 
uint64_t uOffset
 
uint64_t vOffset
 
int32_t lumMmxFilter [4 *MAX_FILTER_SIZE]
 
int32_t chrMmxFilter [4 *MAX_FILTER_SIZE]
 
int dstW_mmx
 
uint64_t esp
 
uint64_t vRounder
 
uint64_t u_temp
 
uint64_t v_temp
 
uint64_t y_temp
 
int32_t alpMmxFilter [4 *MAX_FILTER_SIZE]
 
ptrdiff_t uv_off
 offset (in pixels) between u and v planes More...
 
ptrdiff_t uv_offx2
 offset (in bytes) between u and v planes More...
 
uint16_t dither16 [8]
 
uint32_t dither32 [8]
 
const uint8_t * chrDither8
 
const uint8_t * lumDither8
 
int use_mmx_vfilter
 
int16_t * xyzgamma
 
int16_t * rgbgamma
 
int16_t * xyzgammainv
 
int16_t * rgbgammainv
 
int16_t xyz2rgb_matrix [3][4]
 
int16_t rgb2xyz_matrix [3][4]
 
yuv2planar1_fn yuv2plane1
 
yuv2planarX_fn yuv2planeX
 
yuv2interleavedX_fn yuv2nv12cX
 
yuv2packed1_fn yuv2packed1
 
yuv2packed2_fn yuv2packed2
 
yuv2packedX_fn yuv2packedX
 
yuv2anyX_fn yuv2anyX
 
void * input_opaque
 Opaque data pointer passed to all input functions. More...
 
planar1_YV12_fn lumToYV12
 
planar1_YV12_fn alpToYV12
 
planar2_YV12_fn chrToYV12
 
planarX_YV12_fn readLumPlanar
 Functions to read planar input, such as planar RGB, and convert internally to Y/UV/A. More...
 
planarX_YV12_fn readAlpPlanar
 
planarX2_YV12_fn readChrPlanar
 
void(* hyscale_fast )(SwsInternal *c, int16_t *dst, int dstWidth, const uint8_t *src, int srcW, int xInc)
 Scale one horizontal line of input data using a bilinear filter to produce one line of output data. More...
 
void(* hcscale_fast )(SwsInternal *c, int16_t *dst1, int16_t *dst2, int dstWidth, const uint8_t *src1, const uint8_t *src2, int srcW, int xInc)
 
void(* hyScale )(SwsInternal *c, int16_t *dst, int dstW, const uint8_t *src, const int16_t *filter, const int32_t *filterPos, int filterSize)
 Scale one horizontal line of input data using a filter over the input lines, to produce one (differently sized) line of output data. More...
 
void(* hcScale )(SwsInternal *c, int16_t *dst, int dstW, const uint8_t *src, const int16_t *filter, const int32_t *filterPos, int filterSize)
 
void(* lumConvertRange )(int16_t *dst, int width, uint32_t coeff, int64_t offset)
 Color range conversion functions if needed. More...
 
void(* chrConvertRange )(int16_t *dst1, int16_t *dst2, int width, uint32_t coeff, int64_t offset)
 

Detailed Description

Definition at line 317 of file swscale_internal.h.

Field Documentation

◆ opts

SwsContext SwsInternal::opts

Definition at line 319 of file swscale_internal.h.

◆ parent

SwsContext* SwsInternal::parent

Definition at line 322 of file swscale_internal.h.

Referenced by context_init_threaded().

◆ slicethread

AVSliceThread* SwsInternal::slicethread

Definition at line 324 of file swscale_internal.h.

◆ slice_ctx

SwsContext** SwsInternal::slice_ctx

Definition at line 325 of file swscale_internal.h.

Referenced by ff_sws_slice_worker(), and slice_ctx().

◆ slice_err

int* SwsInternal::slice_err

Definition at line 326 of file swscale_internal.h.

Referenced by ff_sws_slice_worker().

◆ nb_slice_ctx

int SwsInternal::nb_slice_ctx

Definition at line 327 of file swscale_internal.h.

Referenced by slice_ctx().

◆ graph

SwsGraph* SwsInternal::graph[2]

Definition at line 330 of file swscale_internal.h.

◆ dst_slice_start

int SwsInternal::dst_slice_start

Definition at line 333 of file swscale_internal.h.

Referenced by ff_sws_slice_worker().

◆ dst_slice_height

int SwsInternal::dst_slice_height

Definition at line 334 of file swscale_internal.h.

Referenced by ff_sws_slice_worker().

◆ convert_unscaled

SwsFunc SwsInternal::convert_unscaled

Note that src, dst, srcStride, dstStride will be copied in the sws_scale() wrapper so they can be freely modified here.

Definition at line 340 of file swscale_internal.h.

◆ chrSrcW

int SwsInternal::chrSrcW

Width of source chroma planes.

Definition at line 341 of file swscale_internal.h.

◆ chrSrcH

int SwsInternal::chrSrcH

Height of source chroma planes.

Definition at line 342 of file swscale_internal.h.

◆ chrDstW

int SwsInternal::chrDstW

Width of destination chroma planes.

Definition at line 343 of file swscale_internal.h.

◆ chrDstH

int SwsInternal::chrDstH

Height of destination chroma planes.

Definition at line 344 of file swscale_internal.h.

◆ lumXInc

int SwsInternal::lumXInc

Definition at line 345 of file swscale_internal.h.

◆ chrXInc

int SwsInternal::chrXInc

Definition at line 345 of file swscale_internal.h.

◆ lumYInc

int SwsInternal::lumYInc

Definition at line 346 of file swscale_internal.h.

◆ chrYInc

int SwsInternal::chrYInc

Definition at line 346 of file swscale_internal.h.

◆ dstFormatBpp

int SwsInternal::dstFormatBpp

Number of bits per pixel of the destination pixel format.

Definition at line 347 of file swscale_internal.h.

◆ srcFormatBpp

int SwsInternal::srcFormatBpp

Number of bits per pixel of the source pixel format.

Definition at line 348 of file swscale_internal.h.

◆ dstBpc

int SwsInternal::dstBpc

Definition at line 349 of file swscale_internal.h.

◆ srcBpc

int SwsInternal::srcBpc

Definition at line 349 of file swscale_internal.h.

◆ chrSrcHSubSample

int SwsInternal::chrSrcHSubSample

Binary logarithm of horizontal subsampling factor between luma/alpha and chroma planes in source image.

Definition at line 350 of file swscale_internal.h.

◆ chrSrcVSubSample

int SwsInternal::chrSrcVSubSample

Binary logarithm of vertical subsampling factor between luma/alpha and chroma planes in source image.

Definition at line 351 of file swscale_internal.h.

◆ chrDstHSubSample

int SwsInternal::chrDstHSubSample

Binary logarithm of horizontal subsampling factor between luma/alpha and chroma planes in destination image.

Definition at line 352 of file swscale_internal.h.

◆ chrDstVSubSample

int SwsInternal::chrDstVSubSample

Binary logarithm of vertical subsampling factor between luma/alpha and chroma planes in destination image.

Definition at line 353 of file swscale_internal.h.

◆ vChrDrop

int SwsInternal::vChrDrop

Binary logarithm of extra vertical subsampling factor in source image chroma planes specified by user.

Definition at line 354 of file swscale_internal.h.

◆ sliceDir

int SwsInternal::sliceDir

Direction that slices are fed to the scaler (1 = top-to-bottom, -1 = bottom-to-top).

Definition at line 355 of file swscale_internal.h.

◆ frame_src

AVFrame* SwsInternal::frame_src

Definition at line 357 of file swscale_internal.h.

Referenced by ff_sws_slice_worker().

◆ frame_dst

AVFrame* SwsInternal::frame_dst

Definition at line 358 of file swscale_internal.h.

Referenced by ff_sws_slice_worker().

◆ src_ranges

RangeList SwsInternal::src_ranges

Definition at line 360 of file swscale_internal.h.

◆ cascaded_context

SwsContext* SwsInternal::cascaded_context[3]

Definition at line 366 of file swscale_internal.h.

◆ cascaded_tmpStride

int SwsInternal::cascaded_tmpStride[2][4]

Definition at line 367 of file swscale_internal.h.

◆ cascaded_tmp

uint8_t* SwsInternal::cascaded_tmp[2][4]

Definition at line 368 of file swscale_internal.h.

◆ cascaded_mainindex

int SwsInternal::cascaded_mainindex

Definition at line 369 of file swscale_internal.h.

◆ gamma_value

double SwsInternal::gamma_value

Definition at line 371 of file swscale_internal.h.

◆ is_internal_gamma

int SwsInternal::is_internal_gamma

Definition at line 372 of file swscale_internal.h.

◆ gamma

uint16_t* SwsInternal::gamma

Definition at line 373 of file swscale_internal.h.

◆ inv_gamma

uint16_t* SwsInternal::inv_gamma

Definition at line 374 of file swscale_internal.h.

◆ numDesc

int SwsInternal::numDesc

Definition at line 376 of file swscale_internal.h.

◆ descIndex

int SwsInternal::descIndex[2]

Definition at line 377 of file swscale_internal.h.

◆ numSlice

int SwsInternal::numSlice

Definition at line 378 of file swscale_internal.h.

◆ slice

struct SwsSlice* SwsInternal::slice

Definition at line 379 of file swscale_internal.h.

◆ desc

struct SwsFilterDescriptor* SwsInternal::desc

Definition at line 380 of file swscale_internal.h.

◆ pal_yuv

uint32_t SwsInternal::pal_yuv[256]

Definition at line 382 of file swscale_internal.h.

Referenced by slice_ctx().

◆ pal_rgb

uint32_t SwsInternal::pal_rgb[256]

Definition at line 383 of file swscale_internal.h.

Referenced by slice_ctx().

◆ uint2float_lut

float SwsInternal::uint2float_lut[256]

Definition at line 385 of file swscale_internal.h.

◆ lastInLumBuf

int SwsInternal::lastInLumBuf

Last scaled horizontal luma/alpha line from source in the ring buffer.

Definition at line 397 of file swscale_internal.h.

◆ lastInChrBuf

int SwsInternal::lastInChrBuf

Last scaled horizontal chroma line from source in the ring buffer.

Definition at line 398 of file swscale_internal.h.

◆ formatConvBuffer

uint8_t* SwsInternal::formatConvBuffer

Definition at line 401 of file swscale_internal.h.

◆ needAlpha

int SwsInternal::needAlpha

Definition at line 402 of file swscale_internal.h.

◆ hLumFilter

int16_t* SwsInternal::hLumFilter

Array of horizontal filter coefficients for luma/alpha planes.

Definition at line 418 of file swscale_internal.h.

◆ hChrFilter

int16_t* SwsInternal::hChrFilter

Array of horizontal filter coefficients for chroma planes.

Definition at line 419 of file swscale_internal.h.

◆ vLumFilter

int16_t* SwsInternal::vLumFilter

Array of vertical filter coefficients for luma/alpha planes.

Definition at line 420 of file swscale_internal.h.

◆ vChrFilter

int16_t* SwsInternal::vChrFilter

Array of vertical filter coefficients for chroma planes.

Definition at line 421 of file swscale_internal.h.

◆ hLumFilterPos

int32_t* SwsInternal::hLumFilterPos

Array of horizontal filter starting positions for each dst[i] for luma/alpha planes.

Definition at line 422 of file swscale_internal.h.

◆ hChrFilterPos

int32_t* SwsInternal::hChrFilterPos

Array of horizontal filter starting positions for each dst[i] for chroma planes.

Definition at line 423 of file swscale_internal.h.

◆ vLumFilterPos

int32_t* SwsInternal::vLumFilterPos

Array of vertical filter starting positions for each dst[i] for luma/alpha planes.

Definition at line 424 of file swscale_internal.h.

◆ vChrFilterPos

int32_t* SwsInternal::vChrFilterPos

Array of vertical filter starting positions for each dst[i] for chroma planes.

Definition at line 425 of file swscale_internal.h.

◆ hLumFilterSize

int SwsInternal::hLumFilterSize

Horizontal filter size for luma/alpha pixels.

Definition at line 426 of file swscale_internal.h.

◆ hChrFilterSize

int SwsInternal::hChrFilterSize

Horizontal filter size for chroma pixels.

Definition at line 427 of file swscale_internal.h.

◆ vLumFilterSize

int SwsInternal::vLumFilterSize

Vertical filter size for luma/alpha pixels.

Definition at line 428 of file swscale_internal.h.

◆ vChrFilterSize

int SwsInternal::vChrFilterSize

Vertical filter size for chroma pixels.

Definition at line 429 of file swscale_internal.h.

◆ lumMmxextFilterCodeSize

int SwsInternal::lumMmxextFilterCodeSize

Runtime-generated MMXEXT horizontal fast bilinear scaler code size for luma/alpha planes.

Definition at line 432 of file swscale_internal.h.

◆ chrMmxextFilterCodeSize

int SwsInternal::chrMmxextFilterCodeSize

Runtime-generated MMXEXT horizontal fast bilinear scaler code size for chroma planes.

Definition at line 433 of file swscale_internal.h.

◆ lumMmxextFilterCode

uint8_t* SwsInternal::lumMmxextFilterCode

Runtime-generated MMXEXT horizontal fast bilinear scaler code for luma/alpha planes.

Definition at line 434 of file swscale_internal.h.

◆ chrMmxextFilterCode

uint8_t* SwsInternal::chrMmxextFilterCode

Runtime-generated MMXEXT horizontal fast bilinear scaler code for chroma planes.

Definition at line 435 of file swscale_internal.h.

◆ canMMXEXTBeUsed

int SwsInternal::canMMXEXTBeUsed

Definition at line 437 of file swscale_internal.h.

◆ warned_unuseable_bilinear

int SwsInternal::warned_unuseable_bilinear

Definition at line 438 of file swscale_internal.h.

◆ dstY

int SwsInternal::dstY

Last destination vertical line output from last slice.

Definition at line 440 of file swscale_internal.h.

Referenced by scale_gamma().

◆ yuvTable

void* SwsInternal::yuvTable

Definition at line 441 of file swscale_internal.h.

◆ table_gV

int SwsInternal::table_gV[256+2 *YUVRGB_TABLE_HEADROOM]

Definition at line 444 of file swscale_internal.h.

◆ table_rV

uint8_t* SwsInternal::table_rV[256+2 *YUVRGB_TABLE_HEADROOM]

Definition at line 445 of file swscale_internal.h.

◆ table_gU

uint8_t* SwsInternal::table_gU[256+2 *YUVRGB_TABLE_HEADROOM]

Definition at line 446 of file swscale_internal.h.

◆ table_bU

uint8_t* SwsInternal::table_bU[256+2 *YUVRGB_TABLE_HEADROOM]

Definition at line 447 of file swscale_internal.h.

◆ input_rgb2yuv_table

int32_t SwsInternal::input_rgb2yuv_table[16+40 *4]

Definition at line 448 of file swscale_internal.h.

◆ dither_error

int* SwsInternal::dither_error[4]

Definition at line 460 of file swscale_internal.h.

◆ contrast

int SwsInternal::contrast

Definition at line 463 of file swscale_internal.h.

◆ brightness

int SwsInternal::brightness

Definition at line 463 of file swscale_internal.h.

◆ saturation

int SwsInternal::saturation

Definition at line 463 of file swscale_internal.h.

◆ srcColorspaceTable

int SwsInternal::srcColorspaceTable[4]

Definition at line 464 of file swscale_internal.h.

◆ dstColorspaceTable

int SwsInternal::dstColorspaceTable[4]

Definition at line 465 of file swscale_internal.h.

◆ src0Alpha

int SwsInternal::src0Alpha

Definition at line 466 of file swscale_internal.h.

◆ dst0Alpha

int SwsInternal::dst0Alpha

Definition at line 467 of file swscale_internal.h.

◆ srcXYZ

int SwsInternal::srcXYZ

Definition at line 468 of file swscale_internal.h.

◆ dstXYZ

int SwsInternal::dstXYZ

Definition at line 469 of file swscale_internal.h.

◆ yuv2rgb_y_offset

int SwsInternal::yuv2rgb_y_offset

Definition at line 470 of file swscale_internal.h.

◆ yuv2rgb_y_coeff

int SwsInternal::yuv2rgb_y_coeff

Definition at line 471 of file swscale_internal.h.

◆ yuv2rgb_v2r_coeff

int SwsInternal::yuv2rgb_v2r_coeff

Definition at line 472 of file swscale_internal.h.

◆ yuv2rgb_v2g_coeff

int SwsInternal::yuv2rgb_v2g_coeff

Definition at line 473 of file swscale_internal.h.

◆ yuv2rgb_u2g_coeff

int SwsInternal::yuv2rgb_u2g_coeff

Definition at line 474 of file swscale_internal.h.

◆ yuv2rgb_u2b_coeff

int SwsInternal::yuv2rgb_u2b_coeff

Definition at line 475 of file swscale_internal.h.

◆ redDither

uint64_t SwsInternal::redDither

Definition at line 503 of file swscale_internal.h.

◆ greenDither

uint64_t SwsInternal::greenDither

Definition at line 504 of file swscale_internal.h.

◆ blueDither

uint64_t SwsInternal::blueDither

Definition at line 505 of file swscale_internal.h.

◆ yCoeff

uint64_t SwsInternal::yCoeff

Definition at line 507 of file swscale_internal.h.

◆ vrCoeff

uint64_t SwsInternal::vrCoeff

Definition at line 508 of file swscale_internal.h.

◆ ubCoeff

uint64_t SwsInternal::ubCoeff

Definition at line 509 of file swscale_internal.h.

◆ vgCoeff

uint64_t SwsInternal::vgCoeff

Definition at line 510 of file swscale_internal.h.

◆ ugCoeff

uint64_t SwsInternal::ugCoeff

Definition at line 511 of file swscale_internal.h.

◆ yOffset

uint64_t SwsInternal::yOffset

Definition at line 512 of file swscale_internal.h.

◆ uOffset

uint64_t SwsInternal::uOffset

Definition at line 513 of file swscale_internal.h.

◆ vOffset

uint64_t SwsInternal::vOffset

Definition at line 514 of file swscale_internal.h.

◆ lumMmxFilter

int32_t SwsInternal::lumMmxFilter[4 *MAX_FILTER_SIZE]

Definition at line 515 of file swscale_internal.h.

◆ chrMmxFilter

int32_t SwsInternal::chrMmxFilter[4 *MAX_FILTER_SIZE]

Definition at line 516 of file swscale_internal.h.

◆ dstW_mmx

int SwsInternal::dstW_mmx

Definition at line 517 of file swscale_internal.h.

◆ esp

uint64_t SwsInternal::esp

Definition at line 518 of file swscale_internal.h.

◆ vRounder

uint64_t SwsInternal::vRounder

Definition at line 519 of file swscale_internal.h.

◆ u_temp

uint64_t SwsInternal::u_temp

Definition at line 520 of file swscale_internal.h.

◆ v_temp

uint64_t SwsInternal::v_temp

Definition at line 521 of file swscale_internal.h.

◆ y_temp

uint64_t SwsInternal::y_temp

Definition at line 522 of file swscale_internal.h.

◆ alpMmxFilter

int32_t SwsInternal::alpMmxFilter[4 *MAX_FILTER_SIZE]

Definition at line 523 of file swscale_internal.h.

◆ uv_off

ptrdiff_t SwsInternal::uv_off

offset (in pixels) between u and v planes

Definition at line 527 of file swscale_internal.h.

◆ uv_offx2

ptrdiff_t SwsInternal::uv_offx2

offset (in bytes) between u and v planes

Definition at line 528 of file swscale_internal.h.

◆ dither16

uint16_t SwsInternal::dither16[8]

Definition at line 529 of file swscale_internal.h.

◆ dither32

uint32_t SwsInternal::dither32[8]

Definition at line 530 of file swscale_internal.h.

◆ chrDither8

const uint8_t* SwsInternal::chrDither8

Definition at line 532 of file swscale_internal.h.

◆ lumDither8

const uint8_t * SwsInternal::lumDither8

Definition at line 532 of file swscale_internal.h.

◆ use_mmx_vfilter

int SwsInternal::use_mmx_vfilter

Definition at line 545 of file swscale_internal.h.

◆ xyzgamma

int16_t* SwsInternal::xyzgamma

Definition at line 550 of file swscale_internal.h.

◆ rgbgamma

int16_t* SwsInternal::rgbgamma

Definition at line 551 of file swscale_internal.h.

◆ xyzgammainv

int16_t* SwsInternal::xyzgammainv

Definition at line 552 of file swscale_internal.h.

◆ rgbgammainv

int16_t* SwsInternal::rgbgammainv

Definition at line 553 of file swscale_internal.h.

◆ xyz2rgb_matrix

int16_t SwsInternal::xyz2rgb_matrix[3][4]

Definition at line 554 of file swscale_internal.h.

◆ rgb2xyz_matrix

int16_t SwsInternal::rgb2xyz_matrix[3][4]

Definition at line 555 of file swscale_internal.h.

◆ yuv2plane1

yuv2planar1_fn SwsInternal::yuv2plane1

Definition at line 558 of file swscale_internal.h.

◆ yuv2planeX

yuv2planarX_fn SwsInternal::yuv2planeX

Definition at line 559 of file swscale_internal.h.

◆ yuv2nv12cX

yuv2interleavedX_fn SwsInternal::yuv2nv12cX

Definition at line 560 of file swscale_internal.h.

◆ yuv2packed1

yuv2packed1_fn SwsInternal::yuv2packed1

Definition at line 561 of file swscale_internal.h.

◆ yuv2packed2

yuv2packed2_fn SwsInternal::yuv2packed2

Definition at line 562 of file swscale_internal.h.

◆ yuv2packedX

yuv2packedX_fn SwsInternal::yuv2packedX

Definition at line 563 of file swscale_internal.h.

◆ yuv2anyX

yuv2anyX_fn SwsInternal::yuv2anyX

Definition at line 564 of file swscale_internal.h.

◆ input_opaque

void* SwsInternal::input_opaque

Opaque data pointer passed to all input functions.

Definition at line 567 of file swscale_internal.h.

◆ lumToYV12

planar1_YV12_fn SwsInternal::lumToYV12

Definition at line 569 of file swscale_internal.h.

◆ alpToYV12

planar1_YV12_fn SwsInternal::alpToYV12

Definition at line 570 of file swscale_internal.h.

◆ chrToYV12

planar2_YV12_fn SwsInternal::chrToYV12

Definition at line 571 of file swscale_internal.h.

◆ readLumPlanar

planarX_YV12_fn SwsInternal::readLumPlanar

Functions to read planar input, such as planar RGB, and convert internally to Y/UV/A.

Definition at line 578 of file swscale_internal.h.

◆ readAlpPlanar

planarX_YV12_fn SwsInternal::readAlpPlanar

Definition at line 579 of file swscale_internal.h.

◆ readChrPlanar

planarX2_YV12_fn SwsInternal::readChrPlanar

Definition at line 580 of file swscale_internal.h.

◆ hyscale_fast

void(* SwsInternal::hyscale_fast) (SwsInternal *c, int16_t *dst, int dstWidth, const uint8_t *src, int srcW, int xInc)

Scale one horizontal line of input data using a bilinear filter to produce one line of output data.

Compared to SwsInternal->hScale(), please take note of the following caveats when using these:

  • Scaling is done using only 7 bits instead of 14-bit coefficients.
  • You can use no more than 5 input pixels to produce 4 output pixels. Therefore, this filter should not be used for downscaling by more than ~20% in width (because that equals more than 5/4th downscaling and thus more than 5 pixels input per 4 pixels output).
  • In general, bilinear filters create artifacts during downscaling (even when <20%), because one output pixel will span more than one input pixel, and thus some pixels will need edges of both neighbor pixels to interpolate the output pixel. Since you can use at most two input pixels per output pixel in bilinear scaling, this is impossible and thus downscaling by any size will create artifacts. To enable this type of scaling, set SWS_FLAG_FAST_BILINEAR in SwsInternal->flags.

Definition at line 602 of file swscale_internal.h.

◆ hcscale_fast

void(* SwsInternal::hcscale_fast) (SwsInternal *c, int16_t *dst1, int16_t *dst2, int dstWidth, const uint8_t *src1, const uint8_t *src2, int srcW, int xInc)

Definition at line 605 of file swscale_internal.h.

◆ hyScale

void(* SwsInternal::hyScale) (SwsInternal *c, int16_t *dst, int dstW, const uint8_t *src, const int16_t *filter, const int32_t *filterPos, int filterSize)

Scale one horizontal line of input data using a filter over the input lines, to produce one (differently sized) line of output data.

Parameters
dstpointer to destination buffer for horizontally scaled data. If the number of bits per component of one destination pixel (SwsInternal->dstBpc) is <= 10, data will be 15 bpc in 16 bits (int16_t) width. Else (i.e. SwsInternal->dstBpc == 16), data will be 19bpc in 32 bits (int32_t) width.
dstWwidth of destination image
srcpointer to source data to be scaled. If the number of bits per component of a source pixel (SwsInternal->srcBpc) is 8, this is 8bpc in 8 bits (uint8_t) width. Else (i.e. SwsInternal->dstBpc > 8), this is native depth in 16 bits (uint16_t) width. In other words, for 9-bit YUV input, this is 9bpc, for 10-bit YUV input, this is 10bpc, and for 16-bit RGB or YUV, this is 16bpc.
filterfilter coefficients to be used per output pixel for scaling. This contains 14bpp filtering coefficients. Guaranteed to contain dstW * filterSize entries.
filterPosposition of the first input pixel to be used for each output pixel during scaling. Guaranteed to contain dstW entries.
filterSizethe number of input coefficients to be used (and thus the number of input pixels to be used) for creating a single output pixel. Is aligned to 4 (and input coefficients thus padded with zeroes) to simplify creating SIMD code.

Definition at line 642 of file swscale_internal.h.

◆ hcScale

void(* SwsInternal::hcScale) (SwsInternal *c, int16_t *dst, int dstW, const uint8_t *src, const int16_t *filter, const int32_t *filterPos, int filterSize)

Definition at line 645 of file swscale_internal.h.

◆ lumConvertRange

void(* SwsInternal::lumConvertRange) (int16_t *dst, int width, uint32_t coeff, int64_t offset)

Color range conversion functions if needed.

If SwsInternal->dstBpc is > 14:

  • int16_t *dst (data is 15 bpc)
  • uint16_t coeff
  • int32_t offset Otherwise (SwsInternal->dstBpc is <= 14):
  • int32_t *dst (data is 19 bpc)
  • uint32_t coeff
  • int64_t offset

Definition at line 662 of file swscale_internal.h.

◆ chrConvertRange

void(* SwsInternal::chrConvertRange) (int16_t *dst1, int16_t *dst2, int width, uint32_t coeff, int64_t offset)

Definition at line 664 of file swscale_internal.h.

◆ lumConvertRange_coeff

uint32_t SwsInternal::lumConvertRange_coeff

Definition at line 668 of file swscale_internal.h.

◆ chrConvertRange_coeff

uint32_t SwsInternal::chrConvertRange_coeff

Definition at line 669 of file swscale_internal.h.

◆ lumConvertRange_offset

int64_t SwsInternal::lumConvertRange_offset

Definition at line 670 of file swscale_internal.h.

◆ chrConvertRange_offset

int64_t SwsInternal::chrConvertRange_offset

Definition at line 671 of file swscale_internal.h.

◆ needs_hcscale

int SwsInternal::needs_hcscale

Set if there are chroma planes to be converted.

Definition at line 673 of file swscale_internal.h.

◆ rgb0_scratch

uint8_t* SwsInternal::rgb0_scratch

Definition at line 678 of file swscale_internal.h.

◆ rgb0_scratch_allocated

unsigned int SwsInternal::rgb0_scratch_allocated

Definition at line 679 of file swscale_internal.h.

◆ xyz_scratch

uint8_t* SwsInternal::xyz_scratch

Definition at line 684 of file swscale_internal.h.

◆ xyz_scratch_allocated

unsigned int SwsInternal::xyz_scratch_allocated

Definition at line 685 of file swscale_internal.h.

◆ dst_slice_align

unsigned int SwsInternal::dst_slice_align

Definition at line 687 of file swscale_internal.h.

Referenced by sws_receive_slice_alignment().

◆ stride_unaligned_warned

atomic_int SwsInternal::stride_unaligned_warned

Definition at line 688 of file swscale_internal.h.

◆ data_unaligned_warned

atomic_int SwsInternal::data_unaligned_warned

Definition at line 689 of file swscale_internal.h.

◆ color_conversion_warned

int SwsInternal::color_conversion_warned

Definition at line 690 of file swscale_internal.h.

◆ h2f_tables

Half2FloatTables* SwsInternal::h2f_tables

Definition at line 692 of file swscale_internal.h.


The documentation for this struct was generated from the following file:
filter
void(* filter)(uint8_t *src, int stride, int qscale)
Definition: h263dsp.c:29
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:83
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:256
FRAC_BITS
#define FRAC_BITS
Definition: g729postfilter.c:36
width
#define width
Definition: dsp.h:85
src
#define src
Definition: vp8dsp.c:248