Coverage Report

Created: 2026-05-31 06:50

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/ffmpeg/libswscale/ops_internal.h
Line
Count
Source
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
0
#define Q(N) ((AVRational) { N, 1 })
30
31
static inline AVRational ff_sws_pixel_expand(SwsPixelType from, SwsPixelType to)
32
0
{
33
0
    const int src = ff_sws_pixel_type_size(from);
34
0
    const int dst = ff_sws_pixel_type_size(to);
35
0
    if (src > dst)
36
0
        return Q(0);
37
0
    int scale = 1;
38
0
    for (int i = 1; i < dst / src; i++)
39
0
        scale = (scale << (src * 8)) | 1;
40
0
    return Q(scale);
41
0
}
Unexecuted instantiation: format.c:ff_sws_pixel_expand
Unexecuted instantiation: ops.c:ff_sws_pixel_expand
Unexecuted instantiation: ops_backend.c:ff_sws_pixel_expand
Unexecuted instantiation: ops_chain.c:ff_sws_pixel_expand
Unexecuted instantiation: ops_dispatch.c:ff_sws_pixel_expand
Unexecuted instantiation: ops_memcpy.c:ff_sws_pixel_expand
Unexecuted instantiation: ops_optimizer.c:ff_sws_pixel_expand
42
43
static inline void ff_sws_pack_op_decode(const SwsOp *op, uint64_t mask[4], int shift[4])
44
0
{
45
0
    int size = 0;
46
0
    for (int i = 0; i < 4; i++)
47
0
        size += op->pack.pattern[i];
48
0
    for (int i = 0; i < 4; i++) {
49
0
        const int bits = op->pack.pattern[i];
50
0
        mask[i] = (UINT64_C(1) << bits) - 1;
51
0
        shift[i] = (i ? shift[i - 1] : size) - bits;
52
0
    }
53
0
}
Unexecuted instantiation: format.c:ff_sws_pack_op_decode
Unexecuted instantiation: ops.c:ff_sws_pack_op_decode
Unexecuted instantiation: ops_backend.c:ff_sws_pack_op_decode
Unexecuted instantiation: ops_chain.c:ff_sws_pack_op_decode
Unexecuted instantiation: ops_dispatch.c:ff_sws_pack_op_decode
Unexecuted instantiation: ops_memcpy.c:ff_sws_pack_op_decode
Unexecuted instantiation: ops_optimizer.c:ff_sws_pack_op_decode
54
55
/**
56
 * "Solve" an op list into a fixed shuffle mask, with an optional ability to
57
 * also directly clear the output value (for e.g. rgb24 -> rgb0). This can
58
 * accept any operation chain that only consists of the following operations:
59
 *
60
 * - SWS_OP_READ (non-planar, non-fractional)
61
 * - SWS_OP_SWIZZLE
62
 * - SWS_OP_SWAP_BYTES
63
 * - SWS_OP_CLEAR to zero (when clear_val is specified)
64
 * - SWS_OP_CONVERT (integer expand)
65
 * - SWS_OP_WRITE (non-planar, non-fractional)
66
 *
67
 * Basically, any operation that purely consists of moving around and reordering
68
 * bytes within a single plane, can be turned into a shuffle mask.
69
 *
70
 * @param ops         The operation list to decompose.
71
 * @param shuffle     The output shuffle mask.
72
 * @param size        The size (in bytes) of the output shuffle mask.
73
 * @param clear_val   If nonzero, this index will be used to clear the output.
74
 * @param read_bytes  Returns the number of bytes read per shuffle iteration.
75
 * @param write_bytes Returns the number of bytes written per shuffle iteration.
76
 *
77
 * @return  The number of pixels processed per iteration, or a negative error
78
            code; in particular AVERROR(ENOTSUP) for unsupported operations.
79
 */
80
int ff_sws_solve_shuffle(const SwsOpList *ops, uint8_t shuffle[], int size,
81
                         uint8_t clear_val, int *read_bytes, int *write_bytes);
82
83
/**
84
 * Eliminate SWS_OP_FILTER_* operations by merging them with prior SWS_OP_READ
85
 * operations. This may require splitting the op list into multiple subpasses,
86
 * along filter boundaries. After this function, `ops` will no longer contain
87
 * bare filtering operations. The remainder, if any, is output to `out_rest`.
88
 *
89
 * Returns 0 or a negative error code.
90
 */
91
int ff_sws_op_list_subpass(SwsOpList *ops, SwsOpList **out_rest);
92
93
#endif /* SWSCALE_OPS_INTERNAL_H */