forked from OSchip/llvm-project
[InstrProf] Set prof global variables to internal linkage if adding a comdat
COFF has a verifier check that private global variables don't have a comdat of the same name. Reviewed By: rnk Differential Revision: https://reviews.llvm.org/D131043
This commit is contained in:
parent
bc8f2f3649
commit
6e45162adf
|
@ -914,6 +914,11 @@ InstrProfiling::getOrCreateRegionCounters(InstrProfInstBase *Inc) {
|
|||
if (!NeedComdat)
|
||||
C->setSelectionKind(Comdat::NoDeduplicate);
|
||||
GV->setComdat(C);
|
||||
// COFF doesn't allow the comdat group leader to have private linkage, so
|
||||
// upgrade private linkage to internal linkage to produce a symbol table
|
||||
// entry.
|
||||
if (TT.isOSBinFormatCOFF() && GV->hasPrivateLinkage())
|
||||
GV->setLinkage(GlobalValue::InternalLinkage);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -924,8 +929,8 @@ InstrProfiling::getOrCreateRegionCounters(InstrProfInstBase *Inc) {
|
|||
CounterPtr->setVisibility(Visibility);
|
||||
CounterPtr->setSection(
|
||||
getInstrProfSectionName(IPSK_cnts, TT.getObjectFormat()));
|
||||
MaybeSetComdat(CounterPtr);
|
||||
CounterPtr->setLinkage(Linkage);
|
||||
MaybeSetComdat(CounterPtr);
|
||||
PD.RegionCounters = CounterPtr;
|
||||
if (DebugInfoCorrelate) {
|
||||
if (auto *SP = Fn->getSubprogram()) {
|
||||
|
@ -1045,7 +1050,6 @@ InstrProfiling::getOrCreateRegionCounters(InstrProfInstBase *Inc) {
|
|||
Data->setSection(getInstrProfSectionName(IPSK_data, TT.getObjectFormat()));
|
||||
Data->setAlignment(Align(INSTR_PROF_DATA_ALIGNMENT));
|
||||
MaybeSetComdat(Data);
|
||||
Data->setLinkage(Linkage);
|
||||
|
||||
PD.DataVar = Data;
|
||||
|
||||
|
|
|
@ -18,9 +18,11 @@ declare void @llvm.instrprof.increment(ptr, i64, i32, i32)
|
|||
|
||||
$foo_inline = comdat any
|
||||
$foo_extern = comdat any
|
||||
$foo_private_profn = comdat any
|
||||
|
||||
@__profn_foo_inline = linkonce_odr hidden constant [10 x i8] c"foo_inline"
|
||||
@__profn_foo_extern = linkonce_odr hidden constant [10 x i8] c"foo_extern"
|
||||
@__profn_foo_private_profn = private constant [17 x i8] c"foo_private_profn"
|
||||
|
||||
;; When value profiling is disabled, __profd_ variables are not referenced by
|
||||
;; code. We can use private linkage. When enabled, __profd_ needs to be
|
||||
|
@ -30,7 +32,7 @@ $foo_extern = comdat any
|
|||
; ELF0: @__profd_foo_inline = private global {{.*}}, section "__llvm_prf_data", comdat($__profc_foo_inline), align 8
|
||||
; ELF1: @__profd_foo_inline = linkonce_odr hidden global {{.*}}, section "__llvm_prf_data", comdat($__profc_foo_inline), align 8
|
||||
; COFF0: @__profc_foo_inline = linkonce_odr hidden global {{.*}}, section ".lprfc$M", comdat, align 8
|
||||
; COFF0: @__profd_foo_inline = private global {{.*}}, section ".lprfd$M", comdat($__profc_foo_inline), align 8
|
||||
; COFF0: @__profd_foo_inline = internal global {{.*}}, section ".lprfd$M", comdat($__profc_foo_inline), align 8
|
||||
; COFF1: @__profc_foo_inline = linkonce_odr hidden global {{.*}}, section ".lprfc$M", comdat, align 8
|
||||
; COFF1: @__profd_foo_inline = linkonce_odr hidden global {{.*}}, section ".lprfd$M", comdat, align 8
|
||||
define weak_odr void @foo_inline() comdat {
|
||||
|
@ -42,16 +44,27 @@ define weak_odr void @foo_inline() comdat {
|
|||
; ELF0: @__profd_foo_extern = private global{{.*}}, section "__llvm_prf_data", comdat($__profc_foo_extern), align 8
|
||||
; ELF1: @__profd_foo_extern = linkonce_odr hidden global{{.*}}, section "__llvm_prf_data", comdat($__profc_foo_extern), align 8
|
||||
; COFF: @__profc_foo_extern = linkonce_odr hidden global{{.*}}, section ".lprfc$M", comdat, align 8
|
||||
; COFF0: @__profd_foo_extern = private global{{.*}}, section ".lprfd$M", comdat($__profc_foo_extern), align 8
|
||||
; COFF0: @__profd_foo_extern = internal global{{.*}}, section ".lprfd$M", comdat($__profc_foo_extern), align 8
|
||||
; COFF1: @__profd_foo_extern = linkonce_odr hidden global{{.*}}, section ".lprfd$M", comdat, align 8
|
||||
define available_externally void @foo_extern() {
|
||||
call void @llvm.instrprof.increment(ptr @__profn_foo_extern, i64 0, i32 1, i32 0)
|
||||
ret void
|
||||
}
|
||||
|
||||
; ELF: @llvm.compiler.used = appending global [2 x ptr] [ptr @__profd_foo_inline, ptr @__profd_foo_extern]
|
||||
; COFF0: @llvm.compiler.used = appending global [3 x ptr] [ptr @__llvm_profile_runtime_user, ptr @__profd_foo_inline, ptr @__profd_foo_extern]
|
||||
; COFF1: @llvm.used = appending global [4 x ptr] [ptr @__llvm_profile_runtime_user, ptr @__profd_foo_inline, ptr @__profd_foo_extern, ptr @__llvm_prf_nm]
|
||||
; ELF: @__profc_foo_private_profn = private global{{.*}}, section "__llvm_prf_cnts", comdat, align 8
|
||||
; ELF0: @__profd_foo_private_profn = private global{{.*}}, section "__llvm_prf_data", comdat($__profc_foo_private_profn), align 8
|
||||
; ELF1: @__profd_foo_private_profn = private global{{.*}}, section "__llvm_prf_data", comdat($__profc_foo_private_profn), align 8
|
||||
; COFF: @__profc_foo_private_profn = internal global{{.*}}, section ".lprfc$M", comdat, align 8
|
||||
; COFF0: @__profd_foo_private_profn = internal global{{.*}}, section ".lprfd$M", comdat($__profc_foo_private_profn), align 8
|
||||
; COFF1: @__profd_foo_private_profn = internal global{{.*}}, section ".lprfd$M", comdat, align 8
|
||||
define void @foo_private_profn() comdat {
|
||||
call void @llvm.instrprof.increment(ptr @__profn_foo_private_profn, i64 0, i32 1, i32 0)
|
||||
ret void
|
||||
}
|
||||
|
||||
; ELF: @llvm.compiler.used = appending global [3 x ptr] [ptr @__profd_foo_inline, ptr @__profd_foo_extern, ptr @__profd_foo_private_profn]
|
||||
; COFF0: @llvm.compiler.used = appending global [4 x ptr] [ptr @__llvm_profile_runtime_user, ptr @__profd_foo_inline, ptr @__profd_foo_extern, ptr @__profd_foo_private_profn]
|
||||
; COFF1: @llvm.used = appending global [5 x ptr] [ptr @__llvm_profile_runtime_user, ptr @__profd_foo_inline, ptr @__profd_foo_extern, ptr @__profd_foo_private_profn, ptr @__llvm_prf_nm]
|
||||
|
||||
;--- disable.ll
|
||||
!llvm.module.flags = !{!0}
|
||||
|
|
|
@ -87,7 +87,7 @@ define linkonce_odr void @foo_inline() {
|
|||
; MACHO: @__profc_foo_extern = linkonce_odr hidden global
|
||||
; MACHO: @__profd_foo_extern = linkonce_odr hidden global
|
||||
; COFF: @__profc_foo_extern = linkonce_odr hidden global {{.*}}section ".lprfc$M", comdat, align 8
|
||||
; COFF: @__profd_foo_extern = private global {{.*}}section ".lprfd$M", comdat($__profc_foo_extern), align 8
|
||||
; COFF: @__profd_foo_extern = internal global {{.*}}section ".lprfd$M", comdat($__profc_foo_extern), align 8
|
||||
; XCOFF: @__profc_foo_extern = private global
|
||||
; XCOFF: @__profd_foo_extern = private global
|
||||
define available_externally void @foo_extern() {
|
||||
|
|
Loading…
Reference in New Issue