160dd49eaSYonghong Song // SPDX-License-Identifier: GPL-2.0
260dd49eaSYonghong Song /* Copyright (c) 2020 Facebook */
360dd49eaSYonghong Song #include "bpf_iter.h"
460dd49eaSYonghong Song #include <bpf/bpf_helpers.h>
560dd49eaSYonghong Song #include <bpf/bpf_tracing.h>
660dd49eaSYonghong Song 
760dd49eaSYonghong Song char _license[] SEC("license") = "GPL";
860dd49eaSYonghong Song 
960dd49eaSYonghong Song struct key_t {
1060dd49eaSYonghong Song 	int a;
1160dd49eaSYonghong Song 	int b;
1260dd49eaSYonghong Song 	int c;
1360dd49eaSYonghong Song };
1460dd49eaSYonghong Song 
1560dd49eaSYonghong Song struct {
1660dd49eaSYonghong Song 	__uint(type, BPF_MAP_TYPE_ARRAY);
1760dd49eaSYonghong Song 	__uint(max_entries, 3);
1860dd49eaSYonghong Song 	__type(key, __u32);
1960dd49eaSYonghong Song 	__type(value, __u64);
2060dd49eaSYonghong Song } arraymap1 SEC(".maps");
2160dd49eaSYonghong Song 
22*8f4bc15bSDave Marchevsky struct {
23*8f4bc15bSDave Marchevsky 	__uint(type, BPF_MAP_TYPE_HASH);
24*8f4bc15bSDave Marchevsky 	__uint(max_entries, 10);
25*8f4bc15bSDave Marchevsky 	__type(key, __u64);
26*8f4bc15bSDave Marchevsky 	__type(value, __u32);
27*8f4bc15bSDave Marchevsky } hashmap1 SEC(".maps");
28*8f4bc15bSDave Marchevsky 
2960dd49eaSYonghong Song __u32 key_sum = 0;
3060dd49eaSYonghong Song __u64 val_sum = 0;
3160dd49eaSYonghong Song 
3260dd49eaSYonghong Song SEC("iter/bpf_map_elem")
dump_bpf_array_map(struct bpf_iter__bpf_map_elem * ctx)3360dd49eaSYonghong Song int dump_bpf_array_map(struct bpf_iter__bpf_map_elem *ctx)
3460dd49eaSYonghong Song {
35*8f4bc15bSDave Marchevsky 	__u32 *hmap_val, *key = ctx->key;
3660dd49eaSYonghong Song 	__u64 *val = ctx->value;
3760dd49eaSYonghong Song 
3860dd49eaSYonghong Song 	if (key == (void *)0 || val == (void *)0)
3960dd49eaSYonghong Song 		return 0;
4060dd49eaSYonghong Song 
4160dd49eaSYonghong Song 	bpf_seq_write(ctx->meta->seq, key, sizeof(__u32));
4260dd49eaSYonghong Song 	bpf_seq_write(ctx->meta->seq, val, sizeof(__u64));
4360dd49eaSYonghong Song 	key_sum += *key;
4460dd49eaSYonghong Song 	val_sum += *val;
45*8f4bc15bSDave Marchevsky 
46*8f4bc15bSDave Marchevsky 	/* workaround - It's necessary to do this convoluted (val, key)
47*8f4bc15bSDave Marchevsky 	 * write into hashmap1, instead of simply doing
48*8f4bc15bSDave Marchevsky 	 *   bpf_map_update_elem(&hashmap1, val, key, BPF_ANY);
49*8f4bc15bSDave Marchevsky 	 * because key has MEM_RDONLY flag and bpf_map_update elem expects
50*8f4bc15bSDave Marchevsky 	 * types without this flag
51*8f4bc15bSDave Marchevsky 	 */
52*8f4bc15bSDave Marchevsky 	bpf_map_update_elem(&hashmap1, val, val, BPF_ANY);
53*8f4bc15bSDave Marchevsky 	hmap_val = bpf_map_lookup_elem(&hashmap1, val);
54*8f4bc15bSDave Marchevsky 	if (hmap_val)
55*8f4bc15bSDave Marchevsky 		*hmap_val = *key;
56*8f4bc15bSDave Marchevsky 
5760dd49eaSYonghong Song 	*val = *key;
5860dd49eaSYonghong Song 	return 0;
5960dd49eaSYonghong Song }
60