1 //===-- llvm/Analysis/DemandedBits.h - Determine demanded bits --*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This pass implements a demanded bits analysis. A demanded bit is one that
11 // contributes to a result; bits that are not demanded can be either zero or
12 // one without affecting control or data flow. For example in this sequence:
14 // %1 = add i32 %x, %y
15 // %2 = trunc i32 %1 to i16
17 // Only the lowest 16 bits of %1 are demanded; the rest are removed by the
20 //===----------------------------------------------------------------------===//
22 #ifndef LLVM_ANALYSIS_DEMANDED_BITS_H
23 #define LLVM_ANALYSIS_DEMANDED_BITS_H
25 #include "llvm/Pass.h"
26 #include "llvm/ADT/APInt.h"
27 #include "llvm/ADT/DenseMap.h"
28 #include "llvm/ADT/SmallPtrSet.h"
36 class AssumptionCache;
38 struct DemandedBits : public FunctionPass {
39 static char ID; // Pass identification, replacement for typeid
42 bool runOnFunction(Function& F) override;
43 void getAnalysisUsage(AnalysisUsage& AU) const override;
45 /// Return the bits demanded from instruction I.
46 APInt getDemandedBits(Instruction *I);
48 /// Return true if, during analysis, I could not be reached.
49 bool isInstructionDead(Instruction *I);
52 void performAnalysis();
53 void determineLiveOperandBits(const Instruction *UserI,
54 const Instruction *I, unsigned OperandNo,
55 const APInt &AOut, APInt &AB,
56 APInt &KnownZero, APInt &KnownOne,
57 APInt &KnownZero2, APInt &KnownOne2);
64 // The set of visited instructions (non-integer-typed only).
65 SmallPtrSet<Instruction*, 128> Visited;
66 DenseMap<Instruction *, APInt> AliveBits;
69 /// Create a demanded bits analysis pass.
70 FunctionPass *createDemandedBitsPass();
72 } // End llvm namespace