Merge "Fail explicitly on length overflow."
This commit is contained in:
commit
d46eb21906
|
@ -189,7 +189,11 @@ bool FileMap::create(const char* origFileName, int fd, off64_t offset, size_t le
|
||||||
|
|
||||||
int adjust = offset % mPageSize;
|
int adjust = offset % mPageSize;
|
||||||
off64_t adjOffset = offset - adjust;
|
off64_t adjOffset = offset - adjust;
|
||||||
size_t adjLength = length + adjust;
|
size_t adjLength;
|
||||||
|
if (__builtin_add_overflow(length, adjust, &adjLength)) {
|
||||||
|
ALOGE("adjusted length overflow: length %zu adjust %d", length, adjust);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
int flags = MAP_SHARED;
|
int flags = MAP_SHARED;
|
||||||
int prot = PROT_READ;
|
int prot = PROT_READ;
|
||||||
|
|
|
@ -52,3 +52,16 @@ TEST(FileMap, large_offset) {
|
||||||
ASSERT_EQ(0u, m.getDataLength());
|
ASSERT_EQ(0u, m.getDataLength());
|
||||||
ASSERT_EQ(offset, m.getDataOffset());
|
ASSERT_EQ(offset, m.getDataOffset());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(FileMap, offset_overflow) {
|
||||||
|
// Make sure that an end that overflows SIZE_MAX will not abort.
|
||||||
|
// See http://b/156997193.
|
||||||
|
TemporaryFile tf;
|
||||||
|
ASSERT_TRUE(tf.fd != -1);
|
||||||
|
|
||||||
|
off64_t offset = 200;
|
||||||
|
size_t length = SIZE_MAX;
|
||||||
|
|
||||||
|
android::FileMap m;
|
||||||
|
ASSERT_FALSE(m.create("test", tf.fd, offset, length, true));
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue