diff options
author | Dave Chinner <dchinner@redhat.com> | 2013-08-27 20:18:14 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2013-09-10 18:56:32 -0400 |
commit | 70534a739c12b908789e27b08512d2615ba40f2f (patch) | |
tree | e41d776d76de06a64b08cb787d87590f80e94f7e | |
parent | ea8352c289294e21ee13bdb105f55dc63497acff (diff) |
shrinker: convert remaining shrinkers to count/scan API
Convert the remaining couple of random shrinkers in the tree to the new
API.
Signed-off-by: Dave Chinner <dchinner@redhat.com>
Signed-off-by: Glauber Costa <glommer@openvz.org>
Cc: Marcelo Tosatti <mtosatti@redhat.com>
Cc: Gleb Natapov <gleb@redhat.com>
Cc: Chuck Lever <chuck.lever@oracle.com>
Cc: J. Bruce Fields <bfields@redhat.com>
Cc: Trond Myklebust <Trond.Myklebust@netapp.com>
Cc: "Theodore Ts'o" <tytso@mit.edu>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Cc: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
Cc: Arve Hjønnevåg <arve@android.com>
Cc: Carlos Maiolino <cmaiolino@redhat.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Chuck Lever <chuck.lever@oracle.com>
Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
Cc: David Rientjes <rientjes@google.com>
Cc: Gleb Natapov <gleb@redhat.com>
Cc: Greg Thelen <gthelen@google.com>
Cc: J. Bruce Fields <bfields@redhat.com>
Cc: Jan Kara <jack@suse.cz>
Cc: Jerome Glisse <jglisse@redhat.com>
Cc: John Stultz <john.stultz@linaro.org>
Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Cc: Kent Overstreet <koverstreet@google.com>
Cc: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Cc: Marcelo Tosatti <mtosatti@redhat.com>
Cc: Mel Gorman <mgorman@suse.de>
Cc: Steven Whitehouse <swhiteho@redhat.com>
Cc: Thomas Hellstrom <thellstrom@vmware.com>
Cc: Trond Myklebust <Trond.Myklebust@netapp.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r-- | arch/x86/kvm/mmu.c | 25 | ||||
-rw-r--r-- | net/sunrpc/auth.c | 41 |
2 files changed, 45 insertions, 21 deletions
diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c index 6e2d2c8f230b..dce0df8150df 100644 --- a/arch/x86/kvm/mmu.c +++ b/arch/x86/kvm/mmu.c | |||
@@ -4421,13 +4421,12 @@ void kvm_mmu_invalidate_mmio_sptes(struct kvm *kvm) | |||
4421 | } | 4421 | } |
4422 | } | 4422 | } |
4423 | 4423 | ||
4424 | static int mmu_shrink(struct shrinker *shrink, struct shrink_control *sc) | 4424 | static unsigned long |
4425 | mmu_shrink_scan(struct shrinker *shrink, struct shrink_control *sc) | ||
4425 | { | 4426 | { |
4426 | struct kvm *kvm; | 4427 | struct kvm *kvm; |
4427 | int nr_to_scan = sc->nr_to_scan; | 4428 | int nr_to_scan = sc->nr_to_scan; |
4428 | 4429 | unsigned long freed = 0; | |
4429 | if (nr_to_scan == 0) | ||
4430 | goto out; | ||
4431 | 4430 | ||
4432 | raw_spin_lock(&kvm_lock); | 4431 | raw_spin_lock(&kvm_lock); |
4433 | 4432 | ||
@@ -4462,25 +4461,37 @@ static int mmu_shrink(struct shrinker *shrink, struct shrink_control *sc) | |||
4462 | goto unlock; | 4461 | goto unlock; |
4463 | } | 4462 | } |
4464 | 4463 | ||
4465 | prepare_zap_oldest_mmu_page(kvm, &invalid_list); | 4464 | if (prepare_zap_oldest_mmu_page(kvm, &invalid_list)) |
4465 | freed++; | ||
4466 | kvm_mmu_commit_zap_page(kvm, &invalid_list); | 4466 | kvm_mmu_commit_zap_page(kvm, &invalid_list); |
4467 | 4467 | ||
4468 | unlock: | 4468 | unlock: |
4469 | spin_unlock(&kvm->mmu_lock); | 4469 | spin_unlock(&kvm->mmu_lock); |
4470 | srcu_read_unlock(&kvm->srcu, idx); | 4470 | srcu_read_unlock(&kvm->srcu, idx); |
4471 | 4471 | ||
4472 | /* | ||
4473 | * unfair on small ones | ||
4474 | * per-vm shrinkers cry out | ||
4475 | * sadness comes quickly | ||
4476 | */ | ||
4472 | list_move_tail(&kvm->vm_list, &vm_list); | 4477 | list_move_tail(&kvm->vm_list, &vm_list); |
4473 | break; | 4478 | break; |
4474 | } | 4479 | } |
4475 | 4480 | ||
4476 | raw_spin_unlock(&kvm_lock); | 4481 | raw_spin_unlock(&kvm_lock); |
4482 | return freed; | ||
4477 | 4483 | ||
4478 | out: | 4484 | } |
4485 | |||
4486 | static unsigned long | ||
4487 | mmu_shrink_count(struct shrinker *shrink, struct shrink_control *sc) | ||
4488 | { | ||
4479 | return percpu_counter_read_positive(&kvm_total_used_mmu_pages); | 4489 | return percpu_counter_read_positive(&kvm_total_used_mmu_pages); |
4480 | } | 4490 | } |
4481 | 4491 | ||
4482 | static struct shrinker mmu_shrinker = { | 4492 | static struct shrinker mmu_shrinker = { |
4483 | .shrink = mmu_shrink, | 4493 | .count_objects = mmu_shrink_count, |
4494 | .scan_objects = mmu_shrink_scan, | ||
4484 | .seeks = DEFAULT_SEEKS * 10, | 4495 | .seeks = DEFAULT_SEEKS * 10, |
4485 | }; | 4496 | }; |
4486 | 4497 | ||
diff --git a/net/sunrpc/auth.c b/net/sunrpc/auth.c index 415159061cd0..5285ead196c0 100644 --- a/net/sunrpc/auth.c +++ b/net/sunrpc/auth.c | |||
@@ -434,12 +434,13 @@ EXPORT_SYMBOL_GPL(rpcauth_destroy_credcache); | |||
434 | /* | 434 | /* |
435 | * Remove stale credentials. Avoid sleeping inside the loop. | 435 | * Remove stale credentials. Avoid sleeping inside the loop. |
436 | */ | 436 | */ |
437 | static int | 437 | static long |
438 | rpcauth_prune_expired(struct list_head *free, int nr_to_scan) | 438 | rpcauth_prune_expired(struct list_head *free, int nr_to_scan) |
439 | { | 439 | { |
440 | spinlock_t *cache_lock; | 440 | spinlock_t *cache_lock; |
441 | struct rpc_cred *cred, *next; | 441 | struct rpc_cred *cred, *next; |
442 | unsigned long expired = jiffies - RPC_AUTH_EXPIRY_MORATORIUM; | 442 | unsigned long expired = jiffies - RPC_AUTH_EXPIRY_MORATORIUM; |
443 | long freed = 0; | ||
443 | 444 | ||
444 | list_for_each_entry_safe(cred, next, &cred_unused, cr_lru) { | 445 | list_for_each_entry_safe(cred, next, &cred_unused, cr_lru) { |
445 | 446 | ||
@@ -451,10 +452,11 @@ rpcauth_prune_expired(struct list_head *free, int nr_to_scan) | |||
451 | */ | 452 | */ |
452 | if (time_in_range(cred->cr_expire, expired, jiffies) && | 453 | if (time_in_range(cred->cr_expire, expired, jiffies) && |
453 | test_bit(RPCAUTH_CRED_HASHED, &cred->cr_flags) != 0) | 454 | test_bit(RPCAUTH_CRED_HASHED, &cred->cr_flags) != 0) |
454 | return 0; | 455 | break; |
455 | 456 | ||
456 | list_del_init(&cred->cr_lru); | 457 | list_del_init(&cred->cr_lru); |
457 | number_cred_unused--; | 458 | number_cred_unused--; |
459 | freed++; | ||
458 | if (atomic_read(&cred->cr_count) != 0) | 460 | if (atomic_read(&cred->cr_count) != 0) |
459 | continue; | 461 | continue; |
460 | 462 | ||
@@ -467,29 +469,39 @@ rpcauth_prune_expired(struct list_head *free, int nr_to_scan) | |||
467 | } | 469 | } |
468 | spin_unlock(cache_lock); | 470 | spin_unlock(cache_lock); |
469 | } | 471 | } |
470 | return (number_cred_unused / 100) * sysctl_vfs_cache_pressure; | 472 | return freed; |
471 | } | 473 | } |
472 | 474 | ||
473 | /* | 475 | /* |
474 | * Run memory cache shrinker. | 476 | * Run memory cache shrinker. |
475 | */ | 477 | */ |
476 | static int | 478 | static unsigned long |
477 | rpcauth_cache_shrinker(struct shrinker *shrink, struct shrink_control *sc) | 479 | rpcauth_cache_shrink_scan(struct shrinker *shrink, struct shrink_control *sc) |
480 | |||
478 | { | 481 | { |
479 | LIST_HEAD(free); | 482 | LIST_HEAD(free); |
480 | int res; | 483 | unsigned long freed; |
481 | int nr_to_scan = sc->nr_to_scan; | 484 | |
482 | gfp_t gfp_mask = sc->gfp_mask; | 485 | if ((sc->gfp_mask & GFP_KERNEL) != GFP_KERNEL) |
486 | return SHRINK_STOP; | ||
483 | 487 | ||
484 | if ((gfp_mask & GFP_KERNEL) != GFP_KERNEL) | 488 | /* nothing left, don't come back */ |
485 | return (nr_to_scan == 0) ? 0 : -1; | ||
486 | if (list_empty(&cred_unused)) | 489 | if (list_empty(&cred_unused)) |
487 | return 0; | 490 | return SHRINK_STOP; |
491 | |||
488 | spin_lock(&rpc_credcache_lock); | 492 | spin_lock(&rpc_credcache_lock); |
489 | res = rpcauth_prune_expired(&free, nr_to_scan); | 493 | freed = rpcauth_prune_expired(&free, sc->nr_to_scan); |
490 | spin_unlock(&rpc_credcache_lock); | 494 | spin_unlock(&rpc_credcache_lock); |
491 | rpcauth_destroy_credlist(&free); | 495 | rpcauth_destroy_credlist(&free); |
492 | return res; | 496 | |
497 | return freed; | ||
498 | } | ||
499 | |||
500 | static unsigned long | ||
501 | rpcauth_cache_shrink_count(struct shrinker *shrink, struct shrink_control *sc) | ||
502 | |||
503 | { | ||
504 | return (number_cred_unused / 100) * sysctl_vfs_cache_pressure; | ||
493 | } | 505 | } |
494 | 506 | ||
495 | /* | 507 | /* |
@@ -805,7 +817,8 @@ rpcauth_uptodatecred(struct rpc_task *task) | |||
805 | } | 817 | } |
806 | 818 | ||
807 | static struct shrinker rpc_cred_shrinker = { | 819 | static struct shrinker rpc_cred_shrinker = { |
808 | .shrink = rpcauth_cache_shrinker, | 820 | .count_objects = rpcauth_cache_shrink_count, |
821 | .scan_objects = rpcauth_cache_shrink_scan, | ||
809 | .seeks = DEFAULT_SEEKS, | 822 | .seeks = DEFAULT_SEEKS, |
810 | }; | 823 | }; |
811 | 824 | ||