<html>
<head>
<style>
.hmmessage P
{
margin:0px;
padding:0px
}
body.hmmessage
{
FONT-SIZE: 10pt;
FONT-FAMILY:Tahoma
}
</style>
</head>
<body class='hmmessage'>
Sure enough, the pointer n is not null, and throws a sigsegv fault. Aftern changing from<BR>
<BR>
*(uint32*)n=(uint32)o->tdir_count;<BR> <BR>TO<BR>
<BR>
_TIFFmemcpy(n, &o->tdir_count, 4)<BR>
<BR>
The execution passes this point, but where as *(uint32*)n should be 1, it is 0. This causes errors later in the GDALOpen call on the tiff dataset, which fails with error "TiffFetchNormalTag:incorrect count for "SamplesPerPixel". <BR><BR>
debugging continues....<BR>
<BR>
-- Dan Greve<BR>
-- Software Engineering<BR>
-- Northrop Grumman Corp.<BR>
<BLOCKQUOTE>
<HR>
From: grevedan@hotmail.com<BR>To: bfriesen@simple.dallas.tx.us; even.rouault@mines-paris.org<BR>Subject: RE: [Tiff] Re: [gdal-dev] Problem with libTiff on Solaris 10<BR>Date: Fri, 30 May 2008 19:53:49 -0400<BR>CC: gdal-dev@lists.osgeo.org; TIFF@lists.osgeo.org; andy.cave@hamillroad.com; tiff@lists.maptools.org<BR><BR>
<META content="Microsoft SafeHTML" name=Generator>
<STYLE>
.ExternalClass .EC_hmmessage P
{padding:0px;}
.ExternalClass body.EC_hmmessage
{font-size:10pt;font-family:Tahoma;}
</STYLE>
>Many compilers will produce a warning if an action is performed in a <BR>>way which does not assure correct alignment.<BR> <BR>I know GCC was throwing a number of warnings in the libtiff directory,<BR>maybe i'll actual pay attention to these in the next rebuild :)<BR> <BR>>I've done a quick 'grep "*(int32*)" *.c ' and 'grep "*(uint32*)" *.c' on <BR>>libtiff 3.8.2 sources and libtiff 4.0.0 sources, and found much more of those <BR>>in the later than in the former, so it is a hint that this may be the <BR>>problem.<BR> <BR>Bodes well that there is a greater likelihood this error would occur in libtiff 4.0.0<BR>(if this is what is included in gdal-1.5.1). I'm time crunched, so i think i'll try to<BR>to go in and replace the direct memory accesses with the TiffMemcpy like Evan<BR>suggested.<BR> <BR>>Anyway, we could be sure of the reason if Dan could print the value of the n <BR>>pointer when the debugger stops on the crash. And I think that 'sigbus' is <BR>>more typical of alignment problems. A null pointer would have given <BR>>a 'sigsegv' I think.<BR><BR>I'll forward the output of the n pointer from gdb, but I'm pretty sure it was not<BR>null. But even though the console output was "bus error", i think the debugger<BR>was segsegv, but will verify this in the morning. Unfortunately, due to the <BR>classification of this machine, I may not be able to provide a stack trace<BR>easily.<BR><BR>Thanks ya'll for the great inputs.<BR><BR>-- Dan Greve<BR>-- Software Engineer<BR>-- Northrop Grumman Corp.<BR><BR><BR><BR><BR>
<HR id=EC_stopSpelling>
<BR>> Date: Fri, 30 May 2008 15:58:02 -0500<BR>> From: bfriesen@simple.dallas.tx.us<BR>> To: even.rouault@mines-paris.org<BR>> CC: andy.cave@hamillroad.com; gdal-dev@lists.osgeo.org; grevedan@hotmail.com; tiff@lists.maptools.org; Shawn.Gong@drdc-rddc.gc.ca<BR>> Subject: Re: [Tiff] Re: [gdal-dev] Problem with libTiff on Solaris 10<BR>> <BR>> On Fri, 30 May 2008, Even Rouault wrote:<BR>> ><BR>> > Related topic, do people know if there's a Valgrind option/patch that could<BR>> > help us to detect that ? I looked a bit but couldn't find one. I imagine<BR>> > that's it's "easy" for Valgrind to detect and report such unaligned memory<BR>> > accesses. That could enable people not having the "chance" of getting access<BR>> > to a SPARC platform to anticipate such problems even with i386 hardware.<BR>> <BR>> Many compilers will produce a warning if an action is performed in a <BR>> way which does not assure correct alignment.<BR>> <BR>> The popular targets for valgrind do not seem to care about aligned <BR>> access, or perhaps unaligned access is just a bit slower.<BR>> <BR>> I have access to SPARC here so if someone can formulate a simple way <BR>> to re-create the problem without GDAL installed then I should be able <BR>> to help debug the issue.<BR>> <BR>> Bob<BR>> ======================================<BR>> Bob Friesenhahn<BR>> bfriesen@simple.dallas.tx.us, http://www.simplesystems.org/users/bfriesen/<BR>> GraphicsMagick Maintainer, http://www.GraphicsMagick.org/<BR>> <BR><BR><BR>
<HR>
Make every e-mail and IM count. <A href="http://im.live.com/Messenger/IM/Join/Default.aspx?source=EML_WL_ MakeCount" target=_blank>Join the i’m Initiative from Microsoft.</A> </BLOCKQUOTE><br /><hr />Keep your kids safer online with Windows Live Family Safety. <a href='http://www.windowslive.com/family_safety/overview.html?ocid=TXT_TAGLM_WL_Refresh_family_safety_052008' target='_new'>Help protect your kids.</a></body>
</html>