sammccall added a reviewer: aaron.ballman.
sammccall added a subscriber: aaron.ballman.
sammccall added a comment.

This looks good to me, I think we should ask @aaron.ballman about the memory 
increase.

If we wanted to eliminate SLocEntry::Offset then we could add 
SourceManager::getOffset(FileID) based on this table and deprecate 
SLocEntry::getOffset().
We'd have to tackle loaded SLocs for that though.

> SemaExpr.cpp:  149529494 -> 149502874

Are these numbers backwards? Why would memory usage go down?



================
Comment at: clang/include/clang/Basic/SourceManager.h:697
+  /// FileID lookup.
+  SmallVector<SourceLocation::UIntTy> LocalLocOffsetTable;
 
----------------
nickdesaulniers wrote:
> nickdesaulniers wrote:
> > `LocalSLocEntryTable` is a vec of `SrcMgr::SLocEntry`. 
> > `SrcMgr::SLocEntry`'s `Offset` is:
> > ```
> > static constexpr int OffsetBits = 8 * sizeof(SourceLocation::UIntTy) - 1;
> >   SourceLocation::UIntTy Offset : OffsetBits;
> > ```
> > So this is a vector of 32b values vs the 24b values we need.  Does packing 
> > this by declaring a struct improve locality further?
> > 
> > ```
> > diff --git a/clang/include/clang/Basic/SourceManager.h 
> > b/clang/include/clang/Basic/SourceManager.h
> > index 70ba85bbe948..518c6ed59120 100644
> > --- a/clang/include/clang/Basic/SourceManager.h
> > +++ b/clang/include/clang/Basic/SourceManager.h
> > @@ -692,9 +692,15 @@ class SourceManager : public 
> > RefCountedBase<SourceManager> {
> >    /// Positive FileIDs are indexes into this table. Entry 0 indicates an 
> > invalid
> >    /// expansion.
> >    SmallVector<SrcMgr::SLocEntry, 0> LocalSLocEntryTable;
> > +
> > +  struct SMOffset {
> > +    SourceLocation::UIntTy Offset : 24;
> > +    SMOffset (SourceLocation::UIntTy O): Offset(O){}
> > +    operator SourceLocation::UIntTy() const { return Offset; }
> > +  };
> >    /// An in-parallel SlocEntry offset table, merely used for speeding up 
> > the
> >    /// FileID lookup.
> > -  SmallVector<SourceLocation::UIntTy> LocalLocOffsetTable;
> > +  SmallVector<SMOffset> LocalLocOffsetTable;
> >  
> >    /// The table of SLocEntries that are loaded from other modules.
> >    ///
> > ```
> `struct SMOffset { ... } __attribute__((packed));`
> So this is a vector of 32b values vs the 24b values we need

It's 31 bits: `8 * sizeof - 1`, not `8 * (sizeof - 1)`.
(And none of those bits are spare in practice)


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D135440/new/

https://reviews.llvm.org/D135440

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to