Developer Reference
Migrating OpenCL™ FPGA Designs to SYCL*
A newer version of this document is available. Customers should click here to go to the newest version.
Channels/Pipes APIs
Channels/pipes allow passing data between kernels and synchronizing kernels with high efficiency and low latency. They allow kernels to communicate directly with each other using on-chip FIFO buffers implemented using FPGA memory resources. The compiler supports concurrent kernel execution with out-of-order queues that allows launching kernels concurrently with a single command queue. Using channels/pipes for data movement between concurrently executing kernels allows for data transfer without waiting for kernel completion, which can significantly increase the throughput of your design. Refer to Pipes and Pipes Extension topics in the FPGA Optimization Guide for Intel oneAPI Toolkits for additional information.
The following table depicts how to implement channels/pipes in OpenCL and SYCL:
| OpenCL | SYCL | 
|---|---|
|  |  | 
I/O Pipes
| OpenCL | SYCL | 
|---|---|
|  |  |