diff options
| author | 2024-02-21 23:41:40 +0000 | |
|---|---|---|
| committer | 2024-05-13 16:30:19 +0000 | |
| commit | 89591d0bc44afce25a41801515c240e89494b90a (patch) | |
| tree | 1fffaed86147ace14e6edb48add127db81e5e0c0 /compiler/optimizing/instruction_simplifier_shared.cc | |
| parent | a62b40a338dd6a7fb53fd1fe806d26a6bb423363 (diff) | |
Handle EAGAIN (due to map_lock contention) from uffd ops
This CL does the following:
1) Skip setting 'mapping' state for the pages before they are being
   mapped. This helps with eliminating priority inversion. Kernel
   returns EEXIST when any thread attempts to map a page which is
   already mapped.
2) When kernel supports MMAP_TRYLOCK mode for COPY/ZEROPAGE ioctls, use
   the mode to avoid clogging mmap_lock's wait-list. Mutator's delay is
   decided based on their native-priority.
3) GC-thread doesn't waste time in mmap_lock's wait-list as long as
   there are pages remaining to be compacted. But after that, it maps
   all the pages even if that means waiting for lock. However, due to
   `mmap_lock_is_contended` check in the kernel, the ioctl immediately
   returns thereby not holding up writers and re-attempts the ioctl for
   remaining pages.
Bug: 320478828
Test: boot cuttlefish instance with 5.15 kernel
Change-Id: I9e7d1df27f99b7179bb475a5b0bb587093caa549
Diffstat (limited to 'compiler/optimizing/instruction_simplifier_shared.cc')
0 files changed, 0 insertions, 0 deletions