forked from OSchip/llvm-project
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:
parent
060a4fccf1
commit
10b1a61baf
|
@ -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();
|
||||
|
|
|
@ -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
|
Loading…
Reference in New Issue