1# -*- makefile -*- 2# Makefile for Sphinx documentation 3# 4 5# for cleaning 6subdir- := devicetree/bindings 7 8ifneq ($(MAKECMDGOALS),cleandocs) 9# Check for broken documentation file references 10ifeq ($(CONFIG_WARN_MISSING_DOCUMENTS),y) 11$(shell $(srctree)/scripts/documentation-file-ref-check --warn) 12endif 13 14# Check for broken ABI files 15ifeq ($(CONFIG_WARN_ABI_ERRORS),y) 16$(shell $(srctree)/scripts/get_abi.py --dir $(srctree)/Documentation/ABI validate) 17endif 18endif 19 20# You can set these variables from the command line. 21SPHINXBUILD = sphinx-build 22SPHINXOPTS = 23SPHINXDIRS = . 24DOCS_THEME = 25DOCS_CSS = 26RUSTDOC = 27PAPER = 28BUILDDIR = $(obj)/output 29PDFLATEX = xelatex 30LATEXOPTS = -interaction=batchmode -no-shell-escape 31 32PYTHONPYCACHEPREFIX ?= $(abspath $(BUILDDIR)/__pycache__) 33 34# Wrapper for sphinx-build 35 36BUILD_WRAPPER = $(srctree)/tools/docs/sphinx-build-wrapper 37 38# For denylisting "variable font" files 39# Can be overridden by setting as an env variable 40FONTS_CONF_DENY_VF ?= $(HOME)/deny-vf 41 42# User-friendly check for sphinx-build 43HAVE_SPHINX := $(shell if which $(SPHINXBUILD) >/dev/null 2>&1; then echo 1; else echo 0; fi) 44 45ifeq ($(CONFIG_RUST),y) 46 RUSTDOC="--rustdoc" 47endif 48 49ifeq ($(HAVE_SPHINX),0) 50 51.DEFAULT: 52 $(warning The '$(SPHINXBUILD)' command was not found. Make sure you have Sphinx installed and in PATH, or set the SPHINXBUILD make variable to point to the full path of the '$(SPHINXBUILD)' executable.) 53 @echo 54 @$(srctree)/tools/docs/sphinx-pre-install 55 @echo " SKIP Sphinx $@ target." 56 57else # HAVE_SPHINX 58 59# Common documentation targets 60htmldocs mandocs infodocs texinfodocs latexdocs epubdocs xmldocs pdfdocs linkcheckdocs: 61 $(Q)@$(srctree)/tools/docs/sphinx-pre-install --version-check 62 +$(Q)$(PYTHON3) $(BUILD_WRAPPER) $@ \ 63 --sphinxdirs="$(SPHINXDIRS)" $(RUSTDOC) \ 64 --builddir="$(BUILDDIR)" --deny-vf=$(FONTS_CONF_DENY_VF) \ 65 --theme=$(DOCS_THEME) --css=$(DOCS_CSS) --paper=$(PAPER) 66 67# Special handling for pdfdocs 68ifneq ($(shell which $(PDFLATEX) >/dev/null 2>&1; echo $$?),0) 69pdfdocs: 70 $(warning The '$(PDFLATEX)' command was not found. Make sure you have it installed and in PATH to produce PDF output.) 71 @echo " SKIP Sphinx $@ target." 72endif 73 74htmldocs-redirects: $(srctree)/Documentation/.renames.txt 75 @tools/docs/gen-redirects.py --output $(BUILDDIR) < $< 76endif # HAVE_SPHINX 77 78# The following targets are independent of HAVE_SPHINX, and the rules should 79# work or silently pass without Sphinx. 80 81refcheckdocs: 82 $(Q)cd $(srctree);scripts/documentation-file-ref-check 83 84cleandocs: 85 $(Q)rm -rf $(BUILDDIR) 86 87# Used only on help 88_SPHINXDIRS = $(sort $(patsubst $(srctree)/Documentation/%/index.rst,%,$(wildcard $(srctree)/Documentation/*/index.rst))) 89 90dochelp: 91 @echo ' Linux kernel internal documentation in different formats from ReST:' 92 @echo ' htmldocs - HTML' 93 @echo ' htmldocs-redirects - generate HTML redirects for moved pages' 94 @echo ' texinfodocs - Texinfo' 95 @echo ' infodocs - Info' 96 @echo ' mandocs - Man pages' 97 @echo ' latexdocs - LaTeX' 98 @echo ' pdfdocs - PDF' 99 @echo ' epubdocs - EPUB' 100 @echo ' xmldocs - XML' 101 @echo ' linkcheckdocs - check for broken external links' 102 @echo ' (will connect to external hosts)' 103 @echo ' refcheckdocs - check for references to non-existing files under' 104 @echo ' Documentation' 105 @echo ' cleandocs - clean all generated files' 106 @echo 107 @echo ' make SPHINXDIRS="s1 s2" [target] Generate only docs of folder s1, s2' 108 @echo ' valid values for SPHINXDIRS are: $(_SPHINXDIRS)' 109 @echo 110 @echo ' make DOCS_THEME={sphinx-theme} selects a different Sphinx theme.' 111 @echo 112 @echo ' make DOCS_CSS={a .css file} adds a DOCS_CSS override file for html/epub output.' 113 @echo 114 @echo ' make PAPER={a4|letter} Specifies the paper size used for LaTeX/PDF output.' 115 @echo 116 @echo ' make FONTS_CONF_DENY_VF={path} sets a deny list to block variable Noto CJK fonts' 117 @echo ' for PDF build. See tools/docs/lib/latex_fonts.py for more details' 118 @echo 119 @echo ' Default location for the generated documents is Documentation/output' 120