By John Skiff
I was getting a core dump under Solaris 2.6 when
storing images. My compiler is Forte 6 Update 1. The
problem was in imagbmp.cpp:
t@1 (l@1) signal BUS (invalid address alignment) in
wxANIHandler::DoCanRead at line 1304 in file "imagbmp.cpp"
1304 if ( FCC1 != *riff32 )
(dbx) p FCC1
FCC1 =
31064321
(dbx) p *riff32
*riff32 =
1380533830
(dbx)
I have tested the fix under Windows 2000, Solaris 2.6,
and Irix 6.5.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@16541
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
static const char *listtxt = "LIST";
static const char *icotxt = "icon";
static const char *listtxt = "LIST";
static const char *icotxt = "icon";
- wxInt32 *riff32 = (wxInt32 *) rifftxt;
- wxInt32 *list32 = (wxInt32 *) listtxt;
- wxInt32 *ico32 = (wxInt32 *) icotxt;
+ wxInt32 riff32 = (wxInt32) rifftxt;
+ wxInt32 list32 = (wxInt32) listtxt;
+ wxInt32 ico32 = (wxInt32) icotxt;
int iIcon = 0;
stream.SeekI(0);
stream.Read(&FCC1, 4);
int iIcon = 0;
stream.SeekI(0);
stream.Read(&FCC1, 4);
return FALSE;
// we have a riff file:
return FALSE;
// we have a riff file:
//data should be padded to make even number of bytes
if (datalen % 2 == 1) datalen ++ ;
//now either data or a FCC
//data should be padded to make even number of bytes
if (datalen % 2 == 1) datalen ++ ;
//now either data or a FCC
- if ( (FCC1 == *riff32) || (FCC1 == *list32) )
+ if ( (FCC1 == riff32) || (FCC1 == list32) )
{
stream.Read(&FCC2, 4);
}
else
{
{
stream.Read(&FCC2, 4);
}
else
{
- if (FCC1 == *ico32 && iIcon >= index)
+ if (FCC1 == ico32 && iIcon >= index)
{
return DoLoadFile(image, stream, verbose, -1);
}
else
{
stream.SeekI(stream.TellI() + datalen);
{
return DoLoadFile(image, stream, verbose, -1);
}
else
{
stream.SeekI(stream.TellI() + datalen);
static const char *listtxt = "LIST";
static const char *anihtxt = "anih";
static const char *listtxt = "LIST";
static const char *anihtxt = "anih";
- wxInt32 *riff32 = (wxInt32 *) rifftxt;
- wxInt32 *list32 = (wxInt32 *) listtxt;
- wxInt32 *anih32 = (wxInt32 *) anihtxt;
+ wxInt32 riff32 = (wxInt32) rifftxt;
+ wxInt32 list32 = (wxInt32) listtxt;
+ wxInt32 anih32 = (wxInt32) anihtxt;
stream.SeekI(0);
if ( !stream.Read(&FCC1, 4) )
return FALSE;
stream.SeekI(0);
if ( !stream.Read(&FCC1, 4) )
return FALSE;
return FALSE;
// we have a riff file:
while ( stream.IsOk() )
{
return FALSE;
// we have a riff file:
while ( stream.IsOk() )
{
return TRUE;
// we always have a data size:
stream.Read(&datalen, 4);
return TRUE;
// we always have a data size:
stream.Read(&datalen, 4);
//data should be padded to make even number of bytes
if (datalen % 2 == 1) datalen ++ ;
// now either data or a FCC:
//data should be padded to make even number of bytes
if (datalen % 2 == 1) datalen ++ ;
// now either data or a FCC:
- if ( (FCC1 == *riff32) || (FCC1 == *list32) )
+ if ( (FCC1 == riff32) || (FCC1 == list32) )
{
stream.Read(&FCC2, 4);
}
{
stream.Read(&FCC2, 4);
}
static const char *listtxt = "LIST";
static const char *anihtxt = "anih";
static const char *listtxt = "LIST";
static const char *anihtxt = "anih";
- wxInt32 *riff32 = (wxInt32 *) rifftxt;
- wxInt32 *list32 = (wxInt32 *) listtxt;
- wxInt32 *anih32 = (wxInt32 *) anihtxt;
+ wxInt32 riff32 = (wxInt32) rifftxt;
+ wxInt32 list32 = (wxInt32) listtxt;
+ wxInt32 anih32 = (wxInt32) anihtxt;
stream.SeekI(0);
stream.Read(&FCC1, 4);
stream.SeekI(0);
stream.Read(&FCC1, 4);
return wxNOT_FOUND;
// we have a riff file:
return wxNOT_FOUND;
// we have a riff file:
//data should be padded to make even number of bytes
if (datalen % 2 == 1) datalen ++ ;
// now either data or a FCC:
//data should be padded to make even number of bytes
if (datalen % 2 == 1) datalen ++ ;
// now either data or a FCC:
- if ( (FCC1 == *riff32) || (FCC1 == *list32) )
+ if ( (FCC1 == riff32) || (FCC1 == list32) )
{
stream.Read(&FCC2, 4);
}
else
{
{
stream.Read(&FCC2, 4);
}
else
{
{
wxUint32 *pData = new wxUint32[datalen/4];
stream.Read(pData, datalen);
{
wxUint32 *pData = new wxUint32[datalen/4];
stream.Read(pData, datalen);