From: Caspar Zhang <caspar@casparzhang.com>
To: gaowanlong@cn.fujitsu.com
Cc: LTP list <ltp-list@lists.sourceforge.net>
Subject: Re: [LTP] [PATCH v2] mm/oom05: new testcase
Date: Fri, 04 Jan 2013 15:03:34 +0800 [thread overview]
Message-ID: <50E67EC6.90905@casparzhang.com> (raw)
In-Reply-To: <50E66EDD.2010707@cn.fujitsu.com>
On 01/04/2013 01:55 PM, Wanlong Gao wrote:
> On 08/27/2012 09:01 PM, Zhouping Liu wrote:
>> add a new testcase to test OOM on each NUMA node at the same time.
>>
>> Signed-off-by: Zhouping Liu <zliu@redhat.com>
>
> Any update, or Caspar, did you finish reviewing this?
Talked with Zhouping, we agreed that we need to wait to see if the new
case can bring real benefits to us. So let's hold the patch until an
investigation is done.
Caspar
>
> Thanks,
> Wanlong Gao
>
>
>> ---
>> runtest/mm | 1 +
>> testcases/kernel/mem/oom/oom05.c | 137 +++++++++++++++++++++++++++++++++++++++
>> 2 files changed, 138 insertions(+)
>> create mode 100644 testcases/kernel/mem/oom/oom05.c
>>
>> change log from v1 to v2:
>>
>> used numa_helper.h lib
>>
>> diff --git a/runtest/mm b/runtest/mm
>> index 2dd66f0..a60c04b 100644
>> --- a/runtest/mm
>> +++ b/runtest/mm
>> @@ -77,6 +77,7 @@ oom01 oom01
>> oom02 oom02
>> oom03 oom03
>> oom04 oom04
>> +oom05 oom05
>>
>> swapping01 swapping01 -i 5
>>
>> diff --git a/testcases/kernel/mem/oom/oom05.c b/testcases/kernel/mem/oom/oom05.c
>> new file mode 100644
>> index 0000000..5f49447
>> --- /dev/null
>> +++ b/testcases/kernel/mem/oom/oom05.c
>> @@ -0,0 +1,137 @@
>> +/*
>> + * Out Of Memory (OOM) on Each NUMA node at the same time
>> + *
>> + * The program is designed to cope with unpredictable like amount and
>> + * system physical memory, swap size and other VMM technology like KSM,
>> + * memcg, memory hotplug and so on which may affect the OOM
>> + * behaviours. It simply increase the memory consumption 3G each time
>> + * until all the available memory is consumed and OOM is triggered.
>> + *
>> + * Copyright (C) 2012 Red Hat, Inc.
>> + * This program is free software; you can redistribute it and/or
>> + * modify it under the terms of version 2 of the GNU General Public
>> + * License as published by the Free Software Foundation.
>> + *
>> + * This program is distributed in the hope that it would be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
>> + *
>> + * Further, this software is distributed without any warranty that it
>> + * is free of the rightful claim of any third person regarding
>> + * infringement or the like. Any license provided herein, whether
>> + * implied or otherwise, applies only to this software file. Patent
>> + * licenses, if any, provided herein do not apply to combinations of
>> + * this program with other software, or any other product whatsoever.
>> + *
>> + * You should have received a copy of the GNU General Public License
>> + * along with this program; if not, write the Free Software
>> + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
>> + * 02110-1301, USA.
>> + */
>> +#include <sys/types.h>
>> +#include <sys/stat.h>
>> +#include <sys/wait.h>
>> +#include <errno.h>
>> +#include <fcntl.h>
>> +#include <stdio.h>
>> +#include <stdlib.h>
>> +#include <unistd.h>
>> +
>> +#include "test.h"
>> +#include "safe_macros.h"
>> +#include "usctest.h"
>> +#include "mem.h"
>> +#include "numa_helper.h"
>> +
>> +char *TCID = "oom05";
>> +int TST_TOTAL = 1;
>> +
>> +#if HAVE_NUMA_H && HAVE_LINUX_MEMPOLICY_H && HAVE_NUMAIF_H \
>> + && HAVE_MPOL_CONSTANTS
>> +#include <numa.h>
>> +#include <numaif.h>
>> +
>> +int main(int argc, char *argv[])
>> +{
>> + char *msg;
>> + int lc;
>> + int *nodes, nnodes, i;
>> + pid_t pids[MAXNODES];
>> + int status;
>> + unsigned long nmasks[MAXNODES];
>> +
>> + msg = parse_opts(argc, argv, NULL, NULL);
>> + if (msg != NULL)
>> + tst_brkm(TBROK, NULL, "OPTION PARSING ERROR - %s", msg);
>> +
>> +#if __WORDSIZE == 32
>> + tst_brkm(TCONF, NULL, "test is not designed for 32-bit system.");
>> +#endif
>> + if (get_allowed_nodes_arr(NH_MEMS|NH_CPUS, &nnodes, &nodes) < 0)
>> + tst_brkm(TBROK|TERRNO, NULL, "get_allowed_nodes_arr");
>> + if (nnodes <= 1)
>> + tst_brkm(TCONF, NULL, "requres a NUMA system.");
>> +
>> + setup();
>> +
>> + set_sys_tune("overcommit_memory", 1, 1);
>> +
>> + for (lc = 0; TEST_LOOPING(lc); lc++) {
>> + Tst_count = 0;
>> +
>> + for (i = 0; i < nnodes; i++) {
>> + nmasks[i] = 1 << nodes[i];
>> + switch (pids[i] = fork()) {
>> + case -1:
>> + tst_brkm(TBROK | TERRNO, cleanup, "fork");
>> + case 0:
>> + if (set_mempolicy(MPOL_BIND, &nmasks[i],
>> + MAXNODES)== -1)
>> + tst_brkm(TBROK | TERRNO, cleanup,
>> + "set_mempolicy");
>> +
>> + tst_resm(TINFO, "start oom on numa node%d",
>> + nodes[i]);
>> +
>> + testoom(0, 0, 0);
>> +
>> + exit(0);
>> + }
>> + }
>> +
>> + for (i = 0; i < nnodes; i++) {
>> + if (waitpid(pids[i], &status, WUNTRACED | WCONTINUED)
>> + == -1)
>> + tst_brkm(TBROK | TERRNO, cleanup, "waitpid");
>> + if (WIFEXITED(status) && WEXITSTATUS(status) != 0)
>> + tst_resm(TFAIL,
>> + "check_monitor child exit with status: %d",
>> + status);
>> + }
>> + }
>> + cleanup();
>> + tst_exit();
>> +}
>> +
>> +void setup(void)
>> +{
>> + tst_require_root(NULL);
>> + tst_sig(FORK, DEF_HANDLER, cleanup);
>> + TEST_PAUSE;
>> +
>> + overcommit = get_sys_tune("overcommit_memory");
>> +}
>> +
>> +void cleanup(void)
>> +{
>> + set_sys_tune("overcommit_memory", overcommit, 0);
>> +
>> + TEST_CLEANUP;
>> +}
>> +
>> +#else /* no NUMA */
>> +int main(void)
>> +{
>> + tst_brkm(TCONF, NULL, "no NUMA development packages installed.");
>> +}
>> +#endif
>>
>
------------------------------------------------------------------------------
Master HTML5, CSS3, ASP.NET, MVC, AJAX, Knockout.js, Web API and
much more. Get web development skills now with LearnDevNow -
350+ hours of step-by-step video tutorials by Microsoft MVPs and experts.
SALE $99.99 this month only -- learn more at:
http://p.sf.net/sfu/learnmore_122812
_______________________________________________
Ltp-list mailing list
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list
prev parent reply other threads:[~2013-01-04 7:10 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-08-27 13:01 [LTP] [PATCH v2] mm/oom05: new testcase Zhouping Liu
2013-01-04 5:55 ` Wanlong Gao
2013-01-04 7:03 ` Caspar Zhang [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=50E67EC6.90905@casparzhang.com \
--to=caspar@casparzhang.com \
--cc=gaowanlong@cn.fujitsu.com \
--cc=ltp-list@lists.sourceforge.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox