2 * Copyright (c) 2019 Samsung Electronics Co., Ltd. All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 #include "backend/basic/StaticTensorManager.h"
19 #include "backend/basic/DynamicTensorManager.h"
20 #include "backend/basic/Tensor.h"
21 #include <util/logging.h>
30 StaticTensorManager::StaticTensorManager(const std::shared_ptr<TensorRegistry> ®,
31 DynamicTensorManager *dynamic_tensor_manager)
32 : _nonconst_mgr{new MemoryManager()}, _tensors{reg}, _dynamic_tensor_manager{
33 dynamic_tensor_manager}
38 StaticTensorManager::StaticTensorManager(const std::shared_ptr<TensorRegistry> ®,
39 const std::string planner_id,
40 DynamicTensorManager *dynamic_tensor_manager)
41 : _nonconst_mgr{new MemoryManager(planner_id)}, _tensors{reg}, _dynamic_tensor_manager{
42 dynamic_tensor_manager}
47 void StaticTensorManager::allocateNonconsts(void)
49 _nonconst_mgr->allocate();
51 for (auto &&pair : _tensors->native_tensors())
53 const auto &ind = pair.first;
54 auto tensor = pair.second.get();
55 if (!_as_constants[ind] && !tensor->is_dynamic())
57 auto *buffer = _nonconst_mgr->getBuffer(ind);
58 tensor->setBuffer(buffer);
60 VERBOSE(CPU_StaticTensorManager)
61 << "TENSOR " << ind << " : " << static_cast<void *>(buffer) << std::endl;
66 void StaticTensorManager::deallocateNonconsts(void) { _nonconst_mgr->deallocate(); }
68 void StaticTensorManager::buildTensor(const ir::OperandIndex &ind,
69 const ir::OperandInfo &tensor_info, ir::Layout backend_layout,
72 assert(!_tensors->getNativeTensor(ind));
75 auto tensor = std::make_unique<ExternalTensor>(tensor_info, backend_layout);
76 _tensors->setNativeTensor(ind, std::move(tensor));
80 auto tensor = std::make_unique<Tensor>(tensor_info, backend_layout,
81 _dynamic_tensor_manager->dynamic_mem_mgr().get());
82 _tensors->setNativeTensor(ind, std::move(tensor));
84 _as_constants[ind] = as_const;
87 void StaticTensorManager::claimPlan(const ir::OperandIndex &ind, uint32_t size)
89 assert(_tensors->getNativeTensor(ind));
91 // This method is called only when a tensor has proper shape
92 assert(!_tensors->getNativeTensor(ind)->is_dynamic());
94 if (!_as_constants[ind])
95 _nonconst_mgr->claimPlan(ind, size);
98 void StaticTensorManager::releasePlan(const ir::OperandIndex &ind)
100 assert(_tensors->getNativeTensor(ind));
102 // This method is called only when a tensor has proper shape
103 assert(!_tensors->getNativeTensor(ind)->is_dynamic());
105 if (!_as_constants[ind])
106 _nonconst_mgr->releasePlan(ind);
109 void StaticTensorManager::iterate(const std::function<void(const ir::OperandIndex &)> &fn)
111 for (const auto &it : _tensors->native_tensors())
116 } // namespace backend