mini-llvm 0.1.0
Loading...
Searching...
No Matches
CondSet.h
Go to the documentation of this file.
1// SPDX-License-Identifier: MIT
2
3#pragma once
4
5#include <format>
6#include <memory>
7#include <string>
8#include <unordered_set>
9#include <utility>
10
21
22namespace mini_llvm::mir {
23
25public:
26 CondSet(int width, Condition cond, std::shared_ptr<Register> dst)
27 : width_(width), cond_(cond), dst_(RegisterClass::kGPR, std::move(dst)) {}
28
29 int width() const {
30 return width_;
31 }
32
33 Condition cond() const {
34 return cond_;
35 }
36
38 cond_ = cond;
39 }
40
41 template <typename Self>
42 auto &dst(this Self &&self) {
43 return self.dst_;
44 }
45
46 std::unordered_set<const RegisterOperand *> regOps() const override {
47 return {&dst()};
48 }
49
50 std::unordered_set<const RegisterOperand *> dsts() const override {
51 return {&dst()};
52 }
53
54 std::unordered_set<const RegisterOperand *> srcs() const override {
55 return {};
56 }
57
58 std::unordered_set<const ImmediateOperand *> immOps() const override {
59 return {};
60 }
61
62 std::unordered_set<const MemoryOperand *> memOps() const override {
63 return {};
64 }
65
66 bool hasSideEffects() const override {
67 return false;
68 }
69
70 std::string format() const override {
71 return std::format("CONDSET i{} {} {}", width() * 8, specifier(cond()), *dst());
72 }
73
74 std::unique_ptr<Instruction> clone() const override {
75 return std::make_unique<CondSet>(width(), cond(), share(*dst()));
76 }
77
78 void accept(InstructionVisitor &visitor) override {
79 visitor.visitCondSet(*this);
80 }
81
82 void accept(InstructionVisitor &visitor) const override {
83 visitor.visitCondSet(*this);
84 }
85
86private:
87 int width_;
88 Condition cond_;
89 RegisterOperand dst_;
90};
91
92} // namespace mini_llvm::mir
#define MINI_LLVM_EXPORT
Definition Compiler.h:17
std::string format() const override
Definition CondSet.h:70
std::unordered_set< const MemoryOperand * > memOps() const override
Definition CondSet.h:62
std::unordered_set< const RegisterOperand * > regOps() const override
Definition CondSet.h:46
void accept(InstructionVisitor &visitor) const override
Definition CondSet.h:82
std::unordered_set< const RegisterOperand * > srcs() const override
Definition CondSet.h:54
int width() const
Definition CondSet.h:29
std::unordered_set< const ImmediateOperand * > immOps() const override
Definition CondSet.h:58
void setCond(Condition cond)
Definition CondSet.h:37
std::unique_ptr< Instruction > clone() const override
Definition CondSet.h:74
bool hasSideEffects() const override
Definition CondSet.h:66
CondSet(int width, Condition cond, std::shared_ptr< Register > dst)
Definition CondSet.h:26
void accept(InstructionVisitor &visitor) override
Definition CondSet.h:78
Condition cond() const
Definition CondSet.h:33
auto & dst(this Self &&self)
Definition CondSet.h:42
std::unordered_set< const RegisterOperand * > dsts() const override
Definition CondSet.h:50
Definition InstructionVisitor.h:70
virtual void visitCondSet(CondSet &I)
Definition InstructionVisitor.h:94
Definition RegisterOperand.h:13
Definition BasicBlock.h:22
constexpr const char * specifier(Condition cond)
Definition Condition.h:15
RegisterClass
Definition RegisterClass.h:7
@ kGPR
Definition RegisterClass.h:8
Condition
Definition Condition.h:9
std::shared_ptr< T > share(T &value)
Definition Memory.h:25