gfs2: Fix wrong quota shrinker return value
Function gfs2_qd_isolate must only return LRU_REMOVED when removing the item from the lru list; otherwise, the number of items on the list will go wrong. Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com>
This commit is contained in:
Родитель
e7beb8b6de
Коммит
6b0e9a5f1e
|
@ -149,18 +149,22 @@ static enum lru_status gfs2_qd_isolate(struct list_head *item,
|
|||
struct list_lru_one *lru, spinlock_t *lru_lock, void *arg)
|
||||
{
|
||||
struct list_head *dispose = arg;
|
||||
struct gfs2_quota_data *qd = list_entry(item, struct gfs2_quota_data, qd_lru);
|
||||
struct gfs2_quota_data *qd =
|
||||
list_entry(item, struct gfs2_quota_data, qd_lru);
|
||||
enum lru_status status;
|
||||
|
||||
if (!spin_trylock(&qd->qd_lockref.lock))
|
||||
return LRU_SKIP;
|
||||
|
||||
status = LRU_SKIP;
|
||||
if (qd->qd_lockref.count == 0) {
|
||||
lockref_mark_dead(&qd->qd_lockref);
|
||||
list_lru_isolate_move(lru, &qd->qd_lru, dispose);
|
||||
status = LRU_REMOVED;
|
||||
}
|
||||
|
||||
spin_unlock(&qd->qd_lockref.lock);
|
||||
return LRU_REMOVED;
|
||||
return status;
|
||||
}
|
||||
|
||||
static unsigned long gfs2_qd_shrink_scan(struct shrinker *shrink,
|
||||
|
|
Загрузка…
Ссылка в новой задаче