| // RUN: %clang_cc1 -emit-llvm-only -triple x86_64-linux-gnu -verify %s |
| // RUN: %clang_cc1 -emit-llvm-only -triple x86_64-apple-macosx -verify %s |
| // RUN: %clang_cc1 -emit-llvm-only -triple arm64-apple-macosx -verify %s |
| // RUN: not %clang_cc1 -triple x86_64-linux -emit-llvm-only -fdiagnostics-parseable-fixits %s 2>&1 | FileCheck %s |
| // RUN: not %clang_cc1 -triple x86_64-apple-macosx -emit-llvm-only -fdiagnostics-parseable-fixits %s 2>&1 | FileCheck %s |
| // RUN: not %clang_cc1 -triple arm64-apple-macosx -emit-llvm-only -fdiagnostics-parseable-fixits %s 2>&1 | FileCheck %s |
| |
| extern "C" { |
| __attribute__((used)) static void *resolve_foo() { return 0; } |
| namespace NS { |
| __attribute__((used)) static void *resolve_foo() { return 0; } |
| } // namespace NS |
| |
| // FIXME: This diagnostic is pretty confusing, the issue is that the existence |
| // of the two functions suppresses the 'alias' creation, and thus the ifunc |
| // resolution via the alias as well. In the future we should probably find |
| // some way to improve this diagnostic (likely by diagnosing when we decide |
| // this case suppresses alias creation). |
| __attribute__((ifunc("resolve_foo"))) void foo(); // expected-error{{ifunc must point to a defined function}} |
| // expected-note@-1 {{must refer to its mangled name}} |
| // expected-note@-2 {{function by that name is mangled as}} |
| // expected-note@-3 {{function by that name is mangled as}} |
| // CHECK: fix-it:"{{.*}}":{[[@LINE-4]]:16-[[@LINE-4]]:36}:"ifunc(\"_ZL11resolve_foov\")" |
| // CHECK: fix-it:"{{.*}}":{[[@LINE-5]]:16-[[@LINE-5]]:36}:"ifunc(\"_ZN2NSL11resolve_fooEv\")" |
| } |
| |