staticvoid htab_mem_validate(void)
{ if (!strcmp(use_cases[2].name, args.use_case) && env.producer_cnt % 2) {
fprintf(stderr, "%s needs an even number of producers\n", args.use_case); exit(1);
}
}
staticint htab_mem_bench_init_barriers(void)
{
pthread_barrier_t *barriers; unsignedint i, nr;
if (!ctx.uc->need_sync) return 0;
nr = (env.producer_cnt + 1) / 2;
barriers = calloc(nr, sizeof(*barriers)); if (!barriers) return -1;
/* Used for synchronization between two threads */ for (i = 0; i < nr; i++)
pthread_barrier_init(&barriers[i], NULL, 2);
ctx.notify = barriers; return 0;
}
staticvoid htab_mem_bench_exit_barriers(void)
{ unsignedint i, nr;
if (!ctx.notify) return;
nr = (env.producer_cnt + 1) / 2; for (i = 0; i < nr; i++)
pthread_barrier_destroy(&ctx.notify[i]);
free(ctx.notify);
}
for (i = 0; i < ARRAY_SIZE(use_cases); i++) { if (!strcmp(name, use_cases[i].name)) return &use_cases[i];
}
fprintf(stderr, "no such use-case: %s\n", name);
fprintf(stderr, "available use case:"); for (i = 0; i < ARRAY_SIZE(use_cases); i++)
fprintf(stderr, " %s", use_cases[i].name);
fprintf(stderr, "\n"); exit(1);
}
staticvoid htab_mem_setup(void)
{ struct bpf_map *map; constchar **names; int err;
setup_libbpf();
ctx.uc = htab_mem_find_use_case_or_exit(args.use_case);
err = htab_mem_bench_init_barriers(); if (err) {
fprintf(stderr, "failed to init barrier\n"); exit(1);
}
ctx.fd = cgroup_setup_and_join("/htab_mem"); if (ctx.fd < 0) goto cleanup;
ctx.skel = htab_mem_bench__open(); if (!ctx.skel) {
fprintf(stderr, "failed to open skeleton\n"); goto cleanup;
}
map = ctx.skel->maps.htab;
bpf_map__set_value_size(map, args.value_size); /* Ensure that different CPUs can operate on different subset */
bpf_map__set_max_entries(map, MAX(8192, 64 * env.nr_cpus)); if (args.preallocated)
bpf_map__set_map_flags(map, bpf_map__map_flags(map) & ~BPF_F_NO_PREALLOC);
names = ctx.uc->progs; while (*names) { struct bpf_program *prog;
prog = bpf_object__find_program_by_name(ctx.skel->obj, *names); if (!prog) {
fprintf(stderr, "no such program %s\n", *names); goto cleanup;
}
bpf_program__set_autoload(prog, true);
names++;
}
ctx.skel->bss->nr_thread = env.producer_cnt;
err = htab_mem_bench__load(ctx.skel); if (err) {
fprintf(stderr, "failed to load skeleton\n"); goto cleanup;
}
err = htab_mem_bench__attach(ctx.skel); if (err) {
fprintf(stderr, "failed to attach skeleton\n"); goto cleanup;
} return;
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.