[PATCH] D123629: [InstCombine] Fold memrchr calls with a constant character.
    Nikita Popov via Phabricator via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Wed Apr 13 04:05:00 PDT 2022
    
    
  
nikic added inline comments.
================
Comment at: llvm/lib/Transforms/Utils/SimplifyLibCalls.cpp:922
+                                   "memrchr.ptr_plus");
+      return B.CreateSelect(Cmp, NullPtr, SrcPlus, "memrchr.sel");
+    }
----------------
nikic wrote:
> nikic wrote:
> > I don't think this is correct. Consider an unknown size and a string with two occurrences of C in it. Now assume that at runtime, the size is chosen to lie between the two occurrences of C. I believe your implementation will return null for that case, while it should return the first occurrence.
> Gah, I just realized that this code is only used for a known length, unlike the corresponding memchr() implementation. In this case EndOff will be the exact end offset, and not just an upper bound on it, and this code will always constant fold, so it's fine.
> 
> I think it would be clearer that this is a fully static if this directly emitted the appropriate result based on `LenC->getValue().ule(Pos)` rather than going through constant folding.
Actually, if the length is constant, shouldn't this just directly return the GEP without any further comparisons?
CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D123629/new/
https://reviews.llvm.org/D123629
    
    
More information about the llvm-commits
mailing list