annotate TOOLS/vivodump.c @ 2665:e8d949b1bc5d

dump h263 frame headers from vivo
author arpi
date Sun, 04 Nov 2001 00:00:38 +0000
parents
children a17fcca740ff
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2665
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
1 #include <stdio.h>
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
2
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
3 static const short h263_format[8][2] = {
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
4 { 0, 0 },
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
5 { 128, 96 },
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
6 { 176, 144 },
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
7 { 352, 288 },
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
8 { 704, 576 },
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
9 { 1408, 1152 },
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
10 };
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
11
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
12 unsigned char* buffer;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
13 int bufptr=0;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
14 int bitcnt=0;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
15 unsigned char buf=0;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
16
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
17 unsigned int x_get_bits(int n){
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
18 unsigned int x=0;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
19 while(n-->0){
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
20 if(!bitcnt){
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
21 // fill buff
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
22 buf=buffer[bufptr++];
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
23 bitcnt=8;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
24 }
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
25 //x=(x<<1)|(buf&1);buf>>=1;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
26 x=(x<<1)|(buf>>7);buf<<=1;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
27 --bitcnt;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
28 }
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
29 return x;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
30 }
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
31
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
32 #define get_bits(xxx,n) x_get_bits(n)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
33 #define get_bits1(xxx) x_get_bits(1)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
34 #define skip_bits(xxx,n) x_get_bits(n)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
35 #define skip_bits1(xxx) x_get_bits(1)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
36
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
37 /* most is hardcoded. should extend to handle all h263 streams */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
38 int h263_decode_picture_header(unsigned char *b_ptr)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
39 {
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
40 int format, width, height;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
41
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
42 buffer=b_ptr;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
43 bufptr=bitcnt=buf=0;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
44
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
45 /* picture header */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
46 if (get_bits(&s->gb, 22) != 0x20)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
47 return -1;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
48 skip_bits(&s->gb, 8); /* picture timestamp */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
49
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
50 if (get_bits1(&s->gb) != 1)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
51 return -1; /* marker */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
52 if (get_bits1(&s->gb) != 0)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
53 return -1; /* h263 id */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
54 skip_bits1(&s->gb); /* split screen off */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
55 skip_bits1(&s->gb); /* camera off */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
56 skip_bits1(&s->gb); /* freeze picture release off */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
57
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
58 format = get_bits(&s->gb, 3);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
59
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
60 if (format != 7) {
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
61 printf("h263_plus = 0 format = %d\n",format);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
62 /* H.263v1 */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
63 width = h263_format[format][0];
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
64 height = h263_format[format][1];
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
65 printf("%d x %d\n",width,height);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
66 if (!width)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
67 return -1;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
68
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
69 printf("pict_type=%d\n",get_bits1(&s->gb));
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
70 printf("unrestricted_mv=%d\n",get_bits1(&s->gb));
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
71 #if 1
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
72 printf("SAC: %d\n",get_bits1(&s->gb));
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
73 printf("advanced prediction mode: %d\n",get_bits1(&s->gb));
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
74 printf("PB frame: %d\n",get_bits1(&s->gb));
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
75 #else
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
76 if (get_bits1(&s->gb) != 0)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
77 return -1; /* SAC: off */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
78 if (get_bits1(&s->gb) != 0)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
79 return -1; /* advanced prediction mode: off */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
80 if (get_bits1(&s->gb) != 0)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
81 return -1; /* not PB frame */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
82 #endif
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
83 printf("qscale=%d\n",get_bits(&s->gb, 5));
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
84 skip_bits1(&s->gb); /* Continuous Presence Multipoint mode: off */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
85 } else {
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
86 printf("h263_plus = 1\n");
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
87 /* H.263v2 */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
88 if (get_bits(&s->gb, 3) != 1)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
89 return -1;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
90 if (get_bits(&s->gb, 3) != 6) /* custom source format */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
91 return -1;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
92 skip_bits(&s->gb, 12);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
93 skip_bits(&s->gb, 3);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
94 printf("pict_type=%d\n",get_bits(&s->gb, 3) + 1);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
95 // if (s->pict_type != I_TYPE &&
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
96 // s->pict_type != P_TYPE)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
97 // return -1;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
98 skip_bits(&s->gb, 7);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
99 skip_bits(&s->gb, 4); /* aspect ratio */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
100 width = (get_bits(&s->gb, 9) + 1) * 4;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
101 skip_bits1(&s->gb);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
102 height = get_bits(&s->gb, 9) * 4;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
103 printf("%d x %d\n",width,height);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
104 if (height == 0)
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
105 return -1;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
106 printf("qscale=%d\n",get_bits(&s->gb, 5));
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
107 }
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
108
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
109 /* PEI */
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
110 while (get_bits1(&s->gb) != 0) {
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
111 skip_bits(&s->gb, 8);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
112 }
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
113 // s->f_code = 1;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
114 // s->width = width;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
115 // s->height = height;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
116 return 0;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
117 }
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
118
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
119
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
120 int main(){
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
121 int c;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
122 unsigned int head=-1;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
123 int pos=0;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
124
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
125 while((c=getchar())>=0){
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
126 ++pos;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
127 head=(head<<8)|c;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
128 if((head&0xFFFFFF)==0x80){
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
129 unsigned char buf[33];
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
130 int i;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
131 buf[0]=buf[1]=0; buf[2]=0x80;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
132 printf("%08X: 00 00 80",pos);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
133 for(i=0;i<30;i++){
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
134 c=getchar();++pos;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
135 printf(" %02X",c);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
136 buf[3+i]=c;
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
137 }
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
138 printf("\n");
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
139 h263_decode_picture_header(buf);
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
140 }
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
141 }
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
142
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
143
e8d949b1bc5d dump h263 frame headers from vivo
arpi
parents:
diff changeset
144 }