All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCHv5 net-next 00/15] BPF hardware offload (cls_bpf for now)
@ 2016-09-16  9:36 Jakub Kicinski
  2016-09-16  9:36 ` [PATCHv5 net-next 01/15] net: cls_bpf: add hardware offload Jakub Kicinski
                   ` (14 more replies)
  0 siblings, 15 replies; 20+ messages in thread
From: Jakub Kicinski @ 2016-09-16  9:36 UTC (permalink / raw)
  To: netdev; +Cc: ast, daniel, Jakub Kicinski

Hi!

Dave, this set depends on bitfield.h which is sitting in the
pull request from Kalle.  Please pull wireless-drivers-next 
before applying.

v5:
 - fix names of guard defines in bpf_verfier.h.
v4:
 - rename parser -> analyzer;
 - reorganize the analyzer patches a bit;
 - use bitfield.h directly.

--- merge blurb:
In the last year a lot of progress have been made on offloading
simpler TC classifiers.  There is also growing interest in using
BPF for generic high-speed packet processing in the kernel.
It seems beneficial to tie those two trends together and think
about hardware offloads of BPF programs.  This patch set presents
such offload to Netronome smart NICs.  cls_bpf is extended with
hardware offload capabilities and NFP driver gets a JIT translator
which in presence of capable firmware can be used to offload
the BPF program onto the card.

BPF JIT implementation is not 100% complete (e.g. missing instructions)
but it is functional.  Encouragingly it should be possible to
offload most (if not all) advanced BPF features onto the NIC - 
including packet modification, maps, tunnel encap/decap etc.

Example of basic tests I used:
  __section_cls_entry
  int cls_entry(struct __sk_buff *skb)
  {
	if (load_byte(skb, 0) != 0x0)
		return 0;

	if (load_byte(skb, 4) != 0x1)
		return 0;

	skb->mark = 0xcafe;

	if (load_byte(skb, 50) != 0xff)
		return 0;

	return ~0U;
  }

Above code can be compiled with Clang and loaded like this:
# ethtool -K p1p1 hw-tc-offload on
# tc qdisc add dev p1p1 ingress
# tc filter add dev p1p1 parent ffff:  bpf obj prog.o action drop

This set implements the basic transparent offload, the skip_{sw,hw}
flags and reporting statistics for cls_bpf.

Jakub Kicinski (15):
  net: cls_bpf: add hardware offload
  net: cls_bpf: limit hardware offload by software-only flag
  net: cls_bpf: add support for marking filters as hardware-only
  bpf: don't (ab)use instructions to store state
  bpf: expose internal verfier structures
  bpf: enable non-core use of the verfier
  bpf: recognize 64bit immediate loads as consts
  nfp: add BPF to NFP code translator
  nfp: bpf: add hardware bpf offload
  net: cls_bpf: allow offloaded filters to update stats
  nfp: bpf: allow offloaded filters to update stats
  nfp: bpf: add packet marking support
  net: act_mirred: allow statistic updates from offloaded actions
  nfp: bpf: add support for legacy redirect action
  nfp: bpf: add offload of TC direct action mode

 drivers/net/ethernet/netronome/nfp/Makefile        |    7 +
 drivers/net/ethernet/netronome/nfp/nfp_asm.h       |  233 +++
 drivers/net/ethernet/netronome/nfp/nfp_bpf.h       |  212 +++
 drivers/net/ethernet/netronome/nfp/nfp_bpf_jit.c   | 1816 ++++++++++++++++++++
 .../net/ethernet/netronome/nfp/nfp_bpf_verifier.c  |  160 ++
 drivers/net/ethernet/netronome/nfp/nfp_net.h       |   47 +-
 .../net/ethernet/netronome/nfp/nfp_net_common.c    |  134 +-
 drivers/net/ethernet/netronome/nfp/nfp_net_ctrl.h  |   51 +-
 .../net/ethernet/netronome/nfp/nfp_net_ethtool.c   |   12 +
 .../net/ethernet/netronome/nfp/nfp_net_offload.c   |  291 ++++
 .../net/ethernet/netronome/nfp/nfp_netvf_main.c    |    2 +-
 include/linux/bpf_verifier.h                       |   89 +
 include/linux/netdevice.h                          |    2 +
 include/net/pkt_cls.h                              |   16 +
 include/uapi/linux/pkt_cls.h                       |    1 +
 kernel/bpf/verifier.c                              |  384 +++--
 net/sched/act_mirred.c                             |    8 +
 net/sched/cls_bpf.c                                |  117 +-
 18 files changed, 3376 insertions(+), 206 deletions(-)
 create mode 100644 drivers/net/ethernet/netronome/nfp/nfp_asm.h
 create mode 100644 drivers/net/ethernet/netronome/nfp/nfp_bpf.h
 create mode 100644 drivers/net/ethernet/netronome/nfp/nfp_bpf_jit.c
 create mode 100644 drivers/net/ethernet/netronome/nfp/nfp_bpf_verifier.c
 create mode 100644 drivers/net/ethernet/netronome/nfp/nfp_net_offload.c
 create mode 100644 include/linux/bpf_verifier.h

