mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-01 00:33:09 +00:00
d5003cafd6
minor behavior changes with this, but nothing I have seen evidence of in the wild or expect to be meaningful. The real goal is unifying our logic and simplifying the interfaces. A summary of the changes follows: - Make 'callIsSmall' actually accept a callsite so it can handle intrinsics, and simplify callers appropriately. - Nuke a completely bogus declaration of 'callIsSmall' that was still lurking in InlineCost.h... No idea how this got missed. - Teach the 'isInstructionFree' about the various more intelligent 'free' heuristics that got added to the inline cost analysis during review and testing. This mostly surrounds int->ptr and ptr->int casts. - Switch most of the interesting parts of the inline cost analysis that were essentially computing 'is this instruction free?' to use the code metrics routine instead. This way we won't keep duplicating logic. All of this is motivated by the desire to allow other passes to compute a roughly equivalent 'cost' metric for a particular basic block as the inline cost analysis. Sadly, re-using the same analysis for both is really messy because only the actual inline cost analysis is ever going to go to the contortions required for simplification, SROA analysis, etc. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@156140 91177308-0d34-0410-b5e6-96231b3b80d8
96 lines
3.3 KiB
C++
96 lines
3.3 KiB
C++
//===- CodeMetrics.h - Code cost measurements -------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file implements various weight measurements for code, helping
|
|
// the Inliner and other passes decide whether to duplicate its contents.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_ANALYSIS_CODEMETRICS_H
|
|
#define LLVM_ANALYSIS_CODEMETRICS_H
|
|
|
|
#include "llvm/ADT/DenseMap.h"
|
|
#include "llvm/Support/CallSite.h"
|
|
|
|
namespace llvm {
|
|
class BasicBlock;
|
|
class Function;
|
|
class Instruction;
|
|
class TargetData;
|
|
class Value;
|
|
|
|
/// \brief Check whether an instruction is likely to be "free" when lowered.
|
|
bool isInstructionFree(const Instruction *I, const TargetData *TD = 0);
|
|
|
|
/// \brief Check whether a call will lower to something small.
|
|
///
|
|
/// This tests checks whether this callsite will lower to something
|
|
/// significantly cheaper than a traditional call, often a single
|
|
/// instruction. Note that if isInstructionFree(CS.getInstruction()) would
|
|
/// return true, so will this function.
|
|
bool callIsSmall(ImmutableCallSite CS);
|
|
|
|
/// \brief Utility to calculate the size and a few similar metrics for a set
|
|
/// of basic blocks.
|
|
struct CodeMetrics {
|
|
/// \brief True if this function contains a call to setjmp or other functions
|
|
/// with attribute "returns twice" without having the attribute itself.
|
|
bool exposesReturnsTwice;
|
|
|
|
/// \brief True if this function calls itself.
|
|
bool isRecursive;
|
|
|
|
/// \brief True if this function contains one or more indirect branches.
|
|
bool containsIndirectBr;
|
|
|
|
/// \brief True if this function calls alloca (in the C sense).
|
|
bool usesDynamicAlloca;
|
|
|
|
/// \brief Number of instructions in the analyzed blocks.
|
|
unsigned NumInsts;
|
|
|
|
/// \brief Number of analyzed blocks.
|
|
unsigned NumBlocks;
|
|
|
|
/// \brief Keeps track of basic block code size estimates.
|
|
DenseMap<const BasicBlock *, unsigned> NumBBInsts;
|
|
|
|
/// \brief Keep track of the number of calls to 'big' functions.
|
|
unsigned NumCalls;
|
|
|
|
/// \brief The number of calls to internal functions with a single caller.
|
|
///
|
|
/// These are likely targets for future inlining, likely exposed by
|
|
/// interleaved devirtualization.
|
|
unsigned NumInlineCandidates;
|
|
|
|
/// \brief How many instructions produce vector values.
|
|
///
|
|
/// The inliner is more aggressive with inlining vector kernels.
|
|
unsigned NumVectorInsts;
|
|
|
|
/// \brief How many 'ret' instructions the blocks contain.
|
|
unsigned NumRets;
|
|
|
|
CodeMetrics() : exposesReturnsTwice(false), isRecursive(false),
|
|
containsIndirectBr(false), usesDynamicAlloca(false),
|
|
NumInsts(0), NumBlocks(0), NumCalls(0),
|
|
NumInlineCandidates(0), NumVectorInsts(0),
|
|
NumRets(0) {}
|
|
|
|
/// \brief Add information about a block to the current state.
|
|
void analyzeBasicBlock(const BasicBlock *BB, const TargetData *TD = 0);
|
|
|
|
/// \brief Add information about a function to the current state.
|
|
void analyzeFunction(Function *F, const TargetData *TD = 0);
|
|
};
|
|
}
|
|
|
|
#endif
|