annotate vmnc.c @ 12530:63edd10ad4bc libavcodec tip

Try to fix crashes introduced by r25218 r25218 made assumptions about the existence of past reference frames that weren't necessarily true.
author darkshikari
date Tue, 28 Sep 2010 09:06:22 +0000
parents 7dd2a45249a9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
1 /*
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
2 * VMware Screen Codec (VMnc) decoder
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
3 * Copyright (c) 2006 Konstantin Shishkov
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
4 *
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3920
diff changeset
5 * This file is part of FFmpeg.
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3920
diff changeset
6 *
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3920
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3920
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
11 *
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3920
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
15 * Lesser General Public License for more details.
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
16 *
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3920
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
20 */
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
21
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
22 /**
11644
7dd2a45249a9 Remove explicit filename from Doxygen @file commands.
diego
parents: 11560
diff changeset
23 * @file
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
24 * VMware Screen Codec (VMnc) decoder
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
25 * As Alex Beregszaszi discovered, this is effectively RFB data dump
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
26 */
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
27
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
28 #include <stdio.h>
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
29 #include <stdlib.h>
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
30
8573
2acf0ae7b041 Fix build: Add intreadwrite.h and bswap.h #includes where necessary.
diego
parents: 7823
diff changeset
31 #include "libavutil/intreadwrite.h"
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
32 #include "avcodec.h"
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
33
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
34 enum EncTypes {
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
35 MAGIC_WMVd = 0x574D5664,
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
36 MAGIC_WMVe,
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
37 MAGIC_WMVf,
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
38 MAGIC_WMVg,
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
39 MAGIC_WMVh,
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
40 MAGIC_WMVi,
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
41 MAGIC_WMVj
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
42 };
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
43
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
44 enum HexTile_Flags {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
45 HT_RAW = 1, // tile is raw
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
46 HT_BKG = 2, // background color is present
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
47 HT_FG = 4, // foreground color is present
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
48 HT_SUB = 8, // subrects are present
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
49 HT_CLR = 16 // each subrect has own color
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
50 };
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
51
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
52 /*
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
53 * Decoder context
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
54 */
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
55 typedef struct VmncContext {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
56 AVCodecContext *avctx;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
57 AVFrame pic;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
58
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
59 int bpp;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
60 int bpp2;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
61 int bigendian;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
62 uint8_t pal[768];
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
63 int width, height;
3684
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
64
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
65 /* cursor data */
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
66 int cur_w, cur_h;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
67 int cur_x, cur_y;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
68 int cur_hx, cur_hy;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
69 uint8_t* curbits, *curmask;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
70 uint8_t* screendta;
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
71 } VmncContext;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
72
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
73 /* read pixel value from stream */
6293
michael
parents: 5967
diff changeset
74 static av_always_inline int vmnc_get_pixel(const uint8_t* buf, int bpp, int be) {
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
75 switch(bpp * 2 + be) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
76 case 2:
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
77 case 3: return *buf;
4364
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4283
diff changeset
78 case 4: return AV_RL16(buf);
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4283
diff changeset
79 case 5: return AV_RB16(buf);
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4283
diff changeset
80 case 8: return AV_RL32(buf);
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4283
diff changeset
81 case 9: return AV_RB32(buf);
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
82 default: return 0;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
83 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
84 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
85
6293
michael
parents: 5967
diff changeset
86 static void load_cursor(VmncContext *c, const uint8_t *src)
3684
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
87 {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
88 int i, j, p;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
89 const int bpp = c->bpp2;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
90 uint8_t *dst8 = c->curbits;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
91 uint16_t *dst16 = (uint16_t*)c->curbits;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
92 uint32_t *dst32 = (uint32_t*)c->curbits;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
93
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
94 for(j = 0; j < c->cur_h; j++) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
95 for(i = 0; i < c->cur_w; i++) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
96 p = vmnc_get_pixel(src, bpp, c->bigendian);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
97 src += bpp;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
98 if(bpp == 1) *dst8++ = p;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
99 if(bpp == 2) *dst16++ = p;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
100 if(bpp == 4) *dst32++ = p;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
101 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
102 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
103 dst8 = c->curmask;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
104 dst16 = (uint16_t*)c->curmask;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
105 dst32 = (uint32_t*)c->curmask;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
106 for(j = 0; j < c->cur_h; j++) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
107 for(i = 0; i < c->cur_w; i++) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
108 p = vmnc_get_pixel(src, bpp, c->bigendian);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
109 src += bpp;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
110 if(bpp == 1) *dst8++ = p;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
111 if(bpp == 2) *dst16++ = p;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
112 if(bpp == 4) *dst32++ = p;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
113 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
114 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
115 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
116
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
117 static void put_cursor(uint8_t *dst, int stride, VmncContext *c, int dx, int dy)
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
118 {
3920
3a151ccc6ed7 Remove unused variables and the corresponding warnings along with them.
diego
parents: 3800
diff changeset
119 int i, j;
3684
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
120 int w, h, x, y;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
121 w = c->cur_w;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
122 if(c->width < c->cur_x + c->cur_w) w = c->width - c->cur_x;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
123 h = c->cur_h;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
124 if(c->height < c->cur_y + c->cur_h) h = c->height - c->cur_y;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
125 x = c->cur_x;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
126 y = c->cur_y;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
127 if(x < 0) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
128 w += x;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
129 x = 0;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
130 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
131 if(y < 0) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
132 h += y;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
133 y = 0;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
134 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
135
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
136 if((w < 1) || (h < 1)) return;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
137 dst += x * c->bpp2 + y * stride;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
138
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
139 if(c->bpp2 == 1) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
140 uint8_t* cd = c->curbits, *msk = c->curmask;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
141 for(j = 0; j < h; j++) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
142 for(i = 0; i < w; i++)
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
143 dst[i] = (dst[i] & cd[i]) ^ msk[i];
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
144 msk += c->cur_w;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
145 cd += c->cur_w;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
146 dst += stride;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
147 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
148 } else if(c->bpp2 == 2) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
149 uint16_t* cd = (uint16_t*)c->curbits, *msk = (uint16_t*)c->curmask;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
150 uint16_t* dst2;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
151 for(j = 0; j < h; j++) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
152 dst2 = (uint16_t*)dst;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
153 for(i = 0; i < w; i++)
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
154 dst2[i] = (dst2[i] & cd[i]) ^ msk[i];
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
155 msk += c->cur_w;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
156 cd += c->cur_w;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
157 dst += stride;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
158 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
159 } else if(c->bpp2 == 4) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
160 uint32_t* cd = (uint32_t*)c->curbits, *msk = (uint32_t*)c->curmask;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
161 uint32_t* dst2;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
162 for(j = 0; j < h; j++) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
163 dst2 = (uint32_t*)dst;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
164 for(i = 0; i < w; i++)
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
165 dst2[i] = (dst2[i] & cd[i]) ^ msk[i];
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
166 msk += c->cur_w;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
167 cd += c->cur_w;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
168 dst += stride;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
169 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
170 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
171 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
172
5967
15ed47af1838 Misc spelling fixes, prefer American over British English.
diego
parents: 5215
diff changeset
173 /* fill rectangle with given color */
4283
d6f83e2f8804 rename always_inline to av_always_inline and move to common.h
mru
parents: 3947
diff changeset
174 static av_always_inline void paint_rect(uint8_t *dst, int dx, int dy, int w, int h, int color, int bpp, int stride)
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
175 {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
176 int i, j;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
177 dst += dx * bpp + dy * stride;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
178 if(bpp == 1){
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
179 for(j = 0; j < h; j++) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
180 memset(dst, color, w);
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
181 dst += stride;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
182 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
183 }else if(bpp == 2){
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
184 uint16_t* dst2;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
185 for(j = 0; j < h; j++) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
186 dst2 = (uint16_t*)dst;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
187 for(i = 0; i < w; i++) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
188 *dst2++ = color;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
189 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
190 dst += stride;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
191 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
192 }else if(bpp == 4){
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
193 uint32_t* dst2;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
194 for(j = 0; j < h; j++) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
195 dst2 = (uint32_t*)dst;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
196 for(i = 0; i < w; i++) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
197 dst2[i] = color;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
198 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
199 dst += stride;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
200 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
201 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
202 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
203
6293
michael
parents: 5967
diff changeset
204 static av_always_inline void paint_raw(uint8_t *dst, int w, int h, const uint8_t* src, int bpp, int be, int stride)
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
205 {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
206 int i, j, p;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
207 for(j = 0; j < h; j++) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
208 for(i = 0; i < w; i++) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
209 p = vmnc_get_pixel(src, bpp, be);
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
210 src += bpp;
3678
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
211 switch(bpp){
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
212 case 1:
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
213 dst[i] = p;
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
214 break;
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
215 case 2:
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
216 ((uint16_t*)dst)[i] = p;
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
217 break;
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
218 case 4:
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
219 ((uint32_t*)dst)[i] = p;
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
220 break;
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
221 }
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
222 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
223 dst += stride;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
224 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
225 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
226
6293
michael
parents: 5967
diff changeset
227 static int decode_hextile(VmncContext *c, uint8_t* dst, const uint8_t* src, int ssize, int w, int h, int stride)
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
228 {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
229 int i, j, k;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
230 int bg = 0, fg = 0, rects, color, flags, xy, wh;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
231 const int bpp = c->bpp2;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
232 uint8_t *dst2;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
233 int bw = 16, bh = 16;
6293
michael
parents: 5967
diff changeset
234 const uint8_t *ssrc=src;
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
235
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
236 for(j = 0; j < h; j += 16) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
237 dst2 = dst;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
238 bw = 16;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
239 if(j + 16 > h) bh = h - j;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
240 for(i = 0; i < w; i += 16, dst2 += 16 * bpp) {
3685
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
241 if(src - ssrc >= ssize) {
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
242 av_log(c->avctx, AV_LOG_ERROR, "Premature end of data!\n");
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
243 return -1;
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
244 }
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
245 if(i + 16 > w) bw = w - i;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
246 flags = *src++;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
247 if(flags & HT_RAW) {
3685
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
248 if(src - ssrc > ssize - bw * bh * bpp) {
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
249 av_log(c->avctx, AV_LOG_ERROR, "Premature end of data!\n");
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
250 return -1;
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
251 }
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
252 paint_raw(dst2, bw, bh, src, bpp, c->bigendian, stride);
3678
93a961e40d65 Handle raw blocks correctly (both updating pointer and storing to memory)
kostya
parents: 3677
diff changeset
253 src += bw * bh * bpp;
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
254 } else {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
255 if(flags & HT_BKG) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
256 bg = vmnc_get_pixel(src, bpp, c->bigendian); src += bpp;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
257 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
258 if(flags & HT_FG) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
259 fg = vmnc_get_pixel(src, bpp, c->bigendian); src += bpp;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
260 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
261 rects = 0;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
262 if(flags & HT_SUB)
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
263 rects = *src++;
3685
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
264 color = !!(flags & HT_CLR);
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
265
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
266 paint_rect(dst2, 0, 0, bw, bh, bg, bpp, stride);
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
267
3685
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
268 if(src - ssrc > ssize - rects * (color * bpp + 2)) {
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
269 av_log(c->avctx, AV_LOG_ERROR, "Premature end of data!\n");
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
270 return -1;
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
271 }
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
272 for(k = 0; k < rects; k++) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
273 if(color) {
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
274 fg = vmnc_get_pixel(src, bpp, c->bigendian); src += bpp;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
275 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
276 xy = *src++;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
277 wh = *src++;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
278 paint_rect(dst2, xy >> 4, xy & 0xF, (wh>>4)+1, (wh & 0xF)+1, fg, bpp, stride);
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
279 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
280 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
281 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
282 dst += stride * 16;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
283 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
284 return src - ssrc;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
285 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
286
9355
54bc8a2727b0 Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents: 8718
diff changeset
287 static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, AVPacket *avpkt)
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
288 {
9355
54bc8a2727b0 Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents: 8718
diff changeset
289 const uint8_t *buf = avpkt->data;
54bc8a2727b0 Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents: 8718
diff changeset
290 int buf_size = avpkt->size;
4827
b3ee9a1526b0 Get rid of unnecessary pointer casts.
diego
parents: 4740
diff changeset
291 VmncContext * const c = avctx->priv_data;
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
292 uint8_t *outptr;
6293
michael
parents: 5967
diff changeset
293 const uint8_t *src = buf;
3685
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
294 int dx, dy, w, h, depth, enc, chunks, res, size_left;
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
295
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
296 c->pic.reference = 1;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
297 c->pic.buffer_hints = FF_BUFFER_HINTS_VALID | FF_BUFFER_HINTS_PRESERVE | FF_BUFFER_HINTS_REUSABLE;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
298 if(avctx->reget_buffer(avctx, &c->pic) < 0){
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
299 av_log(avctx, AV_LOG_ERROR, "reget_buffer() failed\n");
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
300 return -1;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
301 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
302
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
303 c->pic.key_frame = 0;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
304 c->pic.pict_type = FF_P_TYPE;
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
305
3684
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
306 //restore screen after cursor
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
307 if(c->screendta) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
308 int i;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
309 w = c->cur_w;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
310 if(c->width < c->cur_x + w) w = c->width - c->cur_x;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
311 h = c->cur_h;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
312 if(c->height < c->cur_y + h) h = c->height - c->cur_y;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
313 dx = c->cur_x;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
314 if(dx < 0) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
315 w += dx;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
316 dx = 0;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
317 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
318 dy = c->cur_y;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
319 if(dy < 0) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
320 h += dy;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
321 dy = 0;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
322 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
323 if((w > 0) && (h > 0)) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
324 outptr = c->pic.data[0] + dx * c->bpp2 + dy * c->pic.linesize[0];
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
325 for(i = 0; i < h; i++) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
326 memcpy(outptr, c->screendta + i * c->cur_w * c->bpp2, w * c->bpp2);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
327 outptr += c->pic.linesize[0];
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
328 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
329 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
330 }
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
331 src += 2;
4364
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4283
diff changeset
332 chunks = AV_RB16(src); src += 2;
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
333 while(chunks--) {
4364
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4283
diff changeset
334 dx = AV_RB16(src); src += 2;
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4283
diff changeset
335 dy = AV_RB16(src); src += 2;
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4283
diff changeset
336 w = AV_RB16(src); src += 2;
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4283
diff changeset
337 h = AV_RB16(src); src += 2;
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4283
diff changeset
338 enc = AV_RB32(src); src += 4;
3684
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
339 outptr = c->pic.data[0] + dx * c->bpp2 + dy * c->pic.linesize[0];
3685
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
340 size_left = buf_size - (src - buf);
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
341 switch(enc) {
3684
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
342 case MAGIC_WMVd: // cursor
3685
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
343 if(size_left < 2 + w * h * c->bpp2 * 2) {
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
344 av_log(avctx, AV_LOG_ERROR, "Premature end of data! (need %i got %i)\n", 2 + w * h * c->bpp2 * 2, size_left);
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
345 return -1;
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
346 }
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
347 src += 2;
3684
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
348 c->cur_w = w;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
349 c->cur_h = h;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
350 c->cur_hx = dx;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
351 c->cur_hy = dy;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
352 if((c->cur_hx > c->cur_w) || (c->cur_hy > c->cur_h)) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
353 av_log(avctx, AV_LOG_ERROR, "Cursor hot spot is not in image: %ix%i of %ix%i cursor size\n", c->cur_hx, c->cur_hy, c->cur_w, c->cur_h);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
354 c->cur_hx = c->cur_hy = 0;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
355 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
356 c->curbits = av_realloc(c->curbits, c->cur_w * c->cur_h * c->bpp2);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
357 c->curmask = av_realloc(c->curmask, c->cur_w * c->cur_h * c->bpp2);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
358 c->screendta = av_realloc(c->screendta, c->cur_w * c->cur_h * c->bpp2);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
359 load_cursor(c, src);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
360 src += w * h * c->bpp2 * 2;
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
361 break;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
362 case MAGIC_WMVe: // unknown
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
363 src += 2;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
364 break;
3684
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
365 case MAGIC_WMVf: // update cursor position
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
366 c->cur_x = dx - c->cur_hx;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
367 c->cur_y = dy - c->cur_hy;
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
368 break;
3686
5fc587a5feea Handle the rest of known blocks (by skipping them)
kostya
parents: 3685
diff changeset
369 case MAGIC_WMVg: // unknown
5fc587a5feea Handle the rest of known blocks (by skipping them)
kostya
parents: 3685
diff changeset
370 src += 10;
5fc587a5feea Handle the rest of known blocks (by skipping them)
kostya
parents: 3685
diff changeset
371 break;
5fc587a5feea Handle the rest of known blocks (by skipping them)
kostya
parents: 3685
diff changeset
372 case MAGIC_WMVh: // unknown
5fc587a5feea Handle the rest of known blocks (by skipping them)
kostya
parents: 3685
diff changeset
373 src += 4;
5fc587a5feea Handle the rest of known blocks (by skipping them)
kostya
parents: 3685
diff changeset
374 break;
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
375 case MAGIC_WMVi: // ServerInitialization struct
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
376 c->pic.key_frame = 1;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
377 c->pic.pict_type = FF_I_TYPE;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
378 depth = *src++;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
379 if(depth != c->bpp) {
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
380 av_log(avctx, AV_LOG_INFO, "Depth mismatch. Container %i bpp, Frame data: %i bpp\n", c->bpp, depth);
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
381 }
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
382 src++;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
383 c->bigendian = *src++;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
384 if(c->bigendian & (~1)) {
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
385 av_log(avctx, AV_LOG_INFO, "Invalid header: bigendian flag = %i\n", c->bigendian);
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
386 return -1;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
387 }
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
388 //skip the rest of pixel format data
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
389 src += 13;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
390 break;
3686
5fc587a5feea Handle the rest of known blocks (by skipping them)
kostya
parents: 3685
diff changeset
391 case MAGIC_WMVj: // unknown
5fc587a5feea Handle the rest of known blocks (by skipping them)
kostya
parents: 3685
diff changeset
392 src += 2;
5fc587a5feea Handle the rest of known blocks (by skipping them)
kostya
parents: 3685
diff changeset
393 break;
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
394 case 0x00000000: // raw rectangle data
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
395 if((dx + w > c->width) || (dy + h > c->height)) {
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
396 av_log(avctx, AV_LOG_ERROR, "Incorrect frame size: %ix%i+%ix%i of %ix%i\n", w, h, dx, dy, c->width, c->height);
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
397 return -1;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
398 }
3685
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
399 if(size_left < w * h * c->bpp2) {
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
400 av_log(avctx, AV_LOG_ERROR, "Premature end of data! (need %i got %i)\n", w * h * c->bpp2, size_left);
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
401 return -1;
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
402 }
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
403 paint_raw(outptr, w, h, src, c->bpp2, c->bigendian, c->pic.linesize[0]);
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
404 src += w * h * c->bpp2;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
405 break;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
406 case 0x00000005: // HexTile encoded rectangle
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
407 if((dx + w > c->width) || (dy + h > c->height)) {
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
408 av_log(avctx, AV_LOG_ERROR, "Incorrect frame size: %ix%i+%ix%i of %ix%i\n", w, h, dx, dy, c->width, c->height);
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
409 return -1;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
410 }
3685
dd2da6e09d32 Tests for overreading input data
kostya
parents: 3684
diff changeset
411 res = decode_hextile(c, outptr, src, size_left, w, h, c->pic.linesize[0]);
3679
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
412 if(res < 0)
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
413 return -1;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
414 src += res;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
415 break;
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
416 default:
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
417 av_log(avctx, AV_LOG_ERROR, "Unsupported block type 0x%08X\n", enc);
2702eec8c8b9 Try to handle all chunks, previous scheme was not correct.
kostya
parents: 3678
diff changeset
418 chunks = 0; // leave chunks decoding loop
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
419 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
420 }
3684
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
421 if(c->screendta){
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
422 int i;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
423 //save screen data before painting cursor
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
424 w = c->cur_w;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
425 if(c->width < c->cur_x + w) w = c->width - c->cur_x;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
426 h = c->cur_h;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
427 if(c->height < c->cur_y + h) h = c->height - c->cur_y;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
428 dx = c->cur_x;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
429 if(dx < 0) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
430 w += dx;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
431 dx = 0;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
432 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
433 dy = c->cur_y;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
434 if(dy < 0) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
435 h += dy;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
436 dy = 0;
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
437 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
438 if((w > 0) && (h > 0)) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
439 outptr = c->pic.data[0] + dx * c->bpp2 + dy * c->pic.linesize[0];
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
440 for(i = 0; i < h; i++) {
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
441 memcpy(c->screendta + i * c->cur_w * c->bpp2, outptr, w * c->bpp2);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
442 outptr += c->pic.linesize[0];
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
443 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
444 outptr = c->pic.data[0];
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
445 put_cursor(outptr, c->pic.linesize[0], c, c->cur_x, c->cur_y);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
446 }
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
447 }
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
448 *data_size = sizeof(AVFrame);
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
449 *(AVFrame*)data = c->pic;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
450
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
451 /* always report that the buffer was completely consumed */
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
452 return buf_size;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
453 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
454
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
455
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
456
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
457 /*
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
458 *
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
459 * Init VMnc decoder
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
460 *
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
461 */
6517
48759bfbd073 Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents: 6293
diff changeset
462 static av_cold int decode_init(AVCodecContext *avctx)
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
463 {
4827
b3ee9a1526b0 Get rid of unnecessary pointer casts.
diego
parents: 4740
diff changeset
464 VmncContext * const c = avctx->priv_data;
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
465
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
466 c->avctx = avctx;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
467
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
468 c->width = avctx->width;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
469 c->height = avctx->height;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
470
7823
4525dcd81357 Bump Major version, this commit is almost just renaming bits_per_sample to
michael
parents: 7040
diff changeset
471 c->bpp = avctx->bits_per_coded_sample;
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
472 c->bpp2 = c->bpp/8;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
473
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
474 switch(c->bpp){
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
475 case 8:
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
476 avctx->pix_fmt = PIX_FMT_PAL8;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
477 break;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
478 case 16:
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
479 avctx->pix_fmt = PIX_FMT_RGB555;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
480 break;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
481 case 32:
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
482 avctx->pix_fmt = PIX_FMT_RGB32;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
483 break;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
484 default:
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
485 av_log(avctx, AV_LOG_ERROR, "Unsupported bitdepth %i\n", c->bpp);
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
486 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
487
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
488 return 0;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
489 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
490
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
491
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
492
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
493 /*
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
494 *
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
495 * Uninit VMnc decoder
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
496 *
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
497 */
6517
48759bfbd073 Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents: 6293
diff changeset
498 static av_cold int decode_end(AVCodecContext *avctx)
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
499 {
4827
b3ee9a1526b0 Get rid of unnecessary pointer casts.
diego
parents: 4740
diff changeset
500 VmncContext * const c = avctx->priv_data;
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
501
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
502 if (c->pic.data[0])
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
503 avctx->release_buffer(avctx, &c->pic);
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
504
3684
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
505 av_free(c->curbits);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
506 av_free(c->curmask);
9f77f4f577b4 Cursor drawing support
kostya
parents: 3679
diff changeset
507 av_free(c->screendta);
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
508 return 0;
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
509 }
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
510
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
511 AVCodec vmnc_decoder = {
6723
2ced96d3cde0 Transform codec short name into a single word.
diego
parents: 6722
diff changeset
512 "vmnc",
11560
8a4984c5cacc Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents: 10397
diff changeset
513 AVMEDIA_TYPE_VIDEO,
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
514 CODEC_ID_VMNC,
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
515 sizeof(VmncContext),
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
516 decode_init,
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
517 NULL,
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
518 decode_end,
6722
6eeb19edcee3 Add long names to some AVCodec declarations.
diego
parents: 6517
diff changeset
519 decode_frame,
9817
eb2a897f89d5 vmware video decoder uses reget_buffer, set CODEC_CAP_DR1
bcoudurier
parents: 9553
diff changeset
520 CODEC_CAP_DR1,
7040
e943e1409077 Make AVCodec long_names definition conditional depending on CONFIG_SMALL.
stefano
parents: 6723
diff changeset
521 .long_name = NULL_IF_CONFIG_SMALL("VMware Screen Codec / VMware Video"),
3677
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
522 };
18b13b923616 VMware Video decoder (fourcc: VMnc)
kostya
parents:
diff changeset
523