[PATCH] D116180: [InstrProf] Add single byte coverage mode
    Ellis Hoag via Phabricator via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Tue Jan 25 09:49:53 PST 2022
    
    
  
ellis added a comment.
In D116180#3268478 <https://reviews.llvm.org/D116180#3268478>, @phosek wrote:
> This change appears to be implementing `func-cov` mode proposed in https://groups.google.com/g/llvm-dev/c/r03Z6JoN7d4. Do you plan on implementing the support for `block-cov` and `func-cnt` modes as well? I'm asking because we're interested in the `block-cov` mode, but also because I'm somewhat concerned about the orthogonality of these modes in the implementation.
>
> For example, this change introduces the `VARIANT_MASK_BYTE_ENTRY_COVERAGE` flag to track whether the `func-cov` mode is used. This means that we're going to need two more bits for `block-cov` and `func-cnt` (three in total). Wouldn't it make more sense to instead have `VARIANT_MASK_BYTE_COVERAGE` and `VARIANT_MASK_ENTRY_COVERAGE` flags which could be combined to represent all four modes, requiring only two bits in total?
I was only planning on adding `func-cov`. A while back I did a small experiment and found very little binary size difference between `block-cov` and full `block-counts`. This is because `block-counts` can instrument a subset of blocks and infer counts from the rest. With `block-cov` we cannot do this in the same way so we need to instrument every block. There might be a smarter way to infer some block coverage, but I don't know it.
I decided to use just `VARIANT_MASK_BYTE_ENTRY_COVERAGE` for simplicity, but I'm open to using two flags like you suggested.
Can I ask why you are interested in `block-cov` rather than using full block counters? If binary size is a concern then I would suggest inferring coverage from 8 bit counters, assuming overflow isn't a problem. If speed is the main concern then maybe `block-cov` is the right way to go.
Repository:
  rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D116180/new/
https://reviews.llvm.org/D116180
    
    
More information about the llvm-commits
mailing list