summaryrefslogtreecommitdiffstats
path: root/src/freedreno/ir3/ir3_nir_imul.py
diff options
context:
space:
mode:
Diffstat (limited to 'src/freedreno/ir3/ir3_nir_imul.py')
-rw-r--r--src/freedreno/ir3/ir3_nir_imul.py5
1 files changed, 5 insertions, 0 deletions
diff --git a/src/freedreno/ir3/ir3_nir_imul.py b/src/freedreno/ir3/ir3_nir_imul.py
index f648cd11071..45dee61ca1d 100644
--- a/src/freedreno/ir3/ir3_nir_imul.py
+++ b/src/freedreno/ir3/ir3_nir_imul.py
@@ -27,6 +27,11 @@ import sys
imul_lowering = [
(('imul', 'a@32', 'b@32'), ('imadsh_mix16', 'b', 'a', ('imadsh_mix16', 'a', 'b', ('umul_low', 'a', 'b')))),
+ # We want to run the imad24 rule late so that it doesn't fight
+ # with constant folding the (imul24, a, b). Since this pass is
+ # run late, and this is kinda imul related, this seems like a
+ # good place for it:
+ (('iadd', ('imul24', 'a', 'b'), 'c'), ('imad24_ir3', 'a', 'b', 'c')),
]