84 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
| # SPDX-License-Identifier: GPL-2.0-only
 | |
| 
 | |
| include ../../../scripts/Makefile.include
 | |
| include ../../../scripts/utilities.mak
 | |
| 
 | |
| INSTALL ?= install
 | |
| RM ?= rm -f
 | |
| RMDIR ?= rmdir --ignore-fail-on-non-empty
 | |
| 
 | |
| ifeq ($(V),1)
 | |
|   Q =
 | |
| else
 | |
|   Q = @
 | |
| endif
 | |
| 
 | |
| prefix ?= /usr/local
 | |
| mandir ?= $(prefix)/man
 | |
| man2dir = $(mandir)/man2
 | |
| man7dir = $(mandir)/man7
 | |
| 
 | |
| SYSCALL_RST = bpf-syscall.rst
 | |
| MAN2_RST = $(SYSCALL_RST)
 | |
| 
 | |
| HELPERS_RST = bpf-helpers.rst
 | |
| MAN7_RST = $(HELPERS_RST)
 | |
| 
 | |
| _DOC_MAN2 = $(patsubst %.rst,%.2,$(MAN2_RST))
 | |
| DOC_MAN2 = $(addprefix $(OUTPUT),$(_DOC_MAN2))
 | |
| 
 | |
| _DOC_MAN7 = $(patsubst %.rst,%.7,$(MAN7_RST))
 | |
| DOC_MAN7 = $(addprefix $(OUTPUT),$(_DOC_MAN7))
 | |
| 
 | |
| DOCTARGETS := helpers syscall
 | |
| 
 | |
| docs: $(DOCTARGETS)
 | |
| syscall: man2
 | |
| helpers: man7
 | |
| man2: $(DOC_MAN2)
 | |
| man7: $(DOC_MAN7)
 | |
| 
 | |
| RST2MAN_DEP := $(shell command -v rst2man 2>/dev/null)
 | |
| 
 | |
| # Configure make rules for the man page bpf-$1.$2.
 | |
| # $1 - target for scripts/bpf_doc.py
 | |
| # $2 - man page section to generate the troff file
 | |
| define DOCS_RULES =
 | |
| $(OUTPUT)bpf-$1.rst: ../../../../include/uapi/linux/bpf.h
 | |
| 	$$(QUIET_GEN)../../../../scripts/bpf_doc.py $1 \
 | |
| 		--filename $$< > $$@
 | |
| 
 | |
| $(OUTPUT)%.$2: $(OUTPUT)%.rst
 | |
| ifndef RST2MAN_DEP
 | |
| 	$$(error "rst2man not found, but required to generate man pages")
 | |
| endif
 | |
| 	$$(QUIET_GEN)rst2man --exit-status=1 $$< > $$@.tmp
 | |
| 	$$(QUIET_GEN)mv $$@.tmp $$@
 | |
| 
 | |
| docs-clean-$1:
 | |
| 	$$(call QUIET_CLEAN, eBPF_$1-manpage)
 | |
| 	$(Q)$(RM) $$(DOC_MAN$2) $(OUTPUT)bpf-$1.rst
 | |
| 
 | |
| docs-install-$1: docs
 | |
| 	$$(call QUIET_INSTALL, eBPF_$1-manpage)
 | |
| 	$(Q)$(INSTALL) -d -m 755 $(DESTDIR)$$(man$2dir)
 | |
| 	$(Q)$(INSTALL) -m 644 $$(DOC_MAN$2) $(DESTDIR)$$(man$2dir)
 | |
| 
 | |
| docs-uninstall-$1:
 | |
| 	$$(call QUIET_UNINST, eBPF_$1-manpage)
 | |
| 	$(Q)$(RM) $$(addprefix $(DESTDIR)$$(man$2dir)/,$$(_DOC_MAN$2))
 | |
| 	$(Q)$(RMDIR) $(DESTDIR)$$(man$2dir)
 | |
| 
 | |
| .PHONY: $1 docs-clean-$1 docs-install-$1 docs-uninstall-$1
 | |
| endef
 | |
| 
 | |
| # Create the make targets to generate manual pages by name and section
 | |
| $(eval $(call DOCS_RULES,helpers,7))
 | |
| $(eval $(call DOCS_RULES,syscall,2))
 | |
| 
 | |
| docs-clean: $(foreach doctarget,$(DOCTARGETS), docs-clean-$(doctarget))
 | |
| docs-install: $(foreach doctarget,$(DOCTARGETS), docs-install-$(doctarget))
 | |
| docs-uninstall: $(foreach doctarget,$(DOCTARGETS), docs-uninstall-$(doctarget))
 | |
| 
 | |
| .PHONY: docs docs-clean docs-install docs-uninstall man2 man7
 |