提交 e9127713 编写于 作者: C coleenp

7017009: Secondary out of c-heap memory error reporting out of memory

Summary: Use os::malloc() to allocate buffer to read elf symbols and check for null
Reviewed-by: zgu, phh, dsamersoff, dholmes, dcubed
上级 dd877cb2
...@@ -39,13 +39,14 @@ ElfSymbolTable::ElfSymbolTable(FILE* file, Elf_Shdr shdr) { ...@@ -39,13 +39,14 @@ ElfSymbolTable::ElfSymbolTable(FILE* file, Elf_Shdr shdr) {
// try to load the string table // try to load the string table
long cur_offset = ftell(file); long cur_offset = ftell(file);
if (cur_offset != -1) { if (cur_offset != -1) {
m_symbols = (Elf_Sym*)NEW_C_HEAP_ARRAY(char, shdr.sh_size); // call malloc so we can back up if memory allocation fails.
m_symbols = (Elf_Sym*)os::malloc(shdr.sh_size);
if (m_symbols) { if (m_symbols) {
if (fseek(file, shdr.sh_offset, SEEK_SET) || if (fseek(file, shdr.sh_offset, SEEK_SET) ||
fread((void*)m_symbols, shdr.sh_size, 1, file) != 1 || fread((void*)m_symbols, shdr.sh_size, 1, file) != 1 ||
fseek(file, cur_offset, SEEK_SET)) { fseek(file, cur_offset, SEEK_SET)) {
m_status = Decoder::file_invalid; m_status = Decoder::file_invalid;
FREE_C_HEAP_ARRAY(char, m_symbols); os::free(m_symbols);
m_symbols = NULL; m_symbols = NULL;
} }
} }
...@@ -59,7 +60,7 @@ ElfSymbolTable::ElfSymbolTable(FILE* file, Elf_Shdr shdr) { ...@@ -59,7 +60,7 @@ ElfSymbolTable::ElfSymbolTable(FILE* file, Elf_Shdr shdr) {
ElfSymbolTable::~ElfSymbolTable() { ElfSymbolTable::~ElfSymbolTable() {
if (m_symbols != NULL) { if (m_symbols != NULL) {
FREE_C_HEAP_ARRAY(char, m_symbols); os::free(m_symbols);
} }
if (m_next != NULL) { if (m_next != NULL) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册