summaryrefslogtreecommitdiffhomepage
path: root/dev/LibCompiler/Backend/arm64.h
diff options
context:
space:
mode:
authorAmlal <amlal@nekernel.org>2025-04-25 13:14:01 +0200
committerAmlal <amlal@nekernel.org>2025-04-25 13:14:01 +0200
commit20042235d1f53ae428aa154e64afdbae5d8d91ad (patch)
tree6ea42d1b30505a57301f8ff2916c78ce94ff6eaf /dev/LibCompiler/Backend/arm64.h
parent0561a8d0a6ae7588309a6e3513bbfeeef5f0aa15 (diff)
meta: update .clang-format, format codebase.
Signed-off-by: Amlal <amlal@nekernel.org>
Diffstat (limited to 'dev/LibCompiler/Backend/arm64.h')
-rw-r--r--dev/LibCompiler/Backend/arm64.h39
1 files changed, 18 insertions, 21 deletions
diff --git a/dev/LibCompiler/Backend/arm64.h b/dev/LibCompiler/Backend/arm64.h
index 08096ee..fb91a1c 100644
--- a/dev/LibCompiler/Backend/arm64.h
+++ b/dev/LibCompiler/Backend/arm64.h
@@ -6,8 +6,8 @@ Copyright (C) 2024-2025 Amlal EL Mahrous, all rights reserved
#pragma once
-#include <stdint.h>
#include <LibCompiler/Defines.h>
+#include <stdint.h>
/// @brief ARM64 encoding support.
/// @file Backend/arm64.hpp
@@ -15,30 +15,27 @@ Copyright (C) 2024-2025 Amlal EL Mahrous, all rights reserved
struct CpuOpcodeArm64;
/// @brief ARM64 opcode header.
-struct PACKED CpuOpcodeArm64_Data final
-{
- uint32_t fOpcode : 10; // Bits 31–22: Opcode for operation
- uint32_t fRm : 5; // Bits 21–16: Source register Rm
- uint32_t fShamt : 6; // Bits 15–10: Shift amount
- uint32_t fRn : 5; // Bits 9–5: Source register Rn
- uint32_t fRd : 5; // Bits 4–0: Destination register Rd
+struct PACKED CpuOpcodeArm64_Data final {
+ uint32_t fOpcode : 10; // Bits 31–22: Opcode for operation
+ uint32_t fRm : 5; // Bits 21–16: Source register Rm
+ uint32_t fShamt : 6; // Bits 15–10: Shift amount
+ uint32_t fRn : 5; // Bits 9–5: Source register Rn
+ uint32_t fRd : 5; // Bits 4–0: Destination register Rd
};
-typedef struct
-{
- uint32_t opcode : 6; // Bits 31–26: Branch opcode
- int32_t offset : 26; // Bits 25–0: Signed offset (branch target)
+typedef struct {
+ uint32_t opcode : 6; // Bits 31–26: Branch opcode
+ int32_t offset : 26; // Bits 25–0: Signed offset (branch target)
} PACKED CpuOpcodeArm64_Branch;
-typedef struct
-{
- uint32_t size : 2; // Bits 31–30: Size of the data
- uint32_t opcode : 7; // Bits 29–23: Opcode for load/store
- uint32_t offset : 12; // Bits 22–10: Offset
- uint32_t rn : 5; // Bits 9–5: Base address register Rn
- uint32_t rt : 5; // Bits 4–0: Target/source register Rt
+typedef struct {
+ uint32_t size : 2; // Bits 31–30: Size of the data
+ uint32_t opcode : 7; // Bits 29–23: Opcode for load/store
+ uint32_t offset : 12; // Bits 22–10: Offset
+ uint32_t rn : 5; // Bits 9–5: Base address register Rn
+ uint32_t rt : 5; // Bits 4–0: Target/source register Rt
} PACKED CpuOpcodeArm64_LoadStore;
-#define kAsmRegisterLimit (30)
+#define kAsmRegisterLimit (30)
#define kAsmRegisterPrefix "x"
-#define kOpcodeARM64Count (1000)
+#define kOpcodeARM64Count (1000)