Mesa (main): aco/optimizer: combine v_mul_lo_u16 + v_add_u16 -> v_mad_u16
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Fri Aug 27 20:15:49 UTC 2021
Module: Mesa
Branch: main
Commit: 8e27ca9953eb55e643eaff7d8afb982d61cb985b
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=8e27ca9953eb55e643eaff7d8afb982d61cb985b
Author: Daniel Schürmann <daniel at schuermann.dev>
Date: Thu Jul 1 18:48:09 2021 +0200
aco/optimizer: combine v_mul_lo_u16 + v_add_u16 -> v_mad_u16
Totals from 192 (0.13% of 150170) affected shaders: (GFX10.3)
CodeSize: 1027224 -> 1019872 (-0.72%)
Instrs: 174784 -> 173863 (-0.53%)
Latency: 4235742 -> 4232177 (-0.08%); split: -0.11%, +0.03%
InvThroughput: 1777026 -> 1775945 (-0.06%); split: -0.09%, +0.03%
Copies: 34098 -> 34099 (+0.00%); split: -0.03%, +0.03%
PreVGPRs: 4920 -> 4850 (-1.42%)
Reviewed-by: Rhys Perry <pendingchaos02 at gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/11678>
---
src/amd/compiler/aco_optimizer.cpp | 14 +++++++++-----
1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/src/amd/compiler/aco_optimizer.cpp b/src/amd/compiler/aco_optimizer.cpp
index 8c9e50c96c6..f739257afaf 100644
--- a/src/amd/compiler/aco_optimizer.cpp
+++ b/src/amd/compiler/aco_optimizer.cpp
@@ -1477,11 +1477,7 @@ label_instruction(opt_ctx& ctx, aco_ptr<Instruction>& instr)
break;
}
case aco_opcode::v_mul_lo_u16:
- if (instr->definitions[0].isNUW()) {
- /* Most of 16-bit mul optimizations are only valid if no overflow. */
- ctx.info[instr->definitions[0].tempId()].set_usedef(instr.get());
- }
- break;
+ case aco_opcode::v_mul_lo_u16_e64:
case aco_opcode::v_mul_u32_u24:
ctx.info[instr->definitions[0].tempId()].set_usedef(instr.get());
break;
@@ -3381,6 +3377,14 @@ combine_instruction(opt_ctx& ctx, aco_ptr<Instruction>& instr)
} else if (combine_three_valu_op(ctx, instr, aco_opcode::s_xor_b32, aco_opcode::v_xor3_b32,
"012", 1 | 2)) {
}
+ } else if (instr->opcode == aco_opcode::v_add_u16) {
+ combine_three_valu_op(
+ ctx, instr, aco_opcode::v_mul_lo_u16,
+ ctx.program->chip_class == GFX8 ? aco_opcode::v_mad_legacy_u16 : aco_opcode::v_mad_u16,
+ "120", 1 | 2);
+ } else if (instr->opcode == aco_opcode::v_add_u16_e64) {
+ combine_three_valu_op(ctx, instr, aco_opcode::v_mul_lo_u16_e64, aco_opcode::v_mad_u16, "120",
+ 1 | 2);
} else if (instr->opcode == aco_opcode::v_add_u32) {
if (combine_add_sub_b2i(ctx, instr, aco_opcode::v_addc_co_u32, 1 | 2)) {
} else if (combine_add_bcnt(ctx, instr)) {
More information about the mesa-commit
mailing list