| Line | Branch | Exec | Source |
|---|---|---|---|
| 1 | /* | ||
| 2 | * RAW H.266 / VVC video demuxer | ||
| 3 | * Copyright (c) 2020 Nuo Mi <nuomi2021@gmail.com> | ||
| 4 | * | ||
| 5 | * This file is part of FFmpeg. | ||
| 6 | * | ||
| 7 | * FFmpeg is free software; you can redistribute it and/or | ||
| 8 | * modify it under the terms of the GNU Lesser General Public | ||
| 9 | * License as published by the Free Software Foundation; either | ||
| 10 | * version 2.1 of the License, or (at your option) any later version. | ||
| 11 | * | ||
| 12 | * FFmpeg is distributed in the hope that it will be useful, | ||
| 13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| 15 | * Lesser General Public License for more details. | ||
| 16 | * | ||
| 17 | * You should have received a copy of the GNU Lesser General Public | ||
| 18 | * License along with FFmpeg; if not, write to the Free Software | ||
| 19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | ||
| 20 | */ | ||
| 21 | |||
| 22 | #include "libavcodec/vvc.h" | ||
| 23 | |||
| 24 | #include "avformat.h" | ||
| 25 | #include "rawdec.h" | ||
| 26 | |||
| 27 | 5381 | static int check_temporal_id(uint8_t nuh_temporal_id_plus1, int type) | |
| 28 | { | ||
| 29 |
2/2✓ Branch 0 taken 1446 times.
✓ Branch 1 taken 3935 times.
|
5381 | if (nuh_temporal_id_plus1 == 0) |
| 30 | 1446 | return 0; | |
| 31 | |||
| 32 |
2/2✓ Branch 0 taken 1667 times.
✓ Branch 1 taken 2268 times.
|
3935 | if (nuh_temporal_id_plus1 != 1) { |
| 33 |
4/4✓ Branch 0 taken 616 times.
✓ Branch 1 taken 1051 times.
✓ Branch 2 taken 437 times.
✓ Branch 3 taken 179 times.
|
1667 | if (type >= VVC_IDR_W_RADL && type <= VVC_RSV_IRAP_11 |
| 34 |
4/4✓ Branch 0 taken 1477 times.
✓ Branch 1 taken 11 times.
✓ Branch 2 taken 1407 times.
✓ Branch 3 taken 70 times.
|
1488 | || type == VVC_DCI_NUT || type == VVC_OPI_NUT |
| 35 |
4/4✓ Branch 0 taken 1390 times.
✓ Branch 1 taken 17 times.
✓ Branch 2 taken 1376 times.
✓ Branch 3 taken 14 times.
|
1407 | || type == VVC_VPS_NUT || type == VVC_SPS_NUT |
| 36 |
4/4✓ Branch 0 taken 1366 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 16 times.
✓ Branch 3 taken 1350 times.
|
1376 | || type == VVC_EOS_NUT || type == VVC_EOB_NUT) |
| 37 | 317 | return 0; | |
| 38 | } | ||
| 39 | |||
| 40 | 3618 | return 1; | |
| 41 | } | ||
| 42 | |||
| 43 | 7467 | static int vvc_probe(const AVProbeData *p) | |
| 44 | { | ||
| 45 | 7467 | uint32_t code = -1; | |
| 46 | 7467 | int sps = 0, pps = 0, irap = 0; | |
| 47 | 7467 | int valid_pps = 0, valid_irap = 0; | |
| 48 | int i; | ||
| 49 | |||
| 50 |
2/2✓ Branch 0 taken 339802201 times.
✓ Branch 1 taken 4712 times.
|
339806913 | for (i = 0; i < p->buf_size - 1; i++) { |
| 51 | 339802201 | code = (code << 8) + p->buf[i]; | |
| 52 |
2/2✓ Branch 0 taken 6373 times.
✓ Branch 1 taken 339795828 times.
|
339802201 | if ((code & 0xffffff00) == 0x100) { |
| 53 | 6373 | uint8_t nal2 = p->buf[i + 1]; | |
| 54 | 6373 | int type = (nal2 & 0xF8) >> 3; | |
| 55 | |||
| 56 |
2/2✓ Branch 0 taken 965 times.
✓ Branch 1 taken 5408 times.
|
6373 | if (code & 0x80) // forbidden_zero_bit |
| 57 | 965 | return 0; | |
| 58 | |||
| 59 |
2/2✓ Branch 0 taken 27 times.
✓ Branch 1 taken 5381 times.
|
5408 | if ((code & 0x3F) > 55) // nuh_layer_id must be in [0, 55] |
| 60 | 27 | return 0; | |
| 61 | |||
| 62 |
2/2✓ Branch 1 taken 1763 times.
✓ Branch 2 taken 3618 times.
|
5381 | if (!check_temporal_id(nal2 & 0x7, type)) |
| 63 | 1763 | return 0; | |
| 64 | |||
| 65 |
4/4✓ Branch 0 taken 69 times.
✓ Branch 1 taken 246 times.
✓ Branch 2 taken 74 times.
✓ Branch 3 taken 3229 times.
|
3618 | switch (type) { |
| 66 | 69 | case VVC_SPS_NUT: sps++; break; | |
| 67 | 246 | case VVC_PPS_NUT: | |
| 68 | 246 | pps++; | |
| 69 |
2/2✓ Branch 0 taken 235 times.
✓ Branch 1 taken 11 times.
|
246 | if (sps) |
| 70 | 235 | valid_pps++; | |
| 71 | 246 | break; | |
| 72 | 74 | case VVC_IDR_N_LP: | |
| 73 | case VVC_IDR_W_RADL: | ||
| 74 | case VVC_CRA_NUT: | ||
| 75 | case VVC_GDR_NUT: | ||
| 76 | 74 | irap++; | |
| 77 |
2/2✓ Branch 0 taken 70 times.
✓ Branch 1 taken 4 times.
|
74 | if (valid_pps) |
| 78 | 70 | valid_irap++; | |
| 79 | 74 | break; | |
| 80 | } | ||
| 81 | } | ||
| 82 | } | ||
| 83 | |||
| 84 |
2/2✓ Branch 0 taken 60 times.
✓ Branch 1 taken 4652 times.
|
4712 | if (valid_irap) |
| 85 | 60 | return AVPROBE_SCORE_EXTENSION + 1; // 1 more than .mpg | |
| 86 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 4650 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
4652 | if (sps && pps && irap) |
| 87 | ✗ | return AVPROBE_SCORE_EXTENSION / 2; | |
| 88 |
5/6✓ Branch 0 taken 4650 times.
✓ Branch 1 taken 2 times.
✓ Branch 2 taken 4646 times.
✓ Branch 3 taken 4 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 4646 times.
|
4652 | if (sps || pps || irap) |
| 89 | 6 | return AVPROBE_SCORE_EXTENSION / 4; | |
| 90 | 4646 | return 0; | |
| 91 | } | ||
| 92 | |||
| 93 | FF_DEF_RAWVIDEO_DEMUXER(vvc, "raw H.266/VVC video", vvc_probe, "h266,266,vvc", AV_CODEC_ID_VVC) | ||
| 94 |