data:image/s3,"s3://crabby-images/7f076/7f0767d6b8d9686bcb1f739e0a732b0dacf5897b" alt="SYCL CPU Device"
* There is no Host Device in SYCL (as of SYCL 2020)
* SYCL 1.2.1 had a concept of a 'magical' host device - an emulated backend
* SYCL 2020 implementations generally offer a CPU device
* Often, the best debugging on a platform is using a CPU device
* Yet, debugging off the CPU is important to discover offloading issues
#### What a SYCL implementation looks like
data:image/s3,"s3://crabby-images/18f82/18f8262b13cabd21c96d26a886ca0c5a2099c2a1" alt="SYCL Backend"
* The back-end interface is where the SYCL runtime calls down into a back-end in order to execute on a particular device
* Many implementations provide OpenCL backends, but some provide additional or different backends.
#### What a SYCL implementation looks like
data:image/s3,"s3://crabby-images/cabf0/cabf00835251755a59ddb37cf3081a125c4415fe" alt="SYCL Compiler"
* The SYCL device compiler is a C++ compiler which can identify SYCL kernels and compile them down to an IR or ISA
* This can be SPIR, SPIR-V, GCN, PTX or any proprietary vendor ISA
* Some SYCL implementations are library only in
which case they do not require a device compiler
**IR** = Intermediate Representation **ISA** = Instruction Set Architecture
#### Std C++ compilation model
data:image/s3,"s3://crabby-images/815a0/815a0e07a28687b9b8f5f45f97802578e96d5058" alt="SYCL Backend"
* This is the typical compilation model for a C++ source file.
#### Std C++ compilation model
data:image/s3,"s3://crabby-images/f1a84/f1a84918966a15227cee18e2ad689fb2b7e920d5" alt="SYCL Backend"
* So how do you compile a source file to also target the GPU?
#### Std C++ compilation model
data:image/s3,"s3://crabby-images/166cf/166cf4dbfaa611aa88c38aff7e02cfdd43a7c8ea" alt="SYCL Backend"
* As SYCL is single source the kernel functions are standard C++ function objects or lambda expressions.
* These are defined by submitting them to specific APIs.
#### Std C++ compilation model
data:image/s3,"s3://crabby-images/057bc/057bc3b1736e62aa6ab6f1ebec98d8ed7d7a56d5" alt="SYCL Backend"
* As well as the standard C++ compiler, the source file is also compiled by a SYCL device compiler.
* This produces a device IR such as SPIR, SPIR-V or PTX or ISA for a specific architecture containing the GPU code.
#### Std C++ compilation model
data:image/s3,"s3://crabby-images/059b3/059b30cc1624dc58efad9c08c176021633f17551" alt="SYCL Backend"
* The CPU object is then linked with the device IR or ISA to form a single executable with both the CPU and GPU code.
#### Std C++ compilation model
data:image/s3,"s3://crabby-images/059b3/059b30cc1624dc58efad9c08c176021633f17551" alt="SYCL Backend"
* This is the multi-compiler compilation model.
* This allows the host compiler (MSVC, clang, icx, gcc) to be independent of the SYCL device compiler.
#### Std C++ compilation model
data:image/s3,"s3://crabby-images/22086/22086bf08c1ea1d229e1d191f5a29b3ea2aaf754" alt="SYCL Backend"
* SYCL also supports a single-compiler compilation model.
* Where both the host compiler and SYCL device compiler are invoked from the same driver.
## Where to Get Started with SYCL
* Visit https://sycl.tech to find out about all the SYCL book, implementations, tutorials, news, and videos
* Visit https://www.khronos.org/sycl/ to find the latest SYCL specifications
* Checkout the documentation provided with one of the SYCL implementations.
#### Exercise
Code_Exercises/What_is_SYCL/source
Configure your environment for using SYCL and compile a source file with the SYCL compiler.