提交 933df2bd 编写于 作者: J jmasa

6806226: Signed integer overflow in growable array code causes JVM crash

Summary: Workaround the overflow by doing the intermediate calculations in an unsigned variable.
Reviewed-by: ysr, jcoomes
上级 46667db9
...@@ -43,11 +43,13 @@ void GenericGrowableArray::check_nesting() { ...@@ -43,11 +43,13 @@ void GenericGrowableArray::check_nesting() {
#endif #endif
void* GenericGrowableArray::raw_allocate(int elementSize) { void* GenericGrowableArray::raw_allocate(int elementSize) {
assert(_max >= 0, "integer overflow");
size_t byte_size = elementSize * (size_t) _max;
if (on_stack()) { if (on_stack()) {
return (void*)resource_allocate_bytes(elementSize * _max); return (void*)resource_allocate_bytes(byte_size);
} else if (on_C_heap()) { } else if (on_C_heap()) {
return (void*)AllocateHeap(elementSize * _max, "GrET in " __FILE__); return (void*)AllocateHeap(byte_size, "GrET in " __FILE__);
} else { } else {
return _arena->Amalloc(elementSize * _max); return _arena->Amalloc(byte_size);
} }
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册