aboutsummaryrefslogtreecommitdiff
path: root/client/src/shellcode/shellcode.h
diff options
context:
space:
mode:
Diffstat (limited to 'client/src/shellcode/shellcode.h')
-rw-r--r--client/src/shellcode/shellcode.h35
1 files changed, 35 insertions, 0 deletions
diff --git a/client/src/shellcode/shellcode.h b/client/src/shellcode/shellcode.h
new file mode 100644
index 0000000..5f0e135
--- /dev/null
+++ b/client/src/shellcode/shellcode.h
@@ -0,0 +1,35 @@
+#pragma once
+
+#include <asmjit/src/asmjit/asmjit.h>
+
+using namespace asmjit;
+
+namespace sc {
+
+class generator {
+ std::vector<uint8_t> m_buf;
+
+ CodeHolder m_code;
+ JitRuntime m_runtime;
+ x86::Assembler m_assembler;
+
+ bool m_x64;
+ public:
+ generator(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