Message ID | 20180410144157.4831-1-quentin.monnet@netronome.com |
---|---|
Headers | show
Return-Path: <netdev-owner@vger.kernel.org> X-Original-To: patchwork-incoming-netdev@ozlabs.org Delivered-To: patchwork-incoming-netdev@ozlabs.org Authentication-Results: ozlabs.org; spf=none (mailfrom) smtp.mailfrom=vger.kernel.org (client-ip=209.132.180.67; helo=vger.kernel.org; envelope-from=netdev-owner@vger.kernel.org; receiver=<UNKNOWN>) Authentication-Results: ozlabs.org; dmarc=none (p=none dis=none) header.from=netronome.com Authentication-Results: ozlabs.org; dkim=pass (2048-bit key; unprotected) header.d=netronome-com.20150623.gappssmtp.com header.i=@netronome-com.20150623.gappssmtp.com header.b="h2vGPmdD"; dkim-atps=neutral Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by ozlabs.org (Postfix) with ESMTP id 40L8yl1R2Kz9rxp for <patchwork-incoming-netdev@ozlabs.org>; Wed, 11 Apr 2018 00:42:23 +1000 (AEST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754228AbeDJOmU (ORCPT <rfc822;patchwork-incoming-netdev@ozlabs.org>); Tue, 10 Apr 2018 10:42:20 -0400 Received: from mail-wm0-f53.google.com ([74.125.82.53]:34848 "EHLO mail-wm0-f53.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753778AbeDJOmR (ORCPT <rfc822;netdev@vger.kernel.org>); Tue, 10 Apr 2018 10:42:17 -0400 Received: by mail-wm0-f53.google.com with SMTP id r82so24053751wme.0 for <netdev@vger.kernel.org>; Tue, 10 Apr 2018 07:42:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=netronome-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id; bh=HmoU1gFp6oJTpnTNQ/E8ez6cVWuL5Qmu3favcc4kP6g=; b=h2vGPmdD/Udp4rJjr3/636p/rfMJqzPdGSWnJxcj8hhyIXnMbsx/SP0eQAR/q0TwQd AWPJAPOD0gEfwg9tApl5m2oU378DPDK1zTct8nV3TDpgmHBxN3K0HWxUsX1PpdpMD4B9 42+QZ1CHn0+4M/uEsFS2GA6v9FCCp5iXnpl2AvWdgKIYvo7Qf6MOVeiILQB9U0KxpS/p 5PNq5KiaKHaA0P1cBLdpdx5fZwB3/5wR3qQr6Rdr5tVYw3f2d3aZ/OJrVmJd8rfhD3pr 13Qntu24DbCoZyQnGcFmsWg3yRfzwbZgUh/LakRsWbRRUSpc+A0JLwGFWg4D8s4ggUkG XWiA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=HmoU1gFp6oJTpnTNQ/E8ez6cVWuL5Qmu3favcc4kP6g=; b=WDMgu4EsPM9dpZ8vaS4owOoh/Qb7oqMPfDl0XZ4e3hgheBr/qb8X2tgIuCRP99k4H4 Bj+qOXf2lFb99PjE/aObqcSdmMjEP38NSAAuBzRhBgpNjY7m4iywGhdw4Vl/4AfE76Ms GWcx3P6KMbA0Ltzw/BycMZmbSk/bpwMP9NcN182/PkKNpaFI/BccZwS+w7aAuZ2yLXrS bu6XA9srJysiOp+UC9q16XfAA3shIClG0Rgc9nUjM6zcVNLCc4PLWJFJ/KfS+TiL5KVg LKXsUdMvL84l4wyo+1mvLeGHM2/nKS3wnG23AUqkgRaSehwOLhfgjWR7U5I1RVWL8e4R aG7w== X-Gm-Message-State: ALQs6tBtLBDVQ1CnYe3Umq65Drnu4VUCOMfbxDzOOnD6ilf3QaiTmet+ cDGq9x8/VEL1xIJxT1Gmdm/GlA== X-Google-Smtp-Source: AIpwx49JIbivG8kxsZs2yL7neIRky7N2X/HSIZ02z7+i1irD/A78ehqrusiputnlmT17O0v9nN4UNQ== X-Received: by 10.80.158.169 with SMTP id a38mr3835703edf.78.1523371336621; Tue, 10 Apr 2018 07:42:16 -0700 (PDT) Received: from reblochon.netronome.com (host-79-78-33-110.static.as9105.net. [79.78.33.110]) by smtp.gmail.com with ESMTPSA id i17sm1948907ede.13.2018.04.10.07.42.15 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 10 Apr 2018 07:42:15 -0700 (PDT) From: Quentin Monnet <quentin.monnet@netronome.com> To: daniel@iogearbox.net, ast@kernel.org Cc: netdev@vger.kernel.org, oss-drivers@netronome.com, quentin.monnet@netronome.com, linux-doc@vger.kernel.org, linux-man@vger.kernel.org Subject: [RFC bpf-next v2 0/8] bpf: document eBPF helpers and add a script to generate man page Date: Tue, 10 Apr 2018 15:41:49 +0100 Message-Id: <20180410144157.4831-1-quentin.monnet@netronome.com> X-Mailer: git-send-email 2.14.1 Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: <netdev.vger.kernel.org> X-Mailing-List: netdev@vger.kernel.org |
Series |
bpf: document eBPF helpers and add a script to generate man page
|
expand
|
eBPF helper functions can be called from within eBPF programs to perform a variety of tasks that would be otherwise hard or impossible to do with eBPF itself. There is a growing number of such helper functions in the kernel, but documentation is scarce. The main user space header file does contain a short commented description of most helpers, but it is somewhat outdated and not complete. It is more a "cheat sheet" than a real documentation accessible to new eBPF developers. This commit attempts to improve the situation by replacing the existing overview for the helpers with a more developed description. Furthermore, a Python script is added to generate a manual page for eBPF helpers. The workflow is the following, and requires the rst2man utility: $ ./scripts/bpf_helpers_doc.py \ --filename include/uapi/linux/bpf.h > /tmp/bpf-helpers.rst $ rst2man /tmp/bpf-helpers.rst > /tmp/bpf-helpers.7 $ man /tmp/bpf-helpers.7 The objective is to keep all documentation related to the helpers in a single place, and to be able to generate from here a manual page that could be packaged in the man-pages repository and shipped with most distributions. Additionally, parsing the prototypes of the helper functions could hopefully be reused, with a different Printer object, to generate header files needed in some eBPF-related projects. Regarding the description of each helper, it comprises several items: - The function prototype. - A description of the function and of its arguments (except for a couple of cases, when there are no arguments and the return value makes the function usage really obvious). - A description of return values (if not void). Additional items such as the list of compatible eBPF program and map types for each helper, Linux kernel version that introduced the helper, GPL-only restriction, and commit hash could be added in the future, but it was decided on the mailing list to leave them aside for now. For several helpers, descriptions are inspired (at times, nearly copied) from the commit logs introducing them in the kernel--Many thanks to their respective authors! They were completed as much as possible, the objective being to have something easily accessible even for people just starting with eBPF. There is probably a bit more work to do in this direction for some helpers. Some RST formatting is used in the descriptions (not in function prototypes, to keep them readable, but the Python script provided in order to generate the RST for the manual page does add formatting to prototypes, to produce something pretty) to get "bold" and "italics" in manual pages. Hopefully, the descriptions in bpf.h file remains perfectly readable. Note that the few trailing white spaces are intentional, removing them would break paragraphs for rst2man. The descriptions should ideally be updated each time someone adds a new helper, or updates the behaviour (new socket option supported, ...) or the interface (new flags available, ...) of existing ones. The second RFC for this set splits the documentation into several patches. Ideally all helper descriptions should be reviewed by the respective authors of the functions they describe. Please do not hesitate to suggest improvements to make descriptions more complete or accessible. v2: - Remove "For" (compatible program and map types), "Since" (minimal Linux kernel version required), "GPL only" sections and commit hashes for the helpers. - Add comment on top of the description list to explain how this documentation is supposed to be processed. - Update Python script accordingly (remove the same sections, and remove paragraphs on program types and GPL restrictions from man page header). - Split series into several patches. Cc: linux-doc@vger.kernel.org Cc: linux-man@vger.kernel.org Signed-off-by: Quentin Monnet <quentin.monnet@netronome.com> Quentin Monnet (8): bpf: add script and prepare bpf.h for new helpers documentation bpf: add documentation for eBPF helpers (01-11) bpf: add documentation for eBPF helpers (12-22) bpf: add documentation for eBPF helpers (23-32) bpf: add documentation for eBPF helpers (33-41) bpf: add documentation for eBPF helpers (42-50) bpf: add documentation for eBPF helpers (51-57) bpf: add documentation for eBPF helpers (58-64) include/uapi/linux/bpf.h | 1580 +++++++++++++++++++++++++++++++++----------- scripts/bpf_helpers_doc.py | 414 ++++++++++++ 2 files changed, 1616 insertions(+), 378 deletions(-) create mode 100755 scripts/bpf_helpers_doc.py