From: 박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 Date: Mon, 1 Oct 2018 01:34:39 +0000 (+0900) Subject: [enco] Introduce CodeIndex (#1678) X-Git-Tag: nncc_backup~1672 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=f453f276a65b1dd2a3cd42855bf5588a8b6142c7;p=platform%2Fcore%2Fml%2Fnnfw.git [enco] Introduce CodeIndex (#1678) This commit introduces CodeIndex class (which is a pair of BlockIndex and InstrIndex). This CodeIndex allows us to decide the order between two instructions without building a sequence map. Signed-off-by: Jonghyun Park --- diff --git a/contrib/enco/core/src/CodeIndex.h b/contrib/enco/core/src/CodeIndex.h new file mode 100644 index 0000000..7f2da64 --- /dev/null +++ b/contrib/enco/core/src/CodeIndex.h @@ -0,0 +1,76 @@ +/* + * Copyright (c) 2018 Samsung Electronics Co., Ltd. All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CODE_INDEX_H__ +#define __CODE_INDEX_H__ + +#include +#include + +/** + * @brief A CodeIndex denotes the index of instruction inside the whole module + */ +class CodeIndex +{ +public: + CodeIndex() = default; + +public: + CodeIndex(const coco::BlockIndex &blk_ind, const coco::InstrIndex &ins_ind) + : _blk_ind{blk_ind}, _ins_ind{ins_ind} + { + } + +public: + const coco::BlockIndex &block(void) const { return _blk_ind; } + const coco::InstrIndex &instr(void) const { return _ins_ind; } + +private: + coco::BlockIndex _blk_ind; + coco::InstrIndex _ins_ind; +}; + +static inline coco::BlockIndex block_index(const coco::Block *blk) +{ + if (blk == nullptr) + { + return coco::BlockIndex{}; + } + + return blk->index(); +} + +static inline CodeIndex code_index(const coco::Instr *ins) +{ + return CodeIndex{block_index(ins->parent()), ins->index()}; +} + +static inline bool operator<(const CodeIndex &lhs, const CodeIndex &rhs) +{ + if (lhs.block() < rhs.block()) + { + return true; + } + + if (lhs.block().value() > rhs.block().value()) + { + return false; + } + + return lhs.instr() < rhs.instr(); +} + +#endif // __CODE_INDEX_H__ diff --git a/contrib/enco/core/src/Transforms/Optimizations.cpp b/contrib/enco/core/src/Transforms/Optimizations.cpp index d4b4ad3..6331978 100644 --- a/contrib/enco/core/src/Transforms/Optimizations.cpp +++ b/contrib/enco/core/src/Transforms/Optimizations.cpp @@ -15,6 +15,7 @@ */ #include "Optimizations.h" +#include "CodeIndex.h" #include @@ -121,6 +122,7 @@ bool hoistable(const coco::Shuffle *shuffle) return true; } +// TODO Remove unused method std::map make_sequence_map(const coco::Module *m) { std::map res; @@ -217,13 +219,11 @@ void hoist_object(enco::Code *code) // // Case 2 // - auto sequence_map = make_sequence_map(m); - for (uint32_t n = 0; n < m->entity()->bag()->size(); ++n) { auto bag = m->entity()->bag()->at(n); - std::map collected; + std::map collected; for (auto reader : coco::readers(bag)) { @@ -231,7 +231,7 @@ void hoist_object(enco::Code *code) { if (auto shuffle = ins->asShuffle()) { - collected[sequence_map.at(shuffle)] = shuffle; + collected[code_index(shuffle)] = shuffle; } } }