mini-llvm
0.1.0
Toggle main menu visibility
Loading...
Searching...
No Matches
SHRA.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
SHRA
:
public
BinaryOperator
{
19
public
:
20
SHRA
(
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<SHRA>(
33
width
(),
share
(*
dst
()),
share
(*
src1
()),
share
(*
src2
()),
extMode
());
34
}
35
36
void
accept
(
InstructionVisitor
&visitor)
override
{
37
visitor.
visitSHRA
(*
this
);
38
}
39
40
void
accept
(
InstructionVisitor
&visitor)
const override
{
41
visitor.
visitSHRA
(*
this
);
42
}
43
44
protected
:
45
const
char
*
mnemonic
()
const override
{
46
return
"SHRA"
;
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::visitSHRA
virtual void visitSHRA(SHRA &I)
Definition
InstructionVisitor.h:127
mini_llvm::mir::SHRA::accept
void accept(InstructionVisitor &visitor) override
Definition
SHRA.h:36
mini_llvm::mir::SHRA::accept
void accept(InstructionVisitor &visitor) const override
Definition
SHRA.h:40
mini_llvm::mir::SHRA::hasSideEffects
bool hasSideEffects() const override
Definition
SHRA.h:27
mini_llvm::mir::SHRA::mnemonic
const char * mnemonic() const override
Definition
SHRA.h:45
mini_llvm::mir::SHRA::SHRA
SHRA(int width, std::shared_ptr< Register > dst, std::shared_ptr< Register > src1, std::shared_ptr< Register > src2, ExtensionMode extMode=ExtensionMode::kNo)
Definition
SHRA.h:20
mini_llvm::mir::SHRA::clone
std::unique_ptr< Instruction > clone() const override
Definition
SHRA.h:31
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
SHRA.h
Generated by
1.17.0