WeChat: cstutorcs
QQ: 749389476
#include “llvm/IR/InstIterator.h”
#include “llvm/IR/Module.h”
#include “llvm/Support/SourceMgr.h”
#include
#include “llvm/AsmParser/Parser.h”
#include “llvm/IRReader/IRReader.h”
#include “Extractor.h”
using namespace llvm;
void exitWithUsage() {
std::cerr << "Usage: constraint <-ReachDef|-Liveness> [–debug]
exitWithUsage();
std::string ModeString;
Extractor::AnalysisMode Mode;
if (!strcmp(“-ReachDef”, argv[1])) {
Mode = Extractor::AnalysisMode::ReachDef;
ModeString = “ReachDef”;
else if (!strcmp(“-Liveness”, argv[1])) {
Mode = Extractor::AnalysisMode::Liveness;
ModeString = “Liveness Analysis”;
exitWithUsage();
int FilenameAtIndex = 2;
bool verbose = false;
if (argc == 4 && !strcmp(argv[2], “–debug”)) {
verbose = true;
FilenameAtIndex = 3;
else if (argc == 4 && strcmp(argv[3], “–debug”)) {
exitWithUsage();
LLVMContext Context;
SMDiagnostic Err;
StringRef FileName(argv[FilenameAtIndex]);
std::unique_ptr
if (!Mod) {
Err.print(argv[0], errs());
// matches lab2
std::cout << "Running " << ModeString << " on main" << std::endl;
* Set up an Extractor. You will set up the neccessary Z3 rules for reaching definitions
* in Extractor.initialize().
Extractor Ext;
Ext.initialize(Mode);
z3::fixedpoint *Solver = Ext.getSolver();
z3::context &C = Ext.getContext();
* Map every instruction to an auto-incrementing integer ID, stored in InstMap.
* All Z3 constraints about Instructions will be expressed with these IDs.
InstMapTy InstMap;
unsigned int Counter = 0;
std::vector
for (auto &F : *Mod) {
for (inst_iterator I = inst_begin(F), E = inst_end(F); I != E; I++) {
InstMap[&*I] = Counter++;
OrderSeen.push_back(&*I);
* Create Z3 facts about each instruction. You will populate several input relations based on what you
* can determine about Instructions. You will implement that in Extractor.extractConstraints().
for (auto &F : *Mod) {
for (inst_iterator I = inst_begin(F), E = inst_end(F); I != E; I++) {
Ext.extractConstraints(InstMap, &*I, Mode);
Ext.print(InstMap, verbose, OrderSeen);