Page MenuHomeFreeBSD

Skip SWAPBLK_NONEs with swap_pager_find_least() in swap_pager_copy().
AbandonedPublic

Authored by ota_j.email.ne.jp on Nov 6 2019, 5:36 AM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, May 10, 7:49 AM
Unknown Object (File)
Tue, May 7, 6:31 AM
Unknown Object (File)
Wed, May 1, 10:22 PM
Unknown Object (File)
Wed, May 1, 10:21 PM
Unknown Object (File)
Wed, May 1, 10:18 PM
Unknown Object (File)
Wed, May 1, 10:18 PM
Unknown Object (File)
Wed, May 1, 10:18 PM
Unknown Object (File)
Wed, May 1, 5:52 PM
Subscribers

Details

Reviewers
kib
dougm
alc
Summary

About 85% to 90% of them are SWAPBLK_NONE based on my experiments.
This will improve searching swblks by a factor of 2.5 to 10 by skipping
despite the cost of double lookups for non-SWAPBLK_NONE ones.

Test Plan

Regression after tapping into swap space.
I use 'make buildworld -j <high#>' to case page in/out.
I have test/experimental code with rate printf.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 27410
Build 25655: arc lint + arc unit

Event Timeline

Created swp_pager_meta_find_least private API to find and delete in a single
operation. swap_pager_find_least calls it for look up.

With this approach, we don't have any penalty for worst cases unlike the
first revision while expected performance gain doubled - 5 ~ 20 times faster
lookups.

Fixed spaces/style.

I need to test this 2nd version, more.

Correct swblk index and exclude swp_pager_swblk_free_empty() changes.