[PATCH] D25126: [InstCombine] fold select X, (ext X), C
    Bjorn Pettersson via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Fri Oct  7 10:57:02 PDT 2016
    
    
  
bjope added inline comments.
================
Comment at: lib/Transforms/InstCombine/InstCombineSelect.cpp:966
+      Constant *AllOnesOrOne = ConstantExpr::getCast(ExtOpcode, One, SelType);
+      NewSel = SelectInst::Create(Cond, AllOnesOrOne, C);
+    } else {
----------------
spatel wrote:
> majnemer wrote:
> > bjope wrote:
> > > Why aren't you using the Builder here? Is it to avoid an implicit fold by the CreateSelect?
> > > To me it looks like you are using a different style compared to the optimization above involving the trunc.
> > > 
> > > And I guess that if you use the Builder, then you won't need to explicitly copyMetadata? Or is that missing from the optimization involving the trunc. There was not a single explicit copyMetadata in this file until now.
> > The code added is in the style of the rest of InstCombine. The builder is used for intermediate instructions but not the final instruction which is RAUW. This has to do with the particular behavior InstCombine has augmented the builder with.
> > 
> > I'm pretty sure the copyMetadata is around to make sure we don't discard the !prof. Other select combines probably drop this information.
> Correct about the !prof - although hopefully we're not dropping that anymore. In the trunc transform above, it is copied with:
>   Builder->CreateSelect(Cond, X, TruncCVal, "narrow", &Sel)  <-- last param means copy metadata from Sel.
Ok. Nothing wrong with the style then. Sorry about that comment.
And yes, the Builder->CreateSelect is copying metadata if the original select is provided. So in many situations the metadata will survive. That is kind of why I wondered why there was an explicit copy of metadata instead of using the Builder in this partiular case. 
(I won't learn if I don't ask questions. Thanks for you answers!)
https://reviews.llvm.org/D25126
    
    
More information about the llvm-commits
mailing list