FFmpeg coverage


Directory: ../../../ffmpeg/
File: src/libavfilter/vf_blackdetect.h
Date: 2026-04-29 00:23:12
Exec Total Coverage
Lines: 20 20 100.0%
Functions: 3 3 100.0%
Branches: 12 12 100.0%

Line Branch Exec Source
1 /*
2 * This file is part of FFmpeg.
3 *
4 * FFmpeg is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
8 *
9 * FFmpeg is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
13 *
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with FFmpeg; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 */
18
19 #ifndef AVFILTER_BLACKDETECT_H
20 #define AVFILTER_BLACKDETECT_H
21
22 #include <stddef.h>
23 #include <stdint.h>
24
25 #include "config.h"
26
27 typedef unsigned (*ff_blackdetect_fn)(const uint8_t *src, ptrdiff_t stride,
28 ptrdiff_t width, ptrdiff_t height,
29 unsigned threshold);
30
31 ff_blackdetect_fn ff_blackdetect_get_fn_riscv(int depth);
32 ff_blackdetect_fn ff_blackdetect_get_fn_x86(int depth);
33
34 3 static unsigned count_pixels8_c(const uint8_t *src, ptrdiff_t stride,
35 ptrdiff_t width, ptrdiff_t height,
36 unsigned threshold)
37 {
38 3 unsigned int counter = 0;
39
2/2
✓ Branch 0 taken 48 times.
✓ Branch 1 taken 3 times.
51 while (height--) {
40
2/2
✓ Branch 0 taken 11904 times.
✓ Branch 1 taken 48 times.
11952 for (int x = 0; x < width; x++)
41 11904 counter += src[x] <= threshold;
42 48 src += stride;
43 }
44 3 return counter;
45 }
46
47 3 static unsigned count_pixels16_c(const uint8_t *src, ptrdiff_t stride,
48 ptrdiff_t width, ptrdiff_t height,
49 unsigned threshold)
50 {
51 3 unsigned int counter = 0;
52
2/2
✓ Branch 0 taken 48 times.
✓ Branch 1 taken 3 times.
51 while (height--) {
53 48 const uint16_t *src16 = (const uint16_t *) src;
54
2/2
✓ Branch 0 taken 5760 times.
✓ Branch 1 taken 48 times.
5808 for (int x = 0; x < width; x++)
55 5760 counter += src16[x] <= threshold;
56 48 src += stride;
57 }
58 3 return counter;
59 }
60
61
62 28 static inline ff_blackdetect_fn ff_blackdetect_get_fn(int depth)
63 {
64 ff_blackdetect_fn fn;
65
66 #if ARCH_RISCV
67 fn = ff_blackdetect_get_fn_riscv(depth);
68 #elif ARCH_X86 && HAVE_X86ASM
69 28 fn = ff_blackdetect_get_fn_x86(depth);
70 #else
71 fn = NULL;
72 #endif
73
74
2/2
✓ Branch 0 taken 26 times.
✓ Branch 1 taken 2 times.
28 if (!fn)
75
2/2
✓ Branch 0 taken 13 times.
✓ Branch 1 taken 13 times.
26 fn = depth == 8 ? count_pixels8_c : count_pixels16_c;
76 28 return fn;
77 }
78
79 #endif /* AVFILTER_BLACKDETECT_H */
80