Skip to content

[SYCL][CUDA] Port CUDA plugin to Unified Runtime #9512

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 45 commits into from
Jun 14, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
da70781
[SYCL][CUDA] Export loader interface for CUDA UR adapter
Apr 4, 2023
46dca60
[SYCL][PI][UR][CUDA] Port CUDA platform, device, context to Unified R…
callumfare Apr 6, 2023
8073f6c
Port program and kernel entry points
omarahmed1111 Apr 10, 2023
506130e
Add UR_KERNEL_GROUP_INFO_GLOBAL_WORK_SIZE to kernel group info
omarahmed1111 Apr 13, 2023
625f1f8
[SYCL][PI][UR][CUDA] Port a few miscellaneous CUDA entry points to UR
callumfare Apr 14, 2023
3ae2329
[SYCL][PI][UR][CUDA] Port CUDA queue and event to Unified Runtime
callumfare Apr 7, 2023
103cec3
AAdd program and kernel ddi tables
omarahmed1111 Apr 18, 2023
c640339
[SYCL][PI][UR][CUDA] Port piEnqueueKernelLaunch to UR
callumfare Apr 17, 2023
8c63247
[SYCL][CUDA][UR] Add missing queue/event entry points to DDI table
callumfare Apr 19, 2023
76d4c5f
[SYCL][CUDA] Remove unused function from pi_cuda
callumfare Apr 19, 2023
3742495
[SYCL][CUDA] Add missing UR_APICALL, UR_APIEXPORT to entry points
callumfare Apr 19, 2023
7e0f0ec
Small fixes
Apr 19, 2023
17f91fc
[SYCL][PI][UR][CUDA] Port CUDA sampler to UR
callumfare Apr 18, 2023
6489ce1
[SYCL][CUDA] Fix missing input validation for various queue entry points
callumfare Apr 21, 2023
ebe90a2
Refactor memory object and entry points into new memory.hpp/cpp files…
martygrant Apr 21, 2023
ef9f224
Port USM entry points
omarahmed1111 Apr 18, 2023
d185543
[UR][CUDA][SYCL] Fix sycl-e2e tests
Apr 27, 2023
398f3e9
[UR][CUDA] Port urEnqueueRead/Write & setArgMemObj
Apr 26, 2023
e02d3d3
Port piextKernelSetArgSampler
omarahmed1111 Apr 28, 2023
816652a
[UR][SYCL][CUDA] Point PI to correct entry point
Apr 28, 2023
6d648f6
Port remaining queue entry-points
omarahmed1111 Apr 27, 2023
4f9277b
Don't check MAX_MEM_ALLOC_SIZE when creating a buffer
callumfare May 2, 2023
8968c1f
[SYCL][CUDA] Port CUDA global variable read/write to UR
callumfare Apr 28, 2023
1fb2afd
[SYCL][CUDA] Only build CUDA UR adapter when CUDA plugin is enabled
callumfare May 3, 2023
96c85ac
[SYCL][CUDA] Don't link non-CUDA adapters with cudadrv
callumfare May 3, 2023
3812978
[SYCL][CUDA] Port piextGetDeviceFunctionPointer and piextDeviceSelect…
callumfare May 4, 2023
764e683
[SYCL][CUDA] Port piPluginGetBackendOption to UR
callumfare May 5, 2023
d98adf8
[SYCL][CUDA] Port read/write host pipe to UR
callumfare May 5, 2023
797d3f7
[CUDA][UR]Fix program_info_kernel_names
omarahmed1111 May 15, 2023
6f68c7c
[SYCL][CUDA] Remove unused code from CUDA PI and move remaining docum…
callumfare May 9, 2023
ff2559f
[SYCL][CUDA] Add a few extra checks to the cuda UR program implementa…
aarongreig May 23, 2023
d69f029
[SYCL][CUDA] Implement UR_DEVICE_INFO_IL_VERSION query for cuda.
aarongreig May 23, 2023
190f3c7
[SYCL][CUDA][UR] Remove queue backward compatability apis
omarahmed1111 May 24, 2023
a441503
[SYCL][CUDA][UR] Add usmPool entry points to ddi tables and fix ur*na…
omarahmed1111 May 25, 2023
3b65369
Fix CUDA adapter formatting
callumfare May 31, 2023
0011b91
Mark KernelFusion/sync_two_queues_event_dep as unsupported on cuda pe…
callumfare May 31, 2023
9e97af7
[SYCL][CUDA] Fix assumption about work dimensions in EnqueueKernelLau…
aarongreig May 24, 2023
b538dd8
[SYCL][CUDA] Correct return type of cuda USM capability queries.
aarongreig May 29, 2023
9811f9b
[SYCL][CUDA] A number of small cuda adapter fixes for cts/spec compli…
aarongreig Jun 5, 2023
fce479c
[SYCL][UR] Avoid zero-length new in pi2ur.
aarongreig Jun 6, 2023
9b3448a
[SYCL][CUDA] Mass fixup of code style in the CUDA adapter
callumfare Jun 8, 2023
a0de2d7
[SYCL][CUDA][PI][UR] Fix PR review comments
Jun 8, 2023
2a50972
[SYCL][CUDA] Tidy CMakeLists.txt
callumfare Jun 9, 2023
c39e794
Fix various build warnings
callumfare Jun 12, 2023
b64fcbd
Address more review feedback
callumfare Jun 14, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
35 changes: 34 additions & 1 deletion sycl/plugins/cuda/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -48,18 +48,51 @@ endif()

