Bug 4679 - StatelessFile bound checks does not work on 64 bit
Summary: StatelessFile bound checks does not work on 64 bit
Status: RESOLVED FIXED
Alias: None
Product: frysk
Classification: Unclassified
Component: general (show other bugs)
Version: unspecified
: P2 normal
Target Milestone: ---
Assignee: Chris Moller
URL:
Keywords:
Depends on:
Blocks: 1595 2243
  Show dependency treegraph
 
Reported: 2007-06-21 00:40 UTC by Phil Muldoon
Modified: 2007-06-21 14:54 UTC (History)
1 user (show)

See Also:
Host:
Target:
Build:
Last reconfirmed:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Phil Muldoon 2007-06-21 00:40:27 UTC
The below code won't work as java longs are signed, so values in the upper
address range will be represented as negative decimal numbers for the purposes
of the < 0 decimal comparisons. So a read at 0xffffffffff600000 will fail as
when rendered to a singed long it will be a negative decimal value in the
comparison and the <0 test will fail.

static void
verifyBounds (jlong fileOffset, jbyteArray bytes, jlong start, jlong length)
{

  // XXX: 64-bit?
  if (fileOffset < 0)
    throw new java::lang::ArrayIndexOutOfBoundsException ();
  if (start < 0)
    throw new java::lang::ArrayIndexOutOfBoundsException ();
  if (length < 0)
    throw new java::lang::ArrayIndexOutOfBoundsException ();
  if (start + length > bytes->length)
    throw new java::lang::ArrayIndexOutOfBoundsException ();
}
Comment 1 Chris Moller 2007-06-21 01:48:46 UTC
Removed verifyBounds()in StatelessFile.java, replaced it with an upper-bound
check, and comitted it.  (Nominally negative signed start and length numbers
interpreted as large unsigned numbers will exceed bytes->length and cause a
bounds exception.  A nominally negative signed fileOffset number interpreted as
a large unsigned value will /probably/ result in a read error and a throwErrno().)
Comment 2 Chris Moller 2007-06-21 14:54:10 UTC
Patched worked.