Re: bpf_fib_lookup support for firewall mark

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



List,

For what it's worth I patched the structure locally by introducing a
new __u32 mark field
to the structure and adding the proper assignment of the field in
filter.c. Recompiled without any issues.
With that patch a bpf lookup matches ip rule that contains fwmark.

Still interested to know how much of a performance penalty adding an 4
bytes to the
structure brings. I'd certainly vote for adding at least the firewall
mark to the set of fields used in the lookup.

Cheers

On Wed, Jun 9, 2021 at 11:30 AM Rumen Telbizov
<rumen.telbizov@xxxxxxxxxxxxxxxxx> wrote:
>
> Hi David,
>
> Thanks for the quick response. I appreciate it.
> A couple of quick follow up questions:
> 1. Do you have any performance data that would indicate how much of a
> performance drop adding an extra 4 or 8 bytes to the structure would
> cause?
> 2. If I patch locally the structure in libc and the kernel by adding
> an extra _u32 mark member is there anything that such a modification
> would break?
>
> Regards,
> Rumen Telbizov
>
>
> On Tue, Jun 8, 2021 at 6:21 PM David Ahern <dsahern@xxxxxxxxx> wrote:
> >
> > On 6/8/21 4:59 PM, Rumen Telbizov wrote:
> > > Dear BPF list,
> > >
> > > I am new to eBPF so go easy on me.
> > > It seems to me that currently eBPF has no support for route table
> > > lookups including firewall marks. The bpf_fib_lookup structure itself
> > > has no mark field as per
> > > https://elixir.bootlin.com/linux/v5.10.28/source/include/uapi/linux/bpf.h#L4864
> > >
> > > Additionally bpf_fib_lookup() function does not incorporate the
> > > firewall mark in its route lookup. It explicitly sets it to 0 as per
> > > https://elixir.bootlin.com/linux/v5.10.28/source/net/core/filter.c#L5329
> > > along with other fields which are used during the regular routing
> > > policy database lookup.
> > >
> > > Thus lookups from within eBPF and outside of it result in different
> > > outcomes if there are rules directing traffic based on fwmark.
> > > Can you please advise what the rationale for this is or if there
> > > anything that I might be missing.
> > >
> > > Let me know if I can provide any further information.
> > >
> >
> > The API (struct bpf_fib_lookup) is constrained to 64B for performance.
> > It is not possible to support all of the policy routing options that
> > Linux has in 64B. Choices had to be made.



[Index of Archives]     [Linux Samsung SoC]     [Linux Rockchip SoC]     [Linux Actions SoC]     [Linux for Synopsys ARC Processors]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]


  Powered by Linux