diff mbox series

[-next] kunit: fix possible memory leak in kunit_filter_suites()

Message ID 20230801073700.3740895-1-ruanjinjie@huawei.com (mailing list archive)
State Accepted
Commit abbf73816b6f5f4268fbfb3b3505003c2356d4a9
Delegated to: Brendan Higgins
Headers show
Series [-next] kunit: fix possible memory leak in kunit_filter_suites() | expand

Commit Message

Jinjie Ruan Aug. 1, 2023, 7:37 a.m. UTC
Inject fault while probing drm_kunit_helpers.ko, if one of
kunit_next_attr_filter(), kunit_filter_glob_tests() and
kunit_filter_attr_tests() fails, parsed_filters,
parsed_glob.suite_glob/test_glob alloced in
kunit_parse_glob_filter() is leaked.
And the filtered_suite->test_cases alloced in kunit_filter_glob_tests()
or kunit_filter_attr_tests() may also be leaked.

unreferenced object 0xff110001067e4800 (size 1024):
  comm "kunit_try_catch", pid 96, jiffies 4294671796 (age 763.547s)
  hex dump (first 32 bytes):
    73 75 69 74 65 32 00 00 00 00 00 00 00 00 00 00  suite2..........
    00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
  backtrace:
    [<00000000116e8eba>] __kmalloc_node_track_caller+0x4e/0x140
    [<00000000e2f9cce9>] kmemdup+0x2c/0x60
    [<000000002a36710b>] kunit_filter_suites+0x3e4/0xa50
    [<0000000045779fb9>] filter_suites_test+0x1b7/0x440
    [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
    [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
    [<00000000d195ac13>] kthread+0x2c7/0x3c0
    [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
    [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
unreferenced object 0xff11000105d79b00 (size 192):
  comm "kunit_try_catch", pid 96, jiffies 4294671796 (age 763.547s)
  hex dump (first 32 bytes):
    f0 e1 5a 88 ff ff ff ff 60 59 bb 8a ff ff ff ff  ..Z.....`Y......
    00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
  backtrace:
    [<000000000d6e4891>] __kmalloc+0x4d/0x140
    [<000000006afe50bd>] kunit_filter_suites+0x424/0xa50
    [<0000000045779fb9>] filter_suites_test+0x1b7/0x440
    [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
    [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
    [<00000000d195ac13>] kthread+0x2c7/0x3c0
    [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
    [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
unreferenced object 0xff110001067e6000 (size 1024):
  comm "kunit_try_catch", pid 98, jiffies 4294671798 (age 763.545s)
  hex dump (first 32 bytes):
    73 75 69 74 65 32 00 00 00 00 00 00 00 00 00 00  suite2..........
    00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
  backtrace:
    [<00000000116e8eba>] __kmalloc_node_track_caller+0x4e/0x140
    [<00000000e2f9cce9>] kmemdup+0x2c/0x60
    [<000000002a36710b>] kunit_filter_suites+0x3e4/0xa50
    [<00000000f452f130>] filter_suites_test_glob_test+0x1b7/0x660
    [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
    [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
    [<00000000d195ac13>] kthread+0x2c7/0x3c0
    [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
    [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
unreferenced object 0xff11000103f3a800 (size 96):
  comm "kunit_try_catch", pid 98, jiffies 4294671798 (age 763.545s)
  hex dump (first 32 bytes):
    f0 e1 5a 88 ff ff ff ff 40 39 bb 8a ff ff ff ff  ..Z.....@9......
    00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
  backtrace:
    [<000000000d6e4891>] __kmalloc+0x4d/0x140
    [<000000006afe50bd>] kunit_filter_suites+0x424/0xa50
    [<00000000f452f130>] filter_suites_test_glob_test+0x1b7/0x660
    [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
    [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
    [<00000000d195ac13>] kthread+0x2c7/0x3c0
    [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
    [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
unreferenced object 0xff11000101a72ac0 (size 16):
  comm "kunit_try_catch", pid 104, jiffies 4294671814 (age 763.529s)
  hex dump (first 16 bytes):
    00 00 00 00 00 00 00 00 e0 2a a7 01 01 00 11 ff  .........*......
  backtrace:
    [<000000000d6e4891>] __kmalloc+0x4d/0x140
    [<00000000c7b724e7>] kunit_filter_suites+0x108/0xa50
    [<00000000bad5427d>] filter_attr_test+0x1e9/0x6a0
    [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
    [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
    [<00000000d195ac13>] kthread+0x2c7/0x3c0
    [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
    [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
unreferenced object 0xff11000103caf880 (size 32):
  comm "kunit_try_catch", pid 104, jiffies 4294671814 (age 763.547s)
  hex dump (first 32 bytes):
    00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
    00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
  backtrace:
    [<000000000d6e4891>] __kmalloc+0x4d/0x140
    [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
    [<00000000bad5427d>] filter_attr_test+0x1e9/0x6a0
    [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
    [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
    [<00000000d195ac13>] kthread+0x2c7/0x3c0
    [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
    [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
unreferenced object 0xff11000101a72ae0 (size 16):
  comm "kunit_try_catch", pid 106, jiffies 4294671823 (age 763.538s)
  hex dump (first 16 bytes):
    00 00 00 00 00 00 00 00 00 2b a7 01 01 00 11 ff  .........+......
  backtrace:
    [<000000000d6e4891>] __kmalloc+0x4d/0x140
    [<00000000c7b724e7>] kunit_filter_suites+0x108/0xa50
    [<0000000096255c51>] filter_attr_empty_test+0x1b0/0x310
    [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
    [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
    [<00000000d195ac13>] kthread+0x2c7/0x3c0
    [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
    [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
unreferenced object 0xff11000103caf9c0 (size 32):
  comm "kunit_try_catch", pid 106, jiffies 4294671823 (age 763.538s)
  hex dump (first 32 bytes):
    00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
    00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
  backtrace:
    [<000000000d6e4891>] __kmalloc+0x4d/0x140
    [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
    [<0000000096255c51>] filter_attr_empty_test+0x1b0/0x310
    [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
    [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
    [<00000000d195ac13>] kthread+0x2c7/0x3c0
    [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
    [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
unreferenced object 0xff11000101a72b00 (size 16):
  comm "kunit_try_catch", pid 108, jiffies 4294671832 (age 763.529s)
  hex dump (first 16 bytes):
    00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
  backtrace:
    [<000000000d6e4891>] __kmalloc+0x4d/0x140
    [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
    [<00000000881258cc>] filter_attr_skip_test+0x148/0x770
    [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
    [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
    [<00000000d195ac13>] kthread+0x2c7/0x3c0
    [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
    [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30

Fixes: 5d31f71efcb6 ("kunit: add kunit.filter_glob cmdline option to filter suites")
Fixes: 529534e8cba3 ("kunit: Add ability to filter attributes")
Signed-off-by: Ruan Jinjie <ruanjinjie@huawei.com>
---
 lib/kunit/executor.c | 17 ++++++++++++-----
 1 file changed, 12 insertions(+), 5 deletions(-)

Comments

Rae Moar Aug. 1, 2023, 9:22 p.m. UTC | #1
On Tue, Aug 1, 2023 at 3:37 AM 'Ruan Jinjie' via KUnit Development
<kunit-dev@googlegroups.com> wrote:
>
> Inject fault while probing drm_kunit_helpers.ko, if one of
> kunit_next_attr_filter(), kunit_filter_glob_tests() and
> kunit_filter_attr_tests() fails, parsed_filters,
> parsed_glob.suite_glob/test_glob alloced in
> kunit_parse_glob_filter() is leaked.
> And the filtered_suite->test_cases alloced in kunit_filter_glob_tests()
> or kunit_filter_attr_tests() may also be leaked.
>
> unreferenced object 0xff110001067e4800 (size 1024):
>   comm "kunit_try_catch", pid 96, jiffies 4294671796 (age 763.547s)
>   hex dump (first 32 bytes):
>     73 75 69 74 65 32 00 00 00 00 00 00 00 00 00 00  suite2..........
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<00000000116e8eba>] __kmalloc_node_track_caller+0x4e/0x140
>     [<00000000e2f9cce9>] kmemdup+0x2c/0x60
>     [<000000002a36710b>] kunit_filter_suites+0x3e4/0xa50
>     [<0000000045779fb9>] filter_suites_test+0x1b7/0x440
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000105d79b00 (size 192):
>   comm "kunit_try_catch", pid 96, jiffies 4294671796 (age 763.547s)
>   hex dump (first 32 bytes):
>     f0 e1 5a 88 ff ff ff ff 60 59 bb 8a ff ff ff ff  ..Z.....`Y......
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<000000006afe50bd>] kunit_filter_suites+0x424/0xa50
>     [<0000000045779fb9>] filter_suites_test+0x1b7/0x440
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff110001067e6000 (size 1024):
>   comm "kunit_try_catch", pid 98, jiffies 4294671798 (age 763.545s)
>   hex dump (first 32 bytes):
>     73 75 69 74 65 32 00 00 00 00 00 00 00 00 00 00  suite2..........
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<00000000116e8eba>] __kmalloc_node_track_caller+0x4e/0x140
>     [<00000000e2f9cce9>] kmemdup+0x2c/0x60
>     [<000000002a36710b>] kunit_filter_suites+0x3e4/0xa50
>     [<00000000f452f130>] filter_suites_test_glob_test+0x1b7/0x660
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000103f3a800 (size 96):
>   comm "kunit_try_catch", pid 98, jiffies 4294671798 (age 763.545s)
>   hex dump (first 32 bytes):
>     f0 e1 5a 88 ff ff ff ff 40 39 bb 8a ff ff ff ff  ..Z.....@9......
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<000000006afe50bd>] kunit_filter_suites+0x424/0xa50
>     [<00000000f452f130>] filter_suites_test_glob_test+0x1b7/0x660
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000101a72ac0 (size 16):
>   comm "kunit_try_catch", pid 104, jiffies 4294671814 (age 763.529s)
>   hex dump (first 16 bytes):
>     00 00 00 00 00 00 00 00 e0 2a a7 01 01 00 11 ff  .........*......
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<00000000c7b724e7>] kunit_filter_suites+0x108/0xa50
>     [<00000000bad5427d>] filter_attr_test+0x1e9/0x6a0
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000103caf880 (size 32):
>   comm "kunit_try_catch", pid 104, jiffies 4294671814 (age 763.547s)
>   hex dump (first 32 bytes):
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
>     [<00000000bad5427d>] filter_attr_test+0x1e9/0x6a0
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000101a72ae0 (size 16):
>   comm "kunit_try_catch", pid 106, jiffies 4294671823 (age 763.538s)
>   hex dump (first 16 bytes):
>     00 00 00 00 00 00 00 00 00 2b a7 01 01 00 11 ff  .........+......
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<00000000c7b724e7>] kunit_filter_suites+0x108/0xa50
>     [<0000000096255c51>] filter_attr_empty_test+0x1b0/0x310
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000103caf9c0 (size 32):
>   comm "kunit_try_catch", pid 106, jiffies 4294671823 (age 763.538s)
>   hex dump (first 32 bytes):
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
>     [<0000000096255c51>] filter_attr_empty_test+0x1b0/0x310
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000101a72b00 (size 16):
>   comm "kunit_try_catch", pid 108, jiffies 4294671832 (age 763.529s)
>   hex dump (first 16 bytes):
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
>     [<00000000881258cc>] filter_attr_skip_test+0x148/0x770
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>
> Fixes: 5d31f71efcb6 ("kunit: add kunit.filter_glob cmdline option to filter suites")
> Fixes: 529534e8cba3 ("kunit: Add ability to filter attributes")
> Signed-off-by: Ruan Jinjie <ruanjinjie@huawei.com>

