据wikipedia,高性能的包过滤最早是在bsd上作为一个问题被解决,被称为bpf,在内核实现了一个解释器,进行包匹配,用户态提供一个字符设备, linux作为后来者,支持与bsd基本相同的packet...filter,称为lpf,不同的是,linux是通过在一个raw socket来支持包过滤的,通过setsockopt来SO_ATTACH_FILTER,挂载过滤器. strace 可知,libpcap...实际上进行了如下syscall:
1
2 socket(PF_PACKET, SOCK_RAW, 768) = 59
setsockopt(59, SOL_SOCKET, SO_ATTACH_FILTER