FFmpeg
ops_internal.h
Go to the documentation of this file.
1 /**
2  * Copyright (C) 2025 Niklas Haas
3  *
4  * This file is part of FFmpeg.
5  *
6  * FFmpeg is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * FFmpeg is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with FFmpeg; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20 
21 #ifndef SWSCALE_OPS_INTERNAL_H
22 #define SWSCALE_OPS_INTERNAL_H
23 
24 #include "libavutil/mem_internal.h"
25 
26 #include "ops.h"
27 #include "ops_dispatch.h"
28 
29 #define Q(N) ((AVRational) { N, 1 })
30 
32 {
33  const int src = ff_sws_pixel_type_size(from);
34  const int dst = ff_sws_pixel_type_size(to);
35  if (src > dst)
36  return Q(0);
37  int scale = 1;
38  for (int i = 1; i < dst / src; i++)
39  scale = (scale << (src * 8)) | 1;
40  return Q(scale);
41 }
42 
43 static inline void ff_sws_pack_op_decode(const SwsOp *op, uint64_t mask[4], int shift[4])
44 {
45  int size = 0;
46  for (int i = 0; i < 4; i++)
47  size += op->pack.pattern[i];
48  for (int i = 0; i < 4; i++) {
49  const int bits = op->pack.pattern[i];
50  mask[i] = (UINT64_C(1) << bits) - 1;
51  shift[i] = (i ? shift[i - 1] : size) - bits;
52  }
53 }
54 
55 typedef struct SwsOpBackend {
56  const char *name; /* Descriptive name for this backend */
57 
58  /**
59  * Compile an operation list to an implementation chain. May modify `ops`
60  * freely; the original list will be freed automatically by the caller.
61  *
62  * Returns 0 or a negative error code.
63  */
65 
66  /**
67  * If NONE, backend only supports software frames.
68  * Otherwise, frame hardware format must match hw_format for the backend
69  * to be used.
70  */
72 } SwsOpBackend;
73 
74 /* List of all backends, terminated by NULL */
75 extern const SwsOpBackend *const ff_sws_op_backends[];
76 
77 /**
78  * Attempt to compile a list of operations using a specific backend.
79  *
80  * Returns 0 on success, or a negative error code on failure.
81  */
83  const SwsOpList *ops, SwsCompiledOp *out);
84 
85 /**
86  * Compile a list of operations using the best available backend.
87  *
88  * Returns 0 on success, or a negative error code on failure.
89  */
91 
92 /**
93  * "Solve" an op list into a fixed shuffle mask, with an optional ability to
94  * also directly clear the output value (for e.g. rgb24 -> rgb0). This can
95  * accept any operation chain that only consists of the following operations:
96  *
97  * - SWS_OP_READ (non-planar, non-fractional)
98  * - SWS_OP_SWIZZLE
99  * - SWS_OP_SWAP_BYTES
100  * - SWS_OP_CLEAR to zero (when clear_val is specified)
101  * - SWS_OP_CONVERT (integer expand)
102  * - SWS_OP_WRITE (non-planar, non-fractional)
103  *
104  * Basically, any operation that purely consists of moving around and reordering
105  * bytes within a single plane, can be turned into a shuffle mask.
106  *
107  * @param ops The operation list to decompose.
108  * @param shuffle The output shuffle mask.
109  * @param size The size (in bytes) of the output shuffle mask.
110  * @param clear_val If nonzero, this index will be used to clear the output.
111  * @param read_bytes Returns the number of bytes read per shuffle iteration.
112  * @param write_bytes Returns the number of bytes written per shuffle iteration.
113  *
114  * @return The number of pixels processed per iteration, or a negative error
115  code; in particular AVERROR(ENOTSUP) for unsupported operations.
116  */
117 int ff_sws_solve_shuffle(const SwsOpList *ops, uint8_t shuffle[], int size,
118  uint8_t clear_val, int *read_bytes, int *write_bytes);
119 
120 #endif /* SWSCALE_OPS_INTERNAL_H */
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:71
mem_internal.h
out
static FILE * out
Definition: movenc.c:55
mask
int mask
Definition: mediacodecdec_common.c:154
ops.h
read_bytes
static void read_bytes(const uint8_t *src, float *dst, int src_stride, int dst_stride, int width, int height, float scale)
Definition: vf_nnedi.c:442
Q
#define Q(N)
Copyright (C) 2025 Niklas Haas.
Definition: ops_internal.h:29
ops_dispatch.h
SwsOpBackend::name
const char * name
Definition: ops_internal.h:56
ff_sws_pixel_type_size
int ff_sws_pixel_type_size(SwsPixelType type)
Definition: ops.c:63
SwsPixelType
SwsPixelType
Copyright (C) 2025 Niklas Haas.
Definition: ops.h:30
ff_sws_op_backends
const SwsOpBackend *const ff_sws_op_backends[]
Definition: ops.c:36
SwsOpBackend::compile
int(* compile)(SwsContext *ctx, SwsOpList *ops, SwsCompiledOp *out)
Compile an operation list to an implementation chain.
Definition: ops_internal.h:64
SwsOpBackend::hw_format
enum AVPixelFormat hw_format
If NONE, backend only supports software frames.
Definition: ops_internal.h:71
ff_sws_ops_compile_backend
int ff_sws_ops_compile_backend(SwsContext *ctx, const SwsOpBackend *backend, const SwsOpList *ops, SwsCompiledOp *out)
Attempt to compile a list of operations using a specific backend.
Definition: ops_dispatch.c:47
op
static int op(uint8_t **dst, const uint8_t *dst_end, GetByteContext *gb, int pixel, int count, int *x, int width, int linesize)
Perform decode operation.
Definition: anm.c:76
bits
uint8_t bits
Definition: vp3data.h:128
from
const char * from
Definition: jacosubdec.c:64
ctx
static AVFormatContext * ctx
Definition: movenc.c:49
ff_sws_pixel_expand
static AVRational ff_sws_pixel_expand(SwsPixelType from, SwsPixelType to)
Definition: ops_internal.h:31
SwsOpBackend
Definition: ops_internal.h:55
AVRational
Rational number (pair of numerator and denominator).
Definition: rational.h:58
to
const char * to
Definition: webvttdec.c:35
shift
static int shift(int a, int b)
Definition: bonk.c:261
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:87
i
#define i(width, name, range_min, range_max)
Definition: cbs_h264.c:63
for
for(k=2;k<=8;++k)
Definition: h264pred_template.c:424
size
int size
Definition: twinvq_data.h:10344
ff_sws_ops_compile
int ff_sws_ops_compile(SwsContext *ctx, const SwsOpList *ops, SwsCompiledOp *out)
Compile a list of operations using the best available backend.
Definition: ops_dispatch.c:74
SwsOp
Definition: ops.h:188
write_bytes
static void write_bytes(const float *src, uint8_t *dst, int src_stride, int dst_stride, int width, int height, int depth, float scale)
Definition: vf_nnedi.c:484
SwsCompiledOp
Definition: ops_dispatch.h:75
ff_sws_solve_shuffle
int ff_sws_solve_shuffle(const SwsOpList *ops, uint8_t shuffle[], int size, uint8_t clear_val, int *read_bytes, int *write_bytes)
"Solve" an op list into a fixed shuffle mask, with an optional ability to also directly clear the out...
Definition: ops_optimizer.c:686
scale
static void scale(int *out, const int *in, const int w, const int h, const int shift)
Definition: intra.c:278
ff_sws_pack_op_decode
static void ff_sws_pack_op_decode(const SwsOp *op, uint64_t mask[4], int shift[4])
Definition: ops_internal.h:43
SwsOpList
Helper struct for representing a list of operations.
Definition: ops.h:224
SwsContext
Main external API structure.
Definition: swscale.h:191
shuffle
static uint64_t shuffle(uint64_t in, const uint8_t *shuffle, int shuffle_len)
Definition: des.c:179
src
#define src
Definition: vp8dsp.c:248