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)
Mon, Jun 30, 1:44 AM
Unknown Object (File)
Fri, Jun 27, 2:13 AM
Unknown Object (File)
Tue, Jun 24, 10:25 PM
Unknown Object (File)
Sun, Jun 22, 8:27 PM
Unknown Object (File)
Wed, Jun 18, 11:01 AM
Unknown Object (File)
Sun, Jun 15, 10:05 PM
Unknown Object (File)
Mon, Jun 9, 12:57 AM
Unknown Object (File)
Sun, Jun 8, 7:41 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 27411
Build 25656: 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.