summaryrefslogtreecommitdiffhomepage
path: root/Source/ThreadLocalStorage.cxx
diff options
context:
space:
mode:
authorAmlal El Mahrouss <amlal.elmahrouss@icloud.com>2024-01-06 09:14:11 +0100
committerAmlal El Mahrouss <amlal.elmahrouss@icloud.com>2024-01-06 09:14:11 +0100
commit5339d016c07bf717ee388f4feb73544087324af0 (patch)
tree94be6f67ed626091f24aee24ec3b3be03d01e4e7 /Source/ThreadLocalStorage.cxx
git: port from mercurial repo.
Signed-off-by: Amlal El Mahrouss <amlal.elmahrouss@icloud.com>
Diffstat (limited to 'Source/ThreadLocalStorage.cxx')
-rw-r--r--Source/ThreadLocalStorage.cxx33
1 files changed, 33 insertions, 0 deletions
diff --git a/Source/ThreadLocalStorage.cxx b/Source/ThreadLocalStorage.cxx
new file mode 100644
index 00000000..36f59df5
--- /dev/null
+++ b/Source/ThreadLocalStorage.cxx
@@ -0,0 +1,33 @@
+/*
+ * ========================================================
+ *
+ * hCore
+ * Copyright Mahrouss Logic, all rights reserved.
+ *
+ * ========================================================
+ */
+
+#include <KernelKit/ProcessManager.hpp>
+#include <KernelKit/ThreadLocalStorage.hxx>
+
+#include <KernelKit/SharedObjectCore.hxx>
+
+using namespace hCore;
+
+Boolean hcore_tls_check(VoidPtr ptr)
+{
+ if (!ptr)
+ return false;
+
+ const char *_ptr = (const char *)ptr;
+ return _ptr[0] == kRTLMag0 && _ptr[1] == kRTLMag1 && _ptr[2] == kRTLMag2;
+}
+
+void hcore_tls_check_syscall_impl(VoidPtr ptr) noexcept
+{
+ if (!hcore_tls_check(ptr))
+ {
+ kcout << "TLS: Thread check failure, crashing...\n";
+ ProcessManager::Shared().Leak().GetCurrent().Leak().Crash();
+ }
+}