All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] PM / Hiberante : optimize swsusp_free()
@ 2015-03-19  8:28 Tom(JeHyeon) Yeon
  2015-03-19  8:54 ` Pavel Machek
  2015-03-19 11:37 ` Rafael J. Wysocki
  0 siblings, 2 replies; 9+ messages in thread
From: Tom(JeHyeon) Yeon @ 2015-03-19  8:28 UTC (permalink / raw)
  To: pavel, len.brown, jroedel, linux-pm; +Cc: linux-kernel, Tom(JeHyeon) Yeon

From: "Tom(JeHyeon) Yeon" <tom.yeon@windriver.com>

I tested the performance of swsusp_free operation.
The free time took about 58768us before commit fdd64ed, and
the free time took about 40535us after the commit fdd64ed.

But, I optimized the function before I saw commit fdd64ed.
So, I applied the patch in my system.(ARM Coretex A9, Dual Core 1GHz)
The free time took about 35164us.
I think that the finding routine for the same pfn is redundant

Signed-off-by: Tom(JeHyeon) Yeon <tom.yeon@windriver.com>
---
 kernel/power/snapshot.c |   43 ++++++++++---------------------------------
 1 file changed, 10 insertions(+), 33 deletions(-)

diff --git a/kernel/power/snapshot.c b/kernel/power/snapshot.c
index c24d5a2..a1ad801 100644
--- a/kernel/power/snapshot.c
+++ b/kernel/power/snapshot.c
@@ -726,14 +726,6 @@ static void memory_bm_clear_bit(struct memory_bitmap *bm, unsigned long pfn)
 	clear_bit(bit, addr);
 }
 
-static void memory_bm_clear_current(struct memory_bitmap *bm)
-{
-	int bit;
-
-	bit = max(bm->cur.node_bit - 1, 0);
-	clear_bit(bit, bm->cur.node->data);
-}
-
 static int memory_bm_test_bit(struct memory_bitmap *bm, unsigned long pfn)
 {
 	void *addr;
@@ -1342,36 +1334,21 @@ static struct memory_bitmap copy_bm;
 
 void swsusp_free(void)
 {
-	unsigned long fb_pfn, fr_pfn;
+	unsigned long pfn;
 
 	if (!forbidden_pages_map || !free_pages_map)
 		goto out;
 
 	memory_bm_position_reset(forbidden_pages_map);
-	memory_bm_position_reset(free_pages_map);
-
-loop:
-	fr_pfn = memory_bm_next_pfn(free_pages_map);
-	fb_pfn = memory_bm_next_pfn(forbidden_pages_map);
-
-	/*
-	 * Find the next bit set in both bitmaps. This is guaranteed to
-	 * terminate when fb_pfn == fr_pfn == BM_END_OF_MAP.
-	 */
-	do {
-		if (fb_pfn < fr_pfn)
-			fb_pfn = memory_bm_next_pfn(forbidden_pages_map);
-		if (fr_pfn < fb_pfn)
-			fr_pfn = memory_bm_next_pfn(free_pages_map);
-	} while (fb_pfn != fr_pfn);
-
-	if (fr_pfn != BM_END_OF_MAP && pfn_valid(fr_pfn)) {
-		struct page *page = pfn_to_page(fr_pfn);
-
-		memory_bm_clear_current(forbidden_pages_map);
-		memory_bm_clear_current(free_pages_map);
-		__free_page(page);
-		goto loop;
+	for ( ; ; ) {
+		pfn  = memory_bm_next_pfn(forbidden_pages_map);
+		if (BM_END_OF_MAP == pfn)
+			break;
+		if (memory_bm_test_bit(free_pages_map, pfn)) {
+			memory_bm_clear_bit(forbidden_pages_map, pfn);
+			memory_bm_clear_bit(free_pages_map, pfn);
+			__free_page(pfn_to_page(pfn));
+		}
 	}
 
 out:
-- 
1.7.9.5


^ permalink raw reply related	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2015-04-15  1:41 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-03-19  8:28 [PATCH] PM / Hiberante : optimize swsusp_free() Tom(JeHyeon) Yeon
2015-03-19  8:54 ` Pavel Machek
2015-03-19 11:37 ` Rafael J. Wysocki
2015-03-24  0:50   ` Yeon, JeHyeon (Tom)
2015-03-24  0:50     ` Yeon, JeHyeon (Tom)
2015-03-25  1:49   ` Yeon, JeHyeon (Tom)
2015-03-25  1:49     ` Yeon, JeHyeon (Tom)
2015-04-11  0:20     ` Rafael J. Wysocki
2015-04-15  1:40       ` tyeon

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.