blob: 9d2dbf78381519ed4e24fafd1e4b6577b0fb712b [file] [log] [blame]
telsoa01c577f2c2018-08-31 09:22:23 +01001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003// SPDX-License-Identifier: MIT
telsoa01c577f2c2018-08-31 09:22:23 +01004//
5#pragma once
6
Matteo Martincighe5b8eb92019-11-28 15:45:42 +00007#include <armnn/backends/IMemoryManager.hpp>
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +00008#include <backendsCommon/WorkloadFactory.hpp>
telsoa01c577f2c2018-08-31 09:22:23 +01009
Narumol Prangnawarat680f9912019-10-01 11:32:10 +010010#if defined(ARMCOMPUTENEON_ENABLED) || defined(ARMCOMPUTECL_ENABLED)
David Beckac42efd2018-09-26 17:41:13 +010011#include <arm_compute/runtime/MemoryGroup.h>
telsoa01c577f2c2018-08-31 09:22:23 +010012#endif
13
telsoa01c577f2c2018-08-31 09:22:23 +010014#if defined(ARMCOMPUTENEON_ENABLED) || defined(ARMCOMPUTECL_ENABLED)
David Beckac42efd2018-09-26 17:41:13 +010015#include <arm_compute/runtime/IAllocator.h>
16#include <arm_compute/runtime/IMemoryGroup.h>
17#include <arm_compute/runtime/MemoryManagerOnDemand.h>
telsoa01c577f2c2018-08-31 09:22:23 +010018#endif
19
20namespace armnn
21{
22
Aron Virginas-Tar56055192018-11-12 18:10:43 +000023class BaseMemoryManager : public IMemoryManager
telsoa01c577f2c2018-08-31 09:22:23 +010024{
25public:
26 enum class MemoryAffinity
27 {
28 Buffer,
29 Offset
30 };
31
32 BaseMemoryManager() { }
33 virtual ~BaseMemoryManager() { }
34
Aron Virginas-Tar56055192018-11-12 18:10:43 +000035 void Acquire() override;
36 void Release() override;
37
telsoa01c577f2c2018-08-31 09:22:23 +010038#if defined(ARMCOMPUTENEON_ENABLED) || defined(ARMCOMPUTECL_ENABLED)
telsoa01c577f2c2018-08-31 09:22:23 +010039 BaseMemoryManager(std::unique_ptr<arm_compute::IAllocator> alloc, MemoryAffinity memoryAffinity);
40
41 std::shared_ptr<arm_compute::MemoryManagerOnDemand>& GetIntraLayerManager() { return m_IntraLayerMemoryMgr; }
42 std::shared_ptr<arm_compute::MemoryManagerOnDemand>& GetInterLayerManager() { return m_InterLayerMemoryMgr; }
43 std::shared_ptr<arm_compute::IMemoryGroup>& GetInterLayerMemoryGroup() { return m_InterLayerMemoryGroup; }
44
telsoa01c577f2c2018-08-31 09:22:23 +010045protected:
telsoa01c577f2c2018-08-31 09:22:23 +010046 std::unique_ptr<arm_compute::IAllocator> m_Allocator;
47 std::shared_ptr<arm_compute::MemoryManagerOnDemand> m_IntraLayerMemoryMgr;
48 std::shared_ptr<arm_compute::MemoryManagerOnDemand> m_InterLayerMemoryMgr;
49 std::shared_ptr<arm_compute::IMemoryGroup> m_InterLayerMemoryGroup;
50
51 std::shared_ptr<arm_compute::MemoryManagerOnDemand> CreateArmComputeMemoryManager(MemoryAffinity memoryAffinity);
52
53 virtual std::shared_ptr<arm_compute::IMemoryGroup>
54 CreateMemoryGroup(const std::shared_ptr<arm_compute::MemoryManagerOnDemand>& memoryManager) = 0;
telsoa01c577f2c2018-08-31 09:22:23 +010055#endif
56};
57
Matteo Martincighd95e9062019-01-31 15:35:59 +000058#if defined(ARMCOMPUTENEON_ENABLED)
telsoa01c577f2c2018-08-31 09:22:23 +010059class NeonMemoryManager : public BaseMemoryManager
60{
61public:
62 NeonMemoryManager() {}
63 virtual ~NeonMemoryManager() {}
64
telsoa01c577f2c2018-08-31 09:22:23 +010065 NeonMemoryManager(std::unique_ptr<arm_compute::IAllocator> alloc, MemoryAffinity memoryAffinity)
66 : BaseMemoryManager(std::move(alloc), memoryAffinity)
67 {
68 m_InterLayerMemoryGroup = CreateMemoryGroup(m_InterLayerMemoryMgr);
69 }
70
71protected:
Matteo Martincighd95e9062019-01-31 15:35:59 +000072 std::shared_ptr<arm_compute::IMemoryGroup>
telsoa01c577f2c2018-08-31 09:22:23 +010073 CreateMemoryGroup(const std::shared_ptr<arm_compute::MemoryManagerOnDemand>& memoryManager) override;
telsoa01c577f2c2018-08-31 09:22:23 +010074};
Matteo Martincighd95e9062019-01-31 15:35:59 +000075#endif
telsoa01c577f2c2018-08-31 09:22:23 +010076
Matteo Martincighd95e9062019-01-31 15:35:59 +000077#if defined(ARMCOMPUTECL_ENABLED)
telsoa01c577f2c2018-08-31 09:22:23 +010078class ClMemoryManager : public BaseMemoryManager
79{
80public:
81 ClMemoryManager() {}
82 virtual ~ClMemoryManager() {}
83
telsoa01c577f2c2018-08-31 09:22:23 +010084 ClMemoryManager(std::unique_ptr<arm_compute::IAllocator> alloc)
85 : BaseMemoryManager(std::move(alloc), MemoryAffinity::Buffer)
86 {
87 m_InterLayerMemoryGroup = CreateMemoryGroup(m_InterLayerMemoryMgr);
88 }
89
90protected:
Matteo Martincighd95e9062019-01-31 15:35:59 +000091 std::shared_ptr<arm_compute::IMemoryGroup>
telsoa01c577f2c2018-08-31 09:22:23 +010092 CreateMemoryGroup(const std::shared_ptr<arm_compute::MemoryManagerOnDemand>& memoryManager) override;
telsoa01c577f2c2018-08-31 09:22:23 +010093};
Matteo Martincighd95e9062019-01-31 15:35:59 +000094#endif
telsoa01c577f2c2018-08-31 09:22:23 +010095
Aron Virginas-Tarf9aeef02018-10-12 15:18:03 +010096} //namespace armnn