summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorIvan Shapovalov <intelfx@intelfx.name>2016-07-11 22:36:39 +0300
committerIvan Shapovalov <intelfx@intelfx.name>2016-07-22 11:15:52 +0300
commit2dd5ee3f758f817238cf74c068c5cad6eb3d46dd (patch)
tree03eba812b12c434ec650da3397103535d56e41cc /src
parent1ae71614ac227e9b80678505fcb5ecc18a3d3383 (diff)
clblast::RunKernel, cl::Kernel: take const vector as waitForEvents
Diffstat (limited to 'src')
-rw-r--r--src/clpp11.hpp4
-rw-r--r--src/routines/common.cpp2
-rw-r--r--src/routines/common.hpp4
3 files changed, 6 insertions, 4 deletions
diff --git a/src/clpp11.hpp b/src/clpp11.hpp
index af9d2ea4..9fa683ac 100644
--- a/src/clpp11.hpp
+++ b/src/clpp11.hpp
@@ -109,7 +109,9 @@ class Event {
// Accessor to the private data-member
cl_event& operator()() { return *event_; }
+ const cl_event& operator()() const { return *event_; }
cl_event* pointer() { return &(*event_); }
+ const cl_event* pointer() const { return &(*event_); }
private:
std::shared_ptr<cl_event> event_;
};
@@ -686,7 +688,7 @@ class Kernel {
// As above, but with an event waiting list
void Launch(const Queue &queue, const std::vector<size_t> &global,
const std::vector<size_t> &local, EventPointer event,
- std::vector<Event>& waitForEvents) {
+ const std::vector<Event> &waitForEvents) {
if (waitForEvents.size() == 0) { return Launch(queue, global, local, event); }
// Builds a plain version of the events waiting list
diff --git a/src/routines/common.cpp b/src/routines/common.cpp
index 2e82e04d..21e16954 100644
--- a/src/routines/common.cpp
+++ b/src/routines/common.cpp
@@ -22,7 +22,7 @@ namespace clblast {
// Enqueues a kernel, waits for completion, and checks for errors
StatusCode RunKernel(Kernel &kernel, Queue &queue, const Device &device,
std::vector<size_t> global, const std::vector<size_t> &local,
- EventPointer event, std::vector<Event>& waitForEvents) {
+ EventPointer event, const std::vector<Event> &waitForEvents) {
// Tests for validity of the local thread sizes
if (local.size() > device.MaxWorkItemDimensions()) {
diff --git a/src/routines/common.hpp b/src/routines/common.hpp
index d53bdc25..d0bbc707 100644
--- a/src/routines/common.hpp
+++ b/src/routines/common.hpp
@@ -29,7 +29,7 @@ namespace clblast {
// Enqueues a kernel, waits for completion, and checks for errors
StatusCode RunKernel(Kernel &kernel, Queue &queue, const Device &device,
std::vector<size_t> global, const std::vector<size_t> &local,
- EventPointer event, std::vector<Event>& waitForEvents);
+ EventPointer event, const std::vector<Event> &waitForEvents);
// As above, but without an event waiting list
StatusCode RunKernel(Kernel &kernel, Queue &queue, const Device &device,
@@ -43,7 +43,7 @@ StatusCode RunKernel(Kernel &kernel, Queue &queue, const Device &device,
template <typename T>
StatusCode PadCopyTransposeMatrix(Queue &queue, const Device &device,
const Database &db,
- EventPointer event, std::vector<Event>& waitForEvents,
+ EventPointer event, const std::vector<Event> &waitForEvents,
const size_t src_one, const size_t src_two,
const size_t src_ld, const size_t src_offset,
const Buffer<T> &src,