-- 
1.9.1

^ permalink raw reply	[flat|nested] 20+ messages in thread

end of thread, other threads:[~2016-09-16 22:47 UTC | newest]

Thread overview: 20+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-09-16  9:36 [PATCHv5 net-next 00/15] BPF hardware offload (cls_bpf for now) Jakub Kicinski
2016-09-16  9:36 ` [PATCHv5 net-next 01/15] net: cls_bpf: add hardware offload Jakub Kicinski
2016-09-16  9:36 ` [PATCHv5 net-next 02/15] net: cls_bpf: limit hardware offload by software-only flag Jakub Kicinski
2016-09-16  9:36 ` [PATCHv5 net-next 03/15] net: cls_bpf: add support for marking filters as hardware-only Jakub Kicinski
2016-09-16  9:36 ` [PATCHv5 net-next 04/15] bpf: don't (ab)use instructions to store state Jakub Kicinski
2016-09-16 21:22   ` Daniel Borkmann
2016-09-16  9:36 ` [PATCHv5 net-next 05/15] bpf: expose internal verfier structures Jakub Kicinski
2016-09-16 22:47   ` Daniel Borkmann
2016-09-16  9:36 ` [PATCHv5 net-next 06/15] bpf: enable non-core use of the verfier Jakub Kicinski
2016-09-16 22:31   ` Daniel Borkmann
2016-09-16  9:36 ` [PATCHv5 net-next 07/15] bpf: recognize 64bit immediate loads as consts Jakub Kicinski
2016-09-16 21:37   ` Daniel Borkmann
2016-09-16  9:36 ` [PATCHv5 net-next 08/15] nfp: add BPF to NFP code translator Jakub Kicinski
2016-09-16  9:36 ` [PATCHv5 net-next 09/15] nfp: bpf: add hardware bpf offload Jakub Kicinski
2016-09-16  9:36 ` [PATCHv5 net-next 10/15] net: cls_bpf: allow offloaded filters to update stats Jakub Kicinski
2016-09-16  9:36 ` [PATCHv5 net-next 11/15] nfp: bpf: " Jakub Kicinski
2016-09-16  9:36 ` [PATCHv5 net-next 12/15] nfp: bpf: add packet marking support Jakub Kicinski
2016-09-16  9:37 ` [PATCHv5 net-next 13/15] net: act_mirred: allow statistic updates from offloaded actions Jakub Kicinski
2016-09-16  9:37 ` [PATCHv5 net-next 14/15] nfp: bpf: add support for legacy redirect action Jakub Kicinski
2016-09-16  9:37 ` [PATCHv5 net-next 15/15] nfp: bpf: add offload of TC direct action mode Jakub Kicinski

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.