https://github.com/pmur updated https://github.com/llvm/llvm-project/pull/184641
>From d615adb6a4b8737277441a23f04615efd99667dc Mon Sep 17 00:00:00 2001 From: Paul Murphy <[email protected]> Date: Tue, 3 Mar 2026 14:43:18 -0600 Subject: [PATCH 1/3] [LLVM][CodeGen][X86] Support mnop-mcount and mrecord-mcount attributes Support mnop-mcount and mrecord-mcount attributes when used with the fentry-call=true attribute. Similar to SystemZ, use the mnop-mcount attribute to place a nop instead of a call to __fentry__. Likewise, use the mrecord-mcount attribute to record the location of the call to fentry (or nop if used with the above) to a section named __mcount_loc. --- llvm/lib/Target/X86/X86ISelDAGToDAG.cpp | 14 ++++-- llvm/lib/Target/X86/X86MCInstLower.cpp | 18 ++++++++ llvm/test/CodeGen/X86/mnop-mcount-01.ll | 36 +++++++++++++++ llvm/test/CodeGen/X86/mnop-mcount-02.ll | 11 +++++ llvm/test/CodeGen/X86/mrecord-mcount-01.ll | 51 ++++++++++++++++++++++ llvm/test/CodeGen/X86/mrecord-mcount-02.ll | 11 +++++ 6 files changed, 138 insertions(+), 3 deletions(-) create mode 100644 llvm/test/CodeGen/X86/mnop-mcount-01.ll create mode 100644 llvm/test/CodeGen/X86/mnop-mcount-02.ll create mode 100644 llvm/test/CodeGen/X86/mrecord-mcount-01.ll create mode 100644 llvm/test/CodeGen/X86/mrecord-mcount-02.ll diff --git a/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp b/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp index 101ea3e231a5c..aa7efb8a05e1c 100644 --- a/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp +++ b/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp @@ -179,11 +179,19 @@ namespace { bool runOnMachineFunction(MachineFunction &MF) override { // Reset the subtarget each time through. Subtarget = &MF.getSubtarget<X86Subtarget>(); - IndirectTlsSegRefs = MF.getFunction().hasFnAttribute( - "indirect-tls-seg-refs"); + const Function &F = MF.getFunction(); + + IndirectTlsSegRefs = F.hasFnAttribute("indirect-tls-seg-refs"); + + if (F.getFnAttribute("fentry-call").getValueAsString() != "true") { + if (F.hasFnAttribute("mnop-mcount")) + report_fatal_error("mnop-mcount only supported with fentry-call"); + if (F.hasFnAttribute("mrecord-mcount")) + report_fatal_error("mrecord-mcount only supported with fentry-call"); + } // OptFor[Min]Size are used in pattern predicates that isel is matching. - OptForMinSize = MF.getFunction().hasMinSize(); + OptForMinSize = F.hasMinSize(); return SelectionDAGISel::runOnMachineFunction(MF); } diff --git a/llvm/lib/Target/X86/X86MCInstLower.cpp b/llvm/lib/Target/X86/X86MCInstLower.cpp index 4ef4718e1b01c..8bbd40d973fab 100644 --- a/llvm/lib/Target/X86/X86MCInstLower.cpp +++ b/llvm/lib/Target/X86/X86MCInstLower.cpp @@ -26,6 +26,7 @@ #include "llvm/ADT/STLExtras.h" #include "llvm/ADT/SmallString.h" #include "llvm/ADT/StringExtras.h" +#include "llvm/BinaryFormat/ELF.h" #include "llvm/CodeGen/MachineBranchProbabilityInfo.h" #include "llvm/CodeGen/MachineConstantPool.h" #include "llvm/CodeGen/MachineFunction.h" @@ -44,6 +45,7 @@ #include "llvm/MC/MCInst.h" #include "llvm/MC/MCInstBuilder.h" #include "llvm/MC/MCSection.h" +#include "llvm/MC/MCSectionELF.h" #include "llvm/MC/MCStreamer.h" #include "llvm/MC/MCSymbol.h" #include "llvm/MC/TargetRegistry.h" @@ -885,6 +887,22 @@ void X86AsmPrinter::LowerFENTRY_CALL(const MachineInstr &MI, X86MCInstLower &MCIL) { bool Is64Bits = Subtarget->is64Bit(); MCContext &Ctx = OutStreamer->getContext(); + + if (MF->getFunction().hasFnAttribute("mrecord-mcount")) { + MCSymbol *DotSym = OutContext.createTempSymbol(); + OutStreamer->pushSection(); + OutStreamer->switchSection( + Ctx.getELFSection("__mcount_loc", ELF::SHT_PROGBITS, ELF::SHF_ALLOC)); + OutStreamer->emitSymbolValue(DotSym, Is64Bits ? 8 : 4); + OutStreamer->popSection(); + OutStreamer->emitLabel(DotSym); + } + + if (MF->getFunction().hasFnAttribute("mnop-mcount")) { + emitX86Nops(*OutStreamer, 5, Subtarget); + return; + } + MCSymbol *fentry = Ctx.getOrCreateSymbol("__fentry__"); const MCSymbolRefExpr *Op = MCSymbolRefExpr::create(fentry, Ctx); diff --git a/llvm/test/CodeGen/X86/mnop-mcount-01.ll b/llvm/test/CodeGen/X86/mnop-mcount-01.ll new file mode 100644 index 0000000000000..ede06b74bcc8e --- /dev/null +++ b/llvm/test/CodeGen/X86/mnop-mcount-01.ll @@ -0,0 +1,36 @@ +; RUN: llc %s -mtriple=x86_64-linux-gnu -o - -verify-machineinstrs \ +; RUN: | FileCheck --check-prefixes=X64 %s +; RUN: llc %s -mtriple=i686-linux-gnu -o - -verify-machineinstrs \ +; RUN: | FileCheck --check-prefix=X86 %s + +define void @test1() #0 { +entry: + ret void + +; X64-LABEL: @test1 +; X64: callq __fentry__ +; X64: retq +; X86-LABEL: @test1 +; X86: calll __fentry__ +; X86: retl +} + +define void @test2() #1 { +entry: + ret void + +; X64-LABEL: @test2 +; X64-NOT: callq __fentry__ +; X64: nopl 8(%rax,%rax) +; X64: retq +; X86-LABEL: @test2 +; X86-NOT: calll __fentry__ +; X86: xchgw %ax, %ax +; X86: xchgw %ax, %ax +; X86: nop +; X86: retl +} + +attributes #0 = { "fentry-call"="true" } +attributes #1 = { "fentry-call"="true" "mnop-mcount" } + diff --git a/llvm/test/CodeGen/X86/mnop-mcount-02.ll b/llvm/test/CodeGen/X86/mnop-mcount-02.ll new file mode 100644 index 0000000000000..9721278d66430 --- /dev/null +++ b/llvm/test/CodeGen/X86/mnop-mcount-02.ll @@ -0,0 +1,11 @@ +; RUN: not --crash llc %s -mtriple=x86_64-linux-gnu -o - 2>&1 | FileCheck %s +; RUN: not --crash llc %s -mtriple=i686-linux-gnu -o - 2>&1 | FileCheck %s +; +; CHECK: LLVM ERROR: mnop-mcount only supported with fentry-call + +define void @test1() #0 { +entry: + ret void +} + +attributes #0 = { "instrument-function-entry-inlined"="mcount" "mnop-mcount" } diff --git a/llvm/test/CodeGen/X86/mrecord-mcount-01.ll b/llvm/test/CodeGen/X86/mrecord-mcount-01.ll new file mode 100644 index 0000000000000..cc27f1eb791ad --- /dev/null +++ b/llvm/test/CodeGen/X86/mrecord-mcount-01.ll @@ -0,0 +1,51 @@ +; RUN: llc %s -mtriple=x86_64-linux-gnu -o - -verify-machineinstrs \ +; RUN: | FileCheck --check-prefix=X64 %s +; RUN: llc %s -mtriple=i686-linux-gnu -o - -verify-machineinstrs \ +; RUN: | FileCheck --check-prefix=X86 %s + +define void @test1() #0 { +entry: + ret void + +; X64-LABEL: test1: +; X64: .section __mcount_loc,"a",@progbits +; X64: .quad .Ltmp0 +; X64: .text +; X64: .Ltmp0: +; X64: callq __fentry__ +; X64: retq +; X86-LABEL: test1: +; X86: .section __mcount_loc,"a",@progbits +; X86: .long .Ltmp0 +; X86: .text +; X86: .Ltmp0: +; X86: calll __fentry__ +; X86: retl +} + +define void @test2() #1 { +entry: + ret void + +; X64-LABEL: test2: +; X64: .section __mcount_loc,"a",@progbits +; X64: .quad .Ltmp1 +; X64: .text +; X64: .Ltmp1: +; X64: nopl 8(%rax,%rax) +; X64-NOT: callq __fentry__ +; X64: retq +; X86-LABEL: test2: +; X86: .section __mcount_loc,"a",@progbits +; X86: .long .Ltmp1 +; X86: .text +; X86: .Ltmp1: +; X86: xchgw %ax, %ax +; X86: xchgw %ax, %ax +; X86: nop +; X86-NOT: calll __fentry__ +; X86: retl +} + +attributes #0 = { "fentry-call"="true" "mrecord-mcount" } +attributes #1 = { "fentry-call"="true" "mnop-mcount" "mrecord-mcount" } diff --git a/llvm/test/CodeGen/X86/mrecord-mcount-02.ll b/llvm/test/CodeGen/X86/mrecord-mcount-02.ll new file mode 100644 index 0000000000000..2ee317c77a703 --- /dev/null +++ b/llvm/test/CodeGen/X86/mrecord-mcount-02.ll @@ -0,0 +1,11 @@ +; RUN: not --crash llc %s -mtriple=x86_64-linux-gnu -o - 2>&1 | FileCheck %s +; RUN: not --crash llc %s -mtriple=i686-linux-gnu -o - 2>&1 | FileCheck %s +; +; CHECK: LLVM ERROR: mrecord-mcount only supported with fentry-call + +define void @test1() #0 { +entry: + ret void +} + +attributes #0 = { "instrument-function-entry-inlined"="mcount" "mrecord-mcount" } >From aae97742d55d7589dcfcaf543018fd5bdfb10ed0 Mon Sep 17 00:00:00 2001 From: Paul Murphy <[email protected]> Date: Wed, 4 Mar 2026 08:47:16 -0600 Subject: [PATCH 2/3] [clang] enable -mnop-mcount -mrecord-mcount for x86 These are gated by -mfentry. --- clang/lib/Driver/ToolChains/Clang.cpp | 6 ++++-- clang/test/CodeGen/mnop-mcount.c | 16 ++++++++++++++++ clang/test/CodeGen/mrecord-mcount.c | 16 ++++++++++++++++ clang/test/Driver/mcount.c | 5 ++--- 4 files changed, 38 insertions(+), 5 deletions(-) diff --git a/clang/lib/Driver/ToolChains/Clang.cpp b/clang/lib/Driver/ToolChains/Clang.cpp index e860136aae5b3..999074889a8ef 100644 --- a/clang/lib/Driver/ToolChains/Clang.cpp +++ b/clang/lib/Driver/ToolChains/Clang.cpp @@ -6884,14 +6884,16 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA, << A->getAsString(Args) << TripleStr; } if (Arg *A = Args.getLastArg(options::OPT_mnop_mcount)) { - if (Arch == llvm::Triple::systemz) + if (Arch == llvm::Triple::systemz || + (TC.getTriple().isX86() && TC.getTriple().isOSBinFormatELF())) A->render(Args, CmdArgs); else D.Diag(diag::err_drv_unsupported_opt_for_target) << A->getAsString(Args) << TripleStr; } if (Arg *A = Args.getLastArg(options::OPT_mrecord_mcount)) { - if (Arch == llvm::Triple::systemz) + if (Arch == llvm::Triple::systemz || + (TC.getTriple().isX86() && TC.getTriple().isOSBinFormatELF())) A->render(Args, CmdArgs); else D.Diag(diag::err_drv_unsupported_opt_for_target) diff --git a/clang/test/CodeGen/mnop-mcount.c b/clang/test/CodeGen/mnop-mcount.c index ebb21cc560e37..9455043b0d4e3 100644 --- a/clang/test/CodeGen/mnop-mcount.c +++ b/clang/test/CodeGen/mnop-mcount.c @@ -6,6 +6,22 @@ // RUN: %s 2>&1 | FileCheck -check-prefix=NOPG %s // RUN: %clang_cc1 -mnop-mcount -triple s390x-ibm-linux -emit-llvm -o - %s \ // RUN: 2>&1 | FileCheck -check-prefix=NOPG %s +// RUN: %clang_cc1 -pg -mfentry -mnop-mcount -triple x86_64-unknown-linux -emit-llvm \ +// RUN: -o - %s 2>&1 | FileCheck %s +// RUN: not %clang_cc1 -pg -mnop-mcount -triple x86_64-unknown-linux -emit-llvm -o - \ +// RUN: %s 2>&1 | FileCheck -check-prefix=NOMFENTRY %s +// RUN: %clang_cc1 -mfentry -mnop-mcount -triple x86_64-unknown-linux -emit-llvm -o - \ +// RUN: %s 2>&1 | FileCheck -check-prefix=NOPG %s +// RUN: %clang_cc1 -mnop-mcount -triple x86_64-unknown-linux -emit-llvm -o - %s \ +// RUN: 2>&1 | FileCheck -check-prefix=NOPG %s +// RUN: %clang_cc1 -pg -mfentry -mnop-mcount -triple i686-unknown-linux -emit-llvm \ +// RUN: -o - %s 2>&1 | FileCheck %s +// RUN: not %clang_cc1 -pg -mnop-mcount -triple i686-unknown-linux -emit-llvm -o - \ +// RUN: %s 2>&1 | FileCheck -check-prefix=NOMFENTRY %s +// RUN: %clang_cc1 -mfentry -mnop-mcount -triple i686-unknown-linux -emit-llvm -o - \ +// RUN: %s 2>&1 | FileCheck -check-prefix=NOPG %s +// RUN: %clang_cc1 -mnop-mcount -triple i686-unknown-linux -emit-llvm -o - %s \ +// RUN: 2>&1 | FileCheck -check-prefix=NOPG %s int foo(void) { return 0; diff --git a/clang/test/CodeGen/mrecord-mcount.c b/clang/test/CodeGen/mrecord-mcount.c index 292a807073cef..f00b4594f5d8e 100644 --- a/clang/test/CodeGen/mrecord-mcount.c +++ b/clang/test/CodeGen/mrecord-mcount.c @@ -6,6 +6,22 @@ // RUN: %s 2>&1 | FileCheck -check-prefix=NOPG %s // RUN: %clang_cc1 -mrecord-mcount -triple s390x-ibm-linux -emit-llvm -o - %s \ // RUN: 2>&1 | FileCheck -check-prefix=NOPG %s +// RUN: %clang_cc1 -pg -mfentry -mrecord-mcount -triple x86_64-unknown-linux -emit-llvm \ +// RUN: -o - %s 2>&1 | FileCheck %s +// RUN: not %clang_cc1 -pg -mrecord-mcount -triple x86_64-unknown-linux -emit-llvm -o - \ +// RUN: %s 2>&1 | FileCheck -check-prefix=NOMFENTRY %s +// RUN: %clang_cc1 -mfentry -mrecord-mcount -triple x86_64-unknown-linux -emit-llvm -o - \ +// RUN: %s 2>&1 | FileCheck -check-prefix=NOPG %s +// RUN: %clang_cc1 -mrecord-mcount -triple x86_64-unknown-linux -emit-llvm -o - %s \ +// RUN: 2>&1 | FileCheck -check-prefix=NOPG %s +// RUN: %clang_cc1 -pg -mfentry -mrecord-mcount -triple i686-unknown-linux -emit-llvm \ +// RUN: -o - %s 2>&1 | FileCheck %s +// RUN: not %clang_cc1 -pg -mrecord-mcount -triple i686-unknown-linux -emit-llvm -o - \ +// RUN: %s 2>&1 | FileCheck -check-prefix=NOMFENTRY %s +// RUN: %clang_cc1 -mfentry -mrecord-mcount -triple i686-unknown-linux -emit-llvm -o - \ +// RUN: %s 2>&1 | FileCheck -check-prefix=NOPG %s +// RUN: %clang_cc1 -mrecord-mcount -triple i686-unknown-linux -emit-llvm -o - %s \ +// RUN: 2>&1 | FileCheck -check-prefix=NOPG %s int foo(void) { return 0; diff --git a/clang/test/Driver/mcount.c b/clang/test/Driver/mcount.c index 70f554745b9c3..d50055f90344e 100644 --- a/clang/test/Driver/mcount.c +++ b/clang/test/Driver/mcount.c @@ -1,12 +1,11 @@ // RUN: %clang --target=s390x -c -### %s -mnop-mcount -mrecord-mcount 2>&1 | FileCheck %s +// RUN: %clang --target=x86_64 -c -### %s -mnop-mcount -mrecord-mcount 2>&1 | FileCheck %s +// RUN: %clang --target=i686 -c -### %s -mnop-mcount -mrecord-mcount 2>&1 | FileCheck %s // CHECK: "-mnop-mcount" // CHECK: "-mrecord-mcount" -// RUN: not %clang --target=x86_64 -c -### %s -mnop-mcount -mrecord-mcount 2>&1 | FileCheck --check-prefix=ERR1 %s // RUN: not %clang --target=aarch64 -c -### %s -mnop-mcount -mrecord-mcount 2>&1 | FileCheck --check-prefix=ERR2 %s -// ERR1: error: unsupported option '-mnop-mcount' for target 'x86_64' -// ERR1: error: unsupported option '-mrecord-mcount' for target 'x86_64' // ERR2: error: unsupported option '-mnop-mcount' for target 'aarch64' // ERR2: error: unsupported option '-mrecord-mcount' for target 'aarch64' >From 18c218ed16d212d68e64afc30f1805bd2533ad25 Mon Sep 17 00:00:00 2001 From: Paul Murphy <[email protected]> Date: Wed, 27 May 2026 13:42:33 -0500 Subject: [PATCH 3/3] [LLVM][CodeGen][X86] Support larger NOOPs on x86 when available The mnop-mcount attribute benefits from using a single no-op instruction instead of 3 when supported. Update codegen to support single instruction 3-10 byte NOOPs. --- llvm/lib/Target/X86/X86MCInstLower.cpp | 22 ++++++++++++---------- llvm/test/CodeGen/X86/mnop-mcount-01.ll | 9 +++++++++ llvm/test/CodeGen/X86/mrecord-mcount-01.ll | 17 +++++++++++++++++ 3 files changed, 38 insertions(+), 10 deletions(-) diff --git a/llvm/lib/Target/X86/X86MCInstLower.cpp b/llvm/lib/Target/X86/X86MCInstLower.cpp index 8bbd40d973fab..9144fbb3d87cb 100644 --- a/llvm/lib/Target/X86/X86MCInstLower.cpp +++ b/llvm/lib/Target/X86/X86MCInstLower.cpp @@ -664,9 +664,8 @@ static unsigned emitNop(MCStreamer &OS, unsigned NumBytes, // target cpu. 15-bytes is the longest single NOP instruction, but some // platforms can't decode the longest forms efficiently. unsigned MaxNopLength = 1; + unsigned BaseReg = X86::RAX; if (Subtarget->is64Bit()) { - // FIXME: We can use NOOPL on 32-bit targets with FeatureNOPL, but the - // IndexReg/BaseReg below need to be updated. if (Subtarget->hasFeature(X86::TuningFast7ByteNOP)) MaxNopLength = 7; else if (Subtarget->hasFeature(X86::TuningFast15ByteNOP)) @@ -675,16 +674,19 @@ static unsigned emitNop(MCStreamer &OS, unsigned NumBytes, MaxNopLength = 11; else MaxNopLength = 10; - } if (Subtarget->is32Bit()) + } else if (Subtarget->is32Bit() && Subtarget->getFeatureBits()[X86::FeatureNOPL]) { + BaseReg = X86::EAX; + MaxNopLength = 10; + } + else if (Subtarget->is32Bit()) MaxNopLength = 2; // Cap a single nop emission at the profitable value for the target NumBytes = std::min(NumBytes, MaxNopLength); unsigned NopSize; - unsigned Opc, BaseReg, ScaleVal, IndexReg, Displacement, SegmentReg; + unsigned Opc, ScaleVal, IndexReg, Displacement, SegmentReg; IndexReg = Displacement = SegmentReg = 0; - BaseReg = X86::RAX; ScaleVal = 1; switch (NumBytes) { case 0: @@ -711,13 +713,13 @@ static unsigned emitNop(MCStreamer &OS, unsigned NumBytes, NopSize = 5; Opc = X86::NOOPL; Displacement = 8; - IndexReg = X86::RAX; + IndexReg = BaseReg; break; case 6: NopSize = 6; Opc = X86::NOOPW; Displacement = 8; - IndexReg = X86::RAX; + IndexReg = BaseReg; break; case 7: NopSize = 7; @@ -728,19 +730,19 @@ static unsigned emitNop(MCStreamer &OS, unsigned NumBytes, NopSize = 8; Opc = X86::NOOPL; Displacement = 512; - IndexReg = X86::RAX; + IndexReg = BaseReg; break; case 9: NopSize = 9; Opc = X86::NOOPW; Displacement = 512; - IndexReg = X86::RAX; + IndexReg = BaseReg; break; default: NopSize = 10; Opc = X86::NOOPW; Displacement = 512; - IndexReg = X86::RAX; + IndexReg = BaseReg; SegmentReg = X86::CS; break; } diff --git a/llvm/test/CodeGen/X86/mnop-mcount-01.ll b/llvm/test/CodeGen/X86/mnop-mcount-01.ll index ede06b74bcc8e..4e99774f1d08e 100644 --- a/llvm/test/CodeGen/X86/mnop-mcount-01.ll +++ b/llvm/test/CodeGen/X86/mnop-mcount-01.ll @@ -2,6 +2,8 @@ ; RUN: | FileCheck --check-prefixes=X64 %s ; RUN: llc %s -mtriple=i686-linux-gnu -o - -verify-machineinstrs \ ; RUN: | FileCheck --check-prefix=X86 %s +; RUN: llc %s -mtriple=i686-linux-gnu -mcpu=pentium_pro -o - -verify-machineinstrs \ +; RUN: | FileCheck --check-prefix=PPRO %s define void @test1() #0 { entry: @@ -13,6 +15,9 @@ entry: ; X86-LABEL: @test1 ; X86: calll __fentry__ ; X86: retl +; PPRO-LABEL: @test1 +; PPRO: calll __fentry__ +; PPRO: retl } define void @test2() #1 { @@ -29,6 +34,10 @@ entry: ; X86: xchgw %ax, %ax ; X86: nop ; X86: retl +; PPRO-LABEL: @test2 +; PPRO: nopl 8(%eax,%eax) +; PPRO-NOT: calll __fentry__ +; PPRO: retl } attributes #0 = { "fentry-call"="true" } diff --git a/llvm/test/CodeGen/X86/mrecord-mcount-01.ll b/llvm/test/CodeGen/X86/mrecord-mcount-01.ll index cc27f1eb791ad..829b111a87504 100644 --- a/llvm/test/CodeGen/X86/mrecord-mcount-01.ll +++ b/llvm/test/CodeGen/X86/mrecord-mcount-01.ll @@ -2,6 +2,8 @@ ; RUN: | FileCheck --check-prefix=X64 %s ; RUN: llc %s -mtriple=i686-linux-gnu -o - -verify-machineinstrs \ ; RUN: | FileCheck --check-prefix=X86 %s +; RUN: llc %s -mtriple=i686-linux-gnu -mcpu=pentium_pro -o - -verify-machineinstrs \ +; RUN: | FileCheck --check-prefix=PPRO %s define void @test1() #0 { entry: @@ -21,6 +23,13 @@ entry: ; X86: .Ltmp0: ; X86: calll __fentry__ ; X86: retl +; PPRO-LABEL: test1: +; PPRO: .section __mcount_loc,"a",@progbits +; PPRO: .long .Ltmp0 +; PPRO: .text +; PPRO: .Ltmp0: +; PPRO: calll __fentry__ +; PPRO: retl } define void @test2() #1 { @@ -45,6 +54,14 @@ entry: ; X86: nop ; X86-NOT: calll __fentry__ ; X86: retl +; PPRO-LABEL: test2: +; PPRO: .section __mcount_loc,"a",@progbits +; PPRO: .long .Ltmp1 +; PPRO: .text +; PPRO: .Ltmp1: +; PPRO: nopl 8(%eax,%eax) +; PPRO-NOT: calll __fentry__ +; PPRO: retl } attributes #0 = { "fentry-call"="true" "mrecord-mcount" } _______________________________________________ cfe-commits mailing list [email protected] https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
