[compiler-rt] [win/asan] Don't intercept memset etc. in ntdll (PR #120397)

Reid Kleckner via llvm-commits llvm-commits at lists.llvm.org
Wed Dec 18 18:49:12 PST 2024


================
@@ -1281,9 +1280,22 @@ uptr InternalGetProcAddress(void *module, const char *func_name) {
 
 bool OverrideFunction(
     const char *func_name, uptr new_func, uptr *orig_old_func) {
+  static const char *kNtDllIgnore[] = {
+    "memcmp", "memcpy", "memmove", "memset"
+  };
+
   bool hooked = false;
   void **DLLs = InterestingDLLsAvailable();
   for (size_t i = 0; DLLs[i]; ++i) {
+    if (DLLs[i + 1] == nullptr) {
+      // This is the last DLL, i.e. NTDLL. It exports some functions that
+      // we only want to override in the CRT.
+      for (const char *ignored : kNtDllIgnore) {
+        if (strcmp(func_name, ignored) == 0)
----------------
rnk wrote:

Is there some `internal_strcmp` function we should be calling instead in order to avoid libc re-entrancy, like hitting the ASan strcmp interceptor, for example?

https://github.com/llvm/llvm-project/pull/120397


More information about the llvm-commits mailing list