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.
|
// I am not sure on If this is going to hold as an invariant. Revisit.
|
||||||
if (!Name)
|
if (!Name)
|
||||||
return Name.takeError();
|
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
|
// TODO: weak and hidden
|
||||||
if (SymRef.isExternal())
|
if (SymRef.isExternal())
|
||||||
bindings = {Linkage::Strong, Scope::Default};
|
bindings = {Linkage::Strong, Scope::Default};
|
||||||
|
@ -561,12 +550,18 @@ private:
|
||||||
JITSymbolTable[SymbolIndex] = &S;
|
JITSymbolTable[SymbolIndex] = &S;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// }
|
||||||
// TODO: The following has to be implmented.
|
// TODO: The following has to be implmented.
|
||||||
// leaving commented out to save time for future patchs
|
// leaving commented out to save time for future patchs
|
||||||
/*
|
/*
|
||||||
G->addAbsoluteSymbol(*Name, SymRef.getValue(), SymRef.st_size,
|
G->addAbsoluteSymbol(*Name, SymRef.getValue(), SymRef.st_size,
|
||||||
Linkage::Strong, Scope::Default, false);
|
Linkage::Strong, Scope::Default, false);
|
||||||
*/
|
|
||||||
|
if(SymRef.isCommon()) {
|
||||||
|
G->addCommonSymbol(*Name, Scope::Default, getCommonSection(), 0, 0,
|
||||||
|
SymRef.getValue(), false);
|
||||||
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return Error::success();
|
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