tilelang.transform.pass_config¶
Classes¶
Pass configuration keys for TileLang compiler. |
Module Contents¶
- class tilelang.transform.pass_config.PassConfigKey¶
Bases:
str,enum.EnumPass configuration keys for TileLang compiler.
- TL_SIMPLIFY = 'tl.Simplify'¶
True
- Type:
Enable/disable TileLang simplification passes. Default
- TL_DYNAMIC_ALIGNMENT = 'tl.dynamic_alignment'¶
16
- Type:
Memory alignment requirement for dynamic shapes. Default
- TL_DISABLE_DYNAMIC_TAIL_SPLIT = 'tl.disable_dynamic_tail_split'¶
False
- Type:
Disable dynamic tail splitting optimization. Default
- TL_DISABLE_WARP_SPECIALIZED = 'tl.disable_warp_specialized'¶
False
- Type:
Disable warp specialization optimization. Default
- TL_DISABLE_FAST_MATH = 'tl.disable_fast_math'¶
True will be deprecated in the 0.1.7 release
- Type:
Disable fast math optimization. Default
- TL_ENABLE_FAST_MATH = 'tl.enable_fast_math'¶
False if enabled, –use_fast_math will be passed to nvcc
- Type:
Enable fast math optimization. Default
- TL_PTXAS_REGISTER_USAGE_LEVEL = 'tl.ptxas_register_usage_level'¶
The PTXAS register usage level in [0, 10], which controls the aggressiveness of optimizations that affect register usage. Default: None
- TL_ENABLE_PTXAS_VERBOSE_OUTPUT = 'tl.enable_ptxas_verbose_output'¶
False
- Type:
Enable ptxas verbose output. Default
- TL_CONFIG_INDEX_BITWIDTH = 'tl.config_index_bitwidth'¶
32
- Type:
Bitwidth for configuration indices. Default
- TL_DISABLE_TMA_LOWER = 'tl.disable_tma_lower'¶
False
- Type:
Disable TMA (Tensor Memory Access) lowering. Default
- TL_DISABLE_SAFE_MEMORY_ACCESS = 'tl.disable_safe_memory_legalize'¶
False
- Type:
Disable safe memory access optimization. Default
- TL_DISABLE_VECTORIZE_256 = 'tl.disable_vectorize_256'¶
False
- Type:
Disable usage of LDG/STG 256. Default
- TL_DISABLE_WGMMA = 'tl.disable_wgmma'¶
False
- Type:
Disable usage of Hopper WGMMA. Default
- TL_DEBUG_MERGE_SHARED_MEMORY_ALLOCATIONS = 'tl.debug_merge_shared_memory_allocations'¶
False
- Type:
Enable debug information for merge shared memory allocations. Default
- TL_ENABLE_AGGRESSIVE_SHARED_MEMORY_MERGE = 'tl.enable_aggressive_shared_memory_merge'¶
False
- Type:
Enable aggressive merge of shared memory allocations. Default
- TL_DISABLE_SHUFFLE_ELECT = 'tl.disable_shuffle_elect'¶
False
- Type:
Disable shuffle election optimization. Default
- TL_DISABLE_THREAD_STORAGE_SYNC = 'tl.disable_thread_storage_sync'¶
Disable thread storage synchronization pass. When enabled, disables the automatic insertion of thread synchronization barriers (e.g., __syncthreads()) for shared memory access coordination. This can be useful for performance optimization in cases where manual synchronization is preferred or when synchronization is not needed. Default: False
- TL_FORCE_LET_INLINE = 'tl.force_let_inline'¶
False
- Type:
Force TileLang to inline let bindings during simplification. Default
- TL_STORAGE_REWRITE_DETECT_INPLACE = 'tl.storage_rewrite_detect_inplace'¶
Control StorageRewrite inplace detection.
When False (default) StorageRewrite keeps distinct temporaries for patterns such as dst[i] = f(src[i]), avoiding implicit aliasing:
` read = T.allocate([1], "int32", "local.var") write = T.allocate([1], "int32", "local.var") read_buf = T.Buffer((1,), "int32", data=read, scope="local.var") write_buf = T.Buffer((1,), "int32", data=write, scope="local.var") write_buf[0] = read_buf[0] * 2 f(write_buf[0]) `Setting the flag to True allows StorageRewrite to reuse the read buffer for the write when it can prove the update is safely inplace, producing IR like:
` read = T.allocate([1], "int32", "local.var") read_buf = T.Buffer((1,), "int32", data=read, scope="local.var") read_buf[0] = read_buf[0] * 2 f(read_buf[0]) `This reduces local memory usage but introduces aliasing between the buffers.
Usage:
```python from tilelang.transform import PassContext, PassConfigKey
- with PassContext(
config={PassConfigKey.TL_STORAGE_REWRITE_DETECT_INPLACE.value: True}
- ):
mod = tilelang.transform.StorageRewrite()(mod)
- TIR_ENABLE_EQUIV_TERMS_IN_CSE = 'tir.enable_equiv_terms_in_cse_tir'¶
True
- Type:
Enable equivalent terms in TIR Common Subexpression Elimination. Default
- TIR_DISABLE_CSE = 'tir.disable_cse_tir'¶
False
- Type:
Disable TIR Common Subexpression Elimination. Default
- TIR_SIMPLIFY = 'tir.Simplify'¶
True
- Type:
Enable/disable TIR simplification passes. Default
- TIR_DISABLE_STORAGE_REWRITE = 'tir.disable_storage_rewrite'¶
False
- Type:
Disable storage rewrite optimization. Default
- TIR_DISABLE_VECTORIZE = 'tir.disable_vectorize'¶
False
- Type:
Disable vectorization optimization. Default
- TIR_USE_ASYNC_COPY = 'tir.use_async_copy'¶
True
- Type:
Enable asynchronous memory copy operations. Default
- TIR_ENABLE_DEBUG = 'tir.enable_debug'¶
False
- Type:
Enable debug information in generated code. Default
- TIR_MERGE_STATIC_SMEM = 'tir.merge_static_smem'¶
True
- Type:
Merge static shared memory allocations. Default
- TIR_ADD_LOWER_PASS = 'tir.add_lower_pass'¶
None
- Type:
Additional lowering passes to be applied. Default
- TIR_NOALIAS = 'tir.noalias'¶
True
- Type:
Enable pointer non-aliasing assumptions. Default
- CUDA_KERNELS_OUTPUT_DIR = 'cuda.kernels_output_dir'¶
empty string
- Type:
Output directory for generated CUDA kernels. Default