[PATCH] D127961: [OpenCL] Reduce emitting candidate notes for builtins
Sven van Haastregt via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Thu Jun 16 06:26:32 PDT 2022
svenvh created this revision.
svenvh added a reviewer: Anastasia.
svenvh added a project: clang.
Herald added subscribers: Naghasan, ldrumm, yaxunl.
Herald added a project: All.
svenvh requested review of this revision.
Herald added a subscriber: cfe-commits.
When overload resolution fails, clang emits a note diagnostic for each
candidate. For OpenCL builtins this often leads to many repeated note
diagnostics with no new information. Stop emitting such notes.
Update a test that was relying on counting those notes to check how
many builtins are available for certain extension configurations.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D127961
Files:
clang/lib/Sema/SemaOverload.cpp
clang/test/SemaOpenCL/fdeclare-opencl-builtins.cl
Index: clang/test/SemaOpenCL/fdeclare-opencl-builtins.cl
===================================================================
--- clang/test/SemaOpenCL/fdeclare-opencl-builtins.cl
+++ clang/test/SemaOpenCL/fdeclare-opencl-builtins.cl
@@ -171,14 +171,14 @@
// extension is disabled. Test this by counting the number of notes about
// candidate functions.
void test_atomic_double_reporting(volatile __generic atomic_int *a) {
- atomic_init(a);
+ atomic_init(a, a);
// expected-error at -1{{no matching function for call to 'atomic_init'}}
#if defined(NO_FP64)
// Expecting 5 candidates: int, uint, long, ulong, float
- // expected-note at -4 5 {{candidate function not viable: requires 2 arguments, but 1 was provided}}
+ // expected-note at -4 5 {{candidate function not viable: no known conversion}}
#else
// Expecting 6 candidates: int, uint, long, ulong, float, double
- // expected-note at -7 6 {{candidate function not viable: requires 2 arguments, but 1 was provided}}
+ // expected-note at -7 6 {{candidate function not viable: no known conversion}}
#endif
}
@@ -198,7 +198,6 @@
atomic_exchange_explicit(a_int, d, memory_order_seq_cst);
// expected-error at -1{{no matching function for call to 'atomic_exchange_explicit'}}
- // expected-note at -2 + {{candidate function not viable}}
atomic_exchange_explicit(a_int, d, memory_order_seq_cst, memory_scope_work_group);
}
@@ -272,9 +271,7 @@
res = read_imageh(image_read_only_image2d, i2);
#if __OPENCL_C_VERSION__ < CL_VERSION_1_2 && !defined(__OPENCL_CPP_VERSION__)
// expected-error at -3{{no matching function for call to 'read_imagef'}}
- // expected-note at -4 + {{candidate function not viable}}
- // expected-error at -4{{no matching function for call to 'read_imageh'}}
- // expected-note at -5 + {{candidate function not viable}}
+ // expected-error at -3{{no matching function for call to 'read_imageh'}}
#endif
res = read_imageh(image_read_only_image2d, sampler, i2);
@@ -304,7 +301,6 @@
write_imagef(image3dwo, i4, i, f4);
#if __OPENCL_C_VERSION__ <= CL_VERSION_1_2 && !defined(__OPENCL_CPP_VERSION__)
// expected-error at -2{{no matching function for call to 'write_imagef'}}
- // expected-note at -3 + {{candidate function not viable}}
#endif
}
Index: clang/lib/Sema/SemaOverload.cpp
===================================================================
--- clang/lib/Sema/SemaOverload.cpp
+++ clang/lib/Sema/SemaOverload.cpp
@@ -11218,6 +11218,13 @@
if (shouldSkipNotingLambdaConversionDecl(Fn))
return;
+ // There is no physical candidate declaration to point to for OpenCL builtins.
+ // Except for failed conversions, the notes are identical for each candidate,
+ // so do not generate such notes.
+ if (S.getLangOpts().OpenCL && Fn->isImplicit() &&
+ Cand->FailureKind != ovl_fail_bad_conversion)
+ return;
+
// Note deleted candidates, but only if they're viable.
if (Cand->Viable) {
if (Fn->isDeleted()) {
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D127961.437523.patch
Type: text/x-patch
Size: 2939 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20220616/ce0f1d01/attachment-0001.bin>
More information about the cfe-commits
mailing list