From e2a7609028346c3b776a424c9be848e49d3a0e2e Mon Sep 17 00:00:00 2001 From: "Claudius \"keldu\" Holeksa" Date: Wed, 12 Jun 2024 17:15:34 +0200 Subject: Working on reference types in std::function deduction --- modules/remote-sycl/examples/sycl_basic.cpp | 4 ++-- modules/remote-sycl/examples/sycl_basic.hpp | 4 ++-- modules/remote-sycl/examples/sycl_basic_kernel.cpp | 20 +++++++++----------- 3 files changed, 13 insertions(+), 15 deletions(-) (limited to 'modules/remote-sycl/examples') diff --git a/modules/remote-sycl/examples/sycl_basic.cpp b/modules/remote-sycl/examples/sycl_basic.cpp index 41aa2a1..677fd29 100644 --- a/modules/remote-sycl/examples/sycl_basic.cpp +++ b/modules/remote-sycl/examples/sycl_basic.cpp @@ -23,7 +23,7 @@ int main(){ saw::id> next_id{0u}; { - auto eov = rpc_server.template call<"increment">(saw::data, saw::encode::Native>{1u}); + auto eov = rpc_server.template call<"increment", saw::storage::Default>(saw::data, saw::encode::Native>{1u}); if(eov.is_error()){ auto& err = eov.get_error(); std::cerr<<"Error: "<(next_id); + auto eov = rpc_server.template call<"increment", saw::storage::Default>(next_id); if(eov.is_error()){ auto& err = eov.get_error(); std::cerr<<"Error: "<, UInt64>, "increment"> + Member, Array>, "increment"> >; } -saw::rpc_server, saw::rmt::Sycl> listen_basic_sycl(saw::remote& ctx, saw::remote_address& addr); +saw::rpc_server listen_basic_sycl(saw::remote& ctx, saw::remote_address& addr); diff --git a/modules/remote-sycl/examples/sycl_basic_kernel.cpp b/modules/remote-sycl/examples/sycl_basic_kernel.cpp index 86e73b5..94583b9 100644 --- a/modules/remote-sycl/examples/sycl_basic_kernel.cpp +++ b/modules/remote-sycl/examples/sycl_basic_kernel.cpp @@ -1,22 +1,20 @@ #include "sycl_basic.hpp" -saw::rpc_server, saw::rmt::Sycl> listen_basic_sycl(saw::remote& ctx, saw::remote_address& addr){ - saw::interface, cl::sycl::queue*> iface{ - [](saw::data, saw::encode::Native> in, cl::sycl::queue* q) -> saw::data> { - uint64_t inr = in.size(); - cl::sycl::buffer d_inc{ &inr, 1u }; - q->submit([&](cl::sycl::handler& h){ - auto a_inc = d_inc.get_access(h); +saw::rpc_server listen_basic_sycl(saw::remote& ctx, saw::remote_address& addr){ + saw::interface iface{ + + [](saw::data, saw::encode::Native, saw::rmt::Sycl> in, cl::sycl::queue* q) -> saw::data, saw::encode::Native, saw::rmt::Sycl> { - h.parallel_for(cl::sycl::range<1>(1u), [=] (cl::sycl::id<1> it){ - a_inc[0] += 1u; + q->submit([&](cl::sycl::handler& h){ + h.parallel_for(cl::sycl::range<1>(1u), [&] (cl::sycl::id<1> it){ + in.at(0u) += 1u; }); }); q->wait(); - return {inr}; + return in; } }; - auto rpc_server = ctx.template listen>(addr, std::move(iface)); + auto rpc_server = ctx.template listen(addr, std::move(iface)); return rpc_server; } -- cgit v1.2.3