You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Consider the following example that contains a conditional lambda expression that is only present for host compilation. Implementations that rely on the Itanium C++ ABI name mangling specification may face challenges correlating names for the unnamed lambda used as a kernel in the call to cgh.single_task() because the presence of the host-only lambda will cause allocation of name mangling discriminators to be misaligned for host and device compilation.
#include <sycl/sycl.hpp>
int main() {
sycl::queue q(sycl::cpu_selector_v);
q.submit([](sycl::handler &cgh) {
#if !defined(__SYCL_DEVICE_ONLY__)
// The presence of a lambda that is only present for one of
// host or device compilation might cause names synthesized
// for unnamed lambdas not to coincide.
[]{}();
#endif
cgh.single_task([]{});
});
q.wait();
}
Is support for an example like the one above intended to be required for an implementation to claim support for the full feature set?
The text was updated successfully, but these errors were encountered:
Per SYCL 2020 4.12.2 (Defining kernels as lambda functions), a C++ lambda can be used as a SYCL kernel. Per section 5.2 (Naming of kernels), lambdas used as kernels can optionally be given a name via a template parameter. Appendix B (Feature sets) specifies a reduced feature set that omits support for unnamed lambdas. Finally, section 5.6 (Preprocessor directives and macros) specifies that an implementation that does not support unnamed lambdas shall not define
SYCL_FEATURE_SET_FULL
and shall defineSYCL_FEATURE_SET_REDUCED=1
.Consider the following example that contains a conditional lambda expression that is only present for host compilation. Implementations that rely on the Itanium C++ ABI name mangling specification may face challenges correlating names for the unnamed lambda used as a kernel in the call to
cgh.single_task()
because the presence of the host-only lambda will cause allocation of name mangling discriminators to be misaligned for host and device compilation.Is support for an example like the one above intended to be required for an implementation to claim support for the full feature set?
The text was updated successfully, but these errors were encountered: