--- qemu/Makefile 2018/04/24 16:50:17 1.1.1.7 +++ qemu/Makefile 2018/04/24 17:33:47 1.1.1.9 @@ -1,68 +1,122 @@ # Makefile for QEMU. +# This needs to be defined before rules.mak +GENERATED_HEADERS = config-host.h + +ifneq ($(wildcard config-host.mak),) +# Put the all: rule here so that config-host.mak can contain dependencies. +all: build-all include config-host.mak include $(SRC_PATH)/rules.mak +config-host.mak: configure + @echo $@ is out-of-date, running configure + @sed -n "/.*Configured with/s/[^:]*: //p" $@ | sh +else +config-host.mak: + @echo "Please call configure before running make!" + @exit 1 +endif + +# Don't try to regenerate Makefile or configure +# We don't generate any of them +Makefile: ; +configure: ; .PHONY: all clean cscope distclean dvi html info install install-doc \ - recurse-all speed tar tarbin test + recurse-all speed tar tarbin test build-all VPATH=$(SRC_PATH):$(SRC_PATH)/hw +LIBS+=-lz $(LIBS_TOOLS) -CFLAGS += $(OS_CFLAGS) $(ARCH_CFLAGS) -LDFLAGS += $(OS_LDFLAGS) $(ARCH_LDFLAGS) - -CPPFLAGS += -I. -I$(SRC_PATH) -MMD -MP -MT $@ -CPPFLAGS += -D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -LIBS= -ifdef CONFIG_STATIC -LDFLAGS += -static -endif ifdef BUILD_DOCS DOCS=qemu-doc.html qemu-tech.html qemu.1 qemu-img.1 qemu-nbd.8 else DOCS= endif -LIBS+=$(AIOLIBS) +SUBDIR_MAKEFLAGS=$(if $(V),,--no-print-directory) +SUBDIR_DEVICES_MAK=$(patsubst %, %/config-devices.mak, $(TARGET_DIRS)) -ifdef CONFIG_SOLARIS -LIBS+=-lsocket -lnsl -lresolv -endif +config-all-devices.mak: $(SUBDIR_DEVICES_MAK) + $(call quiet-command,cat $(SUBDIR_DEVICES_MAK) | grep =y | sort -u > $@," GEN $@") -ifdef CONFIG_WIN32 -LIBS+=-lwinmm -lws2_32 -liphlpapi -endif +%/config-devices.mak: default-configs/%.mak + $(call quiet-command,cat $< > $@.tmp, " GEN $@") + @if test -f $@ ; then \ + echo "WARNING: $@ out of date." ;\ + echo "Run \"make defconfig\" to regenerate." ; \ + rm $@.tmp ; \ + else \ + mv $@.tmp $@ ; \ + fi + +defconfig: + rm -f config-all-devices.mak $(SUBDIR_DEVICES_MAK) + +-include config-all-devices.mak -all: $(TOOLS) $(DOCS) recurse-all +build-all: $(DOCS) $(TOOLS) recurse-all + +config-host.h: config-host.h-timestamp +config-host.h-timestamp: config-host.mak SUBDIR_RULES=$(patsubst %,subdir-%, $(TARGET_DIRS)) -subdir-%: - $(call quiet-command,$(MAKE) -C $* V="$(V)" TARGET_DIR="$*/" all,) +subdir-%: $(GENERATED_HEADERS) + $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) -C $* V="$(V)" TARGET_DIR="$*/" all,) $(filter %-softmmu,$(SUBDIR_RULES)): libqemu_common.a -$(filter %-user,$(SUBDIR_RULES)): libqemu_user.a -recurse-all: $(SUBDIR_RULES) +$(filter %-user,$(SUBDIR_RULES)): libuser.a + +libuser.a: $(GENERATED_HEADERS) + $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) -C libuser V="$(V)" TARGET_DIR="libuser/" all,) + +ROMSUBDIR_RULES=$(patsubst %,romsubdir-%, $(ROMS)) +romsubdir-%: + $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) -C pc-bios/$* V="$(V)" TARGET_DIR="$*/",) + +ALL_SUBDIRS=$(TARGET_DIRS) $(patsubst %,pc-bios/%, $(ROMS)) + +recurse-all: $(SUBDIR_RULES) $(ROMSUBDIR_RULES) ####################################################################### -# BLOCK_OBJS is code used by both qemu system emulation and qemu-img +# QObject +qobject-obj-y = qint.o qstring.o qdict.o qlist.o qfloat.o qbool.o +qobject-obj-y += qjson.o json-lexer.o json-streamer.o json-parser.o +qobject-obj-y += qerror.o -BLOCK_OBJS=cutils.o qemu-malloc.o -BLOCK_OBJS+=block-cow.o block-qcow.o aes.o block-vmdk.o block-cloop.o -BLOCK_OBJS+=block-dmg.o block-bochs.o block-vpc.o block-vvfat.o -BLOCK_OBJS+=block-qcow2.o block-parallels.o block-nbd.o -BLOCK_OBJS+=nbd.o block.o aio.o +####################################################################### +# block-obj-y is code used by both qemu system emulation and qemu-img -ifdef CONFIG_WIN32 -BLOCK_OBJS += block-raw-win32.o -else -ifdef CONFIG_AIO -BLOCK_OBJS += posix-aio-compat.o -endif -BLOCK_OBJS += block-raw-posix.o -endif +block-obj-y = cutils.o cache-utils.o qemu-malloc.o qemu-option.o module.o +block-obj-y += nbd.o block.o aio.o aes.o osdep.o +block-obj-$(CONFIG_POSIX) += posix-aio-compat.o +block-obj-$(CONFIG_LINUX_AIO) += linux-aio.o + +block-nested-y += cow.o qcow.o vdi.o vmdk.o cloop.o dmg.o bochs.o vpc.o vvfat.o +block-nested-y += qcow2.o qcow2-refcount.o qcow2-cluster.o qcow2-snapshot.o +block-nested-y += parallels.o nbd.o +block-nested-$(CONFIG_WIN32) += raw-win32.o +block-nested-$(CONFIG_POSIX) += raw-posix.o +block-nested-$(CONFIG_CURL) += curl.o + +block-obj-y += $(addprefix block/, $(block-nested-y)) + +net-obj-y = net.o +net-nested-y = queue.o checksum.o util.o +net-nested-y += socket.o +net-nested-y += dump.o +net-nested-$(CONFIG_POSIX) += tap.o +net-nested-$(CONFIG_LINUX) += tap-linux.o +net-nested-$(CONFIG_WIN32) += tap-win32.o +net-nested-$(CONFIG_BSD) += tap-bsd.o +net-nested-$(CONFIG_SOLARIS) += tap-solaris.o +net-nested-$(CONFIG_AIX) += tap-aix.o +net-nested-$(CONFIG_SLIRP) += slirp.o +net-nested-$(CONFIG_VDE) += vde.o +net-obj-y += $(addprefix net/, $(net-nested-y)) ###################################################################### # libqemu_common.a: Target independent part of system emulation. The @@ -70,139 +124,150 @@ endif # system emulation, i.e. a single QEMU executable should support all # CPUs and machines. -OBJS=$(BLOCK_OBJS) -OBJS+=readline.o console.o +obj-y = $(block-obj-y) +obj-y += $(net-obj-y) +obj-y += $(qobject-obj-y) +obj-y += readline.o console.o + +obj-y += tcg-runtime.o host-utils.o +obj-y += irq.o ioport.o +obj-$(CONFIG_PTIMER) += ptimer.o +obj-$(CONFIG_MAX7310) += max7310.o +obj-$(CONFIG_WM8750) += wm8750.o +obj-$(CONFIG_TWL92230) += twl92230.o +obj-$(CONFIG_TSC2005) += tsc2005.o +obj-$(CONFIG_LM832X) += lm832x.o +obj-$(CONFIG_TMP105) += tmp105.o +obj-$(CONFIG_STELLARIS_INPUT) += stellaris_input.o +obj-$(CONFIG_SSD0303) += ssd0303.o +obj-$(CONFIG_SSD0323) += ssd0323.o +obj-$(CONFIG_ADS7846) += ads7846.o +obj-$(CONFIG_MAX111X) += max111x.o +obj-$(CONFIG_DS1338) += ds1338.o +obj-y += i2c.o smbus.o smbus_eeprom.o +obj-y += eeprom93xx.o +obj-y += scsi-disk.o cdrom.o +obj-y += scsi-generic.o scsi-bus.o +obj-y += usb.o usb-hub.o usb-$(HOST_USB).o usb-hid.o usb-msd.o usb-wacom.o +obj-y += usb-serial.o usb-net.o usb-bus.o +obj-$(CONFIG_SSI) += ssi.o +obj-$(CONFIG_SSI_SD) += ssi-sd.o +obj-$(CONFIG_SD) += sd.o +obj-y += bt.o bt-host.o bt-vhci.o bt-l2cap.o bt-sdp.o bt-hci.o bt-hid.o usb-bt.o +obj-y += bt-hci-csr.o +obj-y += buffered_file.o migration.o migration-tcp.o qemu-sockets.o +obj-y += qemu-char.o aio.o savevm.o +obj-y += msmouse.o ps2.o +obj-y += qdev.o qdev-properties.o +obj-y += qemu-config.o block-migration.o + +obj-$(CONFIG_BRLAPI) += baum.o +obj-$(CONFIG_POSIX) += migration-exec.o migration-unix.o migration-fd.o + +audio/audio.o audio/fmodaudio.o: QEMU_CFLAGS += $(FMOD_CFLAGS) + +audio-obj-y = audio.o noaudio.o wavaudio.o mixeng.o +audio-obj-$(CONFIG_SDL) += sdlaudio.o +audio-obj-$(CONFIG_OSS) += ossaudio.o +audio-obj-$(CONFIG_COREAUDIO) += coreaudio.o +audio-obj-$(CONFIG_ALSA) += alsaaudio.o +audio-obj-$(CONFIG_DSOUND) += dsoundaudio.o +audio-obj-$(CONFIG_FMOD) += fmodaudio.o +audio-obj-$(CONFIG_ESD) += esdaudio.o +audio-obj-$(CONFIG_PA) += paaudio.o +audio-obj-$(CONFIG_WINWAVE) += winwaveaudio.o +audio-obj-$(CONFIG_AUDIO_PT_INT) += audio_pt_int.o +audio-obj-$(CONFIG_AUDIO_WIN_INT) += audio_win_int.o +audio-obj-y += wavcapture.o +obj-y += $(addprefix audio/, $(audio-obj-y)) + +obj-y += keymaps.o +obj-$(CONFIG_SDL) += sdl.o sdl_zoom.o x_keymap.o +obj-$(CONFIG_CURSES) += curses.o +obj-y += vnc.o acl.o d3des.o +obj-$(CONFIG_VNC_TLS) += vnc-tls.o vnc-auth-vencrypt.o +obj-$(CONFIG_VNC_SASL) += vnc-auth-sasl.o +obj-$(CONFIG_COCOA) += cocoa.o +obj-$(CONFIG_IOTHREAD) += qemu-thread.o + +slirp-obj-y = cksum.o if.o ip_icmp.o ip_input.o ip_output.o +slirp-obj-y += slirp.o mbuf.o misc.o sbuf.o socket.o tcp_input.o tcp_output.o +slirp-obj-y += tcp_subr.o tcp_timer.o udp.o bootp.o tftp.o +obj-$(CONFIG_SLIRP) += $(addprefix slirp/, $(slirp-obj-y)) + +# xen backend driver support +obj-$(CONFIG_XEN) += xen_backend.o xen_devconfig.o +obj-$(CONFIG_XEN) += xen_console.o xenfb.o xen_disk.o xen_nic.o -OBJS+=irq.o -OBJS+=i2c.o smbus.o smbus_eeprom.o max7310.o max111x.o wm8750.o -OBJS+=ssd0303.o ssd0323.o ads7846.o stellaris_input.o twl92230.o -OBJS+=tmp105.o lm832x.o -OBJS+=scsi-disk.o cdrom.o -OBJS+=scsi-generic.o -OBJS+=usb.o usb-hub.o usb-$(HOST_USB).o usb-hid.o usb-msd.o usb-wacom.o -OBJS+=usb-serial.o usb-net.o -OBJS+=sd.o ssi-sd.o -OBJS+=bt.o bt-host.o bt-vhci.o bt-l2cap.o bt-sdp.o bt-hci.o bt-hid.o usb-bt.o -OBJS+=buffered_file.o migration.o migration-tcp.o net.o qemu-sockets.o -OBJS+=qemu-char.o aio.o net-checksum.o savevm.o cache-utils.o - -ifdef CONFIG_BRLAPI -OBJS+= baum.o -LIBS+=-lbrlapi -endif - -ifdef CONFIG_WIN32 -OBJS+=tap-win32.o -else -OBJS+=migration-exec.o -endif +QEMU_CFLAGS+=$(CURL_CFLAGS) -AUDIO_OBJS = audio.o noaudio.o wavaudio.o mixeng.o -ifdef CONFIG_SDL -AUDIO_OBJS += sdlaudio.o -endif -ifdef CONFIG_OSS -AUDIO_OBJS += ossaudio.o -endif -ifdef CONFIG_COREAUDIO -AUDIO_OBJS += coreaudio.o -AUDIO_PT = yes -endif -ifdef CONFIG_ALSA -AUDIO_OBJS += alsaaudio.o -endif -ifdef CONFIG_DSOUND -AUDIO_OBJS += dsoundaudio.o -endif -ifdef CONFIG_FMOD -AUDIO_OBJS += fmodaudio.o -audio/audio.o audio/fmodaudio.o: CPPFLAGS := -I$(CONFIG_FMOD_INC) $(CPPFLAGS) -endif -ifdef CONFIG_ESD -AUDIO_PT = yes -AUDIO_PT_INT = yes -AUDIO_OBJS += esdaudio.o -endif -ifdef CONFIG_PA -AUDIO_PT = yes -AUDIO_PT_INT = yes -AUDIO_OBJS += paaudio.o -endif -ifdef AUDIO_PT -LDFLAGS += -pthread -endif -ifdef AUDIO_PT_INT -AUDIO_OBJS += audio_pt_int.o -endif -AUDIO_OBJS+= wavcapture.o -OBJS+=$(addprefix audio/, $(AUDIO_OBJS)) +cocoa.o: cocoa.m -ifdef CONFIG_SDL -OBJS+=sdl.o x_keymap.o -endif -ifdef CONFIG_CURSES -OBJS+=curses.o -endif -OBJS+=vnc.o d3des.o +keymaps.o: keymaps.c keymaps.h -ifdef CONFIG_COCOA -OBJS+=cocoa.o -endif +sdl_zoom.o: sdl_zoom.c sdl_zoom.h sdl_zoom_template.h -ifdef CONFIG_SLIRP -CPPFLAGS+=-I$(SRC_PATH)/slirp -SLIRP_OBJS=cksum.o if.o ip_icmp.o ip_input.o ip_output.o \ -slirp.o mbuf.o misc.o sbuf.o socket.o tcp_input.o tcp_output.o \ -tcp_subr.o tcp_timer.o udp.o bootp.o debug.o tftp.o -OBJS+=$(addprefix slirp/, $(SLIRP_OBJS)) -endif +sdl.o: sdl.c keymaps.h sdl_keysym.h sdl_zoom.h -LIBS+=$(VDE_LIBS) +sdl.o audio/sdlaudio.o sdl_zoom.o baum.o: QEMU_CFLAGS += $(SDL_CFLAGS) -cocoa.o: cocoa.m +acl.o: acl.h acl.c -sdl.o: sdl.c keymaps.c sdl_keysym.h +vnc.h: vnc-tls.h vnc-auth-vencrypt.h vnc-auth-sasl.h keymaps.h -sdl.o audio/sdlaudio.o: CFLAGS += $(SDL_CFLAGS) +vnc.o: vnc.c vnc.h vnc_keysym.h vnchextile.h d3des.c d3des.h acl.h -vnc.o: vnc.c keymaps.c sdl_keysym.h vnchextile.h d3des.c d3des.h +vnc.o: QEMU_CFLAGS += $(VNC_TLS_CFLAGS) -vnc.o: CFLAGS += $(CONFIG_VNC_TLS_CFLAGS) +vnc-tls.o: vnc-tls.c vnc.h -curses.o: curses.c keymaps.c curses_keys.h +vnc-auth-vencrypt.o: vnc-auth-vencrypt.c vnc.h -bt-host.o: CFLAGS += $(CONFIG_BLUEZ_CFLAGS) +vnc-auth-sasl.o: vnc-auth-sasl.c vnc.h -libqemu_common.a: $(OBJS) +curses.o: curses.c keymaps.h curses_keys.h -####################################################################### -# USER_OBJS is code used by qemu userspace emulation -USER_OBJS=cutils.o cache-utils.o +bt-host.o: QEMU_CFLAGS += $(BLUEZ_CFLAGS) -libqemu_user.a: $(USER_OBJS) +libqemu_common.a: $(obj-y) ###################################################################### -qemu-img$(EXESUF): qemu-img.o qemu-tool.o osdep.o $(BLOCK_OBJS) +qemu-img.o: qemu-img-cmds.h + +qemu-img$(EXESUF): qemu-img.o qemu-tool.o $(block-obj-y) $(qobject-obj-y) + +qemu-nbd$(EXESUF): qemu-nbd.o qemu-tool.o $(block-obj-y) $(qobject-obj-y) + +qemu-io$(EXESUF): qemu-io.o qemu-tool.o cmd.o $(block-obj-y) $(qobject-obj-y) -qemu-nbd$(EXESUF): qemu-nbd.o qemu-tool.o osdep.o $(BLOCK_OBJS) +qemu-img-cmds.h: $(SRC_PATH)/qemu-img-cmds.hx + $(call quiet-command,sh $(SRC_PATH)/hxtool -h < $< > $@," GEN $@") -qemu-img$(EXESUF) qemu-nbd$(EXESUF): LIBS += -lz +check-qint: check-qint.o qint.o qemu-malloc.o +check-qstring: check-qstring.o qstring.o qemu-malloc.o +check-qdict: check-qdict.o qdict.o qint.o qstring.o qbool.o qemu-malloc.o qlist.o +check-qlist: check-qlist.o qlist.o qint.o qemu-malloc.o +check-qfloat: check-qfloat.o qfloat.o qemu-malloc.o +check-qjson: check-qjson.o qfloat.o qint.o qdict.o qstring.o qlist.o qbool.o qjson.o json-streamer.o json-lexer.o json-parser.o qemu-malloc.o clean: # avoid old build problems by removing potentially incorrect old files - rm -f config.mak config.h op-i386.h opc-i386.h gen-op-i386.h op-arm.h opc-arm.h gen-op-arm.h + rm -f config.mak op-i386.h opc-i386.h gen-op-i386.h op-arm.h opc-arm.h gen-op-arm.h rm -f *.o *.d *.a $(TOOLS) TAGS cscope.* *.pod *~ */*~ - rm -f slirp/*.o slirp/*.d audio/*.o audio/*.d + rm -f slirp/*.o slirp/*.d audio/*.o audio/*.d block/*.o block/*.d net/*.o net/*.d + rm -f qemu-img-cmds.h $(MAKE) -C tests clean - for d in $(TARGET_DIRS); do \ - $(MAKE) -C $$d $@ || exit 1 ; \ + for d in $(ALL_SUBDIRS) libhw32 libhw64 libuser; do \ + if test -d $$d; then $(MAKE) -C $$d $@ || exit 1; fi; \ done distclean: clean - rm -f config-host.mak config-host.h $(DOCS) + rm -f config-host.mak config-host.h* config-host.ld $(DOCS) qemu-options.texi qemu-img-cmds.texi qemu-monitor.texi + rm -f config-all-devices.mak + rm -f roms/seabios/config.mak roms/vgabios/config.mak rm -f qemu-{doc,tech}.{info,aux,cp,dvi,fn,info,ky,log,pg,toc,tp,vr} - for d in $(TARGET_DIRS); do \ + for d in $(TARGET_DIRS) libhw32 libhw64 libuser; do \ rm -rf $$d || exit 1 ; \ done @@ -213,39 +278,40 @@ common de-ch es fo fr-ca hu ifdef INSTALL_BLOBS BLOBS=bios.bin vgabios.bin vgabios-cirrus.bin ppc_rom.bin \ video.x openbios-sparc32 openbios-sparc64 openbios-ppc \ -pxe-ne2k_pci.bin pxe-rtl8139.bin pxe-pcnet.bin pxe-e1000.bin \ -bamboo.dtb +pxe-e1000.bin pxe-i82559er.bin \ +pxe-ne2k_pci.bin pxe-pcnet.bin \ +pxe-rtl8139.bin pxe-virtio.bin \ +bamboo.dtb petalogix-s3adsp1800.dtb \ +multiboot.bin linuxboot.bin else BLOBS= endif install-doc: $(DOCS) - mkdir -p "$(DESTDIR)$(docdir)" - $(INSTALL) -m 644 qemu-doc.html qemu-tech.html "$(DESTDIR)$(docdir)" -ifndef CONFIG_WIN32 - mkdir -p "$(DESTDIR)$(mandir)/man1" - $(INSTALL) -m 644 qemu.1 qemu-img.1 "$(DESTDIR)$(mandir)/man1" - mkdir -p "$(DESTDIR)$(mandir)/man8" - $(INSTALL) -m 644 qemu-nbd.8 "$(DESTDIR)$(mandir)/man8" + $(INSTALL_DIR) "$(DESTDIR)$(docdir)" + $(INSTALL_DATA) qemu-doc.html qemu-tech.html "$(DESTDIR)$(docdir)" +ifdef CONFIG_POSIX + $(INSTALL_DIR) "$(DESTDIR)$(mandir)/man1" + $(INSTALL_DATA) qemu.1 qemu-img.1 "$(DESTDIR)$(mandir)/man1" + $(INSTALL_DIR) "$(DESTDIR)$(mandir)/man8" + $(INSTALL_DATA) qemu-nbd.8 "$(DESTDIR)$(mandir)/man8" endif install: all $(if $(BUILD_DOCS),install-doc) - mkdir -p "$(DESTDIR)$(bindir)" + $(INSTALL_DIR) "$(DESTDIR)$(bindir)" ifneq ($(TOOLS),) - $(INSTALL) -m 755 -s $(TOOLS) "$(DESTDIR)$(bindir)" + $(INSTALL_PROG) $(STRIP_OPT) $(TOOLS) "$(DESTDIR)$(bindir)" endif ifneq ($(BLOBS),) - mkdir -p "$(DESTDIR)$(datadir)" + $(INSTALL_DIR) "$(DESTDIR)$(datadir)" set -e; for x in $(BLOBS); do \ - $(INSTALL) -m 644 $(SRC_PATH)/pc-bios/$$x "$(DESTDIR)$(datadir)"; \ + $(INSTALL_DATA) $(SRC_PATH)/pc-bios/$$x "$(DESTDIR)$(datadir)"; \ done endif -ifndef CONFIG_WIN32 - mkdir -p "$(DESTDIR)$(datadir)/keymaps" + $(INSTALL_DIR) "$(DESTDIR)$(datadir)/keymaps" set -e; for x in $(KEYMAPS); do \ - $(INSTALL) -m 644 $(SRC_PATH)/keymaps/$$x "$(DESTDIR)$(datadir)/keymaps"; \ + $(INSTALL_DATA) $(SRC_PATH)/pc-bios/keymaps/$$x "$(DESTDIR)$(datadir)/keymaps"; \ done -endif for d in $(TARGET_DIRS); do \ $(MAKE) -C $$d $@ || exit 1 ; \ done @@ -254,8 +320,9 @@ endif test speed: all $(MAKE) -C tests $@ +.PHONY: TAGS TAGS: - etags *.[ch] tests/*.[ch] + find "$(SRC_PATH)" -name '*.[hc]' -print0 | xargs -0 etags cscope: rm -f ./cscope.* @@ -264,25 +331,40 @@ cscope: # documentation %.html: %.texi - texi2html -monolithic -number $< + $(call quiet-command,texi2html -I=. -monolithic -number $<," GEN $@") %.info: %.texi - makeinfo $< -o $@ + $(call quiet-command,makeinfo -I . $< -o $@," GEN $@") %.dvi: %.texi - texi2dvi $< + $(call quiet-command,texi2dvi -I . $<," GEN $@") + +qemu-options.texi: $(SRC_PATH)/qemu-options.hx + $(call quiet-command,sh $(SRC_PATH)/hxtool -t < $< > $@," GEN $@") + +qemu-monitor.texi: $(SRC_PATH)/qemu-monitor.hx + $(call quiet-command,sh $(SRC_PATH)/hxtool -t < $< > $@," GEN $@") -qemu.1: qemu-doc.texi - $(SRC_PATH)/texi2pod.pl $< qemu.pod - pod2man --section=1 --center=" " --release=" " qemu.pod > $@ - -qemu-img.1: qemu-img.texi - $(SRC_PATH)/texi2pod.pl $< qemu-img.pod - pod2man --section=1 --center=" " --release=" " qemu-img.pod > $@ +qemu-img-cmds.texi: $(SRC_PATH)/qemu-img-cmds.hx + $(call quiet-command,sh $(SRC_PATH)/hxtool -t < $< > $@," GEN $@") + +qemu.1: qemu-doc.texi qemu-options.texi qemu-monitor.texi + $(call quiet-command, \ + perl -Ww -- $(SRC_PATH)/texi2pod.pl $< qemu.pod && \ + pod2man --section=1 --center=" " --release=" " qemu.pod > $@, \ + " GEN $@") + +qemu-img.1: qemu-img.texi qemu-img-cmds.texi + $(call quiet-command, \ + perl -Ww -- $(SRC_PATH)/texi2pod.pl $< qemu-img.pod && \ + pod2man --section=1 --center=" " --release=" " qemu-img.pod > $@, \ + " GEN $@") qemu-nbd.8: qemu-nbd.texi - $(SRC_PATH)/texi2pod.pl $< qemu-nbd.pod - pod2man --section=8 --center=" " --release=" " qemu-nbd.pod > $@ + $(call quiet-command, \ + perl -Ww -- $(SRC_PATH)/texi2pod.pl $< qemu-nbd.pod && \ + pod2man --section=8 --center=" " --release=" " qemu-nbd.pod > $@, \ + " GEN $@") info: qemu-doc.info qemu-tech.info @@ -290,7 +372,7 @@ dvi: qemu-doc.dvi qemu-tech.dvi html: qemu-doc.html qemu-tech.html -qemu-doc.dvi qemu-doc.html qemu-doc.info: qemu-img.texi qemu-nbd.texi +qemu-doc.dvi qemu-doc.html qemu-doc.info: qemu-img.texi qemu-nbd.texi qemu-options.texi qemu-monitor.texi qemu-img-cmds.texi VERSION ?= $(shell cat VERSION) FILE = qemu-$(VERSION) @@ -310,6 +392,7 @@ tarbin: $(bindir)/qemu-system-arm \ $(bindir)/qemu-system-cris \ $(bindir)/qemu-system-m68k \ + $(bindir)/qemu-system-microblaze \ $(bindir)/qemu-system-mips \ $(bindir)/qemu-system-mipsel \ $(bindir)/qemu-system-mips64 \ @@ -327,6 +410,7 @@ tarbin: $(bindir)/qemu-armeb \ $(bindir)/qemu-cris \ $(bindir)/qemu-m68k \ + $(bindir)/qemu-microblaze \ $(bindir)/qemu-mips \ $(bindir)/qemu-mipsel \ $(bindir)/qemu-ppc \ @@ -358,4 +442,4 @@ tarbin: $(mandir)/man8/qemu-nbd.8 # Include automatically generated dependency files --include $(wildcard *.d audio/*.d slirp/*.d) +-include $(wildcard *.d audio/*.d slirp/*.d block/*.d net/*.d)