All of lore.kernel.org
 help / color / mirror / Atom feed
* [LTP] [PATCH] mem/hugeshmat: new case for hugepage leak inspection
@ 2014-12-27  7:13 Li Wang
  2014-12-30  9:23 ` Jan Stancek
  0 siblings, 1 reply; 13+ messages in thread
From: Li Wang @ 2014-12-27  7:13 UTC (permalink / raw)
  To: ltp-list

Description of Problem:
    When over 1GB shared memory was alocated in hugepage, the hugepage
    is not released though process finished.

Signed-off-by: Li Wang <liwang@redhat.com>
---
 runtest/hugetlb                                    |   1 +
 testcases/kernel/mem/.gitignore                    |   1 +
 .../kernel/mem/hugetlb/hugeshmat/hugeshmat04.c     | 185 +++++++++++++++++++++
 3 files changed, 187 insertions(+)
 create mode 100644 testcases/kernel/mem/hugetlb/hugeshmat/hugeshmat04.c

diff --git a/runtest/hugetlb b/runtest/hugetlb
index 3eaf14c..805141d 100644
--- a/runtest/hugetlb
+++ b/runtest/hugetlb
@@ -10,6 +10,7 @@ hugemmap05_3 hugemmap05 -s -m
 hugeshmat01 hugeshmat01 -i 5
 hugeshmat02 hugeshmat02 -i 5
 hugeshmat03 hugeshmat03 -i 5
+hugeshmat04 hugeshamt04 -i 5
 
 hugeshmctl01 hugeshmctl01 -i 5
 hugeshmctl02 hugeshmctl02 -i 5
diff --git a/testcases/kernel/mem/.gitignore b/testcases/kernel/mem/.gitignore
index f96964c..c531563 100644
--- a/testcases/kernel/mem/.gitignore
+++ b/testcases/kernel/mem/.gitignore
@@ -6,6 +6,7 @@
 /hugetlb/hugeshmat/hugeshmat01
 /hugetlb/hugeshmat/hugeshmat02
 /hugetlb/hugeshmat/hugeshmat03
+/hugetlb/hugeshmat/hugeshmat04
 /hugetlb/hugeshmctl/hugeshmctl01
 /hugetlb/hugeshmctl/hugeshmctl02
 /hugetlb/hugeshmctl/hugeshmctl03
diff --git a/testcases/kernel/mem/hugetlb/hugeshmat/hugeshmat04.c b/testcases/kernel/mem/hugetlb/hugeshmat/hugeshmat04.c
new file mode 100644
index 0000000..515947b
--- /dev/null
+++ b/testcases/kernel/mem/hugetlb/hugeshmat/hugeshmat04.c
@@ -0,0 +1,185 @@
+/*
+ *   Copyright (c) Linux Test Project, 2014
+ *
+ *   This program is free software;  you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY;  without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
+ *   the GNU General Public License for more details.
+ *  
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program;  if not, write to the Free Software
+ *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+/*
+ * NAME
+ * 	hugeshmat04.c
+ * 
+ * DESCRIPTION
+ *	hugeshmat04 - test for hugepage leak inspection.
+ *     
+ *      Description of Problem:
+ *          When over 1GB shered memory was alocated in hugepage, the hugepage
+ *          is not released though process finished.
+ *
+ *          You need more than 2GB memory in test job
+ *
+ *	Return value:
+ *	  0: 	 Test successed.  No regression found.
+ *	  1: 	 Test failed.  Maybe memory shortage.  Please retry testing.
+ *	  2: 	 Test failed.  Regression detected.
+ *	  other: Test failed.  Other problem detected.
+ *
+ * HISTORY
+ * 	05/2014 - Written by Fujistu Corp. 
+ *     	12/2014 - Port to LTP by Li Wang.
+ *    
+ * RESTRICTIONS
+ * 	test must be run at root
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <fcntl.h>
+#include <string.h>
+#include <sys/mman.h>
+#include <sys/types.h>
+#include <sys/shm.h>
+#include <sys/wait.h>
+
+#include "test.h"
+#include "mem.h"
+
+#define SIZE	(1024 * 1024 * 1024)
+#define BOUNDARY (1024 * 1024 * 1024)
+
+char *TCID = "hugeshmat04";
+int TST_TOTAL = 3;
+
+static int huge_total;
+static int huge_free;
+static int huge_free2;
+static long hugepages;
+static long orig_hugepages;
+
+static int shared_hugepage(void);
+
+
+int main(int ac, char **av)
+{
+	int lc, i, ret;
+	const char *msg;
+
+	msg = parse_opts(ac,av, NULL, NULL);
+	if (msg != NULL)
+		tst_brkm(TBROK, NULL, "OPTION PARSING ERROR - %s", msg);
+
+	setup();
+
+	for (lc = 0; TEST_LOOPING(lc); lc++) {
+		tst_count = 0;
+
+		for (i = 0; i < TST_TOTAL; i++) {
+			huge_total = read_meminfo("HugePages_Total:");
+			huge_free = read_meminfo("HugePages_Free:");
+
+			if (huge_total == hugepages && huge_free == hugepages) {
+				ret = shared_hugepage();
+
+				huge_free2 = read_meminfo("HugePages_Free:");
+				if (huge_free2 != huge_free)
+					ret = 2;
+			} else {
+				ret = 1;
+			}
+			
+			switch (ret) {
+			case 0:
+				tst_resm(TPASS, 
+					"No regression found.");
+				break;
+			case 1:
+				tst_brkm(TFAIL, cleanup, 
+					"Test failed. Maybe memory shortage.");
+				break;
+			case 2:
+				tst_brkm(TFAIL, cleanup, 
+					"Test failed. Hugepage leak inspection.");
+				break;
+			default:
+				tst_brkm(TFAIL, cleanup, 
+					"Test failed. Other problem detected.");
+				break;
+			}
+
+		}
+	}
+	cleanup();
+	tst_exit();
+}
+
+int shared_hugepage(void)
+{
+	pid_t pid;
+	int status, shmid;
+	size_t size = (size_t)SIZE;
+	void *buf;
+
+	shmid = shmget(IPC_PRIVATE, size, SHM_HUGETLB | IPC_CREAT | 0777);
+	if (shmid < 0)
+		tst_brkm(TBROK | TERRNO, cleanup, "shmget");
+
+	buf = shmat(shmid, (void *)BOUNDARY, SHM_RND | 0777);
+	if ( buf == (void *)-1 ) {
+		shmctl(shmid, IPC_RMID, NULL);
+		tst_brkm(TBROK | TERRNO, cleanup, "shmat");
+	}
+
+	memset(buf, 2, size);
+	sleep(3);
+	pid = fork();
+	
+	if (pid == 0)
+	        exit(1);
+	else if (pid < 0)
+	 	tst_brkm(TBROK | TERRNO, cleanup, "fork");
+	
+	wait(&status);
+	shmdt(buf);
+	shmctl(shmid, IPC_RMID, NULL);
+
+	return 0;
+}
+
+void setup(void)
+{
+	long mem_total, hpage_size;
+	
+	tst_require_root(NULL);
+
+	mem_total = read_meminfo("MemTotal:");
+	if (mem_total < 2097152) {
+		tst_resm(TINFO, "Total memory should greater than 2G.");
+		tst_exit();
+	}
+
+	orig_hugepages = get_sys_tune("nr_hugepages");
+	hpage_size = read_meminfo("Hugepagesize:");
+	
+	hugepages = (orig_hugepages * hpage_size + 1048576) / hpage_size;
+	set_sys_tune("nr_hugepages", hugepages, 1);
+	
+	TEST_PAUSE;
+}
+
+void cleanup(void)
+{
+	TEST_CLEANUP;
+	set_sys_tune("nr_hugepages", orig_hugepages, 0);
+}
-- 
1.8.3.1


------------------------------------------------------------------------------
Dive into the World of Parallel Programming! The Go Parallel Website,
sponsored by Intel and developed in partnership with Slashdot Media, is your
hub for all things parallel software development, from weekly thought
leadership blogs to news, videos, case studies, tutorials and more. Take a
look and join the conversation now. http://goparallel.sourceforge.net
_______________________________________________
Ltp-list mailing list
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list

^ permalink raw reply related	[flat|nested] 13+ messages in thread
* [LTP] [PATCH] mem/hugeshmat: new case for hugepage leak inspection
@ 2014-12-28  3:20 Li Wang
  0 siblings, 0 replies; 13+ messages in thread
From: Li Wang @ 2014-12-28  3:20 UTC (permalink / raw)
  To: ltp-list

Description of Problem:
    When over 1GB shared memory was alocated in hugepage, the hugepage
    is not released though process finished.

Signed-off-by: Li Wang <liwang@redhat.com>
---
 runtest/hugetlb                                    |   1 +
 testcases/kernel/mem/.gitignore                    |   1 +
 .../kernel/mem/hugetlb/hugeshmat/hugeshmat04.c     | 185 +++++++++++++++++++++
 3 files changed, 187 insertions(+)
 create mode 100644 testcases/kernel/mem/hugetlb/hugeshmat/hugeshmat04.c

diff --git a/runtest/hugetlb b/runtest/hugetlb
index 3eaf14c..805141d 100644
--- a/runtest/hugetlb
+++ b/runtest/hugetlb
@@ -10,6 +10,7 @@ hugemmap05_3 hugemmap05 -s -m
 hugeshmat01 hugeshmat01 -i 5
 hugeshmat02 hugeshmat02 -i 5
 hugeshmat03 hugeshmat03 -i 5
+hugeshmat04 hugeshamt04 -i 5
 
 hugeshmctl01 hugeshmctl01 -i 5
 hugeshmctl02 hugeshmctl02 -i 5
diff --git a/testcases/kernel/mem/.gitignore b/testcases/kernel/mem/.gitignore
index f96964c..c531563 100644
--- a/testcases/kernel/mem/.gitignore
+++ b/testcases/kernel/mem/.gitignore
@@ -6,6 +6,7 @@
 /hugetlb/hugeshmat/hugeshmat01
 /hugetlb/hugeshmat/hugeshmat02
 /hugetlb/hugeshmat/hugeshmat03
+/hugetlb/hugeshmat/hugeshmat04
 /hugetlb/hugeshmctl/hugeshmctl01
 /hugetlb/hugeshmctl/hugeshmctl02
 /hugetlb/hugeshmctl/hugeshmctl03
diff --git a/testcases/kernel/mem/hugetlb/hugeshmat/hugeshmat04.c b/testcases/kernel/mem/hugetlb/hugeshmat/hugeshmat04.c
new file mode 100644
index 0000000..515947b
--- /dev/null
+++ b/testcases/kernel/mem/hugetlb/hugeshmat/hugeshmat04.c
@@ -0,0 +1,185 @@
+/*
+ *   Copyright (c) Linux Test Project, 2014
+ *
+ *   This program is free software;  you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY;  without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
+ *   the GNU General Public License for more details.
+ *  
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program;  if not, write to the Free Software
+ *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+/*
+ * NAME
+ * 	hugeshmat04.c
+ * 
+ * DESCRIPTION
+ *	hugeshmat04 - test for hugepage leak inspection.
+ *     
+ *      Description of Problem:
+ *          When over 1GB shered memory was alocated in hugepage, the hugepage
+ *          is not released though process finished.
+ *
+ *          You need more than 2GB memory in test job
+ *
+ *	Return value:
+ *	  0: 	 Test successed.  No regression found.
+ *	  1: 	 Test failed.  Maybe memory shortage.  Please retry testing.
+ *	  2: 	 Test failed.  Regression detected.
+ *	  other: Test failed.  Other problem detected.
+ *
+ * HISTORY
+ * 	05/2014 - Written by Fujistu Corp. 
+ *     	12/2014 - Port to LTP by Li Wang.
+ *    
+ * RESTRICTIONS
+ * 	test must be run at root
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <fcntl.h>
+#include <string.h>
+#include <sys/mman.h>
+#include <sys/types.h>
+#include <sys/shm.h>
+#include <sys/wait.h>
+
+#include "test.h"
+#include "mem.h"
+
+#define SIZE	(1024 * 1024 * 1024)
+#define BOUNDARY (1024 * 1024 * 1024)
+
+char *TCID = "hugeshmat04";
+int TST_TOTAL = 3;
+
+static int huge_total;
+static int huge_free;
+static int huge_free2;
+static long hugepages;
+static long orig_hugepages;
+
+static int shared_hugepage(void);
+
+
+int main(int ac, char **av)
+{
+	int lc, i, ret;
+	const char *msg;
+
+	msg = parse_opts(ac,av, NULL, NULL);
+	if (msg != NULL)
+		tst_brkm(TBROK, NULL, "OPTION PARSING ERROR - %s", msg);
+
+	setup();
+
+	for (lc = 0; TEST_LOOPING(lc); lc++) {
+		tst_count = 0;
+
+		for (i = 0; i < TST_TOTAL; i++) {
+			huge_total = read_meminfo("HugePages_Total:");
+			huge_free = read_meminfo("HugePages_Free:");
+
+			if (huge_total == hugepages && huge_free == hugepages) {
+				ret = shared_hugepage();
+
+				huge_free2 = read_meminfo("HugePages_Free:");
+				if (huge_free2 != huge_free)
+					ret = 2;
+			} else {
+				ret = 1;
+			}
+			
+			switch (ret) {
+			case 0:
+				tst_resm(TPASS, 
+					"No regression found.");
+				break;
+			case 1:
+				tst_brkm(TFAIL, cleanup, 
+					"Test failed. Maybe memory shortage.");
+				break;
+			case 2:
+				tst_brkm(TFAIL, cleanup, 
+					"Test failed. Hugepage leak inspection.");
+				break;
+			default:
+				tst_brkm(TFAIL, cleanup, 
+					"Test failed. Other problem detected.");
+				break;
+			}
+
+		}
+	}
+	cleanup();
+	tst_exit();
+}
+
+int shared_hugepage(void)
+{
+	pid_t pid;
+	int status, shmid;
+	size_t size = (size_t)SIZE;
+	void *buf;
+
+	shmid = shmget(IPC_PRIVATE, size, SHM_HUGETLB | IPC_CREAT | 0777);
+	if (shmid < 0)
+		tst_brkm(TBROK | TERRNO, cleanup, "shmget");
+
+	buf = shmat(shmid, (void *)BOUNDARY, SHM_RND | 0777);
+	if ( buf == (void *)-1 ) {
+		shmctl(shmid, IPC_RMID, NULL);
+		tst_brkm(TBROK | TERRNO, cleanup, "shmat");
+	}
+
+	memset(buf, 2, size);
+	sleep(3);
+	pid = fork();
+	
+	if (pid == 0)
+	        exit(1);
+	else if (pid < 0)
+	 	tst_brkm(TBROK | TERRNO, cleanup, "fork");
+	
+	wait(&status);
+	shmdt(buf);
+	shmctl(shmid, IPC_RMID, NULL);
+
+	return 0;
+}
+
+void setup(void)
+{
+	long mem_total, hpage_size;
+	
+	tst_require_root(NULL);
+
+	mem_total = read_meminfo("MemTotal:");
+	if (mem_total < 2097152) {
+		tst_resm(TINFO, "Total memory should greater than 2G.");
+		tst_exit();
+	}
+
+	orig_hugepages = get_sys_tune("nr_hugepages");
+	hpage_size = read_meminfo("Hugepagesize:");
+	
+	hugepages = (orig_hugepages * hpage_size + 1048576) / hpage_size;
+	set_sys_tune("nr_hugepages", hugepages, 1);
+	
+	TEST_PAUSE;
+}
+
+void cleanup(void)
+{
+	TEST_CLEANUP;
+	set_sys_tune("nr_hugepages", orig_hugepages, 0);
+}
-- 
1.8.3.1


------------------------------------------------------------------------------
Dive into the World of Parallel Programming! The Go Parallel Website,
sponsored by Intel and developed in partnership with Slashdot Media, is your
hub for all things parallel software development, from weekly thought
leadership blogs to news, videos, case studies, tutorials and more. Take a
look and join the conversation now. http://goparallel.sourceforge.net
_______________________________________________
Ltp-list mailing list
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list

^ permalink raw reply related	[flat|nested] 13+ messages in thread
[parent not found: <1419737900-6117-1-git-send-email-liwang@redhat.com>]
[parent not found: <1422336738-617-1-git-send-email-liwang@redhat.com>]

end of thread, other threads:[~2015-01-27 15:31 UTC | newest]

Thread overview: 13+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-12-27  7:13 [LTP] [PATCH] mem/hugeshmat: new case for hugepage leak inspection Li Wang
2014-12-30  9:23 ` Jan Stancek
2015-01-04  3:10   ` Li Wang
2015-01-05 10:16     ` Jan Stancek
2015-01-06  9:51       ` Li Wang
2015-01-06 10:35         ` Jan Stancek
2015-01-06 14:07           ` Li Wang
2015-01-07 12:32             ` Jan Stancek
2015-01-07 14:59               ` Li Wang
2015-01-26 16:48                 ` Cyril Hrubis
2014-12-28  3:20 Li Wang
     [not found] <1419737900-6117-1-git-send-email-liwang@redhat.com>
2014-12-28  4:06 ` Li Wang
     [not found] <1422336738-617-1-git-send-email-liwang@redhat.com>
2015-01-27 15:31 ` Cyril Hrubis

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.