summaryrefslogtreecommitdiffstats
path: root/include/net
diff options
context:
space:
mode:
authorLawrence Brakmo <brakmo@fb.com>2018-01-26 01:14:08 +0100
committerAlexei Starovoitov <ast@kernel.org>2018-01-26 01:41:14 +0100
commitb73042b8a28e2603ac178295ab96c876ba5a97a1 (patch)
treec3db00b9c7a9b9816bb3392f9fa59f7d8b4a5e49 /include/net
parentbpf: Make SOCK_OPS_GET_TCP struct independent (diff)
downloadlinux-b73042b8a28e2603ac178295ab96c876ba5a97a1.tar.xz
linux-b73042b8a28e2603ac178295ab96c876ba5a97a1.zip
bpf: Add write access to tcp_sock and sock fields
This patch adds a macro, SOCK_OPS_SET_FIELD, for writing to struct tcp_sock or struct sock fields. This required adding a new field "temp" to struct bpf_sock_ops_kern for temporary storage that is used by sock_ops_convert_ctx_access. It is used to store and recover the contents of a register, so the register can be used to store the address of the sk. Since we cannot overwrite the dst_reg because it contains the pointer to ctx, nor the src_reg since it contains the value we want to store, we need an extra register to contain the address of the sk. Also adds the macro SOCK_OPS_GET_OR_SET_FIELD that calls one of the GET or SET macros depending on the value of the TYPE field. Signed-off-by: Lawrence Brakmo <brakmo@fb.com> Acked-by: Alexei Starovoitov <ast@kernel.org> Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Diffstat (limited to 'include/net')
-rw-r--r--include/net/tcp.h2
1 files changed, 1 insertions, 1 deletions
diff --git a/include/net/tcp.h b/include/net/tcp.h
index 5a1d26a18599..6092eaff61cf 100644
--- a/include/net/tcp.h
+++ b/include/net/tcp.h
@@ -2011,7 +2011,7 @@ static inline int tcp_call_bpf(struct sock *sk, int op)
struct bpf_sock_ops_kern sock_ops;
int ret;
- memset(&sock_ops, 0, sizeof(sock_ops));
+ memset(&sock_ops, 0, offsetof(struct bpf_sock_ops_kern, temp));
if (sk_fullsock(sk)) {
sock_ops.is_fullsock = 1;
sock_owned_by_me(sk);