From d33d5c1e68faf6630453a016a04d079a1341e0db Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alexander=20Mei=C3=9Fner?= Date: Mon, 30 Dec 2024 21:34:10 +0100 Subject: [PATCH] Fix - ISA docs `mov dst, imm` (#10) * Swaps `mov32 dst, imm` and `mov64 dst, imm` behavior description. * Makes cargo clippy happy. --- .github/workflows/main.yml | 4 ++-- clippy.toml | 1 - doc/bytecode.md | 4 ++-- src/insn_builder.rs | 2 +- src/jit.rs | 2 +- 5 files changed, 6 insertions(+), 7 deletions(-) delete mode 100644 clippy.toml diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 68562d260..67af28950 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -31,7 +31,7 @@ jobs: run: | cargo fmt --all -- --check cargo clippy --all --tests -- --deny=warnings - if: matrix.rust == 'nightly' + if: matrix.rust == 'beta' shell: bash - name: Build and test run: | @@ -45,7 +45,7 @@ jobs: run: | cargo fmt --all --manifest-path cli/Cargo.toml -- --check cargo clippy --all --tests --manifest-path cli/Cargo.toml -- --deny=warnings - if: matrix.rust == 'nightly' + if: matrix.rust == 'beta' shell: bash - name: CLI - Build and test run: | diff --git a/clippy.toml b/clippy.toml deleted file mode 100644 index 1d4a2968a..000000000 --- a/clippy.toml +++ /dev/null @@ -1 +0,0 @@ -doc-valid-idents = ["eBPF", "uBPF"] diff --git a/doc/bytecode.md b/doc/bytecode.md index c2aa83a76..e42eca18f 100644 --- a/doc/bytecode.md +++ b/doc/bytecode.md @@ -114,7 +114,7 @@ The following Rust equivalents assume that: | `9C` / `01111001` | from v2 | `ldxdw dst, [src + off]` | `A4` / `10100100` | all | `xor32 dst, imm` | `dst = (dst as u32).xor(imm) as u64` | `AC` / `10101100` | all | `xor32 dst, src` | `dst = (dst as u32).xor(src as u32) as u64` -| `B4` / `10110100` | all | `mov32 dst, imm` | `dst = imm as i32 as i64 as u64` +| `B4` / `10110100` | all | `mov32 dst, imm` | `dst = imm as u64` | `BC` / `10111100` | until v2 | `mov32 dst, src` | `dst = src as u32 as u64` | `BC` / `10111100` | from v2 | `mov32 dst, src` | `dst = src as i32 as i64 as u64` | `C4` / `11000100` | all | `ash32 dst, imm` | `dst = (dst as i32).wrapping_shr(imm) as u32 as u64` @@ -158,7 +158,7 @@ The following Rust equivalents assume that: | `9F` / `01111011` | from v2 | `stxdw [dst + off], src` | `A7` / `10100111` | all | `xor64 dst, imm` | `dst = dst.xor(imm)` | `AF` / `10101111` | all | `xor64 dst, src` | `dst = dst.xor(src)` -| `B7` / `10110111` | all | `mov64 dst, imm` | `dst = imm as u64` +| `B7` / `10110111` | all | `mov64 dst, imm` | `dst = imm as i32 as i64 as u64` | `BF` / `10111111` | all | `mov64 dst, src` | `dst = src` | `C7` / `11000111` | all | `ash64 dst, imm` | `dst = (dst as i64).wrapping_shr(imm)` | `CF` / `11001111` | all | `ash64 dst, src` | `dst = (dst as i64).wrapping_shr(src as u32)` diff --git a/src/insn_builder.rs b/src/insn_builder.rs index 638cc275d..082f351b9 100644 --- a/src/insn_builder.rs +++ b/src/insn_builder.rs @@ -89,7 +89,7 @@ impl IntoBytes for &I { fn into_bytes(self) -> Self::Bytes { vec![ self.opt_code_byte(), - self.get_src() << 4 | self.get_dst(), + (self.get_src() << 4) | self.get_dst(), self.get_off() as u8, (self.get_off() >> 8) as u8, self.get_imm() as u8, diff --git a/src/jit.rs b/src/jit.rs index 2e77dbbe6..56b9bcb29 100644 --- a/src/jit.rs +++ b/src/jit.rs @@ -1365,7 +1365,7 @@ impl<'a, C: ContextObject> JitCompiler<'a, C> { } } - self.emit_ins(X86Instruction::alu_immediate(size, 0xf7, 0x4 | (division as u8) << 1 | signed as u8, REGISTER_SCRATCH, 0, None)); + self.emit_ins(X86Instruction::alu_immediate(size, 0xf7, 0x4 | ((division as u8) << 1) | signed as u8, REGISTER_SCRATCH, 0, None)); if dst != RDX { if alt_dst {