Commit 5b9e9bd
authored
[TIR] Keep trivial LetStmt in tir.Simplify when used in buffer decl (#14951)
Prior to this commit, any trivial let binding of `var1 = var2` is
inlined. However, buffer definitions are not updated, so this can
result in dangling `tir::Var` instances. This commit updates the
`tir.Simplify` pass to keep trivial let bindings if they are used as
part of a buffer definition.
Ideally, the trivial `LetStmt` variable would be inlined into the
buffer definition as well as other expressions. However, because a
buffer may be implicitly declared, the first usage may be within a
constrained context. If that happens, the simplified shape/strides
expression cannot be used to update the buffer definition, as that
simplification is not valid at all possible usage points of the
buffer.
```python
for i in range(n):
elem_offset = i
view = T.Buffer(1, data=buf, elem_offset = elem_offset)
if i == 0:
# First occurrence in TIR is here, where elem_offset would
# simplify to zero.
view[0] = 1
else:
# But the same buffer is used here, where elem_offset doesn't
# simplify to zero.
view[0] = 2
```
This will be resolvable after #14778
lands, requiring all buffers to be declared with `DeclBuffer` prior to
usage.
```python
for i in range(n):
elem_offset = i
# All variables used by the DeclBuffer are valid across the entire
# body of the DeclBuffer.
view = T.decl_buffer(1, data=buf, elem_offset = elem_offset)
if i == 0:
view[0] = 1
else:
view[0] = 2
```1 parent 0af9ff9 commit 5b9e9bd
File tree
2 files changed
+123
-9
lines changed- src/tir/transforms
- tests/python/unittest
2 files changed
+123
-9
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
33 | 33 | | |
34 | 34 | | |
35 | 35 | | |
| 36 | + | |
36 | 37 | | |
37 | 38 | | |
38 | 39 | | |
| |||
91 | 92 | | |
92 | 93 | | |
93 | 94 | | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
94 | 135 | | |
95 | 136 | | |
96 | 137 | | |
| |||
110 | 151 | | |
111 | 152 | | |
112 | 153 | | |
113 | | - | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
114 | 158 | | |
115 | 159 | | |
116 | 160 | | |
117 | 161 | | |
118 | 162 | | |
119 | | - | |
120 | | - | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
121 | 169 | | |
122 | 170 | | |
| 171 | + | |
123 | 172 | | |
124 | 173 | | |
125 | 174 | | |
| |||
159 | 208 | | |
160 | 209 | | |
161 | 210 | | |
162 | | - | |
163 | | - | |
164 | | - | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
165 | 225 | | |
166 | | - | |
167 | 226 | | |
168 | 227 | | |
169 | 228 | | |
170 | 229 | | |
171 | 230 | | |
172 | 231 | | |
173 | | - | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
174 | 241 | | |
175 | 242 | | |
176 | 243 | | |
| |||
207 | 274 | | |
208 | 275 | | |
209 | 276 | | |
| 277 | + | |
| 278 | + | |
210 | 279 | | |
211 | | - | |
| 280 | + | |
212 | 281 | | |
213 | 282 | | |
214 | 283 | | |
| |||
260 | 329 | | |
261 | 330 | | |
262 | 331 | | |
| 332 | + | |
263 | 333 | | |
264 | 334 | | |
265 | 335 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1689 | 1689 | | |
1690 | 1690 | | |
1691 | 1691 | | |
| 1692 | + | |
| 1693 | + | |
| 1694 | + | |
| 1695 | + | |
| 1696 | + | |
| 1697 | + | |
| 1698 | + | |
| 1699 | + | |
| 1700 | + | |
| 1701 | + | |
| 1702 | + | |
| 1703 | + | |
| 1704 | + | |
| 1705 | + | |
| 1706 | + | |
| 1707 | + | |
| 1708 | + | |
| 1709 | + | |
| 1710 | + | |
| 1711 | + | |
| 1712 | + | |
| 1713 | + | |
| 1714 | + | |
| 1715 | + | |
| 1716 | + | |
| 1717 | + | |
| 1718 | + | |
| 1719 | + | |
| 1720 | + | |
| 1721 | + | |
| 1722 | + | |
| 1723 | + | |
| 1724 | + | |
| 1725 | + | |
| 1726 | + | |
| 1727 | + | |
| 1728 | + | |
| 1729 | + | |
| 1730 | + | |
| 1731 | + | |
| 1732 | + | |
| 1733 | + | |
| 1734 | + | |
| 1735 | + | |
1692 | 1736 | | |
1693 | 1737 | | |
0 commit comments