Commit 714bfd7e authored by Warren Baird's avatar Warren Baird Committed by Alexandre Julliard

Solve alignment problems by converting bitmap headers *after* they

have been copied into an aligned location, and then copying the converted header back over the original header.
parent d3cbb2ed
...@@ -228,6 +228,7 @@ static int convert_bitmap(char *data, int size) ...@@ -228,6 +228,7 @@ static int convert_bitmap(char *data, int size)
BITMAPINFOHEADER *bih = (BITMAPINFOHEADER *)data; BITMAPINFOHEADER *bih = (BITMAPINFOHEADER *)data;
BITMAPV4HEADER *b4h = (BITMAPV4HEADER *)data; BITMAPV4HEADER *b4h = (BITMAPV4HEADER *)data;
int type = 0; int type = 0;
int returnSize = 0; /* size to be returned */
#ifdef WORDS_BIGENDIAN #ifdef WORDS_BIGENDIAN
DWORD bisizel = BYTESWAP_DWORD(sizeof(BITMAPINFOHEADER)); DWORD bisizel = BYTESWAP_DWORD(sizeof(BITMAPINFOHEADER));
DWORD b4sizel = BYTESWAP_DWORD(sizeof(BITMAPV4HEADER)); DWORD b4sizel = BYTESWAP_DWORD(sizeof(BITMAPV4HEADER));
...@@ -240,17 +241,24 @@ static int convert_bitmap(char *data, int size) ...@@ -240,17 +241,24 @@ static int convert_bitmap(char *data, int size)
DWORD b4sizeb = BYTESWAP_DWORD(sizeof(BITMAPV4HEADER)); DWORD b4sizeb = BYTESWAP_DWORD(sizeof(BITMAPV4HEADER));
#endif #endif
/*
* Originally the bih and b4h pointers were simply incremented here,
* and memmoved at the end of the function. This causes alignment
* issues on solaris, so we do the memmove here rather than at the end.
*/
if(data[0] == 'B' && data[1] == 'M') if(data[0] == 'B' && data[1] == 'M')
{ {
/* Little endian signature */ /* Little endian signature */
bih = (BITMAPINFOHEADER *)(data + sizeof(BITMAPFILEHEADER)); memmove(data, data+sizeof(BITMAPFILEHEADER), size - sizeof(BITMAPFILEHEADER));
b4h = (BITMAPV4HEADER *)(data + sizeof(BITMAPFILEHEADER)); returnSize = sizeof(BITMAPFILEHEADER);
} }
else if(data[0] == 'M' && data[1] == 'B') else if(data[0] == 'M' && data[1] == 'B')
{ {
type |= FL_SIGBE; /* Big endian signature */ type |= FL_SIGBE; /* Big endian signature */
bih = (BITMAPINFOHEADER *)(data + sizeof(BITMAPFILEHEADER)); memmove(data, data+sizeof(BITMAPFILEHEADER), size - sizeof(BITMAPFILEHEADER));
b4h = (BITMAPV4HEADER *)(data + sizeof(BITMAPFILEHEADER)); returnSize = sizeof(BITMAPFILEHEADER);
} }
if(bih->biSize == bisizel) if(bih->biSize == bisizel)
...@@ -323,7 +331,7 @@ static int convert_bitmap(char *data, int size) ...@@ -323,7 +331,7 @@ static int convert_bitmap(char *data, int size)
memmove(data, data+sizeof(BITMAPFILEHEADER), size - sizeof(BITMAPFILEHEADER)); memmove(data, data+sizeof(BITMAPFILEHEADER), size - sizeof(BITMAPFILEHEADER));
return sizeof(BITMAPFILEHEADER); return sizeof(BITMAPFILEHEADER);
} }
return 0; return returnSize;
} }
#undef FL_SIGBE #undef FL_SIGBE
#undef FL_SIZEBE #undef FL_SIZEBE
...@@ -423,8 +431,10 @@ static void split_icons(raw_data_t *rd, icon_group_t *icog, int *nico) ...@@ -423,8 +431,10 @@ static void split_icons(raw_data_t *rd, icon_group_t *icog, int *nico)
ico->nclr = ide.nclr; ico->nclr = ide.nclr;
ico->planes = swap ? BYTESWAP_WORD(ide.planes) : ide.planes; ico->planes = swap ? BYTESWAP_WORD(ide.planes) : ide.planes;
ico->bits = swap ? BYTESWAP_WORD(ide.bits) : ide.bits; ico->bits = swap ? BYTESWAP_WORD(ide.bits) : ide.bits;
convert_bitmap((char *)rd->data + ide.offset, 0);
memcpy(&info, rd->data + ide.offset, sizeof(info)); memcpy(&info, rd->data + ide.offset, sizeof(info));
convert_bitmap((char *) &info, 0);
memcpy(rd->data + ide.offset, &info, sizeof(info));
if(!ico->planes) if(!ico->planes)
{ {
/* Argh! They did not fill out the resdir structure */ /* Argh! They did not fill out the resdir structure */
...@@ -513,8 +523,9 @@ static void split_cursors(raw_data_t *rd, cursor_group_t *curg, int *ncur) ...@@ -513,8 +523,9 @@ static void split_cursors(raw_data_t *rd, cursor_group_t *curg, int *ncur)
cur->width = cde.width; cur->width = cde.width;
cur->height = cde.height; cur->height = cde.height;
cur->nclr = cde.nclr; cur->nclr = cde.nclr;
convert_bitmap((char *)rd->data + cde.offset, 0);
memcpy(&info, rd->data + cde.offset, sizeof(info)); memcpy(&info, rd->data + cde.offset, sizeof(info));
convert_bitmap((char *)&info, 0);
memcpy(rd->data + cde.offset, &info, sizeof(info));
/* The bitmap is in destination byteorder. We want native for our structures */ /* The bitmap is in destination byteorder. We want native for our structures */
switch(byteorder) switch(byteorder)
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment