On 06/15/2016 11:40 AM, Balbir Singh wrote:
On Wed, Jun 15, 2016 at 7:34 PM, Ganesh Mahendran
<[email protected]> wrote:
In the callee try_to_compact_pages(), the (order == 0) is checked,
so remove check in __alloc_pages_direct_compact.

Signed-off-by: Ganesh Mahendran <[email protected]>
---
v2:
  remove the check in __alloc_pages_direct_compact - Anshuman Khandual
---
 mm/page_alloc.c | 3 ---
 1 file changed, 3 deletions(-)

diff --git a/mm/page_alloc.c b/mm/page_alloc.c
index b9ea618..2f5a82a 100644
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -3173,9 +3173,6 @@ __alloc_pages_direct_compact(gfp_t gfp_mask, unsigned int 
order,
        struct page *page;
        int contended_compaction;

-       if (!order)
-               return NULL;
-
        current->flags |= PF_MEMALLOC;
        *compact_result = try_to_compact_pages(gfp_mask, order, alloc_flags, ac,
                                                mode, &contended_compaction);

What is the benefit of this. Is an if check more expensive than
calling the function and returning from it? I don't feel strongly
about such changes, but its good to audit the overall code for reading
and performance.

Agree. The majority of calls should be for order == 0 where the check avoids us from modifying current->flags and calling into compaction.c just to return and modify the flags back. I would argue that we should even check order before calling __alloc_pages_direct_compact() to avoid another potential call, but the compiler might be doing the right thing already.

So v1 was better in this aspect. But it wouldn't gain us any measurable performance benefit anyway, so we might as well leave it.

Balbir Singh


Reply via email to