From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1NJjPu-00005G-Ud for qemu-devel@nongnu.org; Sun, 13 Dec 2009 03:02:58 -0500 Received: from exim by lists.gnu.org with spam-scanned (Exim 4.43) id 1NJjPq-0008Ui-Na for qemu-devel@nongnu.org; Sun, 13 Dec 2009 03:02:58 -0500 Received: from [199.232.76.173] (port=47359 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1NJjPq-0008Uf-IN for qemu-devel@nongnu.org; Sun, 13 Dec 2009 03:02:54 -0500 Received: from fmmailgate01.web.de ([217.72.192.221]:60392) by monty-python.gnu.org with esmtp (Exim 4.60) (envelope-from ) id 1NJjPp-0004N2-E0 for qemu-devel@nongnu.org; Sun, 13 Dec 2009 03:02:54 -0500 From: =?UTF-8?q?Andreas=20F=C3=A4rber?= Date: Sun, 13 Dec 2009 09:02:12 +0100 Message-Id: <1260691332-6333-1-git-send-email-andreas.faerber@web.de> In-Reply-To: References: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: andreas.faerber@web.de Content-Transfer-Encoding: quoted-printable Subject: [Qemu-devel] [PATCH] Drop --whole-archive and static libraries List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: =?UTF-8?q?Andreas=20F=C3=A4rber?= , Juan Quintela From: Andreas F=C3=A4rber Juan has donated a cool Makefile infrastructure that enables us to drop static libraries completely: Move shared obj-y definitions to Makefile.objs, prefixed common-, hw-, us= er-. Link those object files directly. Replace HWLIB by HWDIR, specifying only the directory. Drop --whole-archive and ARLIBS in Makefiles and configure. Drop GENERATED_HEADERS dependency in rules.mak, since this rebuilds all common objects after generating a target-specific header. Add dependency rules to Makefile and Makefile.target instead. The early bird catches the bug or so... Signed-off-by: Andreas F=C3=A4rber Cc: Juan Quintela --- Makefile | 123 ++------------------------------------------ Makefile.hw | 33 +----------- Makefile.objs | 156 +++++++++++++++++++++++++++++++++++++++++++++++++= ++++++ Makefile.target | 30 ++++++++--- Makefile.user | 9 +--- configure | 34 +------------ rules.mak | 4 +- 7 files changed, 190 insertions(+), 199 deletions(-) create mode 100644 Makefile.objs diff --git a/Makefile b/Makefile index a662d96..c348ac8 100644 --- a/Makefile +++ b/Makefile @@ -66,7 +66,10 @@ SUBDIR_RULES=3D$(patsubst %,subdir-%, $(TARGET_DIRS)) subdir-%: $(GENERATED_HEADERS) $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) -C $* V=3D"$(V)" TARGE= T_DIR=3D"$*/" all,) =20 -$(filter %-softmmu,$(SUBDIR_RULES)): libqemu_common.a +include $(SRC_PATH)/Makefile.objs + +$(common-obj-y): $(GENERATED_HEADERS) +$(filter %-softmmu,$(SUBDIR_RULES)): $(common-obj-y) =20 $(filter %-user,$(SUBDIR_RULES)): libuser.a =20 @@ -81,124 +84,8 @@ ALL_SUBDIRS=3D$(TARGET_DIRS) $(patsubst %,pc-bios/%, = $(ROMS)) =20 recurse-all: $(SUBDIR_RULES) $(ROMSUBDIR_RULES) =20 -####################################################################### -# QObject -qobject-obj-y =3D qint.o qstring.o qdict.o qlist.o qfloat.o qbool.o -qobject-obj-y +=3D qjson.o json-lexer.o json-streamer.o json-parser.o -qobject-obj-y +=3D qerror.o - -####################################################################### -# block-obj-y is code used by both qemu system emulation and qemu-img - -block-obj-y =3D cutils.o cache-utils.o qemu-malloc.o qemu-option.o modul= e.o -block-obj-y +=3D nbd.o block.o aio.o aes.o osdep.o -block-obj-$(CONFIG_POSIX) +=3D posix-aio-compat.o -block-obj-$(CONFIG_LINUX_AIO) +=3D linux-aio.o - -block-nested-y +=3D cow.o qcow.o vdi.o vmdk.o cloop.o dmg.o bochs.o vpc.= o vvfat.o -block-nested-y +=3D qcow2.o qcow2-refcount.o qcow2-cluster.o qcow2-snaps= hot.o -block-nested-y +=3D parallels.o nbd.o -block-nested-$(CONFIG_WIN32) +=3D raw-win32.o -block-nested-$(CONFIG_POSIX) +=3D raw-posix.o -block-nested-$(CONFIG_CURL) +=3D curl.o - -block-obj-y +=3D $(addprefix block/, $(block-nested-y)) - -net-obj-y =3D net.o -net-nested-y =3D queue.o checksum.o util.o -net-nested-y +=3D socket.o -net-nested-y +=3D dump.o -net-nested-$(CONFIG_POSIX) +=3D tap.o -net-nested-$(CONFIG_LINUX) +=3D tap-linux.o -net-nested-$(CONFIG_WIN32) +=3D tap-win32.o -net-nested-$(CONFIG_BSD) +=3D tap-bsd.o -net-nested-$(CONFIG_SOLARIS) +=3D tap-solaris.o -net-nested-$(CONFIG_AIX) +=3D tap-aix.o -net-nested-$(CONFIG_SLIRP) +=3D slirp.o -net-nested-$(CONFIG_VDE) +=3D vde.o -net-obj-y +=3D $(addprefix net/, $(net-nested-y)) - -###################################################################### -# libqemu_common.a: Target independent part of system emulation. The -# long term path is to suppress *all* target specific code in case of -# system emulation, i.e. a single QEMU executable should support all -# CPUs and machines. - -obj-y =3D $(block-obj-y) -obj-y +=3D $(net-obj-y) -obj-y +=3D $(qobject-obj-y) -obj-y +=3D readline.o console.o - -obj-y +=3D tcg-runtime.o host-utils.o -obj-y +=3D irq.o ioport.o -obj-$(CONFIG_PTIMER) +=3D ptimer.o -obj-$(CONFIG_MAX7310) +=3D max7310.o -obj-$(CONFIG_WM8750) +=3D wm8750.o -obj-$(CONFIG_TWL92230) +=3D twl92230.o -obj-$(CONFIG_TSC2005) +=3D tsc2005.o -obj-$(CONFIG_LM832X) +=3D lm832x.o -obj-$(CONFIG_TMP105) +=3D tmp105.o -obj-$(CONFIG_STELLARIS_INPUT) +=3D stellaris_input.o -obj-$(CONFIG_SSD0303) +=3D ssd0303.o -obj-$(CONFIG_SSD0323) +=3D ssd0323.o -obj-$(CONFIG_ADS7846) +=3D ads7846.o -obj-$(CONFIG_MAX111X) +=3D max111x.o -obj-$(CONFIG_DS1338) +=3D ds1338.o -obj-y +=3D i2c.o smbus.o smbus_eeprom.o -obj-y +=3D eeprom93xx.o -obj-y +=3D scsi-disk.o cdrom.o -obj-y +=3D scsi-generic.o scsi-bus.o -obj-y +=3D usb.o usb-hub.o usb-$(HOST_USB).o usb-hid.o usb-msd.o usb-wac= om.o -obj-y +=3D usb-serial.o usb-net.o usb-bus.o -obj-$(CONFIG_SSI) +=3D ssi.o -obj-$(CONFIG_SSI_SD) +=3D ssi-sd.o -obj-$(CONFIG_SD) +=3D sd.o -obj-y +=3D 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 +=3D bt-hci-csr.o -obj-y +=3D buffered_file.o migration.o migration-tcp.o qemu-sockets.o -obj-y +=3D qemu-char.o aio.o savevm.o -obj-y +=3D msmouse.o ps2.o -obj-y +=3D qdev.o qdev-properties.o -obj-y +=3D qemu-config.o block-migration.o - -obj-$(CONFIG_BRLAPI) +=3D baum.o -obj-$(CONFIG_POSIX) +=3D migration-exec.o migration-unix.o migration-fd.= o - audio/audio.o audio/fmodaudio.o: QEMU_CFLAGS +=3D $(FMOD_CFLAGS) =20 -audio-obj-y =3D audio.o noaudio.o wavaudio.o mixeng.o -audio-obj-$(CONFIG_SDL) +=3D sdlaudio.o -audio-obj-$(CONFIG_OSS) +=3D ossaudio.o -audio-obj-$(CONFIG_COREAUDIO) +=3D coreaudio.o -audio-obj-$(CONFIG_ALSA) +=3D alsaaudio.o -audio-obj-$(CONFIG_DSOUND) +=3D dsoundaudio.o -audio-obj-$(CONFIG_FMOD) +=3D fmodaudio.o -audio-obj-$(CONFIG_ESD) +=3D esdaudio.o -audio-obj-$(CONFIG_PA) +=3D paaudio.o -audio-obj-$(CONFIG_WINWAVE) +=3D winwaveaudio.o -audio-obj-$(CONFIG_AUDIO_PT_INT) +=3D audio_pt_int.o -audio-obj-$(CONFIG_AUDIO_WIN_INT) +=3D audio_win_int.o -audio-obj-y +=3D wavcapture.o -obj-y +=3D $(addprefix audio/, $(audio-obj-y)) - -obj-y +=3D keymaps.o -obj-$(CONFIG_SDL) +=3D sdl.o sdl_zoom.o x_keymap.o -obj-$(CONFIG_CURSES) +=3D curses.o -obj-y +=3D vnc.o acl.o d3des.o -obj-$(CONFIG_VNC_TLS) +=3D vnc-tls.o vnc-auth-vencrypt.o -obj-$(CONFIG_VNC_SASL) +=3D vnc-auth-sasl.o -obj-$(CONFIG_COCOA) +=3D cocoa.o -obj-$(CONFIG_IOTHREAD) +=3D qemu-thread.o - -slirp-obj-y =3D cksum.o if.o ip_icmp.o ip_input.o ip_output.o -slirp-obj-y +=3D slirp.o mbuf.o misc.o sbuf.o socket.o tcp_input.o tcp_o= utput.o -slirp-obj-y +=3D tcp_subr.o tcp_timer.o udp.o bootp.o tftp.o -obj-$(CONFIG_SLIRP) +=3D $(addprefix slirp/, $(slirp-obj-y)) - -# xen backend driver support -obj-$(CONFIG_XEN) +=3D xen_backend.o xen_devconfig.o -obj-$(CONFIG_XEN) +=3D xen_console.o xenfb.o xen_disk.o xen_nic.o - QEMU_CFLAGS+=3D$(CURL_CFLAGS) =20 cocoa.o: cocoa.m @@ -229,8 +116,6 @@ curses.o: curses.c keymaps.h curses_keys.h =20 bt-host.o: QEMU_CFLAGS +=3D $(BLUEZ_CFLAGS) =20 -libqemu_common.a: $(obj-y) - ###################################################################### =20 qemu-img.o: qemu-img-cmds.h diff --git a/Makefile.hw b/Makefile.hw index bd252f5..ff87ae4 100644 --- a/Makefile.hw +++ b/Makefile.hw @@ -11,41 +11,12 @@ VPATH=3D$(SRC_PATH):$(SRC_PATH)/hw =20 QEMU_CFLAGS+=3D-I.. -I$(SRC_PATH)/fpu =20 -obj-y =3D -obj-y +=3D loader.o -obj-y +=3D virtio.o -obj-y +=3D fw_cfg.o -obj-y +=3D watchdog.o -obj-$(CONFIG_ECC) +=3D ecc.o -obj-$(CONFIG_NAND) +=3D nand.o +include $(SRC_PATH)/Makefile.objs =20 -obj-$(CONFIG_M48T59) +=3D m48t59.o -obj-$(CONFIG_ESCC) +=3D escc.o - -# PCI watchdog devices -obj-y +=3D wdt_i6300esb.o - -obj-y +=3D msix.o - -# PCI network cards -obj-y +=3D ne2000.o - -obj-$(CONFIG_SMC91C111) +=3D smc91c111.o -obj-$(CONFIG_LAN9118) +=3D lan9118.o - -# SCSI layer -obj-y +=3D lsi53c895a.o -obj-$(CONFIG_ESP) +=3D esp.o - -obj-y +=3D dma-helpers.o sysbus.o isa-bus.o -obj-$(CONFIG_QDEV_ADDR) +=3D qdev-addr.o - -all: $(HWLIB) +all: $(hw-obj-y) # Dummy command so that make thinks it has done something @true =20 -$(HWLIB): $(obj-y) - clean: rm -f *.o *.d *.a *~ =20 diff --git a/Makefile.objs b/Makefile.objs new file mode 100644 index 0000000..fd69717 --- /dev/null +++ b/Makefile.objs @@ -0,0 +1,156 @@ +####################################################################### +# QObject +qobject-obj-y =3D qint.o qstring.o qdict.o qlist.o qfloat.o qbool.o +qobject-obj-y +=3D qjson.o json-lexer.o json-streamer.o json-parser.o +qobject-obj-y +=3D qerror.o + +####################################################################### +# block-obj-y is code used by both qemu system emulation and qemu-img + +block-obj-y =3D cutils.o cache-utils.o qemu-malloc.o qemu-option.o modul= e.o +block-obj-y +=3D nbd.o block.o aio.o aes.o osdep.o +block-obj-$(CONFIG_POSIX) +=3D posix-aio-compat.o +block-obj-$(CONFIG_LINUX_AIO) +=3D linux-aio.o + +block-nested-y +=3D cow.o qcow.o vdi.o vmdk.o cloop.o dmg.o bochs.o vpc.= o vvfat.o +block-nested-y +=3D qcow2.o qcow2-refcount.o qcow2-cluster.o qcow2-snaps= hot.o +block-nested-y +=3D parallels.o nbd.o +block-nested-$(CONFIG_WIN32) +=3D raw-win32.o +block-nested-$(CONFIG_POSIX) +=3D raw-posix.o +block-nested-$(CONFIG_CURL) +=3D curl.o + +block-obj-y +=3D $(addprefix block/, $(block-nested-y)) + +net-obj-y =3D net.o +net-nested-y =3D queue.o checksum.o util.o +net-nested-y +=3D socket.o +net-nested-y +=3D dump.o +net-nested-$(CONFIG_POSIX) +=3D tap.o +net-nested-$(CONFIG_LINUX) +=3D tap-linux.o +net-nested-$(CONFIG_WIN32) +=3D tap-win32.o +net-nested-$(CONFIG_BSD) +=3D tap-bsd.o +net-nested-$(CONFIG_SOLARIS) +=3D tap-solaris.o +net-nested-$(CONFIG_AIX) +=3D tap-aix.o +net-nested-$(CONFIG_SLIRP) +=3D slirp.o +net-nested-$(CONFIG_VDE) +=3D vde.o +net-obj-y +=3D $(addprefix net/, $(net-nested-y)) + +###################################################################### +# libqemu_common.a: Target independent part of system emulation. The +# long term path is to suppress *all* target specific code in case of +# system emulation, i.e. a single QEMU executable should support all +# CPUs and machines. + +common-obj-y =3D $(block-obj-y) +common-obj-y +=3D $(net-obj-y) +common-obj-y +=3D $(qobject-obj-y) +common-obj-y +=3D readline.o console.o + +common-obj-y +=3D tcg-runtime.o host-utils.o +common-obj-y +=3D irq.o ioport.o +common-obj-$(CONFIG_PTIMER) +=3D ptimer.o +common-obj-$(CONFIG_MAX7310) +=3D max7310.o +common-obj-$(CONFIG_WM8750) +=3D wm8750.o +common-obj-$(CONFIG_TWL92230) +=3D twl92230.o +common-obj-$(CONFIG_TSC2005) +=3D tsc2005.o +common-obj-$(CONFIG_LM832X) +=3D lm832x.o +common-obj-$(CONFIG_TMP105) +=3D tmp105.o +common-obj-$(CONFIG_STELLARIS_INPUT) +=3D stellaris_input.o +common-obj-$(CONFIG_SSD0303) +=3D ssd0303.o +common-obj-$(CONFIG_SSD0323) +=3D ssd0323.o +common-obj-$(CONFIG_ADS7846) +=3D ads7846.o +common-obj-$(CONFIG_MAX111X) +=3D max111x.o +common-obj-$(CONFIG_DS1338) +=3D ds1338.o +common-obj-y +=3D i2c.o smbus.o smbus_eeprom.o +common-obj-y +=3D eeprom93xx.o +common-obj-y +=3D scsi-disk.o cdrom.o +common-obj-y +=3D scsi-generic.o scsi-bus.o +common-obj-y +=3D usb.o usb-hub.o usb-$(HOST_USB).o usb-hid.o usb-msd.o = usb-wacom.o +common-obj-y +=3D usb-serial.o usb-net.o usb-bus.o +common-obj-$(CONFIG_SSI) +=3D ssi.o +common-obj-$(CONFIG_SSI_SD) +=3D ssi-sd.o +common-obj-$(CONFIG_SD) +=3D sd.o +common-obj-y +=3D bt.o bt-host.o bt-vhci.o bt-l2cap.o bt-sdp.o bt-hci.o = bt-hid.o usb-bt.o +common-obj-y +=3D bt-hci-csr.o +common-obj-y +=3D buffered_file.o migration.o migration-tcp.o qemu-socke= ts.o +common-obj-y +=3D qemu-char.o savevm.o #aio.o +common-obj-y +=3D msmouse.o ps2.o +common-obj-y +=3D qdev.o qdev-properties.o +common-obj-y +=3D qemu-config.o block-migration.o + +common-obj-$(CONFIG_BRLAPI) +=3D baum.o +common-obj-$(CONFIG_POSIX) +=3D migration-exec.o migration-unix.o migrat= ion-fd.o + +audio-obj-y =3D audio.o noaudio.o wavaudio.o mixeng.o +audio-obj-$(CONFIG_SDL) +=3D sdlaudio.o +audio-obj-$(CONFIG_OSS) +=3D ossaudio.o +audio-obj-$(CONFIG_COREAUDIO) +=3D coreaudio.o +audio-obj-$(CONFIG_ALSA) +=3D alsaaudio.o +audio-obj-$(CONFIG_DSOUND) +=3D dsoundaudio.o +audio-obj-$(CONFIG_FMOD) +=3D fmodaudio.o +audio-obj-$(CONFIG_ESD) +=3D esdaudio.o +audio-obj-$(CONFIG_PA) +=3D paaudio.o +audio-obj-$(CONFIG_WINWAVE) +=3D winwaveaudio.o +audio-obj-$(CONFIG_AUDIO_PT_INT) +=3D audio_pt_int.o +audio-obj-$(CONFIG_AUDIO_WIN_INT) +=3D audio_win_int.o +audio-obj-y +=3D wavcapture.o +common-obj-y +=3D $(addprefix audio/, $(audio-obj-y)) + +common-obj-y +=3D keymaps.o +common-obj-$(CONFIG_SDL) +=3D sdl.o sdl_zoom.o x_keymap.o +common-obj-$(CONFIG_CURSES) +=3D curses.o +common-obj-y +=3D vnc.o acl.o d3des.o +common-obj-$(CONFIG_VNC_TLS) +=3D vnc-tls.o vnc-auth-vencrypt.o +common-obj-$(CONFIG_VNC_SASL) +=3D vnc-auth-sasl.o +common-obj-$(CONFIG_COCOA) +=3D cocoa.o +common-obj-$(CONFIG_IOTHREAD) +=3D qemu-thread.o + +slirp-obj-y =3D cksum.o if.o ip_icmp.o ip_input.o ip_output.o +slirp-obj-y +=3D slirp.o mbuf.o misc.o sbuf.o socket.o tcp_input.o tcp_o= utput.o +slirp-obj-y +=3D tcp_subr.o tcp_timer.o udp.o bootp.o tftp.o +common-obj-$(CONFIG_SLIRP) +=3D $(addprefix slirp/, $(slirp-obj-y)) + +# xen backend driver support +common-obj-$(CONFIG_XEN) +=3D xen_backend.o xen_devconfig.o +common-obj-$(CONFIG_XEN) +=3D xen_console.o xenfb.o xen_disk.o xen_nic.o + +###################################################################### +# libuser + +user-obj-y =3D +user-obj-y +=3D envlist.o path.o +user-obj-y +=3D tcg-runtime.o host-utils.o +user-obj-y +=3D cutils.o cache-utils.o + +###################################################################### +# libhw + +hw-obj-y =3D +hw-obj-y +=3D loader.o +hw-obj-y +=3D virtio.o +hw-obj-y +=3D fw_cfg.o +hw-obj-y +=3D watchdog.o +hw-obj-$(CONFIG_ECC) +=3D ecc.o +hw-obj-$(CONFIG_NAND) +=3D nand.o + +hw-obj-$(CONFIG_M48T59) +=3D m48t59.o +hw-obj-$(CONFIG_ESCC) +=3D escc.o + +# PCI watchdog devices +hw-obj-y +=3D wdt_i6300esb.o + +hw-obj-y +=3D msix.o + +# PCI network cards +hw-obj-y +=3D ne2000.o + +hw-obj-$(CONFIG_SMC91C111) +=3D smc91c111.o +hw-obj-$(CONFIG_LAN9118) +=3D lan9118.o + +# SCSI layer +hw-obj-y +=3D lsi53c895a.o +hw-obj-$(CONFIG_ESP) +=3D esp.o + +hw-obj-y +=3D dma-helpers.o sysbus.o isa-bus.o +hw-obj-$(CONFIG_QDEV_ADDR) +=3D qdev-addr.o + diff --git a/Makefile.target b/Makefile.target index 7c1f30c..22a2f1e 100644 --- a/Makefile.target +++ b/Makefile.target @@ -7,11 +7,14 @@ include ../config-host.mak include config-devices.mak include config-target.mak include $(SRC_PATH)/rules.mak +include $(HWDIR)/config.mak =20 TARGET_PATH=3D$(SRC_PATH)/target-$(TARGET_BASE_ARCH) VPATH=3D$(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw QEMU_CFLAGS+=3D -I.. -I$(TARGET_PATH) -DNEED_CPU_H =20 +include $(SRC_PATH)/Makefile.objs + ifdef CONFIG_USER_ONLY # user emulator name QEMU_PROG=3Dqemu-$(TARGET_ARCH2) @@ -64,9 +67,9 @@ libobj-$(CONFIG_S390_DIS) +=3D s390-dis.o libobj-$(CONFIG_SH4_DIS) +=3D sh4-dis.o libobj-$(CONFIG_SPARC_DIS) +=3D sparc-dis.o =20 -# libqemu +$(libobj-y): $(GENERATED_HEADERS) =20 -libqemu.a: $(libobj-y) +# libqemu =20 translate.o: translate.c cpu.h =20 @@ -106,7 +109,10 @@ obj-arm-y +=3D arm-semi.o =20 obj-m68k-y +=3D m68k-sim.o m68k-semi.o =20 -ARLIBS=3D../libuser/libuser.a libqemu.a +$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS) + +obj-y +=3D $(addprefix ../libuser/, $(user-obj-y)) +obj-y +=3D $(libobj-y) =20 endif #CONFIG_LINUX_USER =20 @@ -128,7 +134,10 @@ obj-y =3D main.o commpage.o machload.o mmap.o signal= .o syscall.o thunk.o \ =20 obj-i386-y +=3D ioport-user.o =20 -ARLIBS=3D../libuser/libuser.a libqemu.a +$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS) + +obj-y +=3D $(addprefix ../libuser/, $(user-obj-y)) +obj-y +=3D $(libobj-y) =20 endif #CONFIG_DARWIN_USER =20 @@ -145,7 +154,10 @@ obj-y =3D main.o bsdload.o elfload.o mmap.o signal.o= strace.o syscall.o \ =20 obj-i386-y +=3D ioport-user.o =20 -ARLIBS=3D../libuser/libuser.a libqemu.a +$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS) + +obj-y +=3D $(addprefix ../libuser/, $(user-obj-y)) +obj-y +=3D $(libobj-y) =20 endif #CONFIG_BSD_USER =20 @@ -303,13 +315,17 @@ vl.o: qemu-options.h =20 monitor.o: qemu-monitor.h =20 -ARLIBS=3D../libqemu_common.a libqemu.a $(HWLIB) +$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS) + +obj-y +=3D $(addprefix ../, $(common-obj-y)) +obj-y +=3D $(libobj-y) +obj-y +=3D $(addprefix $(HWDIR)/, $(hw-obj-y)) =20 endif # CONFIG_SOFTMMU =20 obj-$(CONFIG_GDBSTUB_XML) +=3D gdbstub-xml.o =20 -$(QEMU_PROG): $(obj-y) $(obj-$(TARGET_BASE_ARCH)-y) $(ARLIBS) +$(QEMU_PROG): $(obj-y) $(obj-$(TARGET_BASE_ARCH)-y) $(call LINK,$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y)) =20 =20 diff --git a/Makefile.user b/Makefile.user index 907e74b..4a8824d 100644 --- a/Makefile.user +++ b/Makefile.user @@ -9,17 +9,12 @@ VPATH=3D$(SRC_PATH) =20 QEMU_CFLAGS+=3D-I.. =20 -obj-y =3D -obj-y +=3D envlist.o path.o -obj-y +=3D tcg-runtime.o host-utils.o -obj-y +=3D cutils.o cache-utils.o +include $(SRC_PATH)/Makefile.objs =20 -all: libuser.a +all: $(user-obj-y) # Dummy command so that make thinks it has done something @true =20 -libuser.a: $(obj-y) - clean: rm -f *.o *.d *.a *~ =20 diff --git a/configure b/configure index 273b6b7..6359401 100755 --- a/configure +++ b/configure @@ -1707,37 +1707,6 @@ elif compile_prog "" "-lrt" ; then LIBS=3D"-lrt $LIBS" fi =20 -# Determine what linker flags to use to force archive inclusion -check_linker_flags() -{ - w2=3D - if test "$2" ; then - w2=3D-Wl,$2 - fi - compile_prog "" "-Wl,$1 ${w2}" -} - -cat > $TMPC << EOF -int main(void) { } -EOF -if check_linker_flags --whole-archive --no-whole-archive ; then - # GNU ld - arlibs_begin=3D"-Wl,--whole-archive" - arlibs_end=3D"-Wl,--no-whole-archive" -elif check_linker_flags -z,allextract -z,defaultextract ; then - # Solaris ld - arlibs_begin=3D"-Wl,-z,allextract" - arlibs_end=3D"-Wl,-z,defaultextract" -elif check_linker_flags -all_load ; then - # Mac OS X - arlibs_begin=3D"-all_load" - arlibs_end=3D"" -else - echo "Error: your linker does not support --whole-archive or -z." - echo "Please report to qemu-devel@nongnu.org" - exit 1 -fi - if test "$darwin" !=3D "yes" -a "$mingw32" !=3D "yes" -a "$solaris" !=3D= yes -a \ "$aix" !=3D "yes" ; then libs_softmmu=3D"-lutil $libs_softmmu" @@ -2427,7 +2396,7 @@ fi if test "$target_softmmu" =3D "yes" ; then echo "CONFIG_SOFTMMU=3Dy" >> $config_target_mak echo "LIBS+=3D$libs_softmmu" >> $config_target_mak - echo "HWLIB=3D../libhw$target_phys_bits/libqemuhw$target_phys_bits.a" = >> $config_target_mak + echo "HWDIR=3D../libhw$target_phys_bits" >> $config_target_mak echo "subdir-$target: subdir-libhw$target_phys_bits" >> $config_host_m= ak fi if test "$target_user_only" =3D "yes" ; then @@ -2644,7 +2613,6 @@ for hwlib in 32 64; do mkdir -p $d rm -f $d/Makefile ln -s $source_path/Makefile.hw $d/Makefile - echo "HWLIB=3Dlibqemuhw$hwlib.a" > $d/config.mak echo "QEMU_CFLAGS+=3D-DTARGET_PHYS_ADDR_BITS=3D$hwlib" >> $d/config.ma= k done =20 diff --git a/rules.mak b/rules.mak index 5d9f684..9bcf9af 100644 --- a/rules.mak +++ b/rules.mak @@ -14,7 +14,7 @@ MAKEFLAGS +=3D -rR # Flags for dependency generation QEMU_DGFLAGS +=3D -MMD -MP -MT $@ =20 -%.o: %.c $(GENERATED_HEADERS) +%.o: %.c $(call quiet-command,$(CC) $(QEMU_CFLAGS) $(QEMU_DGFLAGS) $(CFLAGS) -c = -o $@ $<," CC $(TARGET_DIR)$@") =20 %.o: %.S @@ -23,7 +23,7 @@ QEMU_DGFLAGS +=3D -MMD -MP -MT $@ %.o: %.m $(call quiet-command,$(CC) $(QEMU_CFLAGS) $(QEMU_DGFLAGS) $(CFLAGS) -c = -o $@ $<," OBJC $(TARGET_DIR)$@") =20 -LINK =3D $(call quiet-command,$(CC) $(QEMU_CFLAGS) $(CFLAGS) $(LDFLAGS) = -o $@ $(1) $(ARLIBS_BEGIN) $(ARLIBS) $(ARLIBS_END) $(LIBS)," LINK $(TAR= GET_DIR)$@") +LINK =3D $(call quiet-command,$(CC) $(QEMU_CFLAGS) $(CFLAGS) $(LDFLAGS) = -o $@ $(1) $(LIBS)," LINK $(TARGET_DIR)$@") =20 %$(EXESUF): %.o $(call LINK,$^) --=20 1.6.5.3