LIEF: Library to Instrument Executable Formats
Version 1.0.0
Toggle main menu visibility
Loading...
Searching...
No Matches
lief-install
x86_64
static
include
LIEF
asm
riscv
operands
riscv/operands/Memory.hpp
Go to the documentation of this file.
1
/* Copyright 2022 - 2026 R. Thomas
2
*
3
* Licensed under the Apache License, Version 2.0 (the "License");
4
* you may not use this file except in compliance with the License.
5
* You may obtain a copy of the License at
6
*
7
* http://www.apache.org/licenses/LICENSE-2.0
8
*
9
* Unless required by applicable law or agreed to in writing, software
10
* distributed under the License is distributed on an "AS IS" BASIS,
11
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
* See the License for the specific language governing permissions and
13
* limitations under the License.
14
*/
15
#ifndef LIEF_ASM_RISCV_OPERAND_MEMORY_H
16
#define LIEF_ASM_RISCV_OPERAND_MEMORY_H
17
#include <cstdint>
18
19
#include "
LIEF/asm/riscv/Operand.hpp
"
20
#include "
LIEF/asm/riscv/registers.hpp
"
21
22
namespace
LIEF
{
23
namespace
assembly
{
24
namespace
riscv
{
25
namespace
operands
{
26
36
class
LIEF_API
Memory
:
public
Operand {
37
public
:
38
using
Operand::Operand;
39
43
REG
base
()
const
;
44
48
int64_t
displacement
()
const
;
49
50
static
bool
classof
(
const
Operand* op);
51
~Memory
()
override
=
default
;
52
};
53
}
54
}
55
}
56
}
57
#endif
LIEF::assembly::riscv::operands::Memory
This class represents a memory operand.
Definition
riscv/operands/Memory.hpp:36
LIEF::assembly::riscv::operands::Memory::displacement
int64_t displacement() const
The displacement value.
LIEF::assembly::riscv::operands::Memory::~Memory
~Memory() override=default
LIEF::assembly::riscv::operands::Memory::classof
static bool classof(const Operand *op)
LIEF::assembly::riscv::operands::Memory::base
REG base() const
The base register.
LIEF::assembly::riscv::operands
Namespace that wraps the different RISC-V operands.
Definition
riscv/operands/Immediate.hpp:23
LIEF::assembly::riscv
RISC-V architecture-related namespace.
Definition
riscv/Instruction.hpp:27
LIEF::assembly::riscv::REG
REG
Definition
riscv/registers.hpp:25
LIEF::assembly
Namespace related to assembly/disassembly support.
Definition
Abstract/Binary.hpp:48
LIEF
LIEF namespace.
Definition
Abstract/Binary.hpp:41
Operand.hpp
registers.hpp
LIEF_API
#define LIEF_API
Definition
visibility.h:45
Generated by
1.17.0