Commit d75e30d
bpf: Fix issue in verifying allow_ptr_leaks
After we converted the capabilities of our networking-bpf program from
cap_sys_admin to cap_net_admin+cap_bpf, our networking-bpf program
failed to start. Because it failed the bpf verifier, and the error log
is "R3 pointer comparison prohibited".
A simple reproducer as follows,
SEC("cls-ingress")
int ingress(struct __sk_buff *skb)
{
struct iphdr *iph = (void *)(long)skb->data + sizeof(struct ethhdr);
if ((long)(iph + 1) > (long)skb->data_end)
return TC_ACT_STOLEN;
return TC_ACT_OK;
}
Per discussion with Yonghong and Alexei [1], comparison of two packet
pointers is not a pointer leak. This patch fixes it.
Our local kernel is 6.1.y and we expect this fix to be backported to
6.1.y, so stable is CCed.
[1]. https://lore.kernel.org/bpf/CAADnVQ+Nmspr7Si+pxWn8zkE7hX-7s93ugwC+94aXSy4uQ9vBg@mail.gmail.com/
Suggested-by: Yonghong Song <yonghong.song@linux.dev>
Suggested-by: Alexei Starovoitov <alexei.starovoitov@gmail.com>
Signed-off-by: Yafang Shao <laoar.shao@gmail.com>
Acked-by: Eduard Zingerman <eddyz87@gmail.com>
Cc: stable@vger.kernel.org
Link: https://lore.kernel.org/r/20230823020703.3790-2-laoar.shao@gmail.com
Signed-off-by: Alexei Starovoitov <ast@kernel.org>1 parent 29d67fd commit d75e30d
1 file changed
Lines changed: 9 additions & 8 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
14041 | 14041 | | |
14042 | 14042 | | |
14043 | 14043 | | |
| 14044 | + | |
| 14045 | + | |
| 14046 | + | |
| 14047 | + | |
| 14048 | + | |
| 14049 | + | |
14044 | 14050 | | |
14045 | 14051 | | |
14046 | 14052 | | |
| |||
14052 | 14058 | | |
14053 | 14059 | | |
14054 | 14060 | | |
14055 | | - | |
| 14061 | + | |
| 14062 | + | |
| 14063 | + | |
14056 | 14064 | | |
14057 | 14065 | | |
14058 | 14066 | | |
14059 | 14067 | | |
14060 | | - | |
14061 | 14068 | | |
14062 | 14069 | | |
14063 | 14070 | | |
14064 | 14071 | | |
14065 | 14072 | | |
14066 | 14073 | | |
14067 | 14074 | | |
14068 | | - | |
14069 | | - | |
14070 | | - | |
14071 | | - | |
14072 | | - | |
14073 | | - | |
14074 | 14075 | | |
14075 | 14076 | | |
14076 | 14077 | | |
| |||
0 commit comments