Commit 6e73e683 authored by Andrii Nakryiko's avatar Andrii Nakryiko

Merge branch 'Fix bugs found by ASAN when running selftests'

Xu Kuohai says:

====================

From: Xu Kuohai <xukuohai@huawei.com>

This series fixes bugs found by ASAN when running bpf selftests on arm64.

v4:
- Address Andrii's suggestions

v3: https://lore.kernel.org/bpf/5311e154-c2d4-91a5-ccb8-f5adede579ed@huawei.com
- Fix error failure of case test_xdp_adjust_tail_grow exposed by this series

v2: https://lore.kernel.org/bpf/20221010070454.577433-1-xukuohai@huaweicloud.com
- Rebase and fix conflict

v1: https://lore.kernel.org/bpf/20221009131830.395569-1-xukuohai@huaweicloud.com
====================
Signed-off-by: default avatarAndrii Nakryiko <andrii@kernel.org>
parents de9c8d84 cbc1c998
...@@ -219,6 +219,17 @@ static int btf_dump_resize(struct btf_dump *d) ...@@ -219,6 +219,17 @@ static int btf_dump_resize(struct btf_dump *d)
return 0; return 0;
} }
static void btf_dump_free_names(struct hashmap *map)
{
size_t bkt;
struct hashmap_entry *cur;
hashmap__for_each_entry(map, cur, bkt)
free((void *)cur->key);
hashmap__free(map);
}
void btf_dump__free(struct btf_dump *d) void btf_dump__free(struct btf_dump *d)
{ {
int i; int i;
...@@ -237,8 +248,8 @@ void btf_dump__free(struct btf_dump *d) ...@@ -237,8 +248,8 @@ void btf_dump__free(struct btf_dump *d)
free(d->cached_names); free(d->cached_names);
free(d->emit_queue); free(d->emit_queue);
free(d->decl_stack); free(d->decl_stack);
hashmap__free(d->type_names); btf_dump_free_names(d->type_names);
hashmap__free(d->ident_names); btf_dump_free_names(d->ident_names);
free(d); free(d);
} }
...@@ -1524,11 +1535,23 @@ static void btf_dump_emit_type_cast(struct btf_dump *d, __u32 id, ...@@ -1524,11 +1535,23 @@ static void btf_dump_emit_type_cast(struct btf_dump *d, __u32 id,
static size_t btf_dump_name_dups(struct btf_dump *d, struct hashmap *name_map, static size_t btf_dump_name_dups(struct btf_dump *d, struct hashmap *name_map,
const char *orig_name) const char *orig_name)
{ {
char *old_name, *new_name;
size_t dup_cnt = 0; size_t dup_cnt = 0;
int err;
new_name = strdup(orig_name);
if (!new_name)
return 1;
hashmap__find(name_map, orig_name, (void **)&dup_cnt); hashmap__find(name_map, orig_name, (void **)&dup_cnt);
dup_cnt++; dup_cnt++;
hashmap__set(name_map, orig_name, (void *)dup_cnt, NULL, NULL);
err = hashmap__set(name_map, new_name, (void *)dup_cnt,
(const void **)&old_name, NULL);
if (err)
free(new_name);
free(old_name);
return dup_cnt; return dup_cnt;
} }
......
...@@ -1348,25 +1348,23 @@ static int calc_pt_regs_off(const char *reg_name) ...@@ -1348,25 +1348,23 @@ static int calc_pt_regs_off(const char *reg_name)
static int parse_usdt_arg(const char *arg_str, int arg_num, struct usdt_arg_spec *arg) static int parse_usdt_arg(const char *arg_str, int arg_num, struct usdt_arg_spec *arg)
{ {
char *reg_name = NULL; char reg_name[16];
int arg_sz, len, reg_off; int arg_sz, len, reg_off;
long off; long off;
if (sscanf(arg_str, " %d @ \[ %m[a-z0-9], %ld ] %n", &arg_sz, &reg_name, &off, &len) == 3) { if (sscanf(arg_str, " %d @ \[ %15[a-z0-9], %ld ] %n", &arg_sz, reg_name, &off, &len) == 3) {
/* Memory dereference case, e.g., -4@[sp, 96] */ /* Memory dereference case, e.g., -4@[sp, 96] */
arg->arg_type = USDT_ARG_REG_DEREF; arg->arg_type = USDT_ARG_REG_DEREF;
arg->val_off = off; arg->val_off = off;
reg_off = calc_pt_regs_off(reg_name); reg_off = calc_pt_regs_off(reg_name);
free(reg_name);
if (reg_off < 0) if (reg_off < 0)
return reg_off; return reg_off;
arg->reg_off = reg_off; arg->reg_off = reg_off;
} else if (sscanf(arg_str, " %d @ \[ %m[a-z0-9] ] %n", &arg_sz, &reg_name, &len) == 2) { } else if (sscanf(arg_str, " %d @ \[ %15[a-z0-9] ] %n", &arg_sz, reg_name, &len) == 2) {
/* Memory dereference case, e.g., -4@[sp] */ /* Memory dereference case, e.g., -4@[sp] */
arg->arg_type = USDT_ARG_REG_DEREF; arg->arg_type = USDT_ARG_REG_DEREF;
arg->val_off = 0; arg->val_off = 0;
reg_off = calc_pt_regs_off(reg_name); reg_off = calc_pt_regs_off(reg_name);
free(reg_name);
if (reg_off < 0) if (reg_off < 0)
return reg_off; return reg_off;
arg->reg_off = reg_off; arg->reg_off = reg_off;
...@@ -1375,12 +1373,11 @@ static int parse_usdt_arg(const char *arg_str, int arg_num, struct usdt_arg_spec ...@@ -1375,12 +1373,11 @@ static int parse_usdt_arg(const char *arg_str, int arg_num, struct usdt_arg_spec
arg->arg_type = USDT_ARG_CONST; arg->arg_type = USDT_ARG_CONST;
arg->val_off = off; arg->val_off = off;
arg->reg_off = 0; arg->reg_off = 0;
} else if (sscanf(arg_str, " %d @ %m[a-z0-9] %n", &arg_sz, &reg_name, &len) == 2) { } else if (sscanf(arg_str, " %d @ %15[a-z0-9] %n", &arg_sz, reg_name, &len) == 2) {
/* Register read case, e.g., -8@x4 */ /* Register read case, e.g., -8@x4 */
arg->arg_type = USDT_ARG_REG; arg->arg_type = USDT_ARG_REG;
arg->val_off = 0; arg->val_off = 0;
reg_off = calc_pt_regs_off(reg_name); reg_off = calc_pt_regs_off(reg_name);
free(reg_name);
if (reg_off < 0) if (reg_off < 0)
return reg_off; return reg_off;
arg->reg_off = reg_off; arg->reg_off = reg_off;
......
...@@ -325,7 +325,7 @@ static bool symbol_equal(const void *key1, const void *key2, void *ctx __maybe_u ...@@ -325,7 +325,7 @@ static bool symbol_equal(const void *key1, const void *key2, void *ctx __maybe_u
static int get_syms(char ***symsp, size_t *cntp) static int get_syms(char ***symsp, size_t *cntp)
{ {
size_t cap = 0, cnt = 0, i; size_t cap = 0, cnt = 0, i;
char *name, **syms = NULL; char *name = NULL, **syms = NULL;
struct hashmap *map; struct hashmap *map;
char buf[256]; char buf[256];
FILE *f; FILE *f;
...@@ -352,6 +352,8 @@ static int get_syms(char ***symsp, size_t *cntp) ...@@ -352,6 +352,8 @@ static int get_syms(char ***symsp, size_t *cntp)
/* skip modules */ /* skip modules */
if (strchr(buf, '[')) if (strchr(buf, '['))
continue; continue;
free(name);
if (sscanf(buf, "%ms$*[^\n]\n", &name) != 1) if (sscanf(buf, "%ms$*[^\n]\n", &name) != 1)
continue; continue;
/* /*
...@@ -369,32 +371,32 @@ static int get_syms(char ***symsp, size_t *cntp) ...@@ -369,32 +371,32 @@ static int get_syms(char ***symsp, size_t *cntp)
if (!strncmp(name, "__ftrace_invalid_address__", if (!strncmp(name, "__ftrace_invalid_address__",
sizeof("__ftrace_invalid_address__") - 1)) sizeof("__ftrace_invalid_address__") - 1))
continue; continue;
err = hashmap__add(map, name, NULL); err = hashmap__add(map, name, NULL);
if (err) { if (err == -EEXIST)
free(name); continue;
if (err == -EEXIST) if (err)
continue;
goto error; goto error;
}
err = libbpf_ensure_mem((void **) &syms, &cap, err = libbpf_ensure_mem((void **) &syms, &cap,
sizeof(*syms), cnt + 1); sizeof(*syms), cnt + 1);
if (err) { if (err)
free(name);
goto error; goto error;
}
syms[cnt] = name; syms[cnt++] = name;
cnt++; name = NULL;
} }
*symsp = syms; *symsp = syms;
*cntp = cnt; *cntp = cnt;
error: error:
free(name);
fclose(f); fclose(f);
hashmap__free(map); hashmap__free(map);
if (err) { if (err) {
for (i = 0; i < cnt; i++) for (i = 0; i < cnt; i++)
free(syms[cnt]); free(syms[i]);
free(syms); free(syms);
} }
return err; return err;
......
...@@ -105,7 +105,7 @@ static void test_map_kptr_success(bool test_run) ...@@ -105,7 +105,7 @@ static void test_map_kptr_success(bool test_run)
ASSERT_OK(opts.retval, "test_map_kptr_ref2 retval"); ASSERT_OK(opts.retval, "test_map_kptr_ref2 retval");
if (test_run) if (test_run)
return; goto exit;
ret = bpf_map__update_elem(skel->maps.array_map, ret = bpf_map__update_elem(skel->maps.array_map,
&key, sizeof(key), buf, sizeof(buf), 0); &key, sizeof(key), buf, sizeof(buf), 0);
...@@ -132,6 +132,7 @@ static void test_map_kptr_success(bool test_run) ...@@ -132,6 +132,7 @@ static void test_map_kptr_success(bool test_run)
ret = bpf_map__delete_elem(skel->maps.lru_hash_map, &key, sizeof(key), 0); ret = bpf_map__delete_elem(skel->maps.lru_hash_map, &key, sizeof(key), 0);
ASSERT_OK(ret, "lru_hash_map delete"); ASSERT_OK(ret, "lru_hash_map delete");
exit:
map_kptr__destroy(skel); map_kptr__destroy(skel);
} }
......
...@@ -15,7 +15,7 @@ static void test_fentry(void) ...@@ -15,7 +15,7 @@ static void test_fentry(void)
err = tracing_struct__attach(skel); err = tracing_struct__attach(skel);
if (!ASSERT_OK(err, "tracing_struct__attach")) if (!ASSERT_OK(err, "tracing_struct__attach"))
return; goto destroy_skel;
ASSERT_OK(trigger_module_test_read(256), "trigger_read"); ASSERT_OK(trigger_module_test_read(256), "trigger_read");
...@@ -54,6 +54,7 @@ static void test_fentry(void) ...@@ -54,6 +54,7 @@ static void test_fentry(void)
ASSERT_EQ(skel->bss->t5_ret, 1, "t5 ret"); ASSERT_EQ(skel->bss->t5_ret, 1, "t5 ret");
tracing_struct__detach(skel); tracing_struct__detach(skel);
destroy_skel:
tracing_struct__destroy(skel); tracing_struct__destroy(skel);
} }
......
...@@ -18,7 +18,7 @@ static void test_xdp_adjust_tail_shrink(void) ...@@ -18,7 +18,7 @@ static void test_xdp_adjust_tail_shrink(void)
); );
err = bpf_prog_test_load(file, BPF_PROG_TYPE_XDP, &obj, &prog_fd); err = bpf_prog_test_load(file, BPF_PROG_TYPE_XDP, &obj, &prog_fd);
if (ASSERT_OK(err, "test_xdp_adjust_tail_shrink")) if (!ASSERT_OK(err, "test_xdp_adjust_tail_shrink"))
return; return;
err = bpf_prog_test_run_opts(prog_fd, &topts); err = bpf_prog_test_run_opts(prog_fd, &topts);
...@@ -53,7 +53,7 @@ static void test_xdp_adjust_tail_grow(void) ...@@ -53,7 +53,7 @@ static void test_xdp_adjust_tail_grow(void)
); );
err = bpf_prog_test_load(file, BPF_PROG_TYPE_XDP, &obj, &prog_fd); err = bpf_prog_test_load(file, BPF_PROG_TYPE_XDP, &obj, &prog_fd);
if (ASSERT_OK(err, "test_xdp_adjust_tail_grow")) if (!ASSERT_OK(err, "test_xdp_adjust_tail_grow"))
return; return;
err = bpf_prog_test_run_opts(prog_fd, &topts); err = bpf_prog_test_run_opts(prog_fd, &topts);
...@@ -63,6 +63,7 @@ static void test_xdp_adjust_tail_grow(void) ...@@ -63,6 +63,7 @@ static void test_xdp_adjust_tail_grow(void)
expect_sz = sizeof(pkt_v6) + 40; /* Test grow with 40 bytes */ expect_sz = sizeof(pkt_v6) + 40; /* Test grow with 40 bytes */
topts.data_in = &pkt_v6; topts.data_in = &pkt_v6;
topts.data_size_in = sizeof(pkt_v6); topts.data_size_in = sizeof(pkt_v6);
topts.data_size_out = sizeof(buf);
err = bpf_prog_test_run_opts(prog_fd, &topts); err = bpf_prog_test_run_opts(prog_fd, &topts);
ASSERT_OK(err, "ipv6"); ASSERT_OK(err, "ipv6");
ASSERT_EQ(topts.retval, XDP_TX, "ipv6 retval"); ASSERT_EQ(topts.retval, XDP_TX, "ipv6 retval");
...@@ -89,7 +90,7 @@ static void test_xdp_adjust_tail_grow2(void) ...@@ -89,7 +90,7 @@ static void test_xdp_adjust_tail_grow2(void)
); );
err = bpf_prog_test_load(file, BPF_PROG_TYPE_XDP, &obj, &prog_fd); err = bpf_prog_test_load(file, BPF_PROG_TYPE_XDP, &obj, &prog_fd);
if (ASSERT_OK(err, "test_xdp_adjust_tail_grow")) if (!ASSERT_OK(err, "test_xdp_adjust_tail_grow"))
return; return;
/* Test case-64 */ /* Test case-64 */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment