aboutsummaryrefslogtreecommitdiff
path: root/client/asmjit/core/inst.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'client/asmjit/core/inst.cpp')
-rw-r--r--client/asmjit/core/inst.cpp139
1 files changed, 139 insertions, 0 deletions
diff --git a/client/asmjit/core/inst.cpp b/client/asmjit/core/inst.cpp
new file mode 100644
index 0000000..a233b93
--- /dev/null
+++ b/client/asmjit/core/inst.cpp
@@ -0,0 +1,139 @@
+// AsmJit - Machine code generation for C++
+//
+// * Official AsmJit Home Page: https://asmjit.com
+// * Official Github Repository: https://github.com/asmjit/asmjit
+//
+// Copyright (c) 2008-2020 The AsmJit Authors
+//
+// This software is provided 'as-is', without any express or implied
+// warranty. In no event will the authors be held liable for any damages
+// arising from the use of this software.
+//
+// Permission is granted to anyone to use this software for any purpose,
+// including commercial applications, and to alter it and redistribute it
+// freely, subject to the following restrictions:
+//
+// 1. The origin of this software must not be misrepresented; you must not
+// claim that you wrote the original software. If you use this software
+// in a product, an acknowledgment in the product documentation would be
+// appreciated but is not required.
+// 2. Altered source versions must be plainly marked as such, and must not be
+// misrepresented as being the original software.
+// 3. This notice may not be removed or altered from any source distribution.
+
+#include "../core/api-build_p.h"
+#ifdef ASMJIT_BUILD_X86
+
+#include "../core/arch.h"
+#include "../core/inst.h"
+
+#ifdef ASMJIT_BUILD_X86
+ #include "../x86/x86instapi_p.h"
+#endif
+
+#ifdef ASMJIT_BUILD_ARM
+ #include "../arm/arminstapi_p.h"
+#endif
+
+ASMJIT_BEGIN_NAMESPACE
+
+// ============================================================================
+// [asmjit::InstAPI - Text]
+// ============================================================================
+
+#ifndef ASMJIT_NO_TEXT
+Error InstAPI::instIdToString(uint32_t arch, uint32_t instId, String& output) noexcept {
+#ifdef ASMJIT_BUILD_X86
+ if (Environment::isFamilyX86(arch))
+ return x86::InstInternal::instIdToString(arch, instId, output);
+#endif
+
+#ifdef ASMJIT_BUILD_ARM
+ if (Environment::isFamilyARM(arch))
+ return arm::InstInternal::instIdToString(arch, instId, output);
+#endif
+
+ return DebugUtils::errored(kErrorInvalidArch);
+}
+
+uint32_t InstAPI::stringToInstId(uint32_t arch, const char* s, size_t len) noexcept {
+#ifdef ASMJIT_BUILD_X86
+ if (Environment::isFamilyX86(arch))
+ return x86::InstInternal::stringToInstId(arch, s, len);
+#endif
+
+#ifdef ASMJIT_BUILD_ARM
+ if (Environment::isFamilyARM(arch))
+ return arm::InstInternal::stringToInstId(arch, s, len);
+#endif
+
+ return 0;
+}
+#endif // !ASMJIT_NO_TEXT
+
+// ============================================================================
+// [asmjit::InstAPI - Validate]
+// ============================================================================
+
+#ifndef ASMJIT_NO_VALIDATION
+Error InstAPI::validate(uint32_t arch, const BaseInst& inst, const Operand_* operands, size_t opCount, uint32_t validationFlags) noexcept {
+#ifdef ASMJIT_BUILD_X86
+ if (Environment::isFamilyX86(arch))
+ return x86::InstInternal::validate(arch, inst, operands, opCount, validationFlags);
+#endif
+
+#ifdef ASMJIT_BUILD_ARM
+ if (Environment::isFamilyARM(arch))
+ return arm::InstInternal::validate(arch, inst, operands, opCount, validationFlags);
+#endif
+
+ return DebugUtils::errored(kErrorInvalidArch);
+}
+#endif // !ASMJIT_NO_VALIDATION
+
+// ============================================================================
+// [asmjit::InstAPI - QueryRWInfo]
+// ============================================================================
+
+#ifndef ASMJIT_NO_INTROSPECTION
+Error InstAPI::queryRWInfo(uint32_t arch, const BaseInst& inst, const Operand_* operands, size_t opCount, InstRWInfo* out) noexcept {
+ if (ASMJIT_UNLIKELY(opCount > Globals::kMaxOpCount))
+ return DebugUtils::errored(kErrorInvalidArgument);
+
+#ifdef ASMJIT_BUILD_X86
+ if (Environment::isFamilyX86(arch))
+ return x86::InstInternal::queryRWInfo(arch, inst, operands, opCount, out);
+#endif
+
+#ifdef ASMJIT_BUILD_ARM
+ if (Environment::isFamilyARM(arch))
+ return arm::InstInternal::queryRWInfo(arch, inst, operands, opCount, out);
+#endif
+
+ return DebugUtils::errored(kErrorInvalidArch);
+}
+#endif // !ASMJIT_NO_INTROSPECTION
+
+// ============================================================================
+// [asmjit::InstAPI - QueryFeatures]
+// ============================================================================
+
+#ifndef ASMJIT_NO_INTROSPECTION
+Error InstAPI::queryFeatures(uint32_t arch, const BaseInst& inst, const Operand_* operands, size_t opCount, BaseFeatures* out) noexcept {
+#ifdef ASMJIT_BUILD_X86
+ if (Environment::isFamilyX86(arch))
+ return x86::InstInternal::queryFeatures(arch, inst, operands, opCount, out);
+#endif
+
+#ifdef ASMJIT_BUILD_ARM
+ if (Environment::isFamilyARM(arch))
+ return arm::InstInternal::queryFeatures(arch, inst, operands, opCount, out);
+#endif
+
+ return DebugUtils::errored(kErrorInvalidArch);
+}
+#endif // !ASMJIT_NO_INTROSPECTION
+
+ASMJIT_END_NAMESPACE
+
+#endif // ASMJIT_BUILD_X86