[LTP] [PATCH v4] kill01: New case cgroup kill
Wei Gao
wegao@suse.com
Tue Mar 7 09:27:55 CET 2023
On Tue, Mar 07, 2023 at 03:13:56PM +0800, Li Wang wrote:
> Hi Wei,
>
> The new test generally looks good to me.
>
> I'm thinking maybe we make use of guarded buffers which could
> remove the setup/cleanup function then. And doing memset(buf,...)
> before reading into buf[] is quite necessary, to avoid someone
> running this test with parameter '-i N' that the buf[] is polluted
> by the first time.
>
> https://github.com/linux-test-project/ltp/blob/master/doc/c-test-api.txt#L1799
>
> <https://github.com/linux-test-project/ltp/blob/master/doc/c-test-api.txt#L1799>
> e.g.
I have tried use guarded buffers but compile can not pass.
Following error will trigger since buf_len is caculate instead of FIX constant. So
I suppose we can not use guarded buffers?
kill01.c:131:34: error: initializer element is not constant
.bufs = (struct tst_buffers []) {
For memset before reading buf issue, i will update in next patch.
>
> --- a/testcases/kernel/controllers/kill/kill01.c
> +++ b/testcases/kernel/controllers/kill/kill01.c
> @@ -26,7 +26,7 @@
>
> #define MAX_PID_NUM 100
> #define pid_num MIN(MAX_PID_NUM, (tst_ncpus_available() + 1))
> -#define buf_len (20 * pid_num)
> +#define buf_len (10 * MAX_PID_NUM)
>
> static char *buf;
> static struct tst_cg_group *cg_child_test_simple;
> @@ -60,7 +60,6 @@ static void child_fn(void)
>
> while (getppid() == ppid)
> usleep(1000);
> -
> }
>
> static int cg_run_nowait(const struct tst_cg_group *const cg,
> @@ -82,6 +81,8 @@ static int cg_wait_for_proc_count(const struct
> tst_cg_group *cg, int count)
> int attempts;
> char *ptr;
>
> + memset(buf, 0, buf_len);
> +
> for (attempts = 100; attempts >= 0; attempts--) {
> int nr = 0;
>
> @@ -121,23 +122,14 @@ static void run(void)
> cg_child_test_simple = tst_cg_group_rm(cg_child_test_simple);
> }
>
> -static void setup(void)
> -{
> - buf = SAFE_MALLOC(buf_len);
> - memset(buf, 0, buf_len);
> -}
> -
> -static void cleanup(void)
> -{
> - free(buf);
> -}
> -
> static struct tst_test test = {
> .test_all = run,
> - .setup = setup,
> - .cleanup = cleanup,
> .forks_child = 1,
> .max_runtime = 15,
> .needs_cgroup_ctrls = (const char *const []){ "memory", NULL },
> .needs_cgroup_ver = TST_CG_V2,
> + .bufs = (struct tst_buffers []) {
> + {&buf, .size = buf_len},
> + {}
> + }
> };
>
> Anyway this version you could add my reviewed-by:
>
> Reviewed-by: Li Wang <liwang@redhat.com>
>
>
> --
> Regards,
> Li Wang
More information about the ltp
mailing list