summaryrefslogtreecommitdiff
path: root/src/arm32/shifter
diff options
context:
space:
mode:
Diffstat (limited to 'src/arm32/shifter')
-rw-r--r--src/arm32/shifter/mod.rs96
1 files changed, 96 insertions, 0 deletions
diff --git a/src/arm32/shifter/mod.rs b/src/arm32/shifter/mod.rs
new file mode 100644
index 0000000..e5da07b
--- /dev/null
+++ b/src/arm32/shifter/mod.rs
@@ -0,0 +1,96 @@
+// Copyright 2024 Gabriel Bjørnager Jensen.
+//
+// This file is part of Pollex.
+//
+// Pollex is free software: you can redistribute it
+// and/or modify it under the terms of the GNU Af-
+// fero General Public License as published by the
+// Free Software Foundation, either version 3 of
+// the License, or (at your option) any later ver-
+// sion.
+//
+// Pollex is distributed in the hope that it will
+// be useful, but WITHOUT ANY WARRANTY; without
+// even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Affero General Public License for more details.
+//
+// You should have received a copy of the GNU Af-
+// fero General Public License along with Pollex.
+// If not, see <https://www.gnu.org/licenses/>.
+
+use crate::arm32::{Register, Unsigned};
+
+use core::fmt::Display;
+
+/// A shifter operand.
+#[derive(Clone, Copy, Debug, Eq, PartialEq)]
+pub enum Shifter {
+ ArithmeticShiftRightImmediate { source: Register, shift: Unsigned },
+
+ ArithmeticShiftRightRegister { source: Register, shift: Register },
+
+ Immediate { immediate: Unsigned },
+
+ LogicalShiftLeftImmediate { source: Register, shift: Unsigned },
+
+ LogicalShiftLeftRegister { source: Register, shift: Register },
+
+ LogicalShiftRightImmediate { source: Register, shift: Unsigned },
+
+ LogicalShiftRightRegister { source: Register, shift: Register },
+
+ RotateRightExtend { source: Register },
+
+ RotateRightImmediate { source: Register, shift: Unsigned },
+
+ RotateRightRegister { source: Register, shift: Register },
+}
+
+impl Display for Shifter {
+ fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
+ use Shifter::*;
+
+ match *self {
+ ArithmeticShiftRightImmediate { source, shift } => {
+ write!(f, "{source}, ASR {shift}")
+ },
+
+ ArithmeticShiftRightRegister { source, shift } => {
+ write!(f, "{source}, ASR {shift}")
+ },
+
+ Immediate { immediate } => {
+ write!(f, "#{immediate}<")
+ },
+
+ LogicalShiftLeftImmediate { source, shift } => {
+ write!(f, "{source}, LSL {shift}")
+ },
+
+ LogicalShiftLeftRegister { source, shift } => {
+ write!(f, "{source}, LSL {shift}")
+ },
+
+ LogicalShiftRightImmediate { source, shift } => {
+ write!(f, "{source}, LSR {shift}")
+ },
+
+ LogicalShiftRightRegister { source, shift } => {
+ write!(f, "{source}, LSR {shift}")
+ },
+
+ RotateRightExtend { source } => {
+ write!(f, "{source}, RRX")
+ },
+
+ RotateRightImmediate { source, shift } => {
+ write!(f, "{source}, ROR {shift}")
+ },
+
+ RotateRightRegister { source, shift } => {
+ write!(f, "{source}, ROR {shift}")
+ },
+ }
+ }
+}