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)
Sat, Jun 8, 8:58 PM
Unknown Object (File)
Tue, Jun 4, 11:56 PM
Unknown Object (File)
May 10 2024, 7:49 AM
Unknown Object (File)
May 7 2024, 6:31 AM
Unknown Object (File)
May 1 2024, 10:22 PM
Unknown Object (File)
May 1 2024, 10:21 PM
Unknown Object (File)
May 1 2024, 10:18 PM
Unknown Object (File)
May 1 2024, 10:18 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 27416
Build 25660: 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.