diff options
author | Georgios Pinitas <georgios.pinitas@arm.com> | 2018-05-03 20:47:16 +0100 |
---|---|---|
committer | Anthony Barbier <anthony.barbier@arm.com> | 2018-11-02 16:51:50 +0000 |
commit | 3d1489de593574e65ef1e64a7ae64e4e56c2978b (patch) | |
tree | f87f3df521cb5ed8bd383dad89cbeb92c49670ac /src/graph/backends/NEON/NETensorHandle.cpp | |
parent | 54d6fae4dbb4f556cc5ec484c51681ad84c015a7 (diff) | |
download | ComputeLibrary-3d1489de593574e65ef1e64a7ae64e4e56c2978b.tar.gz |
COMPMID-605: Transition buffer memory manager
Change-Id: Ide7c6124eb19f13f15f517e62d705646a0cd1ecd
Reviewed-on: https://eu-gerrit-1.euhpc.arm.com/130184
Reviewed-by: Georgios Pinitas <georgios.pinitas@arm.com>
Tested-by: Jenkins <bsgcomp@arm.com>
Reviewed-by: Anthony Barbier <anthony.barbier@arm.com>
Diffstat (limited to 'src/graph/backends/NEON/NETensorHandle.cpp')
-rw-r--r-- | src/graph/backends/NEON/NETensorHandle.cpp | 35 |
1 files changed, 31 insertions, 4 deletions
diff --git a/src/graph/backends/NEON/NETensorHandle.cpp b/src/graph/backends/NEON/NETensorHandle.cpp index 8508ac9511..5892116caf 100644 --- a/src/graph/backends/NEON/NETensorHandle.cpp +++ b/src/graph/backends/NEON/NETensorHandle.cpp @@ -23,6 +23,9 @@ */ #include "arm_compute/graph/backends/NEON/NETensorHandle.h" +#include "arm_compute/core/utils/misc/Cast.h" +#include "arm_compute/runtime/MemoryGroup.h" + namespace arm_compute { namespace graph @@ -40,14 +43,18 @@ void NETensorHandle::allocate() _tensor.allocator()->allocate(); } -const arm_compute::ITensor &NETensorHandle::tensor() const +void NETensorHandle::free() { - return _tensor; + _tensor.allocator()->free(); } -arm_compute::ITensor &NETensorHandle::tensor() +void NETensorHandle::manage(IMemoryGroup *mg) { - return _tensor; + if(mg != nullptr) + { + auto *ne_mg = arm_compute::utils::cast::polymorphic_downcast<MemoryGroup *>(mg); + ne_mg->manage(&_tensor); + } } void NETensorHandle::map(bool blocking) @@ -68,10 +75,30 @@ void NETensorHandle::release_if_unused() } } +const arm_compute::ITensor &NETensorHandle::tensor() const +{ + return _tensor; +} + +arm_compute::ITensor &NETensorHandle::tensor() +{ + return _tensor; +} + +ITensorHandle *NETensorHandle::parent_handle() +{ + return this; +} + bool NETensorHandle::is_subtensor() const { return false; } + +Target NETensorHandle::target() const +{ + return Target::NEON; +} } // namespace backends } // namespace graph } // namespace arm_compute
\ No newline at end of file |