1 /*
2 * AVS2 video stream probe.
3 *
4 * Copyright (C) 2018 Huiwen Ren, <hwrenx@126.com>
5 *
6 * This file is part of FFmpeg.
7 *
8 * FFmpeg is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License as published by the Free Software Foundation; either
11 * version 2.1 of the License, or (at your option) any later version.
12 *
13 * FFmpeg is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
17 *
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with FFmpeg; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 */
22
27
28 #define AVS2_ISSQH(x) ((x) == 0xB0)
29 #define AVS2_ISEND(x) ((x) == 0xB1)
30 #define AVS2_ISPIC(x) ((x) == 0xB3 || (x) == 0xB6)
31 #define AVS2_ISUNIT(x) (AVS2_ISSQH(x) || AVS2_ISEND(x) || (x) == 0xB2 || AVS2_ISPIC(x) || (x) == 0xB5 || (x) == 0xB7)
32 #define AVS2_ISPROFILE(x) ((x) == 0x20 || (x) == 0x22 || (x) == 0x30 || (x) == 0x32)
33
35 {
36 uint32_t
code = -1, hds = 0, pic = 0, seq = 0;
38 const uint8_t *ptr = p->
buf, *end = p->
buf + p->
buf_size, *sqb = 0;
40 return 0;
41 }
42
43 while (ptr < end) {
46 if ((
code & 0xffffff00) == 0x100) {
48 if (sqb && !hds) {
49 hds = ptr - sqb;
50 }
53 return 0;
54 sqb = ptr;
55 seq++;
57 pic++;
59 break;
60 }
61 }
62 }
63 }
64 if (seq && hds >= 21 && pic){
66 }
67
68 return 0;
69 }
70