aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/kernel/bpf/devmap.c
diff options
context:
space:
mode:
authorbrakmo <brakmo@fb.com>2019-05-28 16:59:36 -0700
committerAlexei Starovoitov <ast@kernel.org>2019-05-31 16:41:29 -0700
commit5cf1e91456301f8c4f6bbc63ff76cff12f92f31b (patch)
treebb669628f303c2d9e20a218c8dbed541d40504ea /kernel/bpf/devmap.c
parentbpf: Create BPF_PROG_CGROUP_INET_EGRESS_RUN_ARRAY (diff)
downloadwireguard-linux-5cf1e91456301f8c4f6bbc63ff76cff12f92f31b.tar.xz
wireguard-linux-5cf1e91456301f8c4f6bbc63ff76cff12f92f31b.zip
bpf: cgroup inet skb programs can return 0 to 3
Allows cgroup inet skb programs to return values in the range [0, 3]. The second bit is used to deterine if congestion occurred and higher level protocol should decrease rate. E.g. TCP would call tcp_enter_cwr() The bpf_prog must set expected_attach_type to BPF_CGROUP_INET_EGRESS at load time if it uses the new return values (i.e. 2 or 3). The expected_attach_type is currently not enforced for BPF_PROG_TYPE_CGROUP_SKB. e.g Meaning the current bpf_prog with expected_attach_type setting to BPF_CGROUP_INET_EGRESS can attach to BPF_CGROUP_INET_INGRESS. Blindly enforcing expected_attach_type will break backward compatibility. This patch adds a enforce_expected_attach_type bit to only enforce the expected_attach_type when it uses the new return value. Signed-off-by: Lawrence Brakmo <brakmo@fb.com> Signed-off-by: Martin KaFai Lau <kafai@fb.com> Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Diffstat (limited to 'kernel/bpf/devmap.c')
0 files changed, 0 insertions, 0 deletions