add_sycl_plugin(cuda
SOURCES
# Some code is shared with the UR adapter
"../unified_runtime/pi2ur.hpp"
"../unified_runtime/pi2ur.cpp"
"../unified_runtime/ur/ur.hpp"
"../unified_runtime/ur/ur.cpp"
"../unified_runtime/ur/usm_allocator.cpp"
"../unified_runtime/ur/usm_allocator.hpp"
"../unified_runtime/ur/adapters/cuda/common.cpp"
"../unified_runtime/ur/adapters/cuda/common.hpp"
"../unified_runtime/ur/adapters/cuda/context.cpp"
"../unified_runtime/ur/adapters/cuda/context.hpp"
"../unified_runtime/ur/adapters/cuda/device.cpp"
"../unified_runtime/ur/adapters/cuda/device.hpp"
"../unified_runtime/ur/adapters/cuda/enqueue.cpp"
"../unified_runtime/ur/adapters/cuda/event.cpp"
"../unified_runtime/ur/adapters/cuda/event.hpp"
"../unified_runtime/ur/adapters/cuda/kernel.cpp"
"../unified_runtime/ur/adapters/cuda/kernel.hpp"
"../unified_runtime/ur/adapters/cuda/memory.cpp"
"../unified_runtime/ur/adapters/cuda/memory.hpp"
"../unified_runtime/ur/adapters/cuda/platform.cpp"
"../unified_runtime/ur/adapters/cuda/platform.hpp"
"../unified_runtime/ur/adapters/cuda/program.cpp"
"../unified_runtime/ur/adapters/cuda/program.hpp"
"../unified_runtime/ur/adapters/cuda/queue.cpp"
"../unified_runtime/ur/adapters/cuda/queue.hpp"
"../unified_runtime/ur/adapters/cuda/sampler.cpp"
"../unified_runtime/ur/adapters/cuda/sampler.hpp"
"../unified_runtime/ur/adapters/cuda/tracing.cpp"
"../unified_runtime/ur/adapters/cuda/ur_interface_loader.cpp"
"../unified_runtime/ur/adapters/cuda/usm.cpp"
# ---
"${sycl_inc_dir}/sycl/detail/pi.h"
"${sycl_inc_dir}/sycl/detail/pi.hpp"
"pi_cuda.hpp"
"pi_cuda.cpp"
"tracing.cpp"
${XPTI_PROXY_SRC}
INCLUDE_DIRS
${sycl_inc_dir}
${XPTI_INCLUDE}
${CMAKE_CURRENT_SOURCE_DIR}/../unified_runtime
LIBRARIES
cudadrv
${XPTI_LIBS}
UnifiedRuntime-Headers
HEADER "${CMAKE_CURRENT_SOURCE_DIR}/include/features.hpp"
)

Expand Down
Loading