tvm
frame.h
Go to the documentation of this file.
1 /*
2  * Licensed to the Apache Software Foundation (ASF) under one
3  * or more contributor license agreements. See the NOTICE file
4  * distributed with this work for additional information
5  * regarding copyright ownership. The ASF licenses this file
6  * to you under the Apache License, Version 2.0 (the
7  * "License"); you may not use this file except in compliance
8  * with the License. You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing,
13  * software distributed under the License is distributed on an
14  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15  * KIND, either express or implied. See the License for the
16  * specific language governing permissions and limitations
17  * under the License.
18  */
19 #ifndef TVM_SCRIPT_IR_BUILDER_TIR_FRAME_H_
20 #define TVM_SCRIPT_IR_BUILDER_TIR_FRAME_H_
21 
24 #include <tvm/tir/stmt.h>
25 
26 #include <utility>
27 
28 namespace tvm {
29 namespace script {
30 namespace ir_builder {
31 namespace tir {
32 
39  public:
41  ffi::Array<tvm::tir::Stmt> stmts;
42 
43  static void RegisterReflection() {
44  namespace refl = tvm::ffi::reflection;
45  refl::ObjectDef<TIRFrameNode>().def_ro("stmts", &TIRFrameNode::stmts);
46  }
47  TVM_FFI_DECLARE_OBJECT_INFO("script.ir_builder.tir.TIRFrame", TIRFrameNode, IRBuilderFrameNode);
48 };
49 
55 class TIRFrame : public IRBuilderFrame {
56  public:
58 
59  protected:
60  TIRFrame() = default;
61  explicit TIRFrame(ObjectPtr<TIRFrameNode> data) : IRBuilderFrame(data) {}
62 };
63 
70  public:
72  ffi::Optional<ffi::String> name;
74  ffi::Array<tvm::tir::Var> args;
76  bool is_private;
78  ffi::Optional<Type> ret_type;
80  ffi::Map<tvm::tir::Var, tvm::tir::Buffer> buffer_map;
82  ffi::Map<ffi::String, Any> attrs;
84  ffi::Map<tvm::tir::Var, tvm::tir::IterVar> env_threads;
86  ffi::Array<tvm::tir::Buffer> root_alloc_buffers;
87 
88  static void RegisterReflection() {
89  namespace refl = tvm::ffi::reflection;
90  refl::ObjectDef<PrimFuncFrameNode>()
91  .def_ro("name", &PrimFuncFrameNode::name)
92  .def_ro("args", &PrimFuncFrameNode::args)
93  .def_ro("is_private", &PrimFuncFrameNode::is_private)
94  .def_ro("ret_type", &PrimFuncFrameNode::ret_type)
95  .def_ro("buffer_map", &PrimFuncFrameNode::buffer_map)
96  .def_ro("attrs", &PrimFuncFrameNode::attrs)
97  .def_ro("env_threads", &PrimFuncFrameNode::env_threads)
98  .def_ro("root_alloc_buffers", &PrimFuncFrameNode::root_alloc_buffers);
99  }
100  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.PrimFuncFrame", PrimFuncFrameNode,
101  TIRFrameNode);
102 
103  public:
108  void ExitWithScope() final;
109 };
110 
116 class PrimFuncFrame : public TIRFrame {
117  public:
118  explicit PrimFuncFrame(ObjectPtr<PrimFuncFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
119  TVM_FFI_ICHECK(data != nullptr);
120  data_ = std::move(data);
121  }
123 };
124 
130 class BlockFrameNode : public TIRFrameNode {
131  public:
133  ffi::String name;
135  ffi::Array<tvm::tir::IterVar> iter_vars;
137  ffi::Optional<ffi::Array<tvm::tir::BufferRegion>> reads;
139  ffi::Optional<ffi::Array<tvm::tir::BufferRegion>> writes;
141  ffi::Optional<tvm::tir::Stmt> init;
143  ffi::Array<tvm::tir::Buffer> alloc_buffers;
145  ffi::Array<tvm::tir::MatchBufferRegion> match_buffers;
147  ffi::Optional<ffi::Map<ffi::String, Any>> annotations;
149  ffi::Array<PrimExpr> iter_values;
154  ffi::Optional<PrimExpr> predicate;
157 
158  static void RegisterReflection() {
159  namespace refl = tvm::ffi::reflection;
160  refl::ObjectDef<BlockFrameNode>()
161  .def_ro("name", &BlockFrameNode::name)
162  .def_ro("iter_vars", &BlockFrameNode::iter_vars)
163  .def_ro("reads", &BlockFrameNode::reads)
164  .def_ro("writes", &BlockFrameNode::writes)
165  .def_ro("init", &BlockFrameNode::init)
166  .def_ro("alloc_buffers", &BlockFrameNode::alloc_buffers)
167  .def_ro("match_buffers", &BlockFrameNode::match_buffers)
168  .def_ro("annotations", &BlockFrameNode::annotations)
169  .def_ro("iter_values", &BlockFrameNode::iter_values)
170  .def_ro("predicate", &BlockFrameNode::predicate)
171  .def_ro("no_realize", &BlockFrameNode::no_realize);
172  }
173  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.BlockFrame", BlockFrameNode,
174  TIRFrameNode);
175 
176  public:
181  void ExitWithScope() final;
182 };
183 
190 class BlockFrame : public TIRFrame {
191  public:
192  explicit BlockFrame(ObjectPtr<BlockFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
193  TVM_FFI_ICHECK(data != nullptr);
194  data_ = std::move(data);
195  }
197 };
198 
205  public:
206  static void RegisterReflection() {
207  namespace refl = tvm::ffi::reflection;
208  refl::ObjectDef<BlockInitFrameNode>();
209  }
210  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.BlockInitFrame", BlockInitFrameNode,
211  TIRFrameNode);
212 
213  public:
218  void EnterWithScope() final;
223  void ExitWithScope() final;
224 };
225 
231 class BlockInitFrame : public TIRFrame {
232  public:
233  explicit BlockInitFrame(ObjectPtr<BlockInitFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
234  TVM_FFI_ICHECK(data != nullptr);
235  data_ = std::move(data);
236  }
238 };
239 
245 class ForFrameNode : public TIRFrameNode {
246  public:
254  using FMakeForLoop = ffi::TypedFunction<tvm::tir::Stmt(
255  ffi::Array<tvm::tir::Var> loop_vars, ffi::Array<Range> loop_extents,
256  ffi::Array<ffi::Optional<PrimExpr>> loop_steps, tvm::tir::Stmt loop_body)>;
258  ffi::Array<tvm::tir::Var> vars;
260  ffi::Array<Range> doms;
262  ffi::Array<ffi::Optional<PrimExpr>> steps;
265 
266  static void RegisterReflection() {
267  namespace refl = tvm::ffi::reflection;
268  refl::ObjectDef<ForFrameNode>()
269  .def_ro("vars", &ForFrameNode::vars)
270  .def_ro("doms", &ForFrameNode::doms);
271  // `f_make_for_loop` is not registered as it's not visited.
272  }
273  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.ForFrame", ForFrameNode, TIRFrameNode);
274 
275  public:
280  void ExitWithScope() final;
281 };
282 
288 class ForFrame : public TIRFrame {
289  public:
290  explicit ForFrame(ObjectPtr<ForFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
291  TVM_FFI_ICHECK(data != nullptr);
292  data_ = std::move(data);
293  }
295 };
296 
304  public:
309 
310  static void RegisterReflection() {
311  namespace refl = tvm::ffi::reflection;
312  refl::ObjectDef<AssertFrameNode>()
313  .def_ro("condition", &AssertFrameNode::condition)
314  .def_ro("message", &AssertFrameNode::message);
315  }
316  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.AssertFrame", AssertFrameNode,
317  TIRFrameNode);
318 
319  public:
324  void ExitWithScope() final;
325 };
326 
332 class AssertFrame : public TIRFrame {
333  public:
334  explicit AssertFrame(ObjectPtr<AssertFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
335  TVM_FFI_ICHECK(data != nullptr);
336  data_ = std::move(data);
337  }
339 };
340 
346 class LetFrameNode : public TIRFrameNode {
347  public:
352 
353  static void RegisterReflection() {
354  namespace refl = tvm::ffi::reflection;
355  refl::ObjectDef<LetFrameNode>()
356  .def_ro("var", &LetFrameNode::var)
357  .def_ro("value", &LetFrameNode::value);
358  }
359  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.LetFrame", LetFrameNode, TIRFrameNode);
360 
361  public:
366  void ExitWithScope() final;
367 };
368 
374 class LetFrame : public TIRFrame {
375  public:
376  explicit LetFrame(ObjectPtr<LetFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
377  TVM_FFI_ICHECK(data != nullptr);
378  data_ = std::move(data);
379  }
381 };
382 
388  public:
392  ffi::String attr_key;
395 
396  static void RegisterReflection() {
397  namespace refl = tvm::ffi::reflection;
398  refl::ObjectDef<LaunchThreadFrameNode>()
399  .def_ro("extent", &LaunchThreadFrameNode::extent)
400  .def_ro("attr_key", &LaunchThreadFrameNode::attr_key)
401  .def_ro("iter_var", &LaunchThreadFrameNode::iter_var);
402  }
403  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.LaunchThreadFrame",
405 
406  public:
411  void ExitWithScope() final;
412 };
413 
419 class LaunchThreadFrame : public TIRFrame {
420  public:
421  explicit LaunchThreadFrame(ObjectPtr<LaunchThreadFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
422  TVM_FFI_ICHECK(data != nullptr);
423  data_ = std::move(data);
424  }
426 };
427 
434  public:
438  ffi::String storage_scope;
441 
442  static void RegisterReflection() {
443  namespace refl = tvm::ffi::reflection;
444  refl::ObjectDef<RealizeFrameNode>()
445  .def_ro("buffer_slice", &RealizeFrameNode::buffer_slice)
446  .def_ro("storage_scope", &RealizeFrameNode::storage_scope)
447  .def_ro("condition", &RealizeFrameNode::condition);
448  }
449  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.RealizeFrame", RealizeFrameNode,
450  TIRFrameNode);
451 
452  public:
457  void ExitWithScope() final;
458 };
459 
465 class RealizeFrame : public TIRFrame {
466  public:
467  explicit RealizeFrame(ObjectPtr<RealizeFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
468  TVM_FFI_ICHECK(data != nullptr);
469  data_ = std::move(data);
470  }
472 };
473 
480  public:
482  ffi::Array<PrimExpr> extents;
486  ffi::String storage_scope;
490  ffi::Map<ffi::String, Any> annotations;
493 
494  static void RegisterReflection() {
495  namespace refl = tvm::ffi::reflection;
496  refl::ObjectDef<AllocateFrameNode>()
497  .def_ro("extents", &AllocateFrameNode::extents)
498  .def_ro("dtype", &AllocateFrameNode::dtype)
499  .def_ro("storage_scope", &AllocateFrameNode::storage_scope)
500  .def_ro("condition", &AllocateFrameNode::condition)
501  .def_ro("annotations", &AllocateFrameNode::annotations)
502  .def_ro("buffer_var", &AllocateFrameNode::buffer_var);
503  }
504  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.AllocateFrame", AllocateFrameNode,
505  TIRFrameNode);
506 
507  public:
512  void ExitWithScope() final;
513 };
514 
520 class AllocateFrame : public TIRFrame {
521  public:
522  explicit AllocateFrame(ObjectPtr<AllocateFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
523  TVM_FFI_ICHECK(data != nullptr);
524  data_ = std::move(data);
525  }
527 };
528 
535  public:
539  ffi::Array<PrimExpr> extents;
545  ffi::Map<ffi::String, Any> annotations;
546 
547  static void RegisterReflection() {
548  namespace refl = tvm::ffi::reflection;
549  refl::ObjectDef<AllocateConstFrameNode>()
550  .def_ro("dtype", &AllocateConstFrameNode::dtype)
551  .def_ro("extents", &AllocateConstFrameNode::extents)
552  .def_ro("data", &AllocateConstFrameNode::data)
553  .def_ro("buffer_var", &AllocateConstFrameNode::buffer_var)
554  .def_ro("annotations", &AllocateConstFrameNode::annotations);
555  }
556  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.AllocateConstFrame",
558 
559  public:
564  void ExitWithScope() final;
565 };
566 
572 class AllocateConstFrame : public TIRFrame {
573  public:
574  explicit AllocateConstFrame(ObjectPtr<AllocateConstFrameNode> data)
575  : TIRFrame(ffi::UnsafeInit{}) {
576  TVM_FFI_ICHECK(data != nullptr);
577  data_ = std::move(data);
578  }
581 };
587 class AttrFrameNode : public TIRFrameNode {
588  public:
590  Any node;
592  ffi::String attr_key;
595 
596  static void RegisterReflection() {
597  namespace refl = tvm::ffi::reflection;
598  refl::ObjectDef<AttrFrameNode>()
599  .def_ro("node", &AttrFrameNode::node)
600  .def_ro("attr_key", &AttrFrameNode::attr_key)
601  .def_ro("value", &AttrFrameNode::value);
602  }
603  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.AttrFrame", AttrFrameNode, TIRFrameNode);
604 
605  public:
610  void ExitWithScope() final;
611 };
612 
618 class AttrFrame : public TIRFrame {
619  public:
620  explicit AttrFrame(ObjectPtr<AttrFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
621  TVM_FFI_ICHECK(data != nullptr);
622  data_ = std::move(data);
623  }
625 };
626 
632 class WhileFrameNode : public TIRFrameNode {
633  public:
636 
637  static void RegisterReflection() {
638  namespace refl = tvm::ffi::reflection;
639  refl::ObjectDef<WhileFrameNode>().def_ro("condition", &WhileFrameNode::condition);
640  }
641  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.WhileFrame", WhileFrameNode,
642  TIRFrameNode);
643 
644  public:
649  void ExitWithScope() final;
650 };
651 
657 class WhileFrame : public TIRFrame {
658  public:
659  explicit WhileFrame(ObjectPtr<WhileFrameNode> data) : TIRFrame(ffi::UnsafeInit{}) {
660  TVM_FFI_ICHECK(data != nullptr);
661  data_ = std::move(data);
662  }
664 };
665 
671 class IfFrameNode : public TIRFrameNode {
672  public:
676  ffi::Optional<ffi::Array<tvm::tir::Stmt>> then_stmts;
678  ffi::Optional<ffi::Array<tvm::tir::Stmt>> else_stmts;
679 
680  static void RegisterReflection() {
681  namespace refl = tvm::ffi::reflection;
682  refl::ObjectDef<IfFrameNode>()
683  .def_ro("condition", &IfFrameNode::condition)
684  .def_ro("then_stmts", &IfFrameNode::then_stmts)
685  .def_ro("else_stmts", &IfFrameNode::else_stmts);
686  }
687  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.IfFrame", IfFrameNode, TIRFrameNode);
688 
689  public:
694  void ExitWithScope() final;
695 };
696 
702 class IfFrame : public TIRFrame {
703  public:
704  explicit IfFrame(ObjectPtr<IfFrameNode> data) : TIRFrame(data) {
705  TVM_FFI_ICHECK(data != nullptr);
706  }
708 };
709 
715 class ThenFrameNode : public TIRFrameNode {
716  public:
717  static void RegisterReflection() {
718  namespace refl = tvm::ffi::reflection;
719  refl::ObjectDef<ThenFrameNode>();
720  }
721  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.ThenFrame", ThenFrameNode, TIRFrameNode);
722 
723  public:
728  void EnterWithScope() final;
733  void ExitWithScope() final;
734 };
735 
741 class ThenFrame : public TIRFrame {
742  public:
743  explicit ThenFrame(ObjectPtr<ThenFrameNode> data) : TIRFrame(data) {
744  TVM_FFI_ICHECK(data != nullptr);
745  }
747 };
748 
754 class ElseFrameNode : public TIRFrameNode {
755  public:
756  static void RegisterReflection() {
757  namespace refl = tvm::ffi::reflection;
758  refl::ObjectDef<ElseFrameNode>();
759  }
760  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.ElseFrame", ElseFrameNode, TIRFrameNode);
761 
762  public:
767  void EnterWithScope() final;
772  void ExitWithScope() final;
773 };
774 
780 class ElseFrame : public TIRFrame {
781  public:
782  explicit ElseFrame(ObjectPtr<ElseFrameNode> data) : TIRFrame(data) {
783  TVM_FFI_ICHECK(data != nullptr);
784  }
785 
787 };
788 
790  public:
794  bool allocated;
795 
796  static void RegisterReflection() {
797  namespace refl = tvm::ffi::reflection;
798  refl::ObjectDef<DeclBufferFrameNode>()
799  .def_ro("buffer", &DeclBufferFrameNode::buffer)
800  .def_ro("allocated", &DeclBufferFrameNode::allocated);
801  }
802  TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.DeclBufferFrame", DeclBufferFrameNode,
803  TIRFrameNode);
804 
805  public:
806  void ExitWithScope() final;
807 };
808 
809 class DeclBufferFrame : public TIRFrame {
810  public:
811  explicit DeclBufferFrame(ObjectPtr<DeclBufferFrameNode> data) : TIRFrame(data) {
812  TVM_FFI_ICHECK(data != nullptr);
813  }
815 };
816 
817 } // namespace tir
818 } // namespace ir_builder
819 } // namespace script
820 } // namespace tvm
821 
822 #endif // TVM_SCRIPT_IR_BUILDER_TIR_FRAME_H_
Reference to PrimExprNode.
Definition: expr.h:124
Runtime primitive data type.
Definition: data_type.h:47
Managed Tensor. The array is backed by reference counted blocks.
Definition: tensor.h:53
Managed reference to an IRBuilderFrameNode.
Definition: base.h:104
A frame represents the allocate constant.
Definition: frame.h:534
tvm::runtime::Tensor data
The data associated with the constant.
Definition: frame.h:541
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.AllocateConstFrame", AllocateConstFrameNode, TIRFrameNode)
tvm::tir::Var buffer_var
The buffer var.
Definition: frame.h:543
ffi::Map< ffi::String, Any > annotations
Additional annotations about the allocation.
Definition: frame.h:545
void ExitWithScope() final
The method called when exiting RAII scope.
ffi::Array< PrimExpr > extents
The extents of the allocate.
Definition: frame.h:539
DataType dtype
The data type of the buffer.
Definition: frame.h:537
static void RegisterReflection()
Definition: frame.h:547
Managed reference to AllocateConstFrameNode.
Definition: frame.h:572
AllocateConstFrame(ObjectPtr< AllocateConstFrameNode > data)
Definition: frame.h:574
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(AllocateConstFrame, TIRFrame, AllocateConstFrameNode)
A frame represents the allocate.
Definition: frame.h:479
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.AllocateFrame", AllocateFrameNode, TIRFrameNode)
tvm::tir::Var buffer_var
The buffer var.
Definition: frame.h:492
ffi::Map< ffi::String, Any > annotations
Additional annotation hints.
Definition: frame.h:490
ffi::String storage_scope
The storage scope.
Definition: frame.h:486
DataType dtype
The data type of the buffer.
Definition: frame.h:484
PrimExpr condition
The condition.
Definition: frame.h:488
static void RegisterReflection()
Definition: frame.h:494
void ExitWithScope() final
The method called when exiting RAII scope.
ffi::Array< PrimExpr > extents
The extents of the allocate.
Definition: frame.h:482
Managed reference to AllocateFrameNode.
Definition: frame.h:520
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(AllocateFrame, TIRFrame, AllocateFrameNode)
AllocateFrame(ObjectPtr< AllocateFrameNode > data)
Definition: frame.h:522
A frame that represents the assert statement. Proceeds if the condition is true, otherwise aborts wit...
Definition: frame.h:303
static void RegisterReflection()
Definition: frame.h:310
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.AssertFrame", AssertFrameNode, TIRFrameNode)
PrimExpr message
The output error message when the assertion failed.
Definition: frame.h:308
PrimExpr condition
The PrimExpr to test.
Definition: frame.h:306
void ExitWithScope() final
The method called when exiting RAII scope.
Managed reference to AssertFrameNode.
Definition: frame.h:332
AssertFrame(ObjectPtr< AssertFrameNode > data)
Definition: frame.h:334
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(AssertFrame, TIRFrame, AssertFrameNode)
A frame that represents attribute node.
Definition: frame.h:587
ffi::String attr_key
Attribute type key.
Definition: frame.h:592
void ExitWithScope() final
The method called when exiting RAII scope.
static void RegisterReflection()
Definition: frame.h:596
Any node
The node to annotate the attribute.
Definition: frame.h:590
PrimExpr value
The value of the attribute.
Definition: frame.h:594
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.AttrFrame", AttrFrameNode, TIRFrameNode)
Managed reference to AttrFrameNode.
Definition: frame.h:618
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(AttrFrame, TIRFrame, AttrFrameNode)
AttrFrame(ObjectPtr< AttrFrameNode > data)
Definition: frame.h:620
A frame that represents the block.
Definition: frame.h:130
ffi::Optional< PrimExpr > predicate
The predicate of the block realization, the block will only be executed when the predicate is true.
Definition: frame.h:154
ffi::Array< tvm::tir::IterVar > iter_vars
The variables of the block.
Definition: frame.h:135
ffi::Optional< ffi::Array< tvm::tir::BufferRegion > > writes
The write buffer regions of the block.
Definition: frame.h:139
void ExitWithScope() final
The method called when exiting RAII scope.
ffi::Array< tvm::tir::Buffer > alloc_buffers
The buffer allocated in the block.
Definition: frame.h:143
static void RegisterReflection()
Definition: frame.h:158
ffi::String name
The name of the block.
Definition: frame.h:133
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.BlockFrame", BlockFrameNode, TIRFrameNode)
ffi::Optional< tvm::tir::Stmt > init
The init statement of the bolck.
Definition: frame.h:141
ffi::Array< PrimExpr > iter_values
The corresponding values of the iter vars.
Definition: frame.h:149
ffi::Optional< ffi::Map< ffi::String, Any > > annotations
The annotation of the block.
Definition: frame.h:147
ffi::Array< tvm::tir::MatchBufferRegion > match_buffers
The match buffer regions.
Definition: frame.h:145
ffi::Optional< ffi::Array< tvm::tir::BufferRegion > > reads
The read buffer regions of the block.
Definition: frame.h:137
bool no_realize
The flag whether to construct BlockRealize or Block.
Definition: frame.h:156
Managed reference to BlockFrameNode.
Definition: frame.h:190
BlockFrame(ObjectPtr< BlockFrameNode > data)
Definition: frame.h:192
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(BlockFrame, TIRFrame, BlockFrameNode)
A frame that represents the block initialization statment.
Definition: frame.h:204
static void RegisterReflection()
Definition: frame.h:206
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.BlockInitFrame", BlockInitFrameNode, TIRFrameNode)
void EnterWithScope() final
The method called when entering RAII scope.
Managed reference to BlockInitFrameNode.
Definition: frame.h:231
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(BlockInitFrame, TIRFrame, BlockInitFrameNode)
BlockInitFrame(ObjectPtr< BlockInitFrameNode > data)
Definition: frame.h:233
void ExitWithScope() final
The method called when exiting RAII scope.
static void RegisterReflection()
Definition: frame.h:796
tvm::tir::Buffer buffer
The declared buffer.
Definition: frame.h:792
bool allocated
The buffer allocated or not.
Definition: frame.h:794
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.DeclBufferFrame", DeclBufferFrameNode, TIRFrameNode)
DeclBufferFrame(ObjectPtr< DeclBufferFrameNode > data)
Definition: frame.h:811
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(DeclBufferFrame, TIRFrame, DeclBufferFrameNode)
A frame that represents else.
Definition: frame.h:754
static void RegisterReflection()
Definition: frame.h:756
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.ElseFrame", ElseFrameNode, TIRFrameNode)
void EnterWithScope() final
The method called when entering RAII scope.
Managed reference to ElseFrameNode.
Definition: frame.h:780
ElseFrame(ObjectPtr< ElseFrameNode > data)
Definition: frame.h:782
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(ElseFrame, TIRFrame, ElseFrameNode)
A frame that represents the for loop.
Definition: frame.h:245
ffi::TypedFunction< tvm::tir::Stmt(ffi::Array< tvm::tir::Var > loop_vars, ffi::Array< Range > loop_extents, ffi::Array< ffi::Optional< PrimExpr > > loop_steps, tvm::tir::Stmt loop_body)> FMakeForLoop
Functions that generate loop nests.
Definition: frame.h:256
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.ForFrame", ForFrameNode, TIRFrameNode)
static void RegisterReflection()
Definition: frame.h:266
ffi::Array< Range > doms
The domains of iteration.
Definition: frame.h:260
FMakeForLoop f_make_for_loop
The for loop generating function.
Definition: frame.h:264
ffi::Array< tvm::tir::Var > vars
The loop variable.
Definition: frame.h:258
void ExitWithScope() final
The method called when exiting RAII scope.
ffi::Array< ffi::Optional< PrimExpr > > steps
The optional steps of iteration.
Definition: frame.h:262
Managed reference to ForFrameNode.
Definition: frame.h:288
ForFrame(ObjectPtr< ForFrameNode > data)
Definition: frame.h:290
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(ForFrame, TIRFrame, ForFrameNode)
A frame that represents if statement.
Definition: frame.h:671
ffi::Optional< ffi::Array< tvm::tir::Stmt > > then_stmts
The statements in the true branch.
Definition: frame.h:676
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.IfFrame", IfFrameNode, TIRFrameNode)
void ExitWithScope() final
The method called when exiting RAII scope.
PrimExpr condition
The condition of the if statement.
Definition: frame.h:674
ffi::Optional< ffi::Array< tvm::tir::Stmt > > else_stmts
The stetements in the false branch.
Definition: frame.h:678
static void RegisterReflection()
Definition: frame.h:680
Managed reference to IfFrameNode.
Definition: frame.h:702
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(IfFrame, TIRFrame, IfFrameNode)
IfFrame(ObjectPtr< IfFrameNode > data)
Definition: frame.h:704
The LaunchThreadFrameNode.
Definition: frame.h:387
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.LaunchThreadFrame", LaunchThreadFrameNode, TIRFrameNode)
void ExitWithScope() final
The method called when exiting RAII scope.
tvm::tir::IterVar iter_var
The iteration variable.
Definition: frame.h:394
ffi::String attr_key
The attribute key, could be either virtual_thread or thread_extent.
Definition: frame.h:392
static void RegisterReflection()
Definition: frame.h:396
PrimExpr extent
The extent of environment thread.
Definition: frame.h:390
Managed reference to LaunchThreadFrameNode.
Definition: frame.h:419
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(LaunchThreadFrame, TIRFrame, LaunchThreadFrameNode)
LaunchThreadFrame(ObjectPtr< LaunchThreadFrameNode > data)
Definition: frame.h:421
A frame represents the let binding expression, which binds a var.
Definition: frame.h:346
tvm::tir::Var var
The variable we bind to.
Definition: frame.h:349
PrimExpr value
The value we bind var to.
Definition: frame.h:351
static void RegisterReflection()
Definition: frame.h:353
void ExitWithScope() final
The method called when exiting RAII scope.
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.LetFrame", LetFrameNode, TIRFrameNode)
Managed reference to LetFrameNode.
Definition: frame.h:374
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(LetFrame, TIRFrame, LetFrameNode)
LetFrame(ObjectPtr< LetFrameNode > data)
Definition: frame.h:376
A frame that represents the PrimFunc containing TIR statements.
Definition: frame.h:69
ffi::Array< tvm::tir::Buffer > root_alloc_buffers
The buffer allocated in root block.
Definition: frame.h:86
static void RegisterReflection()
Definition: frame.h:88
ffi::Map< tvm::tir::Var, tvm::tir::Buffer > buffer_map
Maps some parameters to specific Buffer data structures.
Definition: frame.h:80
void ExitWithScope() final
The method called when exiting RAII scope.
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.PrimFuncFrame", PrimFuncFrameNode, TIRFrameNode)
ffi::Optional< Type > ret_type
The return type of the function.
Definition: frame.h:78
ffi::Array< tvm::tir::Var > args
Function parameters.
Definition: frame.h:74
ffi::Optional< ffi::String > name
The name of the block.
Definition: frame.h:72
ffi::Map< ffi::String, Any > attrs
Additional attributes storing the meta-data.
Definition: frame.h:82
bool is_private
Whether the PrimFunc is annotated as private.
Definition: frame.h:76
ffi::Map< tvm::tir::Var, tvm::tir::IterVar > env_threads
The variable map bound to thread env.
Definition: frame.h:84
Managed reference to PrimFuncFrameNode.
Definition: frame.h:116
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(PrimFuncFrame, TIRFrame, PrimFuncFrameNode)
PrimFuncFrame(ObjectPtr< PrimFuncFrameNode > data)
Definition: frame.h:118
A frame that represents realization.
Definition: frame.h:433
static void RegisterReflection()
Definition: frame.h:442
void ExitWithScope() final
The method called when exiting RAII scope.
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.RealizeFrame", RealizeFrameNode, TIRFrameNode)
PrimExpr condition
The condition expression.
Definition: frame.h:440
tvm::tir::BufferRegion buffer_slice
The region of buffer access.
Definition: frame.h:436
ffi::String storage_scope
The storage scope associated with this realization.
Definition: frame.h:438
Managed reference to RealizeFrameNode.
Definition: frame.h:465
RealizeFrame(ObjectPtr< RealizeFrameNode > data)
Definition: frame.h:467
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(RealizeFrame, TIRFrame, RealizeFrameNode)
A base frame that represents the TIR fame with body of statements.
Definition: frame.h:38
ffi::Array< tvm::tir::Stmt > stmts
The Stmt within in this frame.
Definition: frame.h:41
TVM_FFI_DECLARE_OBJECT_INFO("script.ir_builder.tir.TIRFrame", TIRFrameNode, IRBuilderFrameNode)
static void RegisterReflection()
Definition: frame.h:43
Managed reference to TIRFrameNode.
Definition: frame.h:55
TIRFrame(ObjectPtr< TIRFrameNode > data)
Definition: frame.h:61
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(TIRFrame, IRBuilderFrame, TIRFrameNode)
A frame that represents then.
Definition: frame.h:715
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.ThenFrame", ThenFrameNode, TIRFrameNode)
static void RegisterReflection()
Definition: frame.h:717
void EnterWithScope() final
The method called when entering RAII scope.
Managed reference to ThenFrameNode.
Definition: frame.h:741
ThenFrame(ObjectPtr< ThenFrameNode > data)
Definition: frame.h:743
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(ThenFrame, TIRFrame, ThenFrameNode)
A frame that represents while loop.
Definition: frame.h:632
TVM_FFI_DECLARE_OBJECT_INFO_FINAL("script.ir_builder.tir.WhileFrame", WhileFrameNode, TIRFrameNode)
static void RegisterReflection()
Definition: frame.h:637
PrimExpr condition
The termination condition of while.
Definition: frame.h:635
void ExitWithScope() final
The method called when exiting RAII scope.
Managed reference to WhileFrameNode.
Definition: frame.h:657
WhileFrame(ObjectPtr< WhileFrameNode > data)
Definition: frame.h:659
TVM_FFI_DEFINE_OBJECT_REF_METHODS_NOTNULLABLE(WhileFrame, TIRFrame, WhileFrameNode)
Managed reference to BufferRegionNode.
Definition: stmt.h:855
Buffer is a symbolic n-darray structure. It is a composition of primitive symbolic types,...
Definition: buffer.h:156
Iteration Variable, represents an iteration over an integer interval.
Definition: var.h:297
Container of all statements.
Definition: stmt.h:63
a named variable in TIR
Definition: var.h:77
Definition: repr_printer.h:91
Performance counters for profiling via the PAPI library.
Definition: analyzer.h:37
TIR statements.