diff options
author | Mauro Carvalho Chehab <mchehab@redhat.com> | 2011-05-25 11:24:48 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2011-07-27 16:52:01 -0400 |
commit | 04893043ae9ea8aa82b712491ed25ba6c4ffbca3 (patch) | |
tree | 1f278cf3b65fef2c309a997b47f91b52ba8a4429 /Documentation/DocBook/Makefile | |
parent | 02f8c6aee8df3cdc935e9bdd4f2d020306035dbe (diff) |
[media] DocBook: Add rules to auto-generate some media docbook
Auto-generate the videodev2.h.xml,frontend.h.xml and the indexes.
Some logic at the Makefile helps us to identify when a symbol is missing,
like for example:
Error: no ID for constraint linkend: V4L2-PIX-FMT-JPGL.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'Documentation/DocBook/Makefile')
-rw-r--r-- | Documentation/DocBook/Makefile | 279 |
1 files changed, 258 insertions, 21 deletions
diff --git a/Documentation/DocBook/Makefile b/Documentation/DocBook/Makefile index 3cebfa0d1611..595bdd3acb6d 100644 --- a/Documentation/DocBook/Makefile +++ b/Documentation/DocBook/Makefile | |||
@@ -6,6 +6,8 @@ | |||
6 | # To add a new book the only step required is to add the book to the | 6 | # To add a new book the only step required is to add the book to the |
7 | # list of DOCBOOKS. | 7 | # list of DOCBOOKS. |
8 | 8 | ||
9 | TMPMEDIA=.tmpmedia | ||
10 | |||
9 | DOCBOOKS := z8530book.xml mcabook.xml device-drivers.xml \ | 11 | DOCBOOKS := z8530book.xml mcabook.xml device-drivers.xml \ |
10 | kernel-hacking.xml kernel-locking.xml deviceiobook.xml \ | 12 | kernel-hacking.xml kernel-locking.xml deviceiobook.xml \ |
11 | writing_usb_driver.xml networking.xml \ | 13 | writing_usb_driver.xml networking.xml \ |
@@ -14,7 +16,7 @@ DOCBOOKS := z8530book.xml mcabook.xml device-drivers.xml \ | |||
14 | genericirq.xml s390-drivers.xml uio-howto.xml scsi.xml \ | 16 | genericirq.xml s390-drivers.xml uio-howto.xml scsi.xml \ |
15 | 80211.xml debugobjects.xml sh.xml regulator.xml \ | 17 | 80211.xml debugobjects.xml sh.xml regulator.xml \ |
16 | alsa-driver-api.xml writing-an-alsa-driver.xml \ | 18 | alsa-driver-api.xml writing-an-alsa-driver.xml \ |
17 | tracepoint.xml media.xml drm.xml | 19 | tracepoint.xml $(TMPMEDIA)/media.xml drm.xml |
18 | 20 | ||
19 | ### | 21 | ### |
20 | # The build process is as follows (targets): | 22 | # The build process is as follows (targets): |
@@ -32,7 +34,7 @@ PS_METHOD = $(prefer-db2x) | |||
32 | 34 | ||
33 | ### | 35 | ### |
34 | # The targets that may be used. | 36 | # The targets that may be used. |
35 | PHONY += xmldocs sgmldocs psdocs pdfdocs htmldocs mandocs installmandocs cleandocs xmldoclinks | 37 | PHONY += xmldocs sgmldocs psdocs pdfdocs htmldocs mandocs installmandocs cleandocs mediaprep |
36 | 38 | ||
37 | BOOKS := $(addprefix $(obj)/,$(DOCBOOKS)) | 39 | BOOKS := $(addprefix $(obj)/,$(DOCBOOKS)) |
38 | xmldocs: $(BOOKS) | 40 | xmldocs: $(BOOKS) |
@@ -45,27 +47,13 @@ PDF := $(patsubst %.xml, %.pdf, $(BOOKS)) | |||
45 | pdfdocs: $(PDF) | 47 | pdfdocs: $(PDF) |
46 | 48 | ||
47 | HTML := $(sort $(patsubst %.xml, %.html, $(BOOKS))) | 49 | HTML := $(sort $(patsubst %.xml, %.html, $(BOOKS))) |
48 | htmldocs: $(HTML) xmldoclinks | 50 | htmldocs: $(HTML) |
49 | $(call build_main_index) | 51 | $(call build_main_index) |
50 | $(call build_images) | 52 | $(call build_images) |
51 | 53 | ||
52 | MAN := $(patsubst %.xml, %.9, $(BOOKS)) | 54 | MAN := $(patsubst %.xml, %.9, $(BOOKS)) |
53 | mandocs: $(MAN) | 55 | mandocs: $(MAN) |
54 | 56 | ||
55 | build_images = mkdir -p $(objtree)/Documentation/DocBook/media/ && \ | ||
56 | cp $(srctree)/Documentation/DocBook/dvb/*.png \ | ||
57 | $(srctree)/Documentation/DocBook/v4l/*.gif \ | ||
58 | $(objtree)/Documentation/DocBook/media/ | ||
59 | |||
60 | xmldoclinks: | ||
61 | ifneq ($(objtree),$(srctree)) | ||
62 | for dep in dvb media-entities.tmpl media-indices.tmpl v4l; do \ | ||
63 | rm -f $(objtree)/Documentation/DocBook/$$dep \ | ||
64 | && ln -s $(srctree)/Documentation/DocBook/$$dep $(objtree)/Documentation/DocBook/ \ | ||
65 | || exit; \ | ||
66 | done | ||
67 | endif | ||
68 | |||
69 | installmandocs: mandocs | 57 | installmandocs: mandocs |
70 | mkdir -p /usr/local/man/man9/ | 58 | mkdir -p /usr/local/man/man9/ |
71 | install Documentation/DocBook/man/*.9.gz /usr/local/man/man9/ | 59 | install Documentation/DocBook/man/*.9.gz /usr/local/man/man9/ |
@@ -97,11 +85,11 @@ define rule_docproc | |||
97 | ) > $(dir $@).$(notdir $@).cmd | 85 | ) > $(dir $@).$(notdir $@).cmd |
98 | endef | 86 | endef |
99 | 87 | ||
100 | %.xml: %.tmpl xmldoclinks FORCE | 88 | %.xml: %.tmpl FORCE |
101 | $(call if_changed_rule,docproc) | 89 | $(call if_changed_rule,docproc) |
102 | 90 | ||
103 | ### | 91 | ### |
104 | #Read in all saved dependency files | 92 | #Read in all saved dependency files |
105 | cmd_files := $(wildcard $(foreach f,$(BOOKS),$(dir $(f)).$(notdir $(f)).cmd)) | 93 | cmd_files := $(wildcard $(foreach f,$(BOOKS),$(dir $(f)).$(notdir $(f)).cmd)) |
106 | 94 | ||
107 | ifneq ($(cmd_files),) | 95 | ifneq ($(cmd_files),) |
@@ -150,7 +138,7 @@ quiet_cmd_db2pdf = PDF $@ | |||
150 | 138 | ||
151 | index = index.html | 139 | index = index.html |
152 | main_idx = Documentation/DocBook/$(index) | 140 | main_idx = Documentation/DocBook/$(index) |
153 | build_main_index = rm -rf $(main_idx) && \ | 141 | build_main_index = rm -rf $(main_idx); \ |
154 | echo '<h1>Linux Kernel HTML Documentation</h1>' >> $(main_idx) && \ | 142 | echo '<h1>Linux Kernel HTML Documentation</h1>' >> $(main_idx) && \ |
155 | echo '<h2>Kernel Version: $(KERNELVERSION)</h2>' >> $(main_idx) && \ | 143 | echo '<h2>Kernel Version: $(KERNELVERSION)</h2>' >> $(main_idx) && \ |
156 | cat $(HTML) >> $(main_idx) | 144 | cat $(HTML) >> $(main_idx) |
@@ -240,7 +228,7 @@ clean-files := $(DOCBOOKS) \ | |||
240 | $(patsubst %.xml, %.9, $(DOCBOOKS)) \ | 228 | $(patsubst %.xml, %.9, $(DOCBOOKS)) \ |
241 | $(index) | 229 | $(index) |
242 | 230 | ||
243 | clean-dirs := $(patsubst %.xml,%,$(DOCBOOKS)) man | 231 | clean-dirs := $(patsubst %.xml,%,$(DOCBOOKS)) man $(MEDIA_DIR) |
244 | 232 | ||
245 | cleandocs: | 233 | cleandocs: |
246 | $(Q)rm -f $(call objectify, $(clean-files)) | 234 | $(Q)rm -f $(call objectify, $(clean-files)) |
@@ -250,3 +238,252 @@ cleandocs: | |||
250 | # information in a variable se we can use it in if_changed and friends. | 238 | # information in a variable se we can use it in if_changed and friends. |
251 | 239 | ||
252 | .PHONY: $(PHONY) | 240 | .PHONY: $(PHONY) |
241 | |||
242 | |||
243 | # | ||
244 | # Media build rules - Auto-generates media contents/indexes and *.h xml's | ||
245 | # | ||
246 | |||
247 | SHELL=/bin/bash | ||
248 | |||
249 | MEDIA_DIR=$(objtree)/Documentation/DocBook/$(TMPMEDIA) | ||
250 | |||
251 | V4L_SGMLS = \ | ||
252 | $(shell ls $(srctree)/Documentation/DocBook/v4l/*.xml|perl -ne 'print "$$1 " if (m,.*/(.*)\n,)') \ | ||
253 | capture.c.xml \ | ||
254 | keytable.c.xml \ | ||
255 | v4l2grab.c.xml | ||
256 | |||
257 | DVB_SGMLS = \ | ||
258 | $(shell ls $(srctree)/Documentation/DocBook/dvb/*.xml|perl -ne 'print "$$1 " if (m,.*/(.*)\n,)') | ||
259 | |||
260 | MEDIA_TEMP = media-entities.tmpl \ | ||
261 | media-indices.tmpl \ | ||
262 | videodev2.h.xml \ | ||
263 | frontend.h.xml | ||
264 | |||
265 | MEDIA_SGMLS = $(addprefix ./,$(V4L_SGMLS)) $(addprefix ./,$(DVB_SGMLS)) $(addprefix ./,$(MEDIA_TEMP)) | ||
266 | |||
267 | MEDIA_TEMP_OBJ := $(addprefix $(MEDIA_DIR)/,$(MEDIA_TEMP)) | ||
268 | |||
269 | FUNCS = \ | ||
270 | close \ | ||
271 | ioctl \ | ||
272 | mmap \ | ||
273 | munmap \ | ||
274 | open \ | ||
275 | poll \ | ||
276 | read \ | ||
277 | select \ | ||
278 | write \ | ||
279 | |||
280 | IOCTLS = \ | ||
281 | $(shell perl -ne 'print "$$1 " if /\#define\s+([^\s]+)\s+_IO/' $(srctree)/include/linux/videodev2.h) \ | ||
282 | $(shell perl -ne 'print "$$1 " if /\#define\s+([^\s]+)\s+_IO/' $(srctree)/include/linux/media.h) \ | ||
283 | $(shell perl -ne 'print "$$1 " if /\#define\s+([^\s]+)\s+_IO/' $(srctree)/include/linux/v4l2-subdev.h) \ | ||
284 | VIDIOC_SUBDEV_G_FRAME_INTERVAL \ | ||
285 | VIDIOC_SUBDEV_S_FRAME_INTERVAL \ | ||
286 | VIDIOC_SUBDEV_ENUM_MBUS_CODE \ | ||
287 | VIDIOC_SUBDEV_ENUM_FRAME_SIZE \ | ||
288 | VIDIOC_SUBDEV_ENUM_FRAME_INTERVAL \ | ||
289 | |||
290 | TYPES = \ | ||
291 | $(shell perl -ne 'print "$$1 " if /^typedef\s+[^\s]+\s+([^\s]+)\;/' $(srctree)/include/linux/videodev2.h) | ||
292 | |||
293 | ENUMS = \ | ||
294 | $(shell perl -ne 'print "$$1 " if /^enum\s+([^\s]+)\s+/' $(srctree)/include/linux/videodev2.h) \ | ||
295 | $(shell perl -ne 'print "$$1 " if /^enum\s+([^\s]+)\s+/' $(srctree)/include/linux/media.h) \ | ||
296 | $(shell perl -ne 'print "$$1 " if /^enum\s+([^\s]+)\s+/' $(srctree)/include/linux/v4l2-mediabus.h) \ | ||
297 | $(shell perl -ne 'print "$$1 " if /^enum\s+([^\s]+)\s+/' $(srctree)/include/linux/v4l2-subdev.h) | ||
298 | |||
299 | STRUCTS = \ | ||
300 | $(shell perl -ne 'print "$$1 " if /^struct\s+([^\s]+)\s+/' $(srctree)/include/linux/videodev2.h) \ | ||
301 | $(shell perl -ne 'print "$$1 " if /^struct\s+([^\s]+)\s+/' $(srctree)/include/linux/media.h) \ | ||
302 | $(shell perl -ne 'print "$$1 " if /^struct\s+([^\s]+)\s+/' $(srctree)/include/linux/v4l2-subdev.h) \ | ||
303 | $(shell perl -ne 'print "$$1 " if /^struct\s+([^\s]+)\s+/' $(srctree)/include/linux/v4l2-mediabus.h) | ||
304 | |||
305 | ERRORS = \ | ||
306 | EACCES \ | ||
307 | EAGAIN \ | ||
308 | EBADF \ | ||
309 | EBUSY \ | ||
310 | EFAULT \ | ||
311 | EIO \ | ||
312 | EINTR \ | ||
313 | EINVAL \ | ||
314 | ENFILE \ | ||
315 | ENOMEM \ | ||
316 | ENOSPC \ | ||
317 | ENOTTY \ | ||
318 | ENXIO \ | ||
319 | EMFILE \ | ||
320 | EPERM \ | ||
321 | ERANGE \ | ||
322 | EPIPE \ | ||
323 | |||
324 | ESCAPE = \ | ||
325 | -e "s/&/\\&/g" \ | ||
326 | -e "s/</\\</g" \ | ||
327 | -e "s/>/\\>/g" | ||
328 | |||
329 | FILENAME = \ | ||
330 | -e s,"^[^\/]*/",, \ | ||
331 | -e s/"\\.xml"// \ | ||
332 | -e s/"\\.tmpl"// \ | ||
333 | -e s/\\\./-/g \ | ||
334 | -e s/"^func-"// \ | ||
335 | -e s/"^pixfmt-"// \ | ||
336 | -e s/"^vidioc-"// | ||
337 | |||
338 | # Generate references to these structs in videodev2.h.xml. | ||
339 | DOCUMENTED = \ | ||
340 | -e "s/\(enum *\)v4l2_mpeg_cx2341x_video_\([a-z]*_spatial_filter_type\)/\1<link linkend=\"\2\">v4l2_mpeg_cx2341x_video_\2<\/link>/g" \ | ||
341 | -e "s/\(\(enum\|struct\) *\)\(v4l2_[a-zA-Z0-9_]*\)/\1<link linkend=\"\3\">\3<\/link>/g" \ | ||
342 | -e "s/\(V4L2_PIX_FMT_[A-Z0-9_]\+\) /<link linkend=\"\1\">\1<\/link> /g" \ | ||
343 | -e ":a;s/\(linkend=\".*\)_\(.*\">\)/\1-\2/;ta" \ | ||
344 | -e "s/v4l2\-mpeg\-vbi\-ITV0/v4l2-mpeg-vbi-itv0-1/g" | ||
345 | |||
346 | DVB_DOCUMENTED = \ | ||
347 | -e "s,\(define \)\([A-Z0-9_]\+\)\(\s\+_IO\),\1\<link linkend=\"\2\">\2\<\/link\>\3,g" \ | ||
348 | -e "s/\(linkend\=\"\)FE_SET_PROPERTY/\1FE_GET_PROPERTY/g" | ||
349 | |||
350 | |||
351 | # | ||
352 | # Media targets and dependencies | ||
353 | # | ||
354 | |||
355 | $(obj)/$(TMPMEDIA)/media.xml: $(obj)/media.tmpl $(MEDIA_TEMP_OBJ) FORCE | ||
356 | $(call if_changed_rule,docproc) | ||
357 | |||
358 | $(MEDIA_DIR)/v4l2.xml: | ||
359 | @$($(quiet)gen_xml) | ||
360 | @(mkdir -p $(MEDIA_DIR)) | ||
361 | @(cp $(srctree)/Documentation/DocBook/dvb/*.png $(srctree)/Documentation/DocBook/v4l/*.gif $(MEDIA_DIR)/) | ||
362 | @(ln -sf $(srctree)/Documentation/DocBook/v4l/*xml $(MEDIA_DIR)/) | ||
363 | @(ln -sf $(srctree)/Documentation/DocBook/dvb/*xml $(MEDIA_DIR)/) | ||
364 | |||
365 | $(MEDIA_DIR)/videodev2.h.xml: $(srctree)/include/linux/videodev2.h $(MEDIA_DIR)/v4l2.xml | ||
366 | @$($(quiet)gen_xml) | ||
367 | @( \ | ||
368 | echo "<programlisting>") > $@ | ||
369 | @( \ | ||
370 | expand --tabs=8 < $< | \ | ||
371 | sed $(ESCAPE) $(DOCUMENTED) | \ | ||
372 | sed 's/i\.e\./&ie;/') >> $@ | ||
373 | @( \ | ||
374 | echo "</programlisting>") >> $@ | ||
375 | |||
376 | $(MEDIA_DIR)/frontend.h.xml: $(srctree)/include/linux/dvb/frontend.h $(MEDIA_DIR)/v4l2.xml | ||
377 | @$($(quiet)gen_xml) | ||
378 | @( \ | ||
379 | echo "<programlisting>") > $@ | ||
380 | @( \ | ||
381 | expand --tabs=8 < $< | \ | ||
382 | sed $(ESCAPE) $(DVB_DOCUMENTED) | \ | ||
383 | sed 's/i\.e\./&ie;/') >> $@ | ||
384 | @( \ | ||
385 | echo "</programlisting>") >> $@ | ||
386 | |||
387 | $(MEDIA_DIR)/media-entities.tmpl: $(MEDIA_DIR)/v4l2.xml | ||
388 | @$($(quiet)gen_xml) | ||
389 | @( \ | ||
390 | echo "<!-- Generated file! Do not edit. -->") >$@ | ||
391 | @( \ | ||
392 | echo -e "\n<!-- Functions -->") >>$@ | ||
393 | @( \ | ||
394 | for ident in $(FUNCS) ; do \ | ||
395 | entity=`echo $$ident | tr _ -` ; \ | ||
396 | echo "<!ENTITY func-$$entity \"<link" \ | ||
397 | "linkend='func-$$entity'><function>$$ident()</function></link>\">" \ | ||
398 | >>$@ ; \ | ||
399 | done) | ||
400 | @( \ | ||
401 | echo -e "\n<!-- Ioctls -->") >>$@ | ||
402 | @( \ | ||
403 | for ident in $(IOCTLS) ; do \ | ||
404 | entity=`echo $$ident | tr _ -` ; \ | ||
405 | id=`grep "<refname>$$ident" $(MEDIA_DIR)/vidioc-*.xml | sed -r s,"^.*/(.*).xml.*","\1",` ; \ | ||
406 | echo "<!ENTITY $$entity \"<link" \ | ||
407 | "linkend='$$id'><constant>$$ident</constant></link>\">" \ | ||
408 | >>$@ ; \ | ||
409 | done) | ||
410 | @( \ | ||
411 | echo -e "\n<!-- Types -->") >>$@ | ||
412 | @( \ | ||
413 | for ident in $(TYPES) ; do \ | ||
414 | entity=`echo $$ident | tr _ -` ; \ | ||
415 | echo "<!ENTITY $$entity \"<link" \ | ||
416 | "linkend='$$entity'>$$ident</link>\">" >>$@ ; \ | ||
417 | done) | ||
418 | @( \ | ||
419 | echo -e "\n<!-- Enums -->") >>$@ | ||
420 | @( \ | ||
421 | for ident in $(ENUMS) ; do \ | ||
422 | entity=`echo $$ident | sed -e "s/v4l2_mpeg_cx2341x_video_\([a-z]*_spatial_filter_type\)/\1/" | tr _ -` ; \ | ||
423 | echo "<!ENTITY $$entity \"enum <link" \ | ||
424 | "linkend='$$entity'>$$ident</link>\">" >>$@ ; \ | ||
425 | done) | ||
426 | @( \ | ||
427 | echo -e "\n<!-- Structures -->") >>$@ | ||
428 | @( \ | ||
429 | for ident in $(STRUCTS) ; do \ | ||
430 | entity=`echo $$ident | tr _ - | sed s/v4l2-mpeg-vbi-ITV0/v4l2-mpeg-vbi-itv0-1/g` ; \ | ||
431 | echo "<!ENTITY $$entity \"struct <link" \ | ||
432 | "linkend='$$entity'>$$ident</link>\">" >>$@ ; \ | ||
433 | done) | ||
434 | @( \ | ||
435 | echo -e "\n<!-- Error Codes -->") >>$@ | ||
436 | @( \ | ||
437 | for ident in $(ERRORS) ; do \ | ||
438 | echo "<!ENTITY $$ident \"<errorcode>$$ident</errorcode>" \ | ||
439 | "error code\">" >>$@ ; \ | ||
440 | done) | ||
441 | @( \ | ||
442 | echo -e "\n<!-- Subsections -->") >>$@ | ||
443 | @( \ | ||
444 | for file in $(MEDIA_SGMLS) ; do \ | ||
445 | entity=`echo "$$file" | sed $(FILENAME) -e s/"^([^-]*)"/sub\1/` ; \ | ||
446 | if ! echo "$$file" | \ | ||
447 | grep -q -E -e '^(func|vidioc|pixfmt)-' ; then \ | ||
448 | echo "<!ENTITY sub-$$entity SYSTEM \"$$file\">" >>$@ ; \ | ||
449 | fi ; \ | ||
450 | done) | ||
451 | @( \ | ||
452 | echo -e "\n<!-- Function Reference -->") >>$@ | ||
453 | @( \ | ||
454 | for file in $(MEDIA_SGMLS) ; do \ | ||
455 | if echo "$$file" | \ | ||
456 | grep -q -E -e '(func|vidioc|pixfmt)-' ; then \ | ||
457 | entity=`echo "$$file" |sed $(FILENAME)` ; \ | ||
458 | echo "<!ENTITY $$entity SYSTEM \"$$file\">" >>$@ ; \ | ||
459 | fi ; \ | ||
460 | done) | ||
461 | |||
462 | # Jade can auto-generate a list-of-tables, which includes all structs, | ||
463 | # but we only want data types, all types, and sorted please. | ||
464 | $(MEDIA_DIR)/media-indices.tmpl: $(MEDIA_DIR)/v4l2.xml | ||
465 | @$($(quiet)gen_xml) | ||
466 | @( \ | ||
467 | echo "<!-- Generated file! Do not edit. -->") >$@ | ||
468 | @( \ | ||
469 | echo -e "\n<index><title>List of Types</title>") >>$@ | ||
470 | @( \ | ||
471 | for ident in $(TYPES) ; do \ | ||
472 | id=`echo $$ident | tr _ -` ; \ | ||
473 | echo "<indexentry><primaryie><link" \ | ||
474 | "linkend='$$id'>$$ident</link></primaryie></indexentry>" >>$@ ; \ | ||
475 | done) | ||
476 | @( \ | ||
477 | for ident in $(ENUMS) ; do \ | ||
478 | id=`echo $$ident | sed -e "s/v4l2_mpeg_cx2341x_video_\([a-z]*_spatial_filter_type\)/\1/" | tr _ -`; \ | ||
479 | echo "<indexentry><primaryie>enum <link" \ | ||
480 | "linkend='$$id'>$$ident</link></primaryie></indexentry>" >>$@ ; \ | ||
481 | done) | ||
482 | @( \ | ||
483 | for ident in $(STRUCTS) ; do \ | ||
484 | id=`echo $$ident | tr _ - | sed s/v4l2-mpeg-vbi-ITV0/v4l2-mpeg-vbi-itv0-1/g` ; \ | ||
485 | echo "<indexentry><primaryie>struct <link" \ | ||
486 | "linkend='$$id'>$$ident</link></primaryie></indexentry>" >>$@ ; \ | ||
487 | done) | ||
488 | @( \ | ||
489 | echo "</index>") >>$@ | ||