I don't see an obvious use case, but sure. We'll just need to lookMore importantly, should this program just return a boolean pass orGood point, so consider it was used by sk_filter too, we need to fix it
drop. Taking a length and trimming may introduce bugs later on if the
stack parses the packet unconditionally, expecting a minimum size
to be present.
This was the reason for introducing sk_filter_trim_cap and using that
in other sk_filter sites.
A quick scan shows that tun_put_user expects a full vlan tag to exist
if skb_vlan_tag_present(skb), for instance. If trimmed to below this
length the final call to skb_copy_datagram_iter may have negative
length.
This is an issue with the existing sk_filter call as much as with the
new run_ebpf_filter call.
anyway. Actually, I've considered the boolean return value but finally I
decide to obey the style of sk filter. Maybe the trimming has real user. e.g
high speed header recoding/analysis? Consider it's not hard to fix, how
about just keep that?
at what the minimum trim length needs to be.