mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-09 21:32:49 +00:00
9f3245e86b
llvm-svn: 241
59 lines
1.9 KiB
C++
59 lines
1.9 KiB
C++
//===- llvm/Analysis/Expressions.h - Expression Analysis Utils ---*- C++ -*--=//
|
|
//
|
|
// This file defines a package of expression analysis utilties:
|
|
//
|
|
// ClassifyExpression: Analyze an expression to determine the complexity of the
|
|
// expression, and which other variables it depends on.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_ANALYSIS_EXPRESSIONS_H
|
|
#define LLVM_ANALYSIS_EXPRESSIONS_H
|
|
|
|
#include <assert.h>
|
|
class Value;
|
|
class ConstPoolInt;
|
|
|
|
namespace analysis {
|
|
|
|
struct ExprType;
|
|
|
|
// ClassifyExpression: Analyze an expression to determine the complexity of the
|
|
// expression, and which other values it depends on.
|
|
//
|
|
ExprType ClassifyExpression(Value *Expr);
|
|
|
|
// ExprType - Represent an expression of the form CONST*VAR+CONST
|
|
// or simpler. The expression form that yields the least information about the
|
|
// expression is just the Linear form with no offset.
|
|
//
|
|
struct ExprType {
|
|
enum ExpressionType {
|
|
Constant, // Expr is a simple constant, Offset is value
|
|
Linear, // Expr is linear expr, Value is Var+Offset
|
|
ScaledLinear, // Expr is scaled linear exp, Value is Scale*Var+Offset
|
|
} ExprTy;
|
|
|
|
const ConstPoolInt *Offset; // Offset of expr, or null if 0
|
|
Value *Var; // Var referenced, if Linear or above (null if 0)
|
|
const ConstPoolInt *Scale; // Scale of var if ScaledLinear expr (null if 1)
|
|
|
|
inline ExprType(const ConstPoolInt *CPV = 0) {
|
|
Offset = CPV; Var = 0; Scale = 0;
|
|
ExprTy = Constant;
|
|
}
|
|
inline ExprType(Value *Val) {
|
|
Var = Val; Offset = Scale = 0;
|
|
ExprTy = Var ? Linear : Constant;
|
|
}
|
|
inline ExprType(const ConstPoolInt *scale, Value *var,
|
|
const ConstPoolInt *offset) {
|
|
Scale = scale; Var = var; Offset = offset;
|
|
ExprTy = Scale ? ScaledLinear : (Var ? Linear : Constant);
|
|
}
|
|
};
|
|
|
|
} // End namespace analysis
|
|
|
|
#endif
|