Hello!

I have tested this and this all looks good to me. Sorry for the delay
in responding to the patches addressing the bugs in filtering. I have
been out of the office for a few days. Thanks for addressing this!

Reviewed-by: Rae Moar <rmoar@google.com>

-Rae

> ---
>  lib/kunit/executor.c | 17 ++++++++++++-----
>  1 file changed, 12 insertions(+), 5 deletions(-)
>
> diff --git a/lib/kunit/executor.c b/lib/kunit/executor.c
> index 5b5bed1efb93..481901d245d0 100644
> --- a/lib/kunit/executor.c
> +++ b/lib/kunit/executor.c
> @@ -151,7 +151,7 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>                 for (j = 0; j < filter_count; j++)
>                         parsed_filters[j] = kunit_next_attr_filter(&filters, err);
>                 if (*err)
> -                       return filtered;
> +                       goto err;
>         }
>
>         for (i = 0; &suite_set->start[i] != suite_set->end; i++) {
> @@ -163,7 +163,7 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>                                         parsed_glob.test_glob);
>                         if (IS_ERR(filtered_suite)) {
>                                 *err = PTR_ERR(filtered_suite);
> -                               return filtered;
> +                               goto err;
>                         }
>                 }
>                 if (filter_count) {
> @@ -172,15 +172,18 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>                                                 parsed_filters[k], filter_action, err);
>
>                                 /* Free previous copy of suite */
> -                               if (k > 0 || filter_glob)
> +                               if (k > 0 || filter_glob) {
> +                                       kfree(filtered_suite->test_cases);
>                                         kfree(filtered_suite);
> +                               }
> +
>                                 filtered_suite = new_filtered_suite;
>
>                                 if (*err)
> -                                       return filtered;
> +                                       goto err;
>                                 if (IS_ERR(filtered_suite)) {
>                                         *err = PTR_ERR(filtered_suite);
> -                                       return filtered;
> +                                       goto err;
>                                 }
>                                 if (!filtered_suite)
>                                         break;
> @@ -194,6 +197,10 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>         }
>         filtered.end = copy;
>
> +err:
> +       if (*err)
> +               kfree(copy);
> +
>         if (filter_glob) {
>                 kfree(parsed_glob.suite_glob);
>                 kfree(parsed_glob.test_glob);
> --
> 2.34.1
>
> --
> You received this message because you are subscribed to the Google Groups "KUnit Development" group.
> To unsubscribe from this group and stop receiving emails from it, send an email to kunit-dev+unsubscribe@googlegroups.com.
> To view this discussion on the web visit https://groups.google.com/d/msgid/kunit-dev/20230801073700.3740895-1-ruanjinjie%40huawei.com.
Jinjie Ruan Aug. 2, 2023, 2:10 a.m. UTC | #2
On 2023/8/2 5:22, Rae Moar wrote:
> On Tue, Aug 1, 2023 at 3:37 AM 'Ruan Jinjie' via KUnit Development
> <kunit-dev@googlegroups.com> wrote:
>>
>> Inject fault while probing drm_kunit_helpers.ko, if one of
>> kunit_next_attr_filter(), kunit_filter_glob_tests() and
>> kunit_filter_attr_tests() fails, parsed_filters,
>> parsed_glob.suite_glob/test_glob alloced in
>> kunit_parse_glob_filter() is leaked.
>> And the filtered_suite->test_cases alloced in kunit_filter_glob_tests()
>> or kunit_filter_attr_tests() may also be leaked.
>>
>> unreferenced object 0xff110001067e4800 (size 1024):
>>   comm "kunit_try_catch", pid 96, jiffies 4294671796 (age 763.547s)
>>   hex dump (first 32 bytes):
>>     73 75 69 74 65 32 00 00 00 00 00 00 00 00 00 00  suite2..........
>>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>>   backtrace:
>>     [<00000000116e8eba>] __kmalloc_node_track_caller+0x4e/0x140
>>     [<00000000e2f9cce9>] kmemdup+0x2c/0x60
>>     [<000000002a36710b>] kunit_filter_suites+0x3e4/0xa50
>>     [<0000000045779fb9>] filter_suites_test+0x1b7/0x440
>>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>> unreferenced object 0xff11000105d79b00 (size 192):
>>   comm "kunit_try_catch", pid 96, jiffies 4294671796 (age 763.547s)
>>   hex dump (first 32 bytes):
>>     f0 e1 5a 88 ff ff ff ff 60 59 bb 8a ff ff ff ff  ..Z.....`Y......
>>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>>   backtrace:
>>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>>     [<000000006afe50bd>] kunit_filter_suites+0x424/0xa50
>>     [<0000000045779fb9>] filter_suites_test+0x1b7/0x440
>>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>> unreferenced object 0xff110001067e6000 (size 1024):
>>   comm "kunit_try_catch", pid 98, jiffies 4294671798 (age 763.545s)
>>   hex dump (first 32 bytes):
>>     73 75 69 74 65 32 00 00 00 00 00 00 00 00 00 00  suite2..........
>>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>>   backtrace:
>>     [<00000000116e8eba>] __kmalloc_node_track_caller+0x4e/0x140
>>     [<00000000e2f9cce9>] kmemdup+0x2c/0x60
>>     [<000000002a36710b>] kunit_filter_suites+0x3e4/0xa50
>>     [<00000000f452f130>] filter_suites_test_glob_test+0x1b7/0x660
>>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>> unreferenced object 0xff11000103f3a800 (size 96):
>>   comm "kunit_try_catch", pid 98, jiffies 4294671798 (age 763.545s)
>>   hex dump (first 32 bytes):
>>     f0 e1 5a 88 ff ff ff ff 40 39 bb 8a ff ff ff ff  ..Z.....@9......
>>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>>   backtrace:
>>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>>     [<000000006afe50bd>] kunit_filter_suites+0x424/0xa50
>>     [<00000000f452f130>] filter_suites_test_glob_test+0x1b7/0x660
>>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>> unreferenced object 0xff11000101a72ac0 (size 16):
>>   comm "kunit_try_catch", pid 104, jiffies 4294671814 (age 763.529s)
>>   hex dump (first 16 bytes):
>>     00 00 00 00 00 00 00 00 e0 2a a7 01 01 00 11 ff  .........*......
>>   backtrace:
>>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>>     [<00000000c7b724e7>] kunit_filter_suites+0x108/0xa50
>>     [<00000000bad5427d>] filter_attr_test+0x1e9/0x6a0
>>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>> unreferenced object 0xff11000103caf880 (size 32):
>>   comm "kunit_try_catch", pid 104, jiffies 4294671814 (age 763.547s)
>>   hex dump (first 32 bytes):
>>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>>   backtrace:
>>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>>     [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
>>     [<00000000bad5427d>] filter_attr_test+0x1e9/0x6a0
>>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>> unreferenced object 0xff11000101a72ae0 (size 16):
>>   comm "kunit_try_catch", pid 106, jiffies 4294671823 (age 763.538s)
>>   hex dump (first 16 bytes):
>>     00 00 00 00 00 00 00 00 00 2b a7 01 01 00 11 ff  .........+......
>>   backtrace:
>>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>>     [<00000000c7b724e7>] kunit_filter_suites+0x108/0xa50
>>     [<0000000096255c51>] filter_attr_empty_test+0x1b0/0x310
>>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>> unreferenced object 0xff11000103caf9c0 (size 32):
>>   comm "kunit_try_catch", pid 106, jiffies 4294671823 (age 763.538s)
>>   hex dump (first 32 bytes):
>>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>>   backtrace:
>>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>>     [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
>>     [<0000000096255c51>] filter_attr_empty_test+0x1b0/0x310
>>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>> unreferenced object 0xff11000101a72b00 (size 16):
>>   comm "kunit_try_catch", pid 108, jiffies 4294671832 (age 763.529s)
>>   hex dump (first 16 bytes):
>>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>>   backtrace:
>>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>>     [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
>>     [<00000000881258cc>] filter_attr_skip_test+0x148/0x770
>>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>>
>> Fixes: 5d31f71efcb6 ("kunit: add kunit.filter_glob cmdline option to filter suites")
>> Fixes: 529534e8cba3 ("kunit: Add ability to filter attributes")
>> Signed-off-by: Ruan Jinjie <ruanjinjie@huawei.com>
> 
> Hello!
> 
> I have tested this and this all looks good to me. Sorry for the delay
> in responding to the patches addressing the bugs in filtering. I have
> been out of the office for a few days. Thanks for addressing this!

I find when open kmemleak and some kunit test config, the above memory
leak info always occur.

> 
> Reviewed-by: Rae Moar <rmoar@google.com>
> 
> -Rae
> 
>> ---
>>  lib/kunit/executor.c | 17 ++++++++++++-----
>>  1 file changed, 12 insertions(+), 5 deletions(-)
>>
>> diff --git a/lib/kunit/executor.c b/lib/kunit/executor.c
>> index 5b5bed1efb93..481901d245d0 100644
>> --- a/lib/kunit/executor.c
>> +++ b/lib/kunit/executor.c
>> @@ -151,7 +151,7 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>>                 for (j = 0; j < filter_count; j++)
>>                         parsed_filters[j] = kunit_next_attr_filter(&filters, err);
>>                 if (*err)
>> -                       return filtered;
>> +                       goto err;
>>         }
>>
>>         for (i = 0; &suite_set->start[i] != suite_set->end; i++) {
>> @@ -163,7 +163,7 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>>                                         parsed_glob.test_glob);
>>                         if (IS_ERR(filtered_suite)) {
>>                                 *err = PTR_ERR(filtered_suite);
>> -                               return filtered;
>> +                               goto err;
>>                         }
>>                 }
>>                 if (filter_count) {
>> @@ -172,15 +172,18 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>>                                                 parsed_filters[k], filter_action, err);
>>
>>                                 /* Free previous copy of suite */
>> -                               if (k > 0 || filter_glob)
>> +                               if (k > 0 || filter_glob) {
>> +                                       kfree(filtered_suite->test_cases);
>>                                         kfree(filtered_suite);
>> +                               }
>> +
>>                                 filtered_suite = new_filtered_suite;
>>
>>                                 if (*err)
>> -                                       return filtered;
>> +                                       goto err;
>>                                 if (IS_ERR(filtered_suite)) {
>>                                         *err = PTR_ERR(filtered_suite);
>> -                                       return filtered;
>> +                                       goto err;
>>                                 }
>>                                 if (!filtered_suite)
>>                                         break;
>> @@ -194,6 +197,10 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>>         }
>>         filtered.end = copy;
>>
>> +err:
>> +       if (*err)
>> +               kfree(copy);
>> +
>>         if (filter_glob) {
>>                 kfree(parsed_glob.suite_glob);
>>                 kfree(parsed_glob.test_glob);
>> --
>> 2.34.1
>>
>> --
>> You received this message because you are subscribed to the Google Groups "KUnit Development" group.
>> To unsubscribe from this group and stop receiving emails from it, send an email to kunit-dev+unsubscribe@googlegroups.com.
>> To view this discussion on the web visit https://groups.google.com/d/msgid/kunit-dev/20230801073700.3740895-1-ruanjinjie%40huawei.com.
David Gow Aug. 3, 2023, 10:44 p.m. UTC | #3
On Tue, 1 Aug 2023 at 15:37, 'Ruan Jinjie' via KUnit Development
<kunit-dev@googlegroups.com> wrote:
>
> Inject fault while probing drm_kunit_helpers.ko, if one of
> kunit_next_attr_filter(), kunit_filter_glob_tests() and
> kunit_filter_attr_tests() fails, parsed_filters,
> parsed_glob.suite_glob/test_glob alloced in
> kunit_parse_glob_filter() is leaked.
> And the filtered_suite->test_cases alloced in kunit_filter_glob_tests()
> or kunit_filter_attr_tests() may also be leaked.
>
> unreferenced object 0xff110001067e4800 (size 1024):
>   comm "kunit_try_catch", pid 96, jiffies 4294671796 (age 763.547s)
>   hex dump (first 32 bytes):
>     73 75 69 74 65 32 00 00 00 00 00 00 00 00 00 00  suite2..........
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<00000000116e8eba>] __kmalloc_node_track_caller+0x4e/0x140
>     [<00000000e2f9cce9>] kmemdup+0x2c/0x60
>     [<000000002a36710b>] kunit_filter_suites+0x3e4/0xa50
>     [<0000000045779fb9>] filter_suites_test+0x1b7/0x440
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000105d79b00 (size 192):
>   comm "kunit_try_catch", pid 96, jiffies 4294671796 (age 763.547s)
>   hex dump (first 32 bytes):
>     f0 e1 5a 88 ff ff ff ff 60 59 bb 8a ff ff ff ff  ..Z.....`Y......
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<000000006afe50bd>] kunit_filter_suites+0x424/0xa50
>     [<0000000045779fb9>] filter_suites_test+0x1b7/0x440
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff110001067e6000 (size 1024):
>   comm "kunit_try_catch", pid 98, jiffies 4294671798 (age 763.545s)
>   hex dump (first 32 bytes):
>     73 75 69 74 65 32 00 00 00 00 00 00 00 00 00 00  suite2..........
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<00000000116e8eba>] __kmalloc_node_track_caller+0x4e/0x140
>     [<00000000e2f9cce9>] kmemdup+0x2c/0x60
>     [<000000002a36710b>] kunit_filter_suites+0x3e4/0xa50
>     [<00000000f452f130>] filter_suites_test_glob_test+0x1b7/0x660
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000103f3a800 (size 96):
>   comm "kunit_try_catch", pid 98, jiffies 4294671798 (age 763.545s)
>   hex dump (first 32 bytes):
>     f0 e1 5a 88 ff ff ff ff 40 39 bb 8a ff ff ff ff  ..Z.....@9......
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<000000006afe50bd>] kunit_filter_suites+0x424/0xa50
>     [<00000000f452f130>] filter_suites_test_glob_test+0x1b7/0x660
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000101a72ac0 (size 16):
>   comm "kunit_try_catch", pid 104, jiffies 4294671814 (age 763.529s)
>   hex dump (first 16 bytes):
>     00 00 00 00 00 00 00 00 e0 2a a7 01 01 00 11 ff  .........*......
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<00000000c7b724e7>] kunit_filter_suites+0x108/0xa50
>     [<00000000bad5427d>] filter_attr_test+0x1e9/0x6a0
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000103caf880 (size 32):
>   comm "kunit_try_catch", pid 104, jiffies 4294671814 (age 763.547s)
>   hex dump (first 32 bytes):
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
>     [<00000000bad5427d>] filter_attr_test+0x1e9/0x6a0
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000101a72ae0 (size 16):
>   comm "kunit_try_catch", pid 106, jiffies 4294671823 (age 763.538s)
>   hex dump (first 16 bytes):
>     00 00 00 00 00 00 00 00 00 2b a7 01 01 00 11 ff  .........+......
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<00000000c7b724e7>] kunit_filter_suites+0x108/0xa50
>     [<0000000096255c51>] filter_attr_empty_test+0x1b0/0x310
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000103caf9c0 (size 32):
>   comm "kunit_try_catch", pid 106, jiffies 4294671823 (age 763.538s)
>   hex dump (first 32 bytes):
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
>     [<0000000096255c51>] filter_attr_empty_test+0x1b0/0x310
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
> unreferenced object 0xff11000101a72b00 (size 16):
>   comm "kunit_try_catch", pid 108, jiffies 4294671832 (age 763.529s)
>   hex dump (first 16 bytes):
>     00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
>   backtrace:
>     [<000000000d6e4891>] __kmalloc+0x4d/0x140
>     [<00000000c47b0f75>] kunit_filter_suites+0x189/0xa50
>     [<00000000881258cc>] filter_attr_skip_test+0x148/0x770
>     [<00000000cd1104a7>] kunit_try_run_case+0x119/0x270
>     [<00000000c654c917>] kunit_generic_run_threadfn_adapter+0x4e/0xa0
>     [<00000000d195ac13>] kthread+0x2c7/0x3c0
>     [<00000000b79c1ee9>] ret_from_fork+0x2c/0x70
>     [<000000001167f7e6>] ret_from_fork_asm+0x1b/0x30
>
> Fixes: 5d31f71efcb6 ("kunit: add kunit.filter_glob cmdline option to filter suites")
> Fixes: 529534e8cba3 ("kunit: Add ability to filter attributes")
> Signed-off-by: Ruan Jinjie <ruanjinjie@huawei.com>
> ---

