mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 02:33:33 +00:00
5a9cd4d44e
a cache of assumptions for a single function, and an immutable pass that manages those caches. The motivation for this change is two fold. Immutable analyses are really hacks around the current pass manager design and don't exist in the new design. This is usually OK, but it requires that the core logic of an immutable pass be reasonably partitioned off from the pass logic. This change does precisely that. As a consequence it also paves the way for the *many* utility functions that deal in the assumptions to live in both pass manager worlds by creating an separate non-pass object with its own independent API that they all rely on. Now, the only bits of the system that deal with the actual pass mechanics are those that actually need to deal with the pass mechanics. Once this separation is made, several simplifications become pretty obvious in the assumption cache itself. Rather than using a set and callback value handles, it can just be a vector of weak value handles. The callers can easily skip the handles that are null, and eventually we can wrap all of this up behind a filter iterator. For now, this adds boiler plate to the various passes, but this kind of boiler plate will end up making it possible to port these passes to the new pass manager, and so it will end up factored away pretty reasonably. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@225131 91177308-0d34-0410-b5e6-96231b3b80d8
51 lines
1.7 KiB
C++
51 lines
1.7 KiB
C++
//===- PromoteMemToReg.h - Promote Allocas to Scalars -----------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file exposes an interface to promote alloca instructions to SSA
|
|
// registers, by using the SSA construction algorithm.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_TRANSFORMS_UTILS_PROMOTEMEMTOREG_H
|
|
#define LLVM_TRANSFORMS_UTILS_PROMOTEMEMTOREG_H
|
|
|
|
#include "llvm/ADT/ArrayRef.h"
|
|
|
|
namespace llvm {
|
|
|
|
class AllocaInst;
|
|
class DominatorTree;
|
|
class AliasSetTracker;
|
|
class AssumptionCache;
|
|
|
|
/// \brief Return true if this alloca is legal for promotion.
|
|
///
|
|
/// This is true if there are only loads, stores, and lifetime markers
|
|
/// (transitively) using this alloca. This also enforces that there is only
|
|
/// ever one layer of bitcasts or GEPs between the alloca and the lifetime
|
|
/// markers.
|
|
bool isAllocaPromotable(const AllocaInst *AI);
|
|
|
|
/// \brief Promote the specified list of alloca instructions into scalar
|
|
/// registers, inserting PHI nodes as appropriate.
|
|
///
|
|
/// This function makes use of DominanceFrontier information. This function
|
|
/// does not modify the CFG of the function at all. All allocas must be from
|
|
/// the same function.
|
|
///
|
|
/// If AST is specified, the specified tracker is updated to reflect changes
|
|
/// made to the IR.
|
|
void PromoteMemToReg(ArrayRef<AllocaInst *> Allocas, DominatorTree &DT,
|
|
AliasSetTracker *AST = nullptr,
|
|
AssumptionCache *AC = nullptr);
|
|
|
|
} // End llvm namespace
|
|
|
|
#endif
|