aboutsummaryrefslogtreecommitdiff
path: root/client/src/shellcode/shellcode.h
diff options
context:
space:
mode:
authorauth <[email protected]>2020-07-17 15:49:00 +0200
committerauth <[email protected]>2020-07-17 15:49:00 +0200
commitbc9a539dc2dc40435f3e7b63306ed80a5198458b (patch)
tree85bc4addae613067e175b7c7d7af1593f09b9c4d /client/src/shellcode/shellcode.h
parentMerge branch 'master' into windows (diff)
parentRefactoring. (diff)
downloadloader-bc9a539dc2dc40435f3e7b63306ed80a5198458b.tar.xz
loader-bc9a539dc2dc40435f3e7b63306ed80a5198458b.zip
Merge branch 'master' into windows
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