summaryrefslogtreecommitdiffstats
path: root/libmpdemux
diff options
context:
space:
mode:
authorreimar <reimar@b3059339-0415-0410-9bf9-f77b7e298cf2>2007-01-13 11:37:18 +0000
committerreimar <reimar@b3059339-0415-0410-9bf9-f77b7e298cf2>2007-01-13 11:37:18 +0000
commite52420a9fe15da63c1ebb60c540c56f8e716ef0f (patch)
tree4974a682affb6480793e946291763404a2925948 /libmpdemux
parenteb2b0bc2a72b497798bd5e327a661ba43786ef7a (diff)
downloadmpv-e52420a9fe15da63c1ebb60c540c56f8e716ef0f.tar.bz2
mpv-e52420a9fe15da63c1ebb60c540c56f8e716ef0f.tar.xz
Fix crash for gif images that have Top or Left set
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@21900 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpdemux')
-rw-r--r--libmpdemux/demux_gif.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/libmpdemux/demux_gif.c b/libmpdemux/demux_gif.c
index b233ca6e5b..7aa09c1254 100644
--- a/libmpdemux/demux_gif.c
+++ b/libmpdemux/demux_gif.c
@@ -21,6 +21,7 @@ typedef struct {
int current_pts;
unsigned char *palette;
GifFileType *gif;
+ int w, h;
} gif_priv_t;
#define GIF_SIGNATURE (('G' << 16) | ('I' << 8) | 'F')
@@ -104,7 +105,7 @@ static int demux_gif_fill_buffer(demuxer_t *demuxer, demux_stream_t *ds)
}
len = gif->Image.Width * gif->Image.Height;
- dp = new_demux_packet(len);
+ dp = new_demux_packet(priv->w * priv->h);
buf = malloc(len);
memset(buf, 0, len);
memset(dp->buffer, 0, len);
@@ -121,6 +122,10 @@ static int demux_gif_fill_buffer(demuxer_t *demuxer, demux_stream_t *ds)
int y;
int cnt = effective_map->ColorCount;
if (cnt > 256) cnt = 256;
+ int l = FFMIN(gif->Image.Left, priv->w);
+ int t = FFMIN(gif->Image.Top, priv->h);
+ int w = FFMIN(gif->Image.Width, priv->w - l);
+ int h = FFMIN(gif->Image.Height, priv->h - t);
// copy the palette
for (y = 0; y < cnt; y++) {
@@ -130,14 +135,13 @@ static int demux_gif_fill_buffer(demuxer_t *demuxer, demux_stream_t *ds)
priv->palette[(y * 4) + 3] = 0;
}
- for (y = 0; y < gif->Image.Height; y++) {
+ for (y = 0; y < h; y++) {
unsigned char *drow = dp->buffer;
unsigned char *gbuf = buf + (y * gif->Image.Width);
- drow += gif->Image.Width * (y + gif->Image.Top);
- drow += gif->Image.Left;
+ drow += priv->w * (y + t) + l;
- memcpy(drow, gbuf, gif->Image.Width);
+ memcpy(drow, gbuf, w);
}
}
@@ -204,6 +208,8 @@ static demuxer_t* demux_open_gif(demuxer_t* demuxer)
sh_video->bih->biBitCount = 8;
sh_video->bih->biPlanes = 2;
priv->palette = (unsigned char *)(sh_video->bih + 1);
+ priv->w = sh_video->disp_w;
+ priv->h = sh_video->disp_h;
priv->gif = gif;
demuxer->priv = priv;