llvm-mirror/include/llvm/Analysis/Expressions.h
Chris Lattner 9f3245e86b More functionality, renamed API
llvm-svn: 241
2001-07-21 19:07:19 +00:00

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