[cfe-dev] Fw: [RFC] Add SYCL programming model support.

Ronan KERYELL via cfe-dev cfe-dev at lists.llvm.org
Fri Feb 8 10:55:50 PST 2019


>>>>> On Fri, 8 Feb 2019 12:52:07 +0000, Anastasia Stulova via cfe-dev <cfe-dev at lists.llvm.org> said:

    Alexey> One of the goals of SYCL design is to allow developers to
    Alexey> compile and run SYCL code even if the compiler toolchain
    Alexey> doesn’t support acceleration through OpenCL.

    Anastasia> This is somehow very unfortunate because the
    Anastasia> specification for SYCL is titled "SYCL integrates OpenCL
    Anastasia> devices with modern C++". That implies that it targets
    Anastasia> OpenCL explicitly. If there is shift of focus potentially
    Anastasia> some update is needed to avoid confusions.

Yes, this is the kind of things which are discussed inside the standard
committee.

    Anastasia> However, I believe this is still a side goal of SYCL?

No, the *fundamental goal* since the beginning in SYCL is to have a CPU
mode, for example if you do not have an accelerator available or take
advantage of your multicore SIMD CPU while some other SYCL kernels are
using the accelerators at the same time for example.

    Anastasia> There are plenty of other parallel languages that don't
    Anastasia> target OpenCL. What is the benefit of using SYCL if there
    Anastasia> is no OpenCL available? Anyway, this is probably not the
    Anastasia> discussion that belongs here, but since we are touching
    Anastasia> this topic I feel somehow unfortunate that we have to pay
    Anastasia> the price in the compiler implementation to working
    Anastasia> around something that doesn't seem to be a primary use
    Anastasia> case. :(

Perhaps there is some misunderstanding here on the goals and vision.
Please participate to the SYCL committee and ISO C++ committee if you
can.

Even in plain C++ std::thread works on a monocore non-SMT processor.
std::simd works on processor without SIMD instructions.
But if you have some fancy processor then you can use take advantage
from this.

    Alexey> Unfortunately "OpenCL address spaces" is not C++ standard
    Alexey> feature (yet :)), so if we expose them to the user, the
    Alexey> program written with these extensions will not be supported
    Alexey> by other C++ compiler like GCC or MSVC. Using standard API
    Alexey> allows us to utilize all sorts of extensions for API
    Alexey> implementation and emulate them with standard C++ if
    Alexey> extensions are not available.

    Anastasia> So how do you plan to emulate this it in GCC or MSVC and
    Anastasia> why can't we use the same pure C++ library based approach
    Anastasia> in Clang?

If the compiler does not support outlining of the SYCL kernels to the
accelerators, the sycl.hpp library is just plain C++ and will just run
your code on your CPU because it is just plain C++. This is important
for source code portability.

    Alexey>  It is plausible to assume that it should be easier for
    Alexey> C++ developers to adopt new functionality through
    Alexey> standard C++ concepts like class/function rather than
    Alexey> through language extensions.

Yes, the ISO C++ committee is very reluctant to add new keywords...

    Anastasia> My personal opinion is that learning library APIs or a
    Anastasia> set of new keywords is approximately the same especially
    Anastasia> for those that already mastered the complexity of
    Anastasia> C++. However, I have to say understanding the extra
    Anastasia> "magic" behind what appears to be regular C++ classes
    Anastasia> some developers might find somewhat counter-intuitive.

A fundamental problem with an OpenCL, CUDA, Cilk, C++AMP... program is
that if you insert it in a plain C++ program it just does not compile
because it is not... C++ since the compiler will choke on some strange
keywords. And that is a pain if you have to port a big application from
one standard to the other.

Most of the modern C++ features are provided through classes rather than
keywords. Just think about threads, futures and on-coming executors,
SIMD types, fixed point... A lot of the modern STL has some extra magic.
Or just in plain old C there are some magical functions: exit(),
setjmp()/longjmp()...

But then, how we implement this by splitting the implementation between
some C++ library, Clang and LLVM is what we have to discuss here.

For example, I cannot see why most of your great work on OpenCL address
spaces in C++ cannot be used as is by a SYCL implementation targeting
OpenCL, since the memory model is the same and in that case some SYCL
classes will be just some proxy/wrapper objects hiding some OpenCL
address space attributes .

As I have already told you, triSYCL made a lot of progress just by your
up-streamed Clang OpenCL work. Go on. :-)

Thank you for this again,
-- 
  Ronan KERYELL



More information about the cfe-dev mailing list