Re: [PATCH v3 06/22] perf test: Use pointer for maps

From: Arnaldo Carvalho de Melo
Date: Fri Feb 11 2022 - 12:24:56 EST


Em Fri, Feb 11, 2022 at 02:33:59AM -0800, Ian Rogers escreveu:
> struct maps is reference counted, using a pointer is more idiomatic.
>
> Signed-off-by: Ian Rogers <irogers@xxxxxxxxxx>
> ---
> tools/perf/tests/maps.c | 20 ++++++++++----------
> 1 file changed, 10 insertions(+), 10 deletions(-)
>
> diff --git a/tools/perf/tests/maps.c b/tools/perf/tests/maps.c
> index e308a3296cef..6f53f17f788e 100644
> --- a/tools/perf/tests/maps.c
> +++ b/tools/perf/tests/maps.c
> @@ -35,7 +35,7 @@ static int check_maps(struct map_def *merged, unsigned int size, struct maps *ma
>
> static int test__maps__merge_in(struct test_suite *t __maybe_unused, int subtest __maybe_unused)
> {
> - struct maps maps;
> + struct maps *maps;
> unsigned int i;
> struct map_def bpf_progs[] = {
> { "bpf_prog_1", 200, 300 },
> @@ -64,7 +64,7 @@ static int test__maps__merge_in(struct test_suite *t __maybe_unused, int subtest
> struct map *map_kcore1, *map_kcore2, *map_kcore3;
> int ret;
>
> - maps__init(&maps, NULL);
> + maps = maps__new(NULL);


Any __news() method can fail, so we should check for that and bail out.

> for (i = 0; i < ARRAY_SIZE(bpf_progs); i++) {
> struct map *map;
> @@ -74,7 +74,7 @@ static int test__maps__merge_in(struct test_suite *t __maybe_unused, int subtest
>
> map->start = bpf_progs[i].start;
> map->end = bpf_progs[i].end;
> - maps__insert(&maps, map);
> + maps__insert(maps, map);
> map__put(map);
> }
>
> @@ -99,25 +99,25 @@ static int test__maps__merge_in(struct test_suite *t __maybe_unused, int subtest
> map_kcore3->start = 880;
> map_kcore3->end = 1100;
>
> - ret = maps__merge_in(&maps, map_kcore1);
> + ret = maps__merge_in(maps, map_kcore1);
> TEST_ASSERT_VAL("failed to merge map", !ret);
>
> - ret = check_maps(merged12, ARRAY_SIZE(merged12), &maps);
> + ret = check_maps(merged12, ARRAY_SIZE(merged12), maps);
> TEST_ASSERT_VAL("merge check failed", !ret);
>
> - ret = maps__merge_in(&maps, map_kcore2);
> + ret = maps__merge_in(maps, map_kcore2);
> TEST_ASSERT_VAL("failed to merge map", !ret);
>
> - ret = check_maps(merged12, ARRAY_SIZE(merged12), &maps);
> + ret = check_maps(merged12, ARRAY_SIZE(merged12), maps);
> TEST_ASSERT_VAL("merge check failed", !ret);
>
> - ret = maps__merge_in(&maps, map_kcore3);
> + ret = maps__merge_in(maps, map_kcore3);
> TEST_ASSERT_VAL("failed to merge map", !ret);
>
> - ret = check_maps(merged3, ARRAY_SIZE(merged3), &maps);
> + ret = check_maps(merged3, ARRAY_SIZE(merged3), maps);
> TEST_ASSERT_VAL("merge check failed", !ret);
>
> - maps__exit(&maps);
> + maps__delete(maps);
> return TEST_OK;
> }
>
> --
> 2.35.1.265.g69c8d7142f-goog

--

- Arnaldo