blob: 886b1b0f2b2a87e05add031ccee4884f3da3b07e [file] [log] [blame]
Tom Stellard5cbb53c2014-11-03 19:49:05 +00001//===-- AMDGPUAlwaysInlinePass.cpp - Promote Allocas ----------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10/// \file
11/// This pass marks all internal functions as always_inline and creates
12/// duplicates of all other functions a marks the duplicates as always_inline.
13//
14//===----------------------------------------------------------------------===//
15
16#include "AMDGPU.h"
17#include "llvm/IR/Module.h"
18#include "llvm/Transforms/Utils/Cloning.h"
19
20using namespace llvm;
21
22namespace {
23
24class AMDGPUAlwaysInline : public ModulePass {
Tom Stellard5cbb53c2014-11-03 19:49:05 +000025 static char ID;
26
27public:
28 AMDGPUAlwaysInline() : ModulePass(ID) { }
29 bool runOnModule(Module &M) override;
30 const char *getPassName() const override { return "AMDGPU Always Inline Pass"; }
31};
32
33} // End anonymous namespace
34
35char AMDGPUAlwaysInline::ID = 0;
36
37bool AMDGPUAlwaysInline::runOnModule(Module &M) {
Nikolay Haustoveba80892016-08-31 11:18:33 +000038 std::vector<GlobalAlias*> AliasesToRemove;
Matt Arsenaultca95d442015-07-13 19:08:36 +000039 std::vector<Function *> FuncsToClone;
Tom Stellard5cbb53c2014-11-03 19:49:05 +000040
Nikolay Haustoveba80892016-08-31 11:18:33 +000041 for (GlobalAlias &A : M.aliases()) {
42 if (Function* F = dyn_cast<Function>(A.getAliasee())) {
43 A.replaceAllUsesWith(F);
44 AliasesToRemove.push_back(&A);
45 }
46 }
47
48 for (GlobalAlias* A : AliasesToRemove) {
49 A->eraseFromParent();
50 }
51
Matt Arsenaultca95d442015-07-13 19:08:36 +000052 for (Function &F : M) {
Matt Arsenaultdeaef8e2015-04-22 17:10:44 +000053 if (!F.hasLocalLinkage() && !F.isDeclaration() && !F.use_empty() &&
54 !F.hasFnAttribute(Attribute::NoInline))
Tom Stellard5cbb53c2014-11-03 19:49:05 +000055 FuncsToClone.push_back(&F);
56 }
57
58 for (Function *F : FuncsToClone) {
59 ValueToValueMapTy VMap;
Peter Collingbournedba99562016-05-10 20:23:24 +000060 Function *NewFunc = CloneFunction(F, VMap);
Tom Stellard5cbb53c2014-11-03 19:49:05 +000061 NewFunc->setLinkage(GlobalValue::InternalLinkage);
Tom Stellard5cbb53c2014-11-03 19:49:05 +000062 F->replaceAllUsesWith(NewFunc);
63 }
64
Matt Arsenaultca95d442015-07-13 19:08:36 +000065 for (Function &F : M) {
Matt Arsenaultdeaef8e2015-04-22 17:10:44 +000066 if (F.hasLocalLinkage() && !F.hasFnAttribute(Attribute::NoInline)) {
Tom Stellard5cbb53c2014-11-03 19:49:05 +000067 F.addFnAttr(Attribute::AlwaysInline);
68 }
69 }
70 return false;
71}
72
73ModulePass *llvm::createAMDGPUAlwaysInlinePass() {
74 return new AMDGPUAlwaysInline();
75}