2005-04-16 15:20:36 -07:00
###
# This makefile is used to generate the kernel documentation,
# primarily based on in-line comments in various source files.
# See Documentation/kernel-doc-nano-HOWTO.txt for instruction in how
2006-04-01 01:04:59 +02:00
# to document the SRC - and how to read it.
2005-04-16 15:20:36 -07:00
# To add a new book the only step required is to add the book to the
# list of DOCBOOKS.
2008-08-14 19:18:17 +02:00
DOCBOOKS := z8530book.xml mcabook.xml \
2005-05-01 08:59:27 -07:00
kernel-hacking.xml kernel-locking.xml deviceiobook.xml \
2008-02-13 15:03:25 -08:00
procfs-guide.xml writing_usb_driver.xml networking.xml \
2008-03-20 13:43:45 -05:00
kernel-api.xml filesystems.xml lsm.xml usb.xml kgdb.xml \
2006-06-29 02:24:47 -07:00
gadget.xml libata.xml mtdnand.xml librs.xml rapidio.xml \
2008-02-26 14:34:06 +01:00
genericirq.xml s390-drivers.xml uio-howto.xml scsi.xml \
2008-08-04 12:53:55 +09:00
mac80211.xml debugobjects.xml sh.xml
2005-04-16 15:20:36 -07:00
###
# The build process is as follows (targets):
2007-07-19 01:48:23 -07:00
# (xmldocs) [by docproc]
# file.tmpl --> file.xml +--> file.ps (psdocs) [by db2ps or xmlto]
# +--> file.pdf (pdfdocs) [by db2pdf or xmlto]
# +--> DIR=file (htmldocs) [by xmlto]
# +--> man/ (mandocs) [by xmlto]
2005-04-16 15:20:36 -07:00
2005-11-13 16:08:15 -08:00
# for PDF and PS output you can choose between xmlto and docbook-utils tools
PDF_METHOD = $( prefer-db2x)
PS_METHOD = $( prefer-db2x)
2005-04-16 15:20:36 -07:00
###
# The targets that may be used.
2006-03-05 17:14:10 -05:00
PHONY += xmldocs sgmldocs psdocs pdfdocs htmldocs mandocs installmandocs
2005-04-16 15:20:36 -07:00
BOOKS := $( addprefix $( obj) /,$( DOCBOOKS) )
xmldocs : $( BOOKS )
sgmldocs : xmldocs
PS := $( patsubst %.xml, %.ps, $( BOOKS) )
psdocs : $( PS )
PDF := $( patsubst %.xml, %.pdf, $( BOOKS) )
pdfdocs : $( PDF )
2007-04-11 08:44:12 -07:00
HTML := $( sort $( patsubst %.xml, %.html, $( BOOKS) ) )
2005-04-16 15:20:36 -07:00
htmldocs : $( HTML )
2007-05-08 00:29:36 -07:00
$( call build_main_index)
2005-04-16 15:20:36 -07:00
MAN := $( patsubst %.xml, %.9, $( BOOKS) )
mandocs : $( MAN )
installmandocs : mandocs
2005-05-01 08:59:27 -07:00
mkdir -p /usr/local/man/man9/
install Documentation/DocBook/man/*.9.gz /usr/local/man/man9/
2005-04-16 15:20:36 -07:00
###
#External programs used
2006-12-29 16:49:07 -08:00
KERNELDOC = $( srctree) /scripts/kernel-doc
DOCPROC = $( objtree) /scripts/basic/docproc
2005-05-01 08:59:27 -07:00
2005-06-23 22:05:18 -07:00
XMLTOFLAGS = -m $( srctree) /Documentation/DocBook/stylesheet.xsl
2005-05-01 08:59:27 -07:00
#XMLTOFLAGS += --skip-validation
2005-04-16 15:20:36 -07:00
###
# DOCPROC is used for two purposes:
# 1) To generate a dependency list for a .tmpl file
# 2) To preprocess a .tmpl file and call kernel-doc with
# appropriate parameters.
# The following rules are used to generate the .xml documentation
# required to generate the final targets. (ps, pdf, html).
quiet_cmd_docproc = DOCPROC $@
cmd_docproc = SRCTREE = $( srctree) / $( DOCPROC) doc $< >$@
d e f i n e r u l e _ d o c p r o c
set -e; \
$( if $( $( quiet) cmd_$( 1) ) ,echo ' $($(quiet)cmd_$(1))' ; ) \
$( cmd_$( 1) ) ; \
( \
echo 'cmd_$@ := $(cmd_$(1))' ; \
echo $@ : ` SRCTREE = $( srctree) $( DOCPROC) depend $<` ; \
) > $( dir $@ ) .$( notdir $@ ) .cmd
e n d e f
%.xml : %.tmpl FORCE
$( call if_changed_rule,docproc)
###
#Read in all saved dependency files
cmd_files := $( wildcard $( foreach f,$( BOOKS) ,$( dir $( f) ) .$( notdir $( f) ) .cmd) )
i f n e q ( $( cmd_files ) , )
include $( cmd_files)
e n d i f
###
# Changes in kernel-doc force a rebuild of all documentation
$(BOOKS) : $( KERNELDOC )
###
# procfs guide uses a .c file as example code.
# This requires an explicit dependency
C-procfs-example = procfs_example.xml
C-procfs-example2 = $( addprefix $( obj) /,$( C-procfs-example) )
$(obj)/procfs-guide.xml : $( C -procfs -example 2)
docsrc: build Documentation/ sources
Currently source files in the Documentation/ sub-dir can easily bit-rot
since they are not generally buildable, either because they are hidden in
text files or because there are no Makefile rules for them. This needs to
be fixed so that the source files remain usable and good examples of code
instead of bad examples.
Add the ability to build source files that are in the Documentation/ dir.
Add to Kconfig as "BUILD_DOCSRC" config symbol.
Use "CONFIG_BUILD_DOCSRC=1 make ..." to build objects from the
Documentation/ sources. Or enable BUILD_DOCSRC in the *config system.
However, this symbol depends on HEADERS_CHECK since the header files need
to be installed (for userspace builds).
Built (using cross-tools) for x86-64, i386, alpha, ia64, sparc32,
sparc64, powerpc, sh, m68k, & mips.
Signed-off-by: Randy Dunlap <randy.dunlap@oracle.com>
Reviewed-by: Sam Ravnborg <sam@ravnborg.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2008-08-12 15:09:06 -07:00
# List of programs to build
##oops, this is a kernel module::hostprogs-y := procfs_example
obj-m += procfs_example.o
# Tell kbuild to always build the programs
always := $( hostprogs-y)
2005-11-13 16:08:15 -08:00
notfoundtemplate = echo "*** You have to install docbook-utils or xmlto ***" ; \
exit 1
db2xtemplate = db2TYPE -o $( dir $@ ) $<
xmltotemplate = xmlto TYPE $( XMLTOFLAGS) -o $( dir $@ ) $<
# determine which methods are available
i f e q ( $( shell which db 2ps >/dev /null 2>&1 && echo found ) , f o u n d )
use-db2x = db2x
prefer-db2x = db2x
e l s e
use-db2x = notfound
prefer-db2x = $( use-xmlto)
e n d i f
i f e q ( $( shell which xmlto >/dev /null 2>&1 && echo found ) , f o u n d )
use-xmlto = xmlto
prefer-xmlto = xmlto
e l s e
use-xmlto = notfound
prefer-xmlto = $( use-db2x)
e n d i f
2005-04-16 15:20:36 -07:00
2005-11-13 16:08:15 -08:00
# the commands, generated from the chosen template
quiet_cmd_db2ps = PS $@
cmd_db2ps = $( subst TYPE,ps, $( $( PS_METHOD) template) )
2005-04-16 15:20:36 -07:00
%.ps : %.xml
$( call cmd,db2ps)
2008-10-29 14:00:57 -07:00
quiet_cmd_db2pdf = PDF $@
2005-11-13 16:08:15 -08:00
cmd_db2pdf = $( subst TYPE,pdf, $( $( PDF_METHOD) template) )
2005-04-16 15:20:36 -07:00
%.pdf : %.xml
$( call cmd,db2pdf)
2007-05-08 00:29:36 -07:00
main_idx = Documentation/DocBook/index.html
build_main_index = rm -rf $( main_idx) && \
echo '<h1>Linux Kernel HTML Documentation</h1>' >> $( main_idx) && \
echo '<h2>Kernel Version: $(KERNELVERSION)</h2>' >> $( main_idx) && \
cat $( HTML) >> $( main_idx)
2008-10-29 14:00:57 -07:00
quiet_cmd_db2html = HTML $@
2005-05-01 08:59:27 -07:00
cmd_db2html = xmlto xhtml $( XMLTOFLAGS) -o $( patsubst %.html,%,$@ ) $< && \
2005-05-01 08:59:28 -07:00
echo ' <a HREF = " $( patsubst %.html,%,$( notdir $@ ) ) /index.html " > \
2007-05-08 00:29:36 -07:00
$( patsubst %.html,%,$( notdir $@ ) ) </a><p>' > $@
2005-04-16 15:20:36 -07:00
%.html : %.xml
2005-05-01 08:59:27 -07:00
@( which xmlto > /dev/null 2>& 1) || \
2005-05-01 08:59:28 -07:00
( echo "*** You need to install xmlto ***" ; \
2005-04-16 15:20:36 -07:00
exit 1)
@rm -rf $@ $( patsubst %.html,%,$@ )
$( call cmd,db2html)
@if [ ! -z " $( PNG-$( basename $( notdir $@ ) ) ) " ] ; then \
cp $( PNG-$( basename $( notdir $@ ) ) ) $( patsubst %.html,%,$@ ) ; fi
2005-11-13 16:08:15 -08:00
quiet_cmd_db2man = MAN $@
2005-05-01 08:59:27 -07:00
cmd_db2man = if grep -q refentry $<; then xmlto man $( XMLTOFLAGS) -o $( obj) /man $< ; gzip -f $( obj) /man/*.9; fi
%.9 : %.xml
@( which xmlto > /dev/null 2>& 1) || \
2005-05-01 08:59:28 -07:00
( echo "*** You need to install xmlto ***" ; \
2005-05-01 08:59:27 -07:00
exit 1)
2007-04-13 23:07:00 +02:00
$( Q) mkdir -p $( obj) /man
2005-05-01 08:59:27 -07:00
$( call cmd,db2man)
@touch $@
2005-04-16 15:20:36 -07:00
###
2007-10-20 01:30:25 +02:00
# Rules to generate postscripts and PNG images from .fig format files
2005-04-16 15:20:36 -07:00
quiet_cmd_fig2eps = FIG2EPS $@
cmd_fig2eps = fig2dev -Leps $< $@
%.eps : %.fig
@( which fig2dev > /dev/null 2>& 1) || \
( echo "*** You need to install transfig ***" ; \
exit 1)
$( call cmd,fig2eps)
quiet_cmd_fig2png = FIG2PNG $@
cmd_fig2png = fig2dev -Lpng $< $@
%.png : %.fig
@( which fig2dev > /dev/null 2>& 1) || \
( echo "*** You need to install transfig ***" ; \
exit 1)
$( call cmd,fig2png)
###
# Rule to convert a .c file to inline XML documentation
2008-03-28 14:30:58 -07:00
gen_xml = :
quiet_gen_xml = echo ' GEN $@'
silent_gen_xml = :
2005-04-16 15:20:36 -07:00
%.xml : %.c
2008-03-28 14:30:58 -07:00
@$( $( quiet) gen_xml)
2005-04-16 15:20:36 -07:00
@( \
echo "<programlisting>" ; \
expand --tabs= 8 < $< | \
sed -e "s/&/\\&/g" \
-e "s/</\\</g" \
-e "s/>/\\>/g" ; \
echo "</programlisting>" ) > $@
###
# Help targets as used by the top-level makefile
dochelp :
2006-12-07 00:16:26 +01:00
@echo ' Linux kernel internal documentation in different formats:'
@echo ' htmldocs - HTML'
@echo ' installmandocs - install man pages generated by mandocs'
@echo ' mandocs - man pages'
@echo ' pdfdocs - PDF'
@echo ' psdocs - Postscript'
@echo ' xmldocs - XML DocBook'
2005-04-16 15:20:36 -07:00
###
# Temporary files left by various tools
clean-files := $( DOCBOOKS) \
$( patsubst %.xml, %.dvi, $( DOCBOOKS) ) \
$( patsubst %.xml, %.aux, $( DOCBOOKS) ) \
$( patsubst %.xml, %.tex, $( DOCBOOKS) ) \
$( patsubst %.xml, %.log, $( DOCBOOKS) ) \
$( patsubst %.xml, %.out, $( DOCBOOKS) ) \
$( patsubst %.xml, %.ps, $( DOCBOOKS) ) \
$( patsubst %.xml, %.pdf, $( DOCBOOKS) ) \
$( patsubst %.xml, %.html, $( DOCBOOKS) ) \
$( patsubst %.xml, %.9, $( DOCBOOKS) ) \
$( C-procfs-example)
2007-04-13 23:07:00 +02:00
clean-dirs := $( patsubst %.xml,%,$( DOCBOOKS) ) man
2006-03-05 17:14:10 -05:00
# Declare the contents of the .PHONY variable as phony. We keep that
# information in a variable se we can use it in if_changed and friends.
.PHONY : $( PHONY )