 Chromium Code Reviews
 Chromium Code Reviews Issue 
            1381563004:
    Subzero: Fix a bug in register allocator overlap computation.  (Closed)
    
  
    Issue 
            1381563004:
    Subzero: Fix a bug in register allocator overlap computation.  (Closed) 
  | DescriptionSubzero: Fix a bug in register allocator overlap computation.
When the register allocator decides whether to allow the candidate's live range to overlap its preferred variable's live range (and share their register), it needs to consider whether any redefinitions in one variable occur within the live range of the other variable, in which case overlap should not be allowed.
There was a bug in the API for iterating over the defining instructions for a variable, in which the earliest definition might be ignored in some cases.  This came from the fact that the first definition and latter definitions are split apart for translation speed reasons, and a particular API is needed for finding an unambiguous first definition, which is possible when all definitions are within a single block but not so possible when definitions cross block boundaries.  (This only happens for the simple phi lowering.)
Since both semantics are needed, a separate API is added to support both.
For spec2k, the asm output is identical to before, so this changes nothing.  When translating spec2k with "-O2 -phi-edge-split=0", there is a single minor difference in ammp that actually looks legit in both cases.
However, when testing an upcoming CL, -phi-edge-split=0 triggered the bug, causing gcc and crafty to fail with incorrect output.
This CL also fixes some minor issues, and adds dump output of the instruction definition list when available.
BUG= none
R=jpp@chromium.org
Committed: https://gerrit.chromium.org/gerrit/gitweb?p=native_client/pnacl-subzero.git;a=commit;h=48e3ae5c62d7e626ed1a0dbbe38a7cc11a356260
   Patch Set 1 #
      Total comments: 2
      
     Patch Set 2 : Fix the asserts() guard #
 Messages
    Total messages: 5 (1 generated)
     | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||