| 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 | 5386 | static int check_temporal_id(uint8_t nuh_temporal_id_plus1, int type) | |
| 28 | { | ||
| 29 |
2/2✓ Branch 0 taken 1441 times.
✓ Branch 1 taken 3945 times.
|
5386 | if (nuh_temporal_id_plus1 == 0) |
| 30 | 1441 | return 0; | |
| 31 | |||
| 32 |
2/2✓ Branch 0 taken 1677 times.
✓ Branch 1 taken 2268 times.
|
3945 | if (nuh_temporal_id_plus1 != 1) { |
| 33 |
4/4✓ Branch 0 taken 613 times.
✓ Branch 1 taken 1064 times.
✓ Branch 2 taken 434 times.
✓ Branch 3 taken 179 times.
|
1677 | if (type >= VVC_IDR_W_RADL && type <= VVC_RSV_IRAP_11 |
| 34 |
4/4✓ Branch 0 taken 1487 times.
✓ Branch 1 taken 11 times.
✓ Branch 2 taken 1419 times.
✓ Branch 3 taken 68 times.
|
1498 | || type == VVC_DCI_NUT || type == VVC_OPI_NUT |
| 35 |
4/4✓ Branch 0 taken 1402 times.
✓ Branch 1 taken 17 times.
✓ Branch 2 taken 1388 times.
✓ Branch 3 taken 14 times.
|
1419 | || type == VVC_VPS_NUT || type == VVC_SPS_NUT |
| 36 |
4/4✓ Branch 0 taken 1380 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 16 times.
✓ Branch 3 taken 1364 times.
|
1388 | || type == VVC_EOS_NUT || type == VVC_EOB_NUT) |
| 37 | 313 | return 0; | |
| 38 | } | ||
| 39 | |||
| 40 | 3632 | return 1; | |
| 41 | } | ||
| 42 | |||
| 43 | 7282 | static int vvc_probe(const AVProbeData *p) | |
| 44 | { | ||
| 45 | 7282 | uint32_t code = -1; | |
| 46 | 7282 | int sps = 0, pps = 0, irap = 0; | |
| 47 | 7282 | int valid_pps = 0, valid_irap = 0; | |
| 48 | int i; | ||
| 49 | |||
| 50 |
2/2✓ Branch 0 taken 316347109 times.
✓ Branch 1 taken 4587 times.
|
316351696 | for (i = 0; i < p->buf_size - 1; i++) { |
| 51 | 316347109 | code = (code << 8) + p->buf[i]; | |
| 52 |
2/2✓ Branch 0 taken 6327 times.
✓ Branch 1 taken 316340782 times.
|
316347109 | if ((code & 0xffffff00) == 0x100) { |
| 53 | 6327 | uint8_t nal2 = p->buf[i + 1]; | |
| 54 | 6327 | int type = (nal2 & 0xF8) >> 3; | |
| 55 | |||
| 56 |
2/2✓ Branch 0 taken 941 times.
✓ Branch 1 taken 5386 times.
|
6327 | if (code & 0x80) // forbidden_zero_bit |
| 57 | 941 | return 0; | |
| 58 | |||
| 59 |
2/2✓ Branch 1 taken 1754 times.
✓ Branch 2 taken 3632 times.
|
5386 | if (!check_temporal_id(nal2 & 0x7, type)) |
| 60 | 1754 | return 0; | |
| 61 | |||
| 62 |
4/4✓ Branch 0 taken 69 times.
✓ Branch 1 taken 246 times.
✓ Branch 2 taken 75 times.
✓ Branch 3 taken 3242 times.
|
3632 | switch (type) { |
| 63 | 69 | case VVC_SPS_NUT: sps++; break; | |
| 64 | 246 | case VVC_PPS_NUT: | |
| 65 | 246 | pps++; | |
| 66 |
2/2✓ Branch 0 taken 235 times.
✓ Branch 1 taken 11 times.
|
246 | if (sps) |
| 67 | 235 | valid_pps++; | |
| 68 | 246 | break; | |
| 69 | 75 | case VVC_IDR_N_LP: | |
| 70 | case VVC_IDR_W_RADL: | ||
| 71 | case VVC_CRA_NUT: | ||
| 72 | case VVC_GDR_NUT: | ||
| 73 | 75 | irap++; | |
| 74 |
2/2✓ Branch 0 taken 70 times.
✓ Branch 1 taken 5 times.
|
75 | if (valid_pps) |
| 75 | 70 | valid_irap++; | |
| 76 | 75 | break; | |
| 77 | } | ||
| 78 | } | ||
| 79 | } | ||
| 80 | |||
| 81 |
2/2✓ Branch 0 taken 60 times.
✓ Branch 1 taken 4527 times.
|
4587 | if (valid_irap) |
| 82 | 60 | return AVPROBE_SCORE_EXTENSION + 1; // 1 more than .mpg | |
| 83 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 4525 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
4527 | if (sps && pps && irap) |
| 84 | ✗ | return AVPROBE_SCORE_EXTENSION / 2; | |
| 85 |
6/6✓ Branch 0 taken 4525 times.
✓ Branch 1 taken 2 times.
✓ Branch 2 taken 4518 times.
✓ Branch 3 taken 7 times.
✓ Branch 4 taken 1 times.
✓ Branch 5 taken 4517 times.
|
4527 | if (sps || pps || irap) |
| 86 | 10 | return AVPROBE_SCORE_EXTENSION / 4; | |
| 87 | 4517 | return 0; | |
| 88 | } | ||
| 89 | |||
| 90 | FF_DEF_RAWVIDEO_DEMUXER(vvc, "raw H.266/VVC video", vvc_probe, "h266,266,vvc", AV_CODEC_ID_VVC) | ||
| 91 |