On Thu 05-07-12 02:44:58, Johannes Weiner wrote:
> Charging cache pages may require swapin in the shmem case.  Save the
> forward declaration and just move the swapin functions above the cache
> charging functions.
> 
> Signed-off-by: Johannes Weiner <han...@cmpxchg.org>

OK
Acked-by: Michal Hocko <mho...@suse.cz>

> ---
>  mm/memcontrol.c |   68 +++++++++++++++++++++++++-----------------------------
>  1 files changed, 32 insertions(+), 36 deletions(-)
> 
> diff --git a/mm/memcontrol.c b/mm/memcontrol.c
> index 3d56b4e..4a41b55 100644
> --- a/mm/memcontrol.c
> +++ b/mm/memcontrol.c
> @@ -2729,37 +2729,6 @@ int mem_cgroup_newpage_charge(struct page *page,
>                                       MEM_CGROUP_CHARGE_TYPE_ANON);
>  }
>  
> -static void
> -__mem_cgroup_commit_charge_swapin(struct page *page, struct mem_cgroup *ptr,
> -                                     enum charge_type ctype);
> -
> -int mem_cgroup_cache_charge(struct page *page, struct mm_struct *mm,
> -                             gfp_t gfp_mask)
> -{
> -     struct mem_cgroup *memcg = NULL;
> -     enum charge_type type = MEM_CGROUP_CHARGE_TYPE_CACHE;
> -     int ret;
> -
> -     if (mem_cgroup_disabled())
> -             return 0;
> -     if (PageCompound(page))
> -             return 0;
> -
> -     if (unlikely(!mm))
> -             mm = &init_mm;
> -     if (!page_is_file_cache(page))
> -             type = MEM_CGROUP_CHARGE_TYPE_SHMEM;
> -
> -     if (!PageSwapCache(page))
> -             ret = mem_cgroup_charge_common(page, mm, gfp_mask, type);
> -     else { /* page is swapcache/shmem */
> -             ret = mem_cgroup_try_charge_swapin(mm, page, gfp_mask, &memcg);
> -             if (!ret)
> -                     __mem_cgroup_commit_charge_swapin(page, memcg, type);
> -     }
> -     return ret;
> -}
> -
>  /*
>   * While swap-in, try_charge -> commit or cancel, the page is locked.
>   * And when try_charge() successfully returns, one refcnt to memcg without
> @@ -2806,6 +2775,15 @@ int mem_cgroup_try_charge_swapin(struct mm_struct *mm,
>       return ret;
>  }
>  
> +void mem_cgroup_cancel_charge_swapin(struct mem_cgroup *memcg)
> +{
> +     if (mem_cgroup_disabled())
> +             return;
> +     if (!memcg)
> +             return;
> +     __mem_cgroup_cancel_charge(memcg, 1);
> +}
> +
>  static void
>  __mem_cgroup_commit_charge_swapin(struct page *page, struct mem_cgroup 
> *memcg,
>                                       enum charge_type ctype)
> @@ -2843,13 +2821,31 @@ void mem_cgroup_commit_charge_swapin(struct page 
> *page,
>                                         MEM_CGROUP_CHARGE_TYPE_ANON);
>  }
>  
> -void mem_cgroup_cancel_charge_swapin(struct mem_cgroup *memcg)
> +int mem_cgroup_cache_charge(struct page *page, struct mm_struct *mm,
> +                             gfp_t gfp_mask)
>  {
> +     struct mem_cgroup *memcg = NULL;
> +     enum charge_type type = MEM_CGROUP_CHARGE_TYPE_CACHE;
> +     int ret;
> +
>       if (mem_cgroup_disabled())
> -             return;
> -     if (!memcg)
> -             return;
> -     __mem_cgroup_cancel_charge(memcg, 1);
> +             return 0;
> +     if (PageCompound(page))
> +             return 0;
> +
> +     if (unlikely(!mm))
> +             mm = &init_mm;
> +     if (!page_is_file_cache(page))
> +             type = MEM_CGROUP_CHARGE_TYPE_SHMEM;
> +
> +     if (!PageSwapCache(page))
> +             ret = mem_cgroup_charge_common(page, mm, gfp_mask, type);
> +     else { /* page is swapcache/shmem */
> +             ret = mem_cgroup_try_charge_swapin(mm, page, gfp_mask, &memcg);
> +             if (!ret)
> +                     __mem_cgroup_commit_charge_swapin(page, memcg, type);
> +     }
> +     return ret;
>  }
>  
>  static void mem_cgroup_do_uncharge(struct mem_cgroup *memcg,
> -- 
> 1.7.7.6
> 

-- 
Michal Hocko
SUSE Labs
SUSE LINUX s.r.o.
Lihovarska 1060/12
190 00 Praha 9    
Czech Republic
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to