iovisor/bcc

helper for memmem()

Open

#471 opened on Mar 31, 2016

View on GitHub
 (6 comments) (0 reactions) (0 assignees)C (22,409 stars) (4,051 forks)batch import
enhancementhelp wantedprio:medium

Description

Protocol such as DNS or IPv6 are hard to filter with cBPF because important parts are relative to floating offset, since BPF disallows loops and has relatively narrow registers, we have to unroll them and scan message with a lot of branches, burning the instruction limit.

Proposal

Provide kernel helper such as memmem(off_from, off_to, pattern) where offsets (R0, R1) are relative to packet payload, and pattern (R2) is a b/h/w/dw, and returned value would be offset in packet where the match occured or packet length (no occurence).

Contributor guide

helper for memmem() · iovisor/bcc#471 | Good First Issue