Commit 92ec1cc3 authored by Quentin Monnet's avatar Quentin Monnet Committed by Daniel Borkmann

scripts/bpf: Set date attribute for bpf-helpers(7) man page

The bpf-helpers(7) manual page shipped in the man-pages project is
generated from the documentation contained in the BPF UAPI header, in
the Linux repository, parsed by script/bpf_doc.py and then fed to
rst2man.

The man page should contain the date of last modification of the
documentation. This commit adds the relevant date when generating the
page.

Before:

    $ ./scripts/bpf_doc.py helpers | rst2man | grep '\.TH'
    .TH BPF-HELPERS 7 "" "Linux v5.19-14022-g30d2a4d74e11" ""

After:

    $ ./scripts/bpf_doc.py helpers | rst2man | grep '\.TH'
    .TH BPF-HELPERS 7 "2022-08-15" "Linux v5.19-14022-g30d2a4d74e11" ""

We get the version by using "git log" to look for the commit date of the
latest change to the section of the BPF header containing the
documentation. If the command fails, we just skip the date field. and
keep generating the page.
Reported-by: default avatarAlejandro Colomar <alx.manpages@gmail.com>
Signed-off-by: default avatarQuentin Monnet <quentin@isovalent.com>
Signed-off-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
Reviewed-by: default avatarAlejandro Colomar <alx.manpages@gmail.com>
Link: https://lore.kernel.org/bpf/20220823155327.98888-2-quentin@isovalent.com
parent fd0a38f9
...@@ -12,6 +12,7 @@ import re ...@@ -12,6 +12,7 @@ import re
import sys, os import sys, os
import subprocess import subprocess
helpersDocStart = 'Start of BPF helper function descriptions:'
class NoHelperFound(BaseException): class NoHelperFound(BaseException):
pass pass
...@@ -235,7 +236,7 @@ class HeaderParser(object): ...@@ -235,7 +236,7 @@ class HeaderParser(object):
self.enum_syscalls = re.findall('(BPF\w+)+', bpf_cmd_str) self.enum_syscalls = re.findall('(BPF\w+)+', bpf_cmd_str)
def parse_desc_helpers(self): def parse_desc_helpers(self):
self.seek_to('* Start of BPF helper function descriptions:', self.seek_to(helpersDocStart,
'Could not find start of eBPF helper descriptions list') 'Could not find start of eBPF helper descriptions list')
while True: while True:
try: try:
...@@ -373,6 +374,17 @@ class PrinterRST(Printer): ...@@ -373,6 +374,17 @@ class PrinterRST(Printer):
return 'Linux' return 'Linux'
return 'Linux {version}'.format(version=version) return 'Linux {version}'.format(version=version)
def get_last_doc_update(self, delimiter):
try:
cmd = ['git', 'log', '-1', '--pretty=format:%cs', '--no-patch',
'-L',
'/{}/,/\*\//:include/uapi/linux/bpf.h'.format(delimiter)]
date = subprocess.run(cmd, cwd=linuxRoot,
capture_output=True, check=True)
return date.stdout.decode().rstrip()
except:
return ''
class PrinterHelpersRST(PrinterRST): class PrinterHelpersRST(PrinterRST):
""" """
A printer for dumping collected information about helpers as a ReStructured A printer for dumping collected information about helpers as a ReStructured
...@@ -395,6 +407,7 @@ list of eBPF helper functions ...@@ -395,6 +407,7 @@ list of eBPF helper functions
:Manual section: 7 :Manual section: 7
:Version: {version} :Version: {version}
{date_field}{date}
DESCRIPTION DESCRIPTION
=========== ===========
...@@ -428,9 +441,12 @@ HELPERS ...@@ -428,9 +441,12 @@ HELPERS
======= =======
''' '''
kernelVersion = self.get_kernel_version() kernelVersion = self.get_kernel_version()
lastUpdate = self.get_last_doc_update(helpersDocStart)
PrinterRST.print_license(self) PrinterRST.print_license(self)
print(header.format(version=kernelVersion)) print(header.format(version=kernelVersion,
date_field = ':Date: ' if lastUpdate else '',
date=lastUpdate))
def print_footer(self): def print_footer(self):
footer = ''' footer = '''
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment