> On Sep 4, 2019, at 11:43 AM, Alexei Starovoitov <a...@kernel.org> wrote:
> 
> Implement permissions as stated in uapi/linux/capability.h
> 
> Signed-off-by: Alexei Starovoitov <a...@kernel.org>
> 

[...]

> @@ -1648,11 +1648,11 @@ static int bpf_prog_load(union bpf_attr *attr, union 
> bpf_attr __user *uattr)
>       is_gpl = license_is_gpl_compatible(license);
> 
>       if (attr->insn_cnt == 0 ||
> -         attr->insn_cnt > (capable(CAP_SYS_ADMIN) ? 
> BPF_COMPLEXITY_LIMIT_INSNS : BPF_MAXINSNS))
> +         attr->insn_cnt > (capable_bpf() ? BPF_COMPLEXITY_LIMIT_INSNS : 
> BPF_MAXINSNS))
>               return -E2BIG;
>       if (type != BPF_PROG_TYPE_SOCKET_FILTER &&
>           type != BPF_PROG_TYPE_CGROUP_SKB &&
> -         !capable(CAP_SYS_ADMIN))
> +         !capable_bpf())
>               return -EPERM;

Do we allow load BPF_PROG_TYPE_SOCKET_FILTER and BPF_PROG_TYPE_CGROUP_SKB
without CAP_BPF? If so, maybe highlight in the header?

Thanks,
Song

Reply via email to