Index: llvm/lib/Target/SystemZ/SystemZAsmPrinter.cpp =================================================================== --- llvm/lib/Target/SystemZ/SystemZAsmPrinter.cpp +++ llvm/lib/Target/SystemZ/SystemZAsmPrinter.cpp @@ -16,11 +16,13 @@ #include "SystemZConstantPoolValue.h" #include "SystemZMCInstLower.h" #include "TargetInfo/SystemZTargetInfo.h" +#include "llvm/BinaryFormat/ELF.h" #include "llvm/CodeGen/MachineModuleInfoImpls.h" #include "llvm/CodeGen/TargetLoweringObjectFileImpl.h" #include "llvm/IR/Mangler.h" #include "llvm/MC/MCExpr.h" #include "llvm/MC/MCInstBuilder.h" +#include "llvm/MC/MCSectionELF.h" #include "llvm/MC/MCStreamer.h" #include "llvm/Support/TargetRegistry.h" @@ -553,6 +555,16 @@ void SystemZAsmPrinter::LowerFENTRY_CALL(const MachineInstr &MI, SystemZMCInstLower &Lower) { MCContext &Ctx = MF->getContext(); + if (MF->getFunction().hasFnAttribute("mrecord-mcount")) { + MCSymbol *DotSym = OutContext.createTempSymbol(); + OutStreamer->EmitLabel(DotSym); + OutStreamer->PushSection(); + OutStreamer->SwitchSection( + Ctx.getELFSection("__mcount_loc", ELF::SHT_PROGBITS, ELF::SHF_ALLOC)); + OutStreamer->EmitSymbolValue(DotSym, 8); + OutStreamer->PopSection(); + } + if (MF->getFunction().getFnAttribute("mnop-mcount") .getValueAsString() == "true") { EmitNop(Ctx, *OutStreamer, 6, getSubtargetInfo()); Index: llvm/lib/Target/SystemZ/SystemZISelDAGToDAG.cpp =================================================================== --- llvm/lib/Target/SystemZ/SystemZISelDAGToDAG.cpp +++ llvm/lib/Target/SystemZ/SystemZISelDAGToDAG.cpp @@ -350,6 +350,9 @@ if (F.getFnAttribute("mnop-mcount").getValueAsString() == "true" && F.getFnAttribute("fentry-call").getValueAsString() != "true") report_fatal_error("mnop-mcount only supported with fentry-call"); + if (F.hasFnAttribute("mrecord-mcount") && + F.getFnAttribute("fentry-call").getValueAsString() != "true") + report_fatal_error("mrecord-mcount only supported with fentry-call"); Subtarget = &MF.getSubtarget(); return SelectionDAGISel::runOnMachineFunction(MF); Index: llvm/test/CodeGen/SystemZ/mrecord-mcount-01.ll =================================================================== --- /dev/null +++ llvm/test/CodeGen/SystemZ/mrecord-mcount-01.ll @@ -0,0 +1,33 @@ +; RUN: llc %s -mtriple=s390x-linux-gnu -mcpu=z10 -o - -verify-machineinstrs \ +; RUN: | FileCheck %s + +define void @test1() #0 { +entry: + ret void + +; CHECK-LABEL: test1: +; CHECK: .Ltmp0: +; CHECK: .section __mcount_loc,"a",@progbits +; CHECK: .quad .Ltmp0 +; CHECK: .text +; CHECK: brasl %r0, __fentry__@PLT +; CHECK: br %r14 +} + +define void @test2() #1 { +entry: + ret void + +; CHECK-LABEL: test2: +; CHECK: .Ltmp1: +; CHECK: .section __mcount_loc,"a",@progbits +; CHECK: .quad .Ltmp1 +; CHECK: .text +; CHECK: brcl 0, .Ltmp2 +; CHECK: .Ltmp2: +; CHECK: br %r14 +} + +attributes #0 = { "fentry-call"="true" "mrecord-mcount" } +attributes #1 = { "fentry-call"="true" "mnop-mcount"="true" "mrecord-mcount" } + Index: llvm/test/CodeGen/SystemZ/mrecord-mcount-02.ll =================================================================== --- /dev/null +++ llvm/test/CodeGen/SystemZ/mrecord-mcount-02.ll @@ -0,0 +1,11 @@ +; RUN: not llc %s -mtriple=s390x-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" } +