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)
Feb 19 2024, 10:44 AM
Unknown Object (File)
Dec 24 2023, 3:15 AM
Unknown Object (File)
Dec 23 2023, 3:48 AM
Unknown Object (File)
Nov 11 2023, 2:24 AM
Unknown Object (File)
Nov 7 2023, 2:00 AM
Unknown Object (File)
Nov 6 2023, 5:27 PM
Unknown Object (File)
Nov 1 2023, 8:30 AM
Unknown Object (File)
Oct 10 2023, 1:21 AM
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.