X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;f=Makefile;h=f80db8be9f2d1f91d2416173331f4c0827403a0d;hb=2518bd0dc210cfd167e3378c1bd9cfa5a89ebca2;hp=397ddf1342a439992c8a978595e24f33c6a46cba;hpb=367e86e8476d6373a00d0e56a29b03c4b8f3e2ee;p=qemu.git diff --git a/Makefile b/Makefile index 397ddf134..f80db8be9 100644 --- a/Makefile +++ b/Makefile @@ -1,86 +1,108 @@ -ARCH=i386 -#ARCH=ppc -HOST_CC=gcc +include config-host.mak -ifeq ($(ARCH),i386) -CFLAGS=-Wall -O2 -g -fomit-frame-pointer +CFLAGS=-Wall -O2 -g -fno-strict-aliasing +ifdef CONFIG_DARWIN +CFLAGS+= -mdynamic-no-pic +endif +ifdef CONFIG_WIN32 +CFLAGS+=-fpack-struct +endif LDFLAGS=-g LIBS= -CC=gcc -DEFINES=-DHAVE_BYTESWAP_H +DEFINES+=-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE +TOOLS=qemu-img +ifdef CONFIG_STATIC +LDFLAGS+=-static endif -ifeq ($(ARCH),ppc) -GCC_LIBS_DIR=/usr/netgem/tools/lib/gcc-lib/powerpc-linux/2.95.2 -DIST=/home/fbe/nsv/dist/hw/n6-dtt -CC=powerpc-linux-gcc -msoft-float -CFLAGS=-Wall -pipe -O2 -mcpu=405 -mbig -nostdinc -g -I$(GCC_LIBS_DIR)/include -I$(DIST)/include -LIBS_DIR=$(DIST)/lib -CRT1=$(LIBS_DIR)/crt1.o -CRTI=$(LIBS_DIR)/crti.o -CRTN=$(LIBS_DIR)/crtn.o -CRTBEGIN=$(GCC_LIBS_DIR)/crtbegin.o -CRTEND=$(GCC_LIBS_DIR)/crtend.o -LDFLAGS=-static -g -nostdlib $(CRT1) $(CRTI) $(CRTBEGIN) -LIBS=-L$(LIBS_DIR) -ltinyc -lgcc $(CRTEND) $(CRTN) -DEFINES=-Dsocklen_t=int -endif - -######################################################### - -DEFINES+=-D_GNU_SOURCE -DGEMU -DDOSEMU -DNO_TRACE_MSGS -DEFINES+=-DCONFIG_PREFIX=\"/usr/local\" -LDSCRIPT=$(ARCH).ld -LIBS+=-ldl - -OBJS= i386/fp87.o i386/interp_main.o i386/interp_modrm.o i386/interp_16_32.o \ - i386/interp_32_16.o i386/interp_32_32.o i386/emu-utils.o \ - i386/dis8086.o i386/emu-ldt.o -OBJS+=translate-i386.o op-i386.o -OBJS+= elfload.o main.o thunk.o syscall.o -SRCS = $(OBJS:.o=.c) - -all: gemu - -gemu: $(OBJS) - $(CC) -Wl,-T,$(LDSCRIPT) $(LDFLAGS) -o $@ $^ $(LIBS) - -depend: $(SRCS) - $(CC) -MM $(CFLAGS) $^ 1>.depend +all: dyngen$(EXESUF) $(TOOLS) qemu-doc.html qemu-tech.html qemu.1 + for d in $(TARGET_DIRS); do \ + $(MAKE) -C $$d $@ || exit 1 ; \ + done -# old i386 emulator -i386/interp_32_32.o: i386/interp_32_32.c i386/interp_gen.h +qemu-img: qemu-img.c block.c block-cow.c block-qcow.c aes.c block-vmdk.c block-cloop.c + $(CC) -DQEMU_TOOL $(CFLAGS) $(LDFLAGS) $(DEFINES) -o $@ $^ -lz $(LIBS) -i386/interp_gen.h: i386/gencode - ./i386/gencode > $@ - -i386/gencode: i386/gencode.c - $(CC) -O2 -Wall -g $< -o $@ - -# new i386 emulator -dyngen: dyngen.c - $(HOST_CC) -O2 -Wall -g $< -o $@ - -translate-i386.o: translate-i386.c op-i386.h cpu-i386.h - -op-i386.h: op-i386.o dyngen - ./dyngen -o $@ $< - -op-i386.o: op-i386.c opreg_template.h ops_template.h - $(CC) $(CFLAGS) $(DEFINES) -c -o $@ $< - -%.o: %.c - $(CC) $(CFLAGS) $(DEFINES) -c -o $@ $< +dyngen$(EXESUF): dyngen.c + $(HOST_CC) $(CFLAGS) $(DEFINES) -o $@ $^ clean: - rm -f *.o *~ i386/*.o i386/*~ gemu TAGS +# 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 *.o *.a $(TOOLS) dyngen$(EXESUF) TAGS qemu.pod + $(MAKE) -C tests clean + for d in $(TARGET_DIRS); do \ + $(MAKE) -C $$d $@ || exit 1 ; \ + done + +distclean: clean + rm -f config-host.mak config-host.h + for d in $(TARGET_DIRS); do \ + rm -rf $$d || exit 1 ; \ + done + +install: all + mkdir -p "$(bindir)" +ifndef CONFIG_WIN32 + install -m 755 -s $(TOOLS) "$(bindir)" +endif + mkdir -p "$(datadir)" + install -m 644 pc-bios/bios.bin pc-bios/vgabios.bin \ + pc-bios/vgabios-cirrus.bin \ + pc-bios/ppc_rom.bin \ + pc-bios/linux_boot.bin "$(datadir)" + mkdir -p "$(docdir)" + install -m 644 qemu-doc.html qemu-tech.html "$(docdir)" +ifndef CONFIG_WIN32 + mkdir -p "$(mandir)/man1" + install qemu.1 qemu-mkcow.1 "$(mandir)/man1" +endif + for d in $(TARGET_DIRS); do \ + $(MAKE) -C $$d $@ || exit 1 ; \ + done # various test targets -test speed: gemu - make -C tests $@ +test speed test2: all + $(MAKE) -C tests $@ TAGS: - etags *.[ch] i386/*.[ch] + etags *.[ch] tests/*.[ch] + +# documentation +%.html: %.texi + texi2html -monolithic -number $< + +qemu.1: qemu-doc.texi + ./texi2pod.pl $< qemu.pod + pod2man --section=1 --center=" " --release=" " qemu.pod > $@ + +FILE=qemu-$(shell cat VERSION) + +# tar release (use 'make -k tar' on a checkouted tree) +tar: + rm -rf /tmp/$(FILE) + cp -r . /tmp/$(FILE) + ( cd /tmp ; tar zcvf ~/$(FILE).tar.gz $(FILE) --exclude CVS ) + rm -rf /tmp/$(FILE) + +# generate a binary distribution +tarbin: + ( cd / ; tar zcvf ~/qemu-$(VERSION)-i386.tar.gz \ + $(bindir)/qemu $(bindir)/qemu-fast \ + $(bindir)/qemu-system-ppc \ + $(bindir)/qemu-i386 \ + $(bindir)/qemu-arm \ + $(bindir)/qemu-sparc \ + $(bindir)/qemu-ppc \ + $(bindir)/qemu-img \ + $(datadir)/bios.bin \ + $(datadir)/vgabios.bin \ + $(datadir)/vgabios-cirrus.bin \ + $(datadir)/ppc_rom.bin \ + $(datadir)/linux_boot.bin \ + $(docdir)/qemu-doc.html \ + $(docdir)/qemu-tech.html \ + $(mandir)/man1/qemu.1 $(mandir)/man1/qemu-mkcow.1 ) ifneq ($(wildcard .depend),) include .depend