Line | Branch | Exec | Source |
---|---|---|---|
1 | /* | ||
2 | * RAW H.263 video demuxer | ||
3 | * Copyright (c) 2009 Michael Niedermayer <michaelni@gmx.at> | ||
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 "avformat.h" | ||
23 | #include "rawdec.h" | ||
24 | |||
25 | 7203 | static int h263_probe(const AVProbeData *p) | |
26 | { | ||
27 | 7203 | uint64_t code= -1; | |
28 | int i; | ||
29 | 7203 | int valid_psc=0; | |
30 | 7203 | int invalid_psc=0; | |
31 | 7203 | int res_change=0; | |
32 | 7203 | int src_fmt, last_src_fmt=-1; | |
33 | 7203 | int last_gn=0; | |
34 | 7203 | int tr, last_tr = -1; | |
35 | |||
36 |
2/2✓ Branch 0 taken 383360811 times.
✓ Branch 1 taken 7203 times.
|
383368014 | for(i=0; i<p->buf_size; i++){ |
37 | 383360811 | code = (code<<8) + p->buf[i]; | |
38 |
2/2✓ Branch 0 taken 11125 times.
✓ Branch 1 taken 383349686 times.
|
383360811 | if ((code & 0xfffffc000000) == 0x80000000) { |
39 | 11125 | tr = (code >> 18) & 0xFF; | |
40 | 11125 | src_fmt= (code>>10)&7; | |
41 |
2/2✓ Branch 0 taken 3746 times.
✓ Branch 1 taken 7379 times.
|
11125 | if( src_fmt != last_src_fmt |
42 |
4/4✓ Branch 0 taken 930 times.
✓ Branch 1 taken 2816 times.
✓ Branch 2 taken 334 times.
✓ Branch 3 taken 596 times.
|
3746 | && last_src_fmt>0 && last_src_fmt<6 |
43 |
2/2✓ Branch 0 taken 271 times.
✓ Branch 1 taken 63 times.
|
334 | && src_fmt<6) |
44 | 271 | res_change++; | |
45 | |||
46 |
2/2✓ Branch 0 taken 3710 times.
✓ Branch 1 taken 7415 times.
|
11125 | if (tr == last_tr) { |
47 | 3710 | invalid_psc++; | |
48 | 3710 | continue; | |
49 | } | ||
50 | |||
51 |
6/6✓ Branch 0 taken 6813 times.
✓ Branch 1 taken 602 times.
✓ Branch 2 taken 6337 times.
✓ Branch 3 taken 476 times.
✓ Branch 4 taken 648 times.
✓ Branch 5 taken 5689 times.
|
7415 | if (src_fmt != 7 && !(code&(1<<9)) && (code&(1<<5))) { |
52 | 648 | invalid_psc++; | |
53 | 648 | continue; | |
54 | } | ||
55 | |||
56 |
4/4✓ Branch 0 taken 1401 times.
✓ Branch 1 taken 5366 times.
✓ Branch 2 taken 476 times.
✓ Branch 3 taken 925 times.
|
6767 | if((code&0x30000)==0x20000 && src_fmt){ |
57 | 476 | valid_psc++; | |
58 | 476 | last_gn=0; | |
59 | }else | ||
60 | 6291 | invalid_psc++; | |
61 | 6767 | last_src_fmt= src_fmt; | |
62 | 6767 | last_tr = tr; | |
63 |
2/2✓ Branch 0 taken 565322 times.
✓ Branch 1 taken 382784364 times.
|
383349686 | } else if((code & 0xffff80000000) == 0x80000000) { |
64 | 565322 | int gn= (code>>(31-5)) & 0x1F; | |
65 |
2/2✓ Branch 0 taken 172657 times.
✓ Branch 1 taken 392665 times.
|
565322 | if(gn<last_gn){ |
66 | 172657 | invalid_psc++; | |
67 | }else | ||
68 | 392665 | last_gn= gn; | |
69 | } | ||
70 | } | ||
71 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 7203 times.
|
7203 | if(valid_psc > 2*invalid_psc + 2*res_change + 3){ |
72 | ✗ | return AVPROBE_SCORE_EXTENSION; | |
73 |
2/2✓ Branch 0 taken 179 times.
✓ Branch 1 taken 7024 times.
|
7203 | }else if(valid_psc > 2*invalid_psc) |
74 | 179 | return AVPROBE_SCORE_EXTENSION / 2; | |
75 | 7024 | return 0; | |
76 | } | ||
77 | |||
78 | FF_DEF_RAWVIDEO_DEMUXER(h263, "raw H.263", h263_probe, NULL, AV_CODEC_ID_H263) | ||
79 |