[compiler-rt] [scudo] Avoid splitting aligned allocations on Trusty (PR #69281)
Andrei Homescu via llvm-commits
llvm-commits at lists.llvm.org
Mon Feb 5 14:29:55 PST 2024
================
@@ -122,18 +122,35 @@ bool mapSecondary(const Options &Options, uptr CommitBase, uptr CommitSize,
Flags |= MAP_RESIZABLE;
Flags |= MAP_ALLOWNOMEM;
- const uptr MaxUnusedCacheBytes = MaxUnusedCachePages * getPageSizeCached();
+ const uptr PageSize = getPageSizeCached();
+ const uptr MaxUnusedCacheBytes = MaxUnusedCachePages * PageSize;
if (useMemoryTagging<Config>(Options) && CommitSize > MaxUnusedCacheBytes) {
- const uptr UntaggedPos = Max(AllocPos, CommitBase + MaxUnusedCacheBytes);
- return MemMap.remap(CommitBase, UntaggedPos - CommitBase, "scudo:secondary",
- MAP_MEMTAG | Flags) &&
- MemMap.remap(UntaggedPos, CommitBase + CommitSize - UntaggedPos,
- "scudo:secondary", Flags);
- } else {
- const uptr RemapFlags =
- (useMemoryTagging<Config>(Options) ? MAP_MEMTAG : 0) | Flags;
- return MemMap.remap(CommitBase, CommitSize, "scudo:secondary", RemapFlags);
+ if (SCUDO_TRUSTY) {
+ /*
----------------
ahomescu wrote:
I think that might require duplicating lines 151-153 for Trusty, would that be alright?
https://github.com/llvm/llvm-project/pull/69281
More information about the llvm-commits
mailing list