aboutsummaryrefslogtreecommitdiff
path: root/client/src/assembler/shellcode.h
diff options
context:
space:
mode:
Diffstat (limited to 'client/src/assembler/shellcode.h')
-rw-r--r--client/src/assembler/shellcode.h29
1 files changed, 29 insertions, 0 deletions
diff --git a/client/src/assembler/shellcode.h b/client/src/assembler/shellcode.h
new file mode 100644
index 0000000..6fb2f61
--- /dev/null
+++ b/client/src/assembler/shellcode.h
@@ -0,0 +1,29 @@
+#pragma once
+
+using namespace asmjit;
+
+class sc {
+ std::vector<uint8_t> m_buf;
+
+ CodeHolder m_code;
+ JitRuntime m_runtime;
+ x86::Assembler m_assembler;
+
+ bool m_x64;
+ public:
+ sc(const bool x64 = false) : m_x64{x64} {
+ Environment env(x64 ? Environment::kArchX64 : Environment::kArchX86);
+
+ m_code.init(env);
+ m_code.attach(&m_assembler);
+ }
+
+ void start();
+ void push(const std::vector<uintptr_t> &args);
+ void call(const uintptr_t addr);
+ void save_ret(const uintptr_t addr);
+ void end();
+
+ auto &operator()() const { return m_buf; }
+ auto &operator->() const { return m_assembler; }
+}; \ No newline at end of file