2021-01-12 19:20:08 -05:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
#include <unordered_set>
|
|
|
|
#include "decompiler/Disasm/Register.h"
|
|
|
|
|
|
|
|
namespace decompiler {
|
|
|
|
|
|
|
|
class Function;
|
|
|
|
|
|
|
|
using RegSet = std::unordered_set<Register, Register::hash>;
|
|
|
|
|
|
|
|
struct RegUsageInfo {
|
|
|
|
struct PerBlock {
|
|
|
|
RegSet use, defs, input, output;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct PerOp {
|
2021-03-22 16:46:02 -04:00
|
|
|
RegSet live, dead, consumes, written_and_unused, live_in;
|
2021-01-12 19:20:08 -05:00
|
|
|
};
|
|
|
|
|
2021-01-16 10:54:09 -05:00
|
|
|
int block_count() const { return int(block.size()); }
|
|
|
|
|
2021-01-12 19:20:08 -05:00
|
|
|
std::vector<PerBlock> block;
|
|
|
|
std::vector<PerOp> op;
|
|
|
|
|
|
|
|
RegUsageInfo() = default;
|
|
|
|
RegUsageInfo(int n_blocks, int n_ops);
|
|
|
|
};
|
|
|
|
|
|
|
|
RegUsageInfo analyze_ir2_register_usage(const Function& function);
|
|
|
|
} // namespace decompiler
|