diff options
author | Jamie Liu <jamieliu@google.com> | 2021-06-09 18:22:27 -0700 |
---|---|---|
committer | gVisor bot <gvisor-bot@google.com> | 2021-06-09 18:25:17 -0700 |
commit | 0c37626a07851668307d85c40345c0998a92e30f (patch) | |
tree | 8d3a1a5050de02dfaf6714132bad98eec409b737 /pkg/sentry | |
parent | 3fb646ed10b8ca425450132dd52b4671d60dcd7a (diff) |
Decommit huge-page-aligned regions during reclaim under manual zeroing.
PiperOrigin-RevId: 378546551
Diffstat (limited to 'pkg/sentry')
-rw-r--r-- | pkg/sentry/pgalloc/pgalloc.go | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/pkg/sentry/pgalloc/pgalloc.go b/pkg/sentry/pgalloc/pgalloc.go index b81292c46..d1a883da4 100644 --- a/pkg/sentry/pgalloc/pgalloc.go +++ b/pkg/sentry/pgalloc/pgalloc.go @@ -1062,10 +1062,20 @@ func (f *MemoryFile) runReclaim() { break } - // If ManualZeroing is in effect, pages will be zeroed on allocation - // and may not be freed by decommitFile, so calling decommitFile is - // unnecessary. - if !f.opts.ManualZeroing { + if f.opts.ManualZeroing { + // If ManualZeroing is in effect, only hugepage-aligned regions may + // be safely passed to decommitFile. Pages will be zeroed on + // reallocation, so we don't need to perform any manual zeroing + // here, whether or not decommitFile succeeds. + if startAddr, ok := hostarch.Addr(fr.Start).HugeRoundUp(); ok { + if endAddr := hostarch.Addr(fr.End).HugeRoundDown(); startAddr < endAddr { + decommitFR := memmap.FileRange{uint64(startAddr), uint64(endAddr)} + if err := f.decommitFile(decommitFR); err != nil { + log.Warningf("Reclaim failed to decommit %v: %v", decommitFR, err) + } + } + } + } else { if err := f.decommitFile(fr); err != nil { log.Warningf("Reclaim failed to decommit %v: %v", fr, err) // Zero the pages manually. This won't reduce memory usage, but at |