summaryrefslogtreecommitdiffhomepage
path: root/asm/intel64/rcl.cpp
diff options
context:
space:
mode:
authorRoland Reichwein <mail@reichwein.it>2020-11-24 10:00:47 +0100
committerRoland Reichwein <mail@reichwein.it>2020-11-24 10:00:47 +0100
commit926b44301aa339b7a204f709959ee44b6ee95902 (patch)
tree7332570f3d6b553887f144a91e62e21dfa22a4af /asm/intel64/rcl.cpp
parent61db05a4127790da3219fccce87c34aa890d1d08 (diff)
Implement Shift Left (WIP)
Diffstat (limited to 'asm/intel64/rcl.cpp')
-rw-r--r--asm/intel64/rcl.cpp8
1 files changed, 4 insertions, 4 deletions
diff --git a/asm/intel64/rcl.cpp b/asm/intel64/rcl.cpp
index 038f3d3..35f37db 100644
--- a/asm/intel64/rcl.cpp
+++ b/asm/intel64/rcl.cpp
@@ -15,17 +15,17 @@ Op_rcl::Op_rcl(const Asm::Args& args)
if (args[0].type() == typeid(Asm::Args::Register8)) { // rcl reg8, 1
machine_code = std::vector<uint8_t>{ 0xD0 } + ModRM("/2", std::any_cast<Asm::Args::Register8>(args[0]).name());
} else if (args[0].type() == typeid(Asm::Args::Register32)) { // rcl reg32, 1
- machine_code = std::vector<uint8_t>{ 0xD1 } + ModRM("/2", std::any_cast<Asm::Args::Register8>(args[0]).name());
+ machine_code = std::vector<uint8_t>{ 0xD1 } + ModRM("/2", std::any_cast<Asm::Args::Register32>(args[0]).name());
} else if (args[0].type() == typeid(Asm::Args::Register64)) { // rcl reg64, 1
- machine_code = REX("W") + std::vector<uint8_t>{ 0xD1 } + ModRM("/2", std::any_cast<Asm::Args::Register8>(args[0]).name());
+ machine_code = REX("W") + std::vector<uint8_t>{ 0xD1 } + ModRM("/2", std::any_cast<Asm::Args::Register64>(args[0]).name());
}
} else { // general version >= 2 bits shift
if (args[0].type() == typeid(Asm::Args::Register8)) { // rcl reg8, imm8
machine_code = std::vector<uint8_t>{ 0xC0 } + ModRM("/2", std::any_cast<Asm::Args::Register8>(args[0]).name()) + shift_offset;
} else if (args[0].type() == typeid(Asm::Args::Register32)) { // rcl reg32, imm8
- machine_code = std::vector<uint8_t>{ 0xC1 } + ModRM("/2", std::any_cast<Asm::Args::Register8>(args[0]).name()) + shift_offset;
+ machine_code = std::vector<uint8_t>{ 0xC1 } + ModRM("/2", std::any_cast<Asm::Args::Register32>(args[0]).name()) + shift_offset;
} else if (args[0].type() == typeid(Asm::Args::Register64)) { // rcl reg64, imm8
- machine_code = REX("W") + std::vector<uint8_t>{ 0xC1 } + ModRM("/2", std::any_cast<Asm::Args::Register8>(args[0]).name()) + shift_offset;
+ machine_code = REX("W") + std::vector<uint8_t>{ 0xC1 } + ModRM("/2", std::any_cast<Asm::Args::Register64>(args[0]).name()) + shift_offset;
}
}