diff options
author | Georgios Pinitas <georgios.pinitas@arm.com> | 2018-11-14 13:16:56 +0000 |
---|---|---|
committer | Isabella Gottardi <isabella.gottardi@arm.com> | 2018-11-21 09:52:04 +0000 |
commit | df3103622b7de05f4e35b22a2c94b4a46eab4efc (patch) | |
tree | 17e10253e7a069c69d10bea0882b699b99d74b86 /arm_compute/runtime/CL/CLMemoryRegion.h | |
parent | c47ef20d69e8ea0f519fdc679435cd7037fc18fe (diff) | |
download | ComputeLibrary-df3103622b7de05f4e35b22a2c94b4a46eab4efc.tar.gz |
COMPMID-1088: Use IMemoryRegion in interfaces where possible
-Simplifies import memory interface
-Changes the used of void** handles with appropriate interfaces.
Change-Id: I5918c855c11f46352058864623336b352162a4b7
Diffstat (limited to 'arm_compute/runtime/CL/CLMemoryRegion.h')
-rw-r--r-- | arm_compute/runtime/CL/CLMemoryRegion.h | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/arm_compute/runtime/CL/CLMemoryRegion.h b/arm_compute/runtime/CL/CLMemoryRegion.h index 01dd54e391..dbfd8225ca 100644 --- a/arm_compute/runtime/CL/CLMemoryRegion.h +++ b/arm_compute/runtime/CL/CLMemoryRegion.h @@ -81,9 +81,9 @@ public: virtual void unmap(cl::CommandQueue &q) = 0; // Inherited methods overridden : - void *buffer() override; - void *buffer() const override; - void **handle() override; + void *buffer() override; + void *buffer() const override; + std::unique_ptr<IMemoryRegion> extract_subregion(size_t offset, size_t size) override; protected: cl::Context _ctx; @@ -102,11 +102,16 @@ public: * @param[in] size Region size */ CLBufferMemoryRegion(cl::Context ctx, cl_mem_flags flags, size_t size); + /** Constructor + * + * @param[in] buffer Buffer to be used as a memory region + */ + CLBufferMemoryRegion(const cl::Buffer &buffer); // Inherited methods overridden : - void *ptr() override; - void *map(cl::CommandQueue &q, bool blocking) override; - void unmap(cl::CommandQueue &q) override; + void *ptr() final; + void *map(cl::CommandQueue &q, bool blocking) final; + void unmap(cl::CommandQueue &q) final; }; /** OpenCL SVM memory region interface */ @@ -153,8 +158,8 @@ public: CLCoarseSVMMemoryRegion(cl::Context ctx, cl_mem_flags flags, size_t size, size_t alignment); // Inherited methods overridden : - void *map(cl::CommandQueue &q, bool blocking) override; - void unmap(cl::CommandQueue &q) override; + void *map(cl::CommandQueue &q, bool blocking) final; + void unmap(cl::CommandQueue &q) final; }; /** OpenCL fine-grain SVM memory region implementation */ @@ -171,8 +176,8 @@ public: CLFineSVMMemoryRegion(cl::Context ctx, cl_mem_flags flags, size_t size, size_t alignment); // Inherited methods overridden : - void *map(cl::CommandQueue &q, bool blocking) override; - void unmap(cl::CommandQueue &q) override; + void *map(cl::CommandQueue &q, bool blocking) final; + void unmap(cl::CommandQueue &q) final; }; } // namespace arm_compute #endif /* __ARM_COMPUTE_RUNTIME_CL_CL_MEMORY_REGION_H__ */ |