From f453f276a65b1dd2a3cd42855bf5588a8b6142c7 Mon Sep 17 00:00:00 2001 From: =?utf8?q?=EB=B0=95=EC=A2=85=ED=98=84/=EB=8F=99=EC=9E=91=EC=A0=9C?= =?utf8?q?=EC=96=B4Lab=28SR=29/Staff=20Engineer/=EC=82=BC=EC=84=B1?= =?utf8?q?=EC=A0=84=EC=9E=90?= Date: Mon, 1 Oct 2018 10:34:39 +0900 Subject: [PATCH] [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 --- contrib/enco/core/src/CodeIndex.h | 76 ++++++++++++++++++++++ contrib/enco/core/src/Transforms/Optimizations.cpp | 8 +-- 2 files changed, 80 insertions(+), 4 deletions(-) create mode 100644 contrib/enco/core/src/CodeIndex.h 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; } } } -- 2.7.4