mini-llvm
0.1.0
Toggle main menu visibility
Loading...
Searching...
No Matches
Mul.h
Go to the documentation of this file.
1
// SPDX-License-Identifier: MIT
2
3
#pragma once
4
5
#include <memory>
6
#include <utility>
7
8
#include "
mini-llvm/common/ExtensionMode.h
"
9
#include "
mini-llvm/mir/Instruction.h
"
10
#include "
mini-llvm/mir/Instruction/BinaryOperator.h
"
11
#include "
mini-llvm/mir/InstructionVisitor.h
"
12
#include "
mini-llvm/mir/Register.h
"
13
#include "
mini-llvm/utils/Compiler.h
"
14
#include "
mini-llvm/utils/Memory.h
"
15
16
namespace
mini_llvm::mir
{
17
18
class
MINI_LLVM_EXPORT
Mul
:
public
BinaryOperator
{
19
public
:
20
Mul
(
int
width
,
21
std::shared_ptr<Register>
dst
,
22
std::shared_ptr<Register>
src1
,
23
std::shared_ptr<Register>
src2
,
24
ExtensionMode
extMode
=
ExtensionMode::kNo
)
25
:
BinaryOperator
(
width
, std::move(
dst
), std::move(
src1
), std::move(
src2
),
extMode
) {}
26
27
bool
hasSideEffects
()
const override
{
28
return
false
;
29
}
30
31
std::unique_ptr<Instruction>
clone
()
const override
{
32
return
std::make_unique<Mul>(
33
width
(),
share
(*
dst
()),
share
(*
src1
()),
share
(*
src2
()),
extMode
());
34
}
35
36
void
accept
(
InstructionVisitor
&visitor)
override
{
37
visitor.
visitMul
(*
this
);
38
}
39
40
void
accept
(
InstructionVisitor
&visitor)
const override
{
41
visitor.
visitMul
(*
this
);
42
}
43
44
protected
:
45
const
char
*
mnemonic
()
const override
{
46
return
"MUL"
;
47
}
48
};
49
50
}
// namespace mini_llvm::mir
BinaryOperator.h
Compiler.h
MINI_LLVM_EXPORT
#define MINI_LLVM_EXPORT
Definition
Compiler.h:17
ExtensionMode.h
Memory.h
Register.h
mini_llvm::mir::BinaryOperator::dst
auto & dst(this Self &&self)
Definition
BinaryOperator.h:28
mini_llvm::mir::BinaryOperator::extMode
ExtensionMode extMode() const
Definition
BinaryOperator.h:42
mini_llvm::mir::BinaryOperator::BinaryOperator
BinaryOperator(int width, std::shared_ptr< Register > dst, std::shared_ptr< Register > src1, std::shared_ptr< Register > src2, ExtensionMode extMode)
Definition
BinaryOperator.h:69
mini_llvm::mir::BinaryOperator::width
int width() const
Definition
BinaryOperator.h:23
mini_llvm::mir::BinaryOperator::src1
auto & src1(this Self &&self)
Definition
BinaryOperator.h:33
mini_llvm::mir::BinaryOperator::src2
auto & src2(this Self &&self)
Definition
BinaryOperator.h:38
mini_llvm::mir::InstructionVisitor
Definition
InstructionVisitor.h:70
mini_llvm::mir::InstructionVisitor::visitMul
virtual void visitMul(Mul &I)
Definition
InstructionVisitor.h:118
mini_llvm::mir::Mul::accept
void accept(InstructionVisitor &visitor) const override
Definition
Mul.h:40
mini_llvm::mir::Mul::Mul
Mul(int width, std::shared_ptr< Register > dst, std::shared_ptr< Register > src1, std::shared_ptr< Register > src2, ExtensionMode extMode=ExtensionMode::kNo)
Definition
Mul.h:20
mini_llvm::mir::Mul::accept
void accept(InstructionVisitor &visitor) override
Definition
Mul.h:36
mini_llvm::mir::Mul::clone
std::unique_ptr< Instruction > clone() const override
Definition
Mul.h:31
mini_llvm::mir::Mul::hasSideEffects
bool hasSideEffects() const override
Definition
Mul.h:27
mini_llvm::mir::Mul::mnemonic
const char * mnemonic() const override
Definition
Mul.h:45
InstructionVisitor.h
Instruction.h
mini_llvm::mir
Definition
BasicBlock.h:22
mini_llvm::ExtensionMode
ExtensionMode
Definition
ExtensionMode.h:7
mini_llvm::ExtensionMode::kNo
@ kNo
Definition
ExtensionMode.h:8
mini_llvm::share
std::shared_ptr< T > share(T &value)
Definition
Memory.h:25
include
mini-llvm
mir
Instruction
Mul.h
Generated by
1.17.0