Looks good to me. Thanks!

Reviewed-by: David Gow <davidgow@google.com>

Cheers,
-- David

>  lib/kunit/executor.c | 17 ++++++++++++-----
>  1 file changed, 12 insertions(+), 5 deletions(-)
>
> diff --git a/lib/kunit/executor.c b/lib/kunit/executor.c
> index 5b5bed1efb93..481901d245d0 100644
> --- a/lib/kunit/executor.c
> +++ b/lib/kunit/executor.c
> @@ -151,7 +151,7 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>                 for (j = 0; j < filter_count; j++)
>                         parsed_filters[j] = kunit_next_attr_filter(&filters, err);
>                 if (*err)
> -                       return filtered;
> +                       goto err;
>         }
>
>         for (i = 0; &suite_set->start[i] != suite_set->end; i++) {
> @@ -163,7 +163,7 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>                                         parsed_glob.test_glob);
>                         if (IS_ERR(filtered_suite)) {
>                                 *err = PTR_ERR(filtered_suite);
> -                               return filtered;
> +                               goto err;
>                         }
>                 }
>                 if (filter_count) {
> @@ -172,15 +172,18 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>                                                 parsed_filters[k], filter_action, err);
>
>                                 /* Free previous copy of suite */
> -                               if (k > 0 || filter_glob)
> +                               if (k > 0 || filter_glob) {
> +                                       kfree(filtered_suite->test_cases);
>                                         kfree(filtered_suite);
> +                               }
> +
>                                 filtered_suite = new_filtered_suite;
>
>                                 if (*err)
> -                                       return filtered;
> +                                       goto err;
>                                 if (IS_ERR(filtered_suite)) {
>                                         *err = PTR_ERR(filtered_suite);
> -                                       return filtered;
> +                                       goto err;
>                                 }
>                                 if (!filtered_suite)
>                                         break;
> @@ -194,6 +197,10 @@ static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
>         }
>         filtered.end = copy;
>
> +err:
> +       if (*err)
> +               kfree(copy);
> +
>         if (filter_glob) {
>                 kfree(parsed_glob.suite_glob);
>                 kfree(parsed_glob.test_glob);
> --
> 2.34.1
>
> --
> You received this message because you are subscribed to the Google Groups "KUnit Development" group.
> To unsubscribe from this group and stop receiving emails from it, send an email to kunit-dev+unsubscribe@googlegroups.com.
> To view this discussion on the web visit https://groups.google.com/d/msgid/kunit-dev/20230801073700.3740895-1-ruanjinjie%40huawei.com.
diff mbox series

Patch

diff --git a/lib/kunit/executor.c b/lib/kunit/executor.c
index 5b5bed1efb93..481901d245d0 100644
--- a/lib/kunit/executor.c
+++ b/lib/kunit/executor.c
@@ -151,7 +151,7 @@  static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
 		for (j = 0; j < filter_count; j++)
 			parsed_filters[j] = kunit_next_attr_filter(&filters, err);
 		if (*err)
-			return filtered;
+			goto err;
 	}
 
 	for (i = 0; &suite_set->start[i] != suite_set->end; i++) {
@@ -163,7 +163,7 @@  static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
 					parsed_glob.test_glob);
 			if (IS_ERR(filtered_suite)) {
 				*err = PTR_ERR(filtered_suite);
-				return filtered;
+				goto err;
 			}
 		}
 		if (filter_count) {
@@ -172,15 +172,18 @@  static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
 						parsed_filters[k], filter_action, err);
 
 				/* Free previous copy of suite */
-				if (k > 0 || filter_glob)
+				if (k > 0 || filter_glob) {
+					kfree(filtered_suite->test_cases);
 					kfree(filtered_suite);
+				}
+
 				filtered_suite = new_filtered_suite;
 
 				if (*err)
-					return filtered;
+					goto err;
 				if (IS_ERR(filtered_suite)) {
 					*err = PTR_ERR(filtered_suite);
-					return filtered;
+					goto err;
 				}
 				if (!filtered_suite)
 					break;
@@ -194,6 +197,10 @@  static struct suite_set kunit_filter_suites(const struct suite_set *suite_set,
 	}
 	filtered.end = copy;
 
+err:
+	if (*err)
+		kfree(copy);
+
 	if (filter_glob) {
 		kfree(parsed_glob.suite_glob);
 		kfree(parsed_glob.test_glob);