xref: /linux/tools/testing/selftests/bpf/Makefile.docs (revision 9f5270d758d955506dcb114cb863a86b30a4c783)
1# SPDX-License-Identifier: GPL-2.0-only
2
3include ../../../scripts/Makefile.include
4include ../../../scripts/utilities.mak
5
6INSTALL ?= install
7RM ?= rm -f
8RMDIR ?= rmdir --ignore-fail-on-non-empty
9
10prefix ?= /usr/local
11mandir ?= $(prefix)/man
12man2dir = $(mandir)/man2
13man7dir = $(mandir)/man7
14
15SYSCALL_RST = bpf-syscall.rst
16MAN2_RST = $(SYSCALL_RST)
17
18HELPERS_RST = bpf-helpers.rst
19MAN7_RST = $(HELPERS_RST)
20
21_DOC_MAN2 = $(patsubst %.rst,%.2,$(MAN2_RST))
22DOC_MAN2 = $(addprefix $(OUTPUT),$(_DOC_MAN2))
23
24_DOC_MAN7 = $(patsubst %.rst,%.7,$(MAN7_RST))
25DOC_MAN7 = $(addprefix $(OUTPUT),$(_DOC_MAN7))
26
27DOCTARGETS := helpers syscall
28
29docs: $(DOCTARGETS)
30syscall: man2
31helpers: man7
32man2: $(DOC_MAN2)
33man7: $(DOC_MAN7)
34
35RST2MAN_DEP := $(shell command -v rst2man 2>/dev/null)
36
37# Configure make rules for the man page bpf-$1.$2.
38# $1 - target for scripts/bpf_doc.py
39# $2 - man page section to generate the troff file
40define DOCS_RULES =
41$(OUTPUT)bpf-$1.rst: ../../../../include/uapi/linux/bpf.h
42	$$(QUIET_GEN)../../../../scripts/bpf_doc.py $1 \
43		--filename $$< > $$@
44
45$(OUTPUT)%.$2: $(OUTPUT)%.rst
46ifndef RST2MAN_DEP
47	$$(error "rst2man not found, but required to generate man pages")
48endif
49	$$(QUIET_GEN)rst2man --exit-status=1 $$< > $$@.tmp
50	$$(QUIET_GEN)mv $$@.tmp $$@
51
52docs-clean-$1:
53	$$(call QUIET_CLEAN, eBPF_$1-manpage)
54	$(Q)$(RM) $$(DOC_MAN$2) $(OUTPUT)bpf-$1.rst
55
56docs-install-$1: docs
57	$$(call QUIET_INSTALL, eBPF_$1-manpage)
58	$(Q)$(INSTALL) -d -m 755 $(DESTDIR)$$(man$2dir)
59	$(Q)$(INSTALL) -m 644 $$(DOC_MAN$2) $(DESTDIR)$$(man$2dir)
60
61docs-uninstall-$1:
62	$$(call QUIET_UNINST, eBPF_$1-manpage)
63	$(Q)$(RM) $$(addprefix $(DESTDIR)$$(man$2dir)/,$$(_DOC_MAN$2))
64	$(Q)$(RMDIR) $(DESTDIR)$$(man$2dir)
65
66.PHONY: $1 docs-clean-$1 docs-install-$1 docs-uninstall-$1
67endef
68
69# Create the make targets to generate manual pages by name and section
70$(eval $(call DOCS_RULES,helpers,7))
71$(eval $(call DOCS_RULES,syscall,2))
72
73docs-clean: $(foreach doctarget,$(DOCTARGETS), docs-clean-$(doctarget))
74docs-install: $(foreach doctarget,$(DOCTARGETS), docs-install-$(doctarget))
75docs-uninstall: $(foreach doctarget,$(DOCTARGETS), docs-uninstall-$(doctarget))
76
77.PHONY: docs docs-clean docs-install docs-uninstall man2 man7
78