-
Notifications
You must be signed in to change notification settings - Fork 750
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[SYCL] Support functors as SYCL kernels (compiler part).
Signed-off-by: Vladimir Lazarev <vladimir.lazarev@intel.com>
- Loading branch information
1 parent
1c93c84
commit 4095f94
Showing
6 changed files
with
1,058 additions
and
261 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,281 @@ | ||
#pragma once | ||
|
||
#include <exception> | ||
#include <functional> | ||
#include <memory> | ||
#include <mutex> | ||
#include <string> | ||
#include <type_traits> | ||
#include <vector> | ||
|
||
#ifndef __SYCL_DEVICE_ONLY__ | ||
#define __global | ||
#endif | ||
|
||
#define ATTR_SYCL_KERNEL __attribute__((sycl_kernel)) | ||
|
||
// Dummy runtime classes to model SYCL API. | ||
namespace cl { | ||
namespace sycl { | ||
|
||
template < class T, class Alloc = std::allocator<T> > | ||
using vector_class = std::vector<T, Alloc>; | ||
|
||
using string_class = std::string; | ||
|
||
template<class R, class... ArgTypes> | ||
using function_class = std::function<R(ArgTypes...)>; | ||
|
||
using mutex_class = std::mutex; | ||
|
||
template <class T> | ||
using unique_ptr_class = std::unique_ptr<T>; | ||
|
||
template <class T> | ||
using shared_ptr_class = std::shared_ptr<T>; | ||
|
||
template <class T> | ||
using weak_ptr_class = std::weak_ptr<T>; | ||
|
||
template <class T> | ||
using hash_class = std::hash<T>; | ||
|
||
using exception_ptr_class = std::exception_ptr; | ||
|
||
template <class T> | ||
using buffer_allocator = std::allocator<T>; | ||
|
||
namespace access { | ||
|
||
enum class target { | ||
global_buffer = 2014, | ||
constant_buffer, | ||
local, | ||
image, | ||
host_buffer, | ||
host_image, | ||
image_array | ||
}; | ||
|
||
enum class mode { | ||
read = 1024, | ||
write, | ||
read_write, | ||
discard_write, | ||
discard_read_write, | ||
atomic | ||
}; | ||
|
||
enum class placeholder { | ||
false_t, | ||
true_t | ||
}; | ||
|
||
enum class address_space : int { | ||
private_space = 0, | ||
global_space, | ||
constant_space, | ||
local_space | ||
}; | ||
} // namespace access | ||
|
||
namespace property { | ||
|
||
enum prop_type { | ||
use_host_ptr = 0, | ||
use_mutex, | ||
context_bound, | ||
enable_profiling, | ||
base_prop | ||
}; | ||
|
||
struct property_base { | ||
virtual prop_type type() const = 0; | ||
}; | ||
} // namespace property | ||
|
||
namespace detail { | ||
template <typename... tail> struct allProperties : std::true_type {}; | ||
template <typename T, typename... tail> | ||
struct allProperties<T, tail...> | ||
: std::conditional< | ||
std::is_base_of<cl::sycl::property::property_base, T>::value, | ||
allProperties<tail...>, std::false_type>::type {}; | ||
} // namespace detail | ||
|
||
class property_list { | ||
public: | ||
template <typename... propertyTN, | ||
typename = typename std::enable_if< | ||
detail::allProperties<propertyTN...>::value>::type> | ||
property_list(propertyTN... props) {} | ||
|
||
template <typename propertyT> bool has_property() const { return true; } | ||
|
||
template <typename propertyT> propertyT get_property() const { | ||
return propertyT{}; | ||
} | ||
|
||
bool operator==(const property_list &rhs) const { return false; } | ||
|
||
bool operator!=(const property_list &rhs) const { return false; } | ||
}; | ||
|
||
template <int dim> | ||
struct id { | ||
}; | ||
|
||
template <int dim> | ||
struct range { | ||
template<typename ...T> range(T...args) {} // fake constructor | ||
}; | ||
|
||
template <int dim> | ||
struct nd_range { | ||
}; | ||
|
||
template <int dim> | ||
struct _ImplT { | ||
range<dim> Range; | ||
}; | ||
|
||
template <typename dataT, int dimensions, access::mode accessmode, | ||
access::target accessTarget = access::target::global_buffer, | ||
access::placeholder isPlaceholder = access::placeholder::false_t> | ||
class accessor { | ||
|
||
public: | ||
|
||
void __set_pointer(__global dataT *Ptr) { } | ||
void __set_range(range<dimensions> Range) { | ||
__impl.Range = Range; | ||
} | ||
void use(void) const {} | ||
template <typename ...T> void use(T...args) { } | ||
template <typename ...T> void use(T...args) const { } | ||
_ImplT<dimensions> __impl; | ||
|
||
}; | ||
|
||
class kernel {}; | ||
class context {}; | ||
class device {}; | ||
class event{}; | ||
|
||
class queue { | ||
public: | ||
template <typename T> event submit(T cgf) { return event{}; } | ||
|
||
void wait() {} | ||
void wait_and_throw() {} | ||
void throw_asynchronous() {} | ||
}; | ||
|
||
class handler { | ||
public: | ||
template <typename KernelName, typename KernelType, int dimensions> | ||
ATTR_SYCL_KERNEL | ||
void parallel_for(range<dimensions> numWorkItems, KernelType kernelFunc) {} | ||
|
||
template <typename KernelName, typename KernelType, int dimensions> | ||
ATTR_SYCL_KERNEL | ||
void parallel_for(nd_range<dimensions> executionRange, | ||
KernelType kernelFunc) {} | ||
|
||
ATTR_SYCL_KERNEL | ||
void single_task(kernel syclKernel) {} | ||
|
||
template <int dimensions> | ||
ATTR_SYCL_KERNEL | ||
void parallel_for(range<dimensions> numWorkItems, kernel syclKernel) {} | ||
|
||
template <int dimensions> | ||
ATTR_SYCL_KERNEL | ||
void parallel_for(nd_range<dimensions> ndRange, kernel syclKernel) {} | ||
|
||
template <typename KernelName, typename KernelType> | ||
ATTR_SYCL_KERNEL | ||
void single_task(kernel syclKernel, KernelType kernelFunc) {} | ||
|
||
template <typename KernelType> | ||
ATTR_SYCL_KERNEL | ||
void single_task(KernelType kernelFunc) {} | ||
|
||
template <typename KernelName, typename KernelType, int dimensions> | ||
ATTR_SYCL_KERNEL | ||
void parallel_for(range<dimensions> numWorkItems, kernel syclKernel, | ||
KernelType kernelFunc) {} | ||
|
||
template <typename KernelType, int dimensions> | ||
ATTR_SYCL_KERNEL | ||
void parallel_for(range<dimensions> numWorkItems, KernelType kernelFunc) {} | ||
|
||
template <typename KernelName, typename KernelType, int dimensions> | ||
ATTR_SYCL_KERNEL | ||
void parallel_for(nd_range<dimensions> ndRange, kernel syclKernel, | ||
KernelType kernelFunc) {} | ||
}; | ||
|
||
template <typename T, int dimensions = 1, | ||
typename AllocatorT = cl::sycl::buffer_allocator<T>> | ||
class buffer { | ||
public: | ||
using value_type = T; | ||
using reference = value_type &; | ||
using const_reference = const value_type &; | ||
using allocator_type = AllocatorT; | ||
|
||
template <typename ...ParamTypes> buffer(ParamTypes...args) {} // fake constructor | ||
|
||
buffer(const range<dimensions> &bufferRange, | ||
const property_list &propList = {}) {} | ||
|
||
buffer(T *hostData, const range<dimensions> &bufferRange, | ||
const property_list &propList = {}) {} | ||
|
||
buffer(const T *hostData, const range<dimensions> &bufferRange, | ||
const property_list &propList = {}) {} | ||
|
||
buffer(const shared_ptr_class<T> &hostData, | ||
const range<dimensions> &bufferRange, | ||
const property_list &propList = {}) {} | ||
|
||
buffer(const buffer &rhs) = default; | ||
|
||
buffer(buffer &&rhs) = default; | ||
|
||
buffer &operator=(const buffer &rhs) = default; | ||
|
||
buffer &operator=(buffer &&rhs) = default; | ||
|
||
~buffer() = default; | ||
|
||
range<dimensions> get_range() const { return range<dimensions>{}; } | ||
|
||
size_t get_count() const { return 0; } | ||
|
||
size_t get_size() const { return 0; } | ||
|
||
template <access::mode mode, | ||
access::target target = access::target::global_buffer> | ||
accessor<T, dimensions, mode, target, access::placeholder::false_t> | ||
get_access(handler &commandGroupHandler) { | ||
return accessor<T, dimensions, mode, target, access::placeholder::false_t>{}; | ||
} | ||
|
||
template <access::mode mode> | ||
accessor<T, dimensions, mode, access::target::host_buffer, | ||
access::placeholder::false_t> | ||
get_access() { | ||
accessor<T, dimensions, mode, access::target::host_buffer, | ||
access::placeholder::false_t>{}; | ||
} | ||
|
||
template <typename Destination = std::nullptr_t> | ||
void set_final_data(Destination finalData = nullptr) {} | ||
}; | ||
|
||
} // namespace sycl | ||
} // namespace cl | ||
|
||
|
Oops, something went wrong.