[clang] [Sema] Mark alias/ifunc targets used and consider mangled names (PR #87130)

Fangrui Song via cfe-commits cfe-commits at lists.llvm.org
Mon Apr 1 23:38:01 PDT 2024


================
@@ -1,7 +1,35 @@
-// RUN: %clang_cc1 -triple x86_64-linux-gnu -Wunneeded-internal-declaration -x c -verify %s
+// RUN: %clang_cc1 -triple x86_64-linux-gnu -Wunused -x c -verify %s
+// RUN: %clang_cc1 -triple x86_64-linux-gnu -Wunused -x c++ -verify %s
+
+#ifdef __cplusplus
+extern "C" {
+#else
 // expected-no-diagnostics
+#endif
 static int f(void) { return 42; }
 int g(void) __attribute__((alias("f")));
 
 static int foo [] = { 42, 0xDEAD };
 extern typeof(foo) bar __attribute__((unused, alias("foo")));
+
+static int (*resolver(void))(void) { return f; }
+int ifunc(void) __attribute__((ifunc("resolver")));
+
+#ifdef __cplusplus
+}
+
+/// We demangle alias/ifunc target and mark all found functions as used.
+static int f1(int) { return 42; }
----------------
MaskRay wrote:

The false negatives are for overloads, which are tested here.

I agree that it would be nice not to take a compromise, but checking whether a declaration will have the specified mangled name is challenging. We'd need to replicate `clang/lib/CodeGen/CodeGenModule.cpp` `getMangledNameImpl` code here. We would need a MangleContext which currently lives in CodeGen ( `clang/lib/CodeGen/CGCXXABI.h`), inaccessible from Sema.

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


More information about the cfe-commits mailing list