- 
                Notifications
    You must be signed in to change notification settings 
- Fork 15k
[libc++] Optimize std::{,ranges}::{fill,fill_n} for segmented iterators #132665
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
892e5b2    to
    bb949d4      
    Compare
  
    | @llvm/pr-subscribers-libcxx Author: Peng Liu (winner245) ChangesThis patch optimizes  Below are the benchmark results comparing the before and after implementations. For reference purposes, we've also provided the benchmarks for  Fixes two subtasks outlined in #102817. 
 | 
9d18306    to
    d89bca5      
    Compare
  
    d89bca5    to
    b3a4fd9      
    Compare
  
    2df2a8f    to
    5616913      
    Compare
  
    There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM with a minor change. Thanks for the optimization!
b426e8d    to
    f780dcc      
    Compare
  
    f780dcc    to
    f128d8a      
    Compare
  
    | Removing from the LLVM 21 release since this missed the branch point. I'll merge this when CI is done running and this will make LLVM 22 though. | 
| ✅ With the latest revision this PR passed the C/C++ code formatter. | 
      
        
              This comment was marked as resolved.
        
        
      
    
  This comment was marked as resolved.
| 
 Looks like the same issue as: #149477 We'll have to skip the tests like we did in f5022bd until we fix it properly | 
      
        
              This comment was marked as resolved.
        
        
      
    
  This comment was marked as resolved.
| LLVM Buildbot has detected a new failure on builder  Full details are available at: https://lab.llvm.org/buildbot/#/builders/169/builds/16076 Here is the relevant piece of the build log for the reference | 
| Thanks for merging this @frederick-vs-ja ! | 
This patch optimizes
std::fill,std::fill_n,std::ranges::fill, andstd::ranges::fill_nfor segmented iterators, achieving substantial performance improvements. Specifically, fordeque<int>iterators, the performance improvements are above 10x for all these algorithms. The optimization also enables filling segmented memory ofdeque<int>to approach the performance of filling contiguous memory ofvector<int>.Benchmark results comparing the before and after implementations are provided below. For additional context, we’ve included
vector<int>results, which remain unchanged, as this patch specifically targets segmented iterators and leaves non-segmented iterator behavior untouched.Fixes two subtasks outlined in #102817.
fill_nfill