From 87f146767ed709f6e354fe46f325c5b6848ad428 Mon Sep 17 00:00:00 2001 From: Bill Wendling Date: Sun, 1 Dec 2019 23:22:50 -0800 Subject: [PATCH] Place the "cold" code piece into the same section as the original function Summary: This cropped up in the Linux kernel where cold code was placed in an incompatible section. Reviewers: compnerd, vsk, tejohnson Reviewed By: vsk Subscribers: hiraditya, llvm-commits Tags: #llvm Differential Revision: https://reviews.llvm.org/D70925 --- llvm/lib/Transforms/IPO/HotColdSplitting.cpp | 3 ++ .../test/Transforms/HotColdSplit/retain-section.ll | 33 ++++++++++++++++++++++ 2 files changed, 36 insertions(+) create mode 100644 llvm/test/Transforms/HotColdSplit/retain-section.ll diff --git a/llvm/lib/Transforms/IPO/HotColdSplitting.cpp b/llvm/lib/Transforms/IPO/HotColdSplitting.cpp index 9db079c..2bd3df3 100644 --- a/llvm/lib/Transforms/IPO/HotColdSplitting.cpp +++ b/llvm/lib/Transforms/IPO/HotColdSplitting.cpp @@ -328,6 +328,9 @@ Function *HotColdSplitting::extractColdRegion( } CI->setIsNoInline(); + if (OrigF->hasSection()) + OutF->setSection(OrigF->getSection()); + markFunctionCold(*OutF, BFI != nullptr); LLVM_DEBUG(llvm::dbgs() << "Outlined Region: " << *OutF); diff --git a/llvm/test/Transforms/HotColdSplit/retain-section.ll b/llvm/test/Transforms/HotColdSplit/retain-section.ll new file mode 100644 index 0000000..8c0cf60 --- /dev/null +++ b/llvm/test/Transforms/HotColdSplit/retain-section.ll @@ -0,0 +1,33 @@ +; RUN: opt -hotcoldsplit -hotcoldsplit-threshold=0 -S < %s | FileCheck %s + +target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128" +target triple = "x86_64-apple-macosx10.14.0" + +; Retain section after cold code is split off. + +; CHECK-LABEL: @fun +; CHECK: call void @fun.cold.1{{.*}} section ".text.cold" +define void @fun() section ".text.cold" { +entry: + br i1 undef, label %if.then, label %if.else + +if.then: + ret void + +if.else: + call void @sink() + ret void +} + +; CHECK: define {{.*}} @foo{{.*}}#[[outlined_func_attr:[0-9]+]] +define void @foo() cold { + ret void +} + +declare void @sink() cold + +; CHECK: define {{.*}} @fun.cold.1{{.*}}#[[outlined_func_attr]] + +; CHECK: attributes #[[outlined_func_attr]] = { +; CHECK-SAME: cold +; CHECK-SAME: minsize -- 2.7.4