1593f6d41SFlorent Revest // SPDX-License-Identifier: GPL-2.0
2593f6d41SFlorent Revest /* Copyright (c) 2020 Google LLC. */
3593f6d41SFlorent Revest #include "bpf_iter.h"
4593f6d41SFlorent Revest #include <bpf/bpf_helpers.h>
5593f6d41SFlorent Revest #include <bpf/bpf_tracing.h>
6593f6d41SFlorent Revest 
7593f6d41SFlorent Revest char _license[] SEC("license") = "GPL";
8593f6d41SFlorent Revest 
9593f6d41SFlorent Revest struct {
10593f6d41SFlorent Revest 	__uint(type, BPF_MAP_TYPE_SK_STORAGE);
11593f6d41SFlorent Revest 	__uint(map_flags, BPF_F_NO_PREALLOC);
12593f6d41SFlorent Revest 	__type(key, int);
13593f6d41SFlorent Revest 	__type(value, int);
14593f6d41SFlorent Revest } sk_stg_map SEC(".maps");
15593f6d41SFlorent Revest 
16593f6d41SFlorent Revest SEC("iter/bpf_sk_storage_map")
delete_bpf_sk_storage_map(struct bpf_iter__bpf_sk_storage_map * ctx)17593f6d41SFlorent Revest int delete_bpf_sk_storage_map(struct bpf_iter__bpf_sk_storage_map *ctx)
18593f6d41SFlorent Revest {
19593f6d41SFlorent Revest 	if (ctx->sk)
20593f6d41SFlorent Revest 		bpf_sk_storage_delete(&sk_stg_map, ctx->sk);
21593f6d41SFlorent Revest 
22593f6d41SFlorent Revest 	return 0;
23593f6d41SFlorent Revest }
24bd9b327eSFlorent Revest 
25bd9b327eSFlorent Revest SEC("iter/task_file")
fill_socket_owner(struct bpf_iter__task_file * ctx)26bd9b327eSFlorent Revest int fill_socket_owner(struct bpf_iter__task_file *ctx)
27bd9b327eSFlorent Revest {
28bd9b327eSFlorent Revest 	struct task_struct *task = ctx->task;
29bd9b327eSFlorent Revest 	struct file *file = ctx->file;
30bd9b327eSFlorent Revest 	struct socket *sock;
31bd9b327eSFlorent Revest 	int *sock_tgid;
32bd9b327eSFlorent Revest 
33bd9b327eSFlorent Revest 	if (!task || !file)
34bd9b327eSFlorent Revest 		return 0;
35bd9b327eSFlorent Revest 
36bd9b327eSFlorent Revest 	sock = bpf_sock_from_file(file);
37bd9b327eSFlorent Revest 	if (!sock)
38bd9b327eSFlorent Revest 		return 0;
39bd9b327eSFlorent Revest 
40bd9b327eSFlorent Revest 	sock_tgid = bpf_sk_storage_get(&sk_stg_map, sock->sk, 0, 0);
41bd9b327eSFlorent Revest 	if (!sock_tgid)
42bd9b327eSFlorent Revest 		return 0;
43bd9b327eSFlorent Revest 
44bd9b327eSFlorent Revest 	*sock_tgid = task->tgid;
45bd9b327eSFlorent Revest 
46bd9b327eSFlorent Revest 	return 0;
47bd9b327eSFlorent Revest }
48*34da8721SFlorent Revest 
49*34da8721SFlorent Revest SEC("iter/tcp")
negate_socket_local_storage(struct bpf_iter__tcp * ctx)50*34da8721SFlorent Revest int negate_socket_local_storage(struct bpf_iter__tcp *ctx)
51*34da8721SFlorent Revest {
52*34da8721SFlorent Revest 	struct sock_common *sk_common = ctx->sk_common;
53*34da8721SFlorent Revest 	int *sock_tgid;
54*34da8721SFlorent Revest 
55*34da8721SFlorent Revest 	if (!sk_common)
56*34da8721SFlorent Revest 		return 0;
57*34da8721SFlorent Revest 
58*34da8721SFlorent Revest 	sock_tgid = bpf_sk_storage_get(&sk_stg_map, sk_common, 0, 0);
59*34da8721SFlorent Revest 	if (!sock_tgid)
60*34da8721SFlorent Revest 		return 0;
61*34da8721SFlorent Revest 
62*34da8721SFlorent Revest 	*sock_tgid = -*sock_tgid;
63*34da8721SFlorent Revest 
64*34da8721SFlorent Revest 	return 0;
65*34da8721SFlorent Revest }
66