transfer_stmt.h 1.3 KB
Newer Older
C
ckey_Dou 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/**
 * Copyright 2020 Huawei Technologies Co., Ltd
 *
 * 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.
 */
16 17
#ifndef POLY_TRANSFER_STMT_H_
#define POLY_TRANSFER_STMT_H_
C
ckey_Dou 已提交
18

19
#include "poly/schedule_pass.h"
C
ckey_Dou 已提交
20 21 22 23 24 25

namespace akg {
namespace ir {
namespace poly {

/*
26 27
 * Transfer specified statements out of outer-most band's filter nodes if they are previously
 * recorded as transfer_stmt.
C
ckey_Dou 已提交
28
 */
29 30 31 32 33 34 35 36
class TransferStmt : public SchedulePass {
 public:
  TransferStmt(ScopInfo &scop_info, PassInfo &pass_info) : scop_info_(scop_info), pass_info_(pass_info) {
    pass_name_ = __FUNCTION__;
  }
  ~TransferStmt(){};

  virtual isl::schedule Run(isl::schedule sch);
C
ckey_Dou 已提交
37

38 39 40
 private:
  ScopInfo &scop_info_;
  PassInfo &pass_info_;
C
ckey_Dou 已提交
41 42 43 44 45 46
};

}  // namespace poly
}  // namespace ir
}  // namespace akg

47
#endif  // POLY_TRANSFER_STMT_H_