Revert "[jitlink][ELF] Add zero-fill blocks for symbols in section SHN_COMMON"

This reverts commit e9955b0843. Cannot reproduce the buildbot failures yet. Reverting in the meantime.
This commit is contained in:
Stefan Gränitz 2020-10-24 15:41:48 +02:00
parent 060a4fccf1
commit 10b1a61baf
2 changed files with 7 additions and 37 deletions

View File

@ -510,17 +510,6 @@ private:
// I am not sure on If this is going to hold as an invariant. Revisit.
if (!Name)
return Name.takeError();
if (SymRef.isCommon()) {
// Symbols in SHN_COMMON refer to uninitialized data. The st_value
// field holds alignment constraints.
Symbol &S =
G->addCommonSymbol(*Name, Scope::Default, getCommonSection(), 0,
SymRef.st_size, SymRef.getValue(), false);
JITSymbolTable[SymbolIndex] = &S;
continue;
}
// TODO: weak and hidden
if (SymRef.isExternal())
bindings = {Linkage::Strong, Scope::Default};
@ -561,12 +550,18 @@ private:
JITSymbolTable[SymbolIndex] = &S;
}
// }
// TODO: The following has to be implmented.
// leaving commented out to save time for future patchs
/*
G->addAbsoluteSymbol(*Name, SymRef.getValue(), SymRef.st_size,
Linkage::Strong, Scope::Default, false);
*/
if(SymRef.isCommon()) {
G->addCommonSymbol(*Name, Scope::Default, getCommonSection(), 0, 0,
SymRef.getValue(), false);
}
*/
}
}
return Error::success();

View File

@ -1,25 +0,0 @@
# RUN: rm -rf %t && mkdir -p %t
# RUN: llvm-mc -triple=x86_64-unknown-linux -position-independent -filetype=obj -o %t/elf_common.o %s
# RUN: llvm-jitlink -entry=load_common -noexec -check %s %t/elf_common.o
.text
.file "elf_common.c"
.globl load_common
.p2align 4, 0x90
.type load_common,@function
load_common:
# Check that common variable GOT entry is synthesized correctly. In order to
# prevent the optimizer from relaxing the edge, we use a movl instruction.
# jitlink-check: decode_operand(load_common, 4) = \
# jitlink-check: got_addr(elf_common.o, common_data) - next_pc(load_common)
# jitlink-check: *{8}(got_addr(elf_common.o, common_data)) = common_data
movl common_data@GOTPCREL(%rip), %eax
ret
.Lfunc_end0:
.size load_common, .Lfunc_end0-load_common
# Check that common is zero-filled.
# jitlink-check: *{4}(common_data) = 0
.type common_data,@object
.comm common_data,4,4