Skip to content

aco: spiller fixes and optimizations and implement long jumps

Rhys Perry requested to merge pendingchaos/mesa:aco_long_jump_mr into master

Implements long jumps for the very rare case when we need to jump more than 32767 dwords. It also improves spilling in some cases. In addition to improving code on their own, the spiller optimizations reduce the impact of aco: reserve 2 sgprs for each branch on Detroit: Become Human.

fossil-db changes for the spiller optimizations (Navi):

 PERCENTAGE DELTAS                Shaders    VGPRs      SpillSGPRs SpillVGPRs CodeSize   Instrs     Cycles     VMEM       SMEM       VClause    SClause    Copies     Branches   PreSGPRs   PreVGPRs   
 assassins_creed_origins          2114          .          .          .       +0.03%     +0.02%     +0.01%        .       +0.01%        .       +0.00%     +0.05%     -0.15%        .          .       
 battlefront2                     4568       +0.00%        .          .       -0.01%     -0.01%     -0.01%     -0.00%     -0.00%        .       -0.03%     -0.15%     -0.17%        .       +0.00%   
 detroit_become_human             19959         .       -41.61%       .       -2.04%     -1.50%     -1.65%     +0.00%     -0.37%        .       -0.14%     -3.47%     -2.07%     -0.04%        .       
 doom_eternal                     1211          .       -70.59%       .       -0.01%     -0.01%     -0.02%     +0.00%     +0.00%        .       -0.02%     -0.04%     -0.01%        .          .       
 f12017                           5503          .          .          .       -0.01%     -0.01%     -0.01%        .       -0.00%        .       -0.00%     -0.05%     -0.07%        .          .       
 parallel-rdp/small_subgroup      246           .          .          .       -0.33%     -0.43%     -0.15%        .       +0.01%        .          .       -1.36%     -1.74%        .          .       
 parallel-rdp/small_uber_subgroup 55            .          .       -33.41%    -6.52%     -6.91%     -7.47%     -17.27%    -0.03%     -20.02%       .       -6.14%     -12.45%       .          .       
 parallel-rdp/subgroup            327           .       -9.52%        .       -0.54%     -0.65%     -0.27%     -0.00%     +0.01%        .          .       -3.24%     -1.64%        .          .       
 parallel-rdp/uber_subgroup       55            .          .       -37.32%    -9.49%     -8.79%     -9.59%     -15.31%    +0.66%     -20.94%       .       -10.01%    -12.47%       .          .       
 rdr2                             3888          .       -0.94%        .       -0.01%     -0.01%     -0.00%     +0.01%     -0.01%        .       -0.01%     -0.09%     -0.06%        .          .       
 sottr_demo                       5711          .          .          .       +0.00%     +0.00%     +0.00%     -0.00%     -0.00%        .       +0.01%     +0.02%        .          .          .       
 -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 All affected                     3210       +0.00%     -39.46%    -35.43%    -3.92%     -2.96%     -3.93%     -0.27%     -1.77%     -0.64%     -0.31%     -6.38%     -4.34%     -0.12%     +0.00%     
 -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 Total                            135946     +0.00%     -38.91%    -35.43%    -0.62%     -0.47%     -1.54%     -0.00%     -0.04%     -0.09%     -0.04%     -1.38%     -1.11%     -0.01%     +0.00%     

fossil-db changes for aco: reserve 2 sgprs for each branch:

 PERCENTAGE DELTAS                Shaders    SGPRs      VGPRs      SpillSGPRs CodeSize   MaxWaves   Instrs     Cycles     VMEM       SMEM       VClause    SClause    Copies     Branches   PreSGPRs   PreVGPRs   
 assassins_creed_origins          2114       +0.02%        .       -1.24%     -0.00%        .       -0.00%     -0.00%        .          .          .          .       -0.01%        .       +0.08%        .       
 battlefront2                     4568       +0.01%        .          .          .          .          .          .          .          .          .          .          .          .       +0.04%        .       
 britannia                        469           .          .          .          .          .          .          .          .          .          .          .          .          .       +0.05%        .       
 dark_souls_1_remastered          4249          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.06%        .       
 dark_souls_2_sotfs               6876          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.00%        .       
 dark_souls_3                     8935          .          .          .       -0.00%        .       -0.00%     -0.00%        .          .          .          .       -0.00%        .       +0.00%        .       
 detroit_become_human             19959         .       +0.27%     +15.70%    +0.11%     -0.07%     +0.08%     +0.10%     +0.02%     +0.24%     -0.06%     -0.09%     +0.22%     -0.21%     +0.14%     +0.18%     
 deus_ex_md                       8063          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.01%        .       
 dirt4                            4078          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.02%        .       
 doom_2016                        2963          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.31%        .       
 doom_eternal                     1211          .          .       +10.00%    +0.00%        .       +0.00%     +0.00%        .       -0.00%        .          .       -0.00%        .       +0.85%        .       
 dota2                            1015       +0.04%        .          .          .          .          .          .          .          .          .          .          .          .       +0.01%        .       
 dow3                             282           .          .          .       -0.00%        .       -0.00%     -0.00%        .          .          .          .       -0.01%        .       +0.04%        .       
 evilwithin_demo                  742           .          .          .          .          .          .          .          .          .          .          .          .          .       +0.01%        .       
 f12017                           5503          .          .          .       +0.00%        .       +0.00%     +0.00%        .       -0.00%        .       +0.00%     +0.00%        .       +0.09%        .       
 gtav                             2991          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.01%        .       
 hitman                           2785          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.14%        .       
 madmax                           948           .          .          .          .          .          .          .          .          .          .          .          .          .          .          .       
 nier                             5492          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.01%        .       
 parallel-rdp/small_subgroup      246           .          .          .       +0.02%        .       +0.03%     +0.01%        .       +0.04%        .          .       +0.34%        .       +0.09%        .       
 parallel-rdp/small_uber_subgroup 55            .          .       +10.93%    +0.36%        .       +0.38%     +0.41%     +0.10%     +0.74%        .          .       +0.60%     -0.04%     +0.54%        .       
 parallel-rdp/subgroup            327           .          .          .       +0.03%        .       +0.04%     +0.02%        .       +0.02%        .          .       +0.54%        .       +0.06%        .       
 parallel-rdp/uber_subgroup       55            .          .       +5.08%     +0.06%        .       -0.01%     -0.01%     +0.26%     +0.63%        .          .       -0.29%     +0.11%     +0.54%        .       
 rdr2                             3888       +0.01%        .          .       +0.00%        .       +0.00%     +0.01%     -0.00%        .          .          .          .          .       +0.16%        .       
 redout                           2520       +0.07%        .          .          .          .          .          .          .          .          .          .          .          .       +0.06%        .       
 rottr                            8130          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.00%        .       
 sottr_demo                       5711          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.00%        .       
 strange_brigade                  1417       +0.01%        .          .       -0.00%        .       -0.00%     -0.00%        .          .          .          .          .          .       +0.46%        .       
 talos                            794           .          .          .          .          .          .          .          .          .          .          .          .          .       +0.01%        .       
 thewitness                       3151       +0.01%        .          .          .          .          .          .          .          .          .          .          .          .       +0.95%        .       
 threekingdoms                    847           .          .          .          .          .          .          .          .          .          .          .          .          .       +0.06%        .       
 tomb_raider                      16232         .          .          .          .          .          .          .          .          .          .          .          .          .       +0.00%        .       
 warhammer2                       1803       +0.02%        .          .          .          .          .          .          .          .          .          .          .          .       +0.03%        .       
 wolfenstein2_fp16                639           .          .          .       +0.00%        .       +0.00%     +0.01%        .          .          .          .          .          .       +0.01%        .       
 worldofwarships                  5590          .          .          .          .          .          .          .          .          .          .          .          .          .       +0.76%        .       
 youngblood                       796           .          .          .          .          .          .          .          .          .          .          .          .          .       +0.40%        .       
 youngblood_fp16                  502           .          .          .          .          .          .          .          .          .          .          .          .          .       +0.03%        .       
 ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 All affected                     10197      +0.02%     +0.29%     +15.01%    +0.10%     -0.26%     +0.07%     +0.10%     +0.11%     +0.39%     -0.06%     -0.09%     +0.21%     -0.20%     +0.63%     +0.20%     
 ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 Total                            135946     +0.00%     +0.04%     +14.27%    +0.03%     -0.01%     +0.02%     +0.08%     +0.00%     +0.03%     -0.01%     -0.02%     +0.08%     -0.10%     +0.13%     +0.04%     
Edited by Rhys Perry

Merge request reports