blob: ef6aef2851bc6ee0a3644e712f275c0de39a084e [file] [log] [blame]
bellard7d132992003-03-06 23:23:54 +00001include config.mak
bellard766a4872003-02-18 23:35:48 +00002
bellard7d132992003-03-06 23:23:54 +00003CFLAGS=-Wall -O2 -g
bellard31e31b82003-02-18 22:55:36 +00004LDFLAGS=-g
bellard766a4872003-02-18 23:35:48 +00005LIBS=
bellard766a4872003-02-18 23:35:48 +00006DEFINES=-DHAVE_BYTESWAP_H
bellard9c5d1242003-06-09 15:33:05 +00007HELPER_CFLAGS=$(CFLAGS)
bellard6b1534c2003-06-25 16:08:39 +00008PROGS=qemu
bellard7d132992003-03-06 23:23:54 +00009
bellard43ce4df2003-06-09 19:53:12 +000010ifdef CONFIG_STATIC
11LDFLAGS+=-static
12endif
13
bellard7d132992003-03-06 23:23:54 +000014ifeq ($(ARCH),i386)
15CFLAGS+=-fomit-frame-pointer
bellardca735202003-03-18 20:41:34 +000016OP_CFLAGS=$(CFLAGS) -mpreferred-stack-boundary=2
bellard6b1534c2003-06-25 16:08:39 +000017ifeq ($(HAVE_GCC3_OPTIONS),yes)
bellardca735202003-03-18 20:41:34 +000018OP_CFLAGS+= -falign-functions=0
19else
20OP_CFLAGS+= -malign-functions=0
21endif
bellard2d92f0b2003-05-28 00:24:44 +000022ifdef TARGET_GPROF
23LDFLAGS+=-Wl,-T,i386.ld
24else
bellard27c75a92003-04-07 21:35:21 +000025# WARNING: this LDFLAGS is _very_ tricky : qemu is an ELF shared object
26# that the kernel ELF loader considers as an executable. I think this
27# is the simplest way to make it self virtualizable!
28LDFLAGS+=-Wl,-shared
bellard766a4872003-02-18 23:35:48 +000029endif
bellard6b1534c2003-06-25 16:08:39 +000030ifeq ($(TARGET_ARCH), i386)
bellard33e39632003-07-06 17:15:21 +000031PROGS+=vl vlmkcow
bellard6b1534c2003-06-25 16:08:39 +000032endif
bellard2d92f0b2003-05-28 00:24:44 +000033endif
bellard766a4872003-02-18 23:35:48 +000034
35ifeq ($(ARCH),ppc)
bellard927f6212003-03-02 19:39:42 +000036OP_CFLAGS=$(CFLAGS)
bellard27c75a92003-04-07 21:35:21 +000037LDFLAGS+=-Wl,-T,ppc.ld
bellard766a4872003-02-18 23:35:48 +000038endif
39
bellardfd429f22003-03-30 20:59:46 +000040ifeq ($(ARCH),s390)
41OP_CFLAGS=$(CFLAGS)
bellard27c75a92003-04-07 21:35:21 +000042LDFLAGS+=-Wl,-T,s390.ld
bellardfd429f22003-03-30 20:59:46 +000043endif
44
bellardae228532003-05-13 18:59:59 +000045ifeq ($(ARCH),sparc)
46CFLAGS+=-m32 -ffixed-g1 -ffixed-g2 -ffixed-g3 -ffixed-g6
47LDFLAGS+=-m32
48OP_CFLAGS=$(CFLAGS) -fno-delayed-branch -ffixed-i0
bellard9c5d1242003-06-09 15:33:05 +000049HELPER_CFLAGS=$(CFLAGS) -ffixed-i0 -mflat
50LDFLAGS+=-Wl,-T,sparc.ld
bellardae228532003-05-13 18:59:59 +000051endif
52
53ifeq ($(ARCH),sparc64)
54CFLAGS+=-m64 -ffixed-g1 -ffixed-g2 -ffixed-g3 -ffixed-g6
55LDFLAGS+=-m64
56OP_CFLAGS=$(CFLAGS) -fno-delayed-branch -ffixed-i0
57endif
58
bellardd6cdca92003-04-29 21:24:00 +000059ifeq ($(ARCH),alpha)
bellarda993ba82003-05-11 12:25:45 +000060# -msmall-data is not used because we want two-instruction relocations
61# for the constant constructions
62OP_CFLAGS=-Wall -O2 -g
bellardd6cdca92003-04-29 21:24:00 +000063# Ensure there's only a single GP
bellard82d19da2003-06-05 00:58:28 +000064CFLAGS += -msmall-data
bellardd6cdca92003-04-29 21:24:00 +000065LDFLAGS+=-Wl,-T,alpha.ld
66endif
67
68ifeq ($(ARCH),ia64)
69OP_CFLAGS=$(CFLAGS)
70endif
71
bellard9c5d1242003-06-09 15:33:05 +000072ifeq ($(ARCH),arm)
73OP_CFLAGS=$(CFLAGS) -mno-sched-prolog
74LDFLAGS+=-Wl,-T,arm.ld
75endif
76
bellard6b1534c2003-06-25 16:08:39 +000077ifeq ($(HAVE_GCC3_OPTIONS),yes)
bellardca735202003-03-18 20:41:34 +000078# very important to generate a return at the end of every operation
79OP_CFLAGS+=-fno-reorder-blocks -fno-optimize-sibling-calls
80endif
81
bellard766a4872003-02-18 23:35:48 +000082#########################################################
83
bellard0ecfa992003-03-03 14:32:43 +000084DEFINES+=-D_GNU_SOURCE
bellard3ef693a2003-03-23 20:17:16 +000085LIBS+=-lm
bellard7d132992003-03-06 23:23:54 +000086
87# profiling code
88ifdef TARGET_GPROF
89LDFLAGS+=-p
bellarddc990652003-03-19 00:00:28 +000090main.o: CFLAGS+=-p
bellard7d132992003-03-06 23:23:54 +000091endif
bellard31e31b82003-02-18 22:55:36 +000092
bellardde83cd02003-06-15 20:25:43 +000093OBJS= elfload.o main.o syscall.o mmap.o signal.o path.o
94ifeq ($(TARGET_ARCH), i386)
95OBJS+= vm86.o
96endif
bellard3ef693a2003-03-23 20:17:16 +000097SRCS:= $(OBJS:.o=.c)
98OBJS+= libqemu.a
bellard612384d2003-03-22 17:31:19 +000099
bellardde83cd02003-06-15 20:25:43 +0000100# cpu emulator library
bellardb4608c02003-06-27 17:34:32 +0000101LIBOBJS=thunk.o exec.o translate.o cpu-exec.o gdbstub.o
bellardde83cd02003-06-15 20:25:43 +0000102
103ifeq ($(TARGET_ARCH), i386)
104LIBOBJS+=translate-i386.o op-i386.o helper-i386.o
105endif
106ifeq ($(TARGET_ARCH), arm)
107LIBOBJS+=translate-arm.o op-arm.o
108endif
bellardaa05ae62003-05-25 16:41:18 +0000109
bellard0ecfa992003-03-03 14:32:43 +0000110# NOTE: the disassembler code is only needed for debugging
bellardde83cd02003-06-15 20:25:43 +0000111LIBOBJS+=disas.o
112ifeq ($(findstring i386, $(TARGET_ARCH) $(ARCH)),i386)
113LIBOBJS+=i386-dis.o
114endif
115ifeq ($(findstring alpha, $(TARGET_ARCH) $(ARCH)),alpha)
bellardaa05ae62003-05-25 16:41:18 +0000116LIBOBJS+=alpha-dis.o
117endif
bellardde83cd02003-06-15 20:25:43 +0000118ifeq ($(findstring ppc, $(TARGET_ARCH) $(ARCH)),ppc)
bellardaa05ae62003-05-25 16:41:18 +0000119LIBOBJS+=ppc-dis.o
120endif
bellardde83cd02003-06-15 20:25:43 +0000121ifeq ($(findstring sparc, $(TARGET_ARCH) $(ARCH)),sparc)
bellard9c5d1242003-06-09 15:33:05 +0000122LIBOBJS+=sparc-dis.o
123endif
bellardde83cd02003-06-15 20:25:43 +0000124ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
bellard9c5d1242003-06-09 15:33:05 +0000125LIBOBJS+=arm-dis.o
126endif
bellard31e31b82003-02-18 22:55:36 +0000127
bellardd6cdca92003-04-29 21:24:00 +0000128ifeq ($(ARCH),ia64)
129OBJS += ia64-syscall.o
130endif
131
bellard6b1534c2003-06-25 16:08:39 +0000132all: $(PROGS) qemu-doc.html
bellard31e31b82003-02-18 22:55:36 +0000133
bellard3ef693a2003-03-23 20:17:16 +0000134qemu: $(OBJS)
bellard27c75a92003-04-07 21:35:21 +0000135 $(CC) $(LDFLAGS) -o $@ $^ $(LIBS)
bellarda993ba82003-05-11 12:25:45 +0000136ifeq ($(ARCH),alpha)
137# Mark as 32 bit binary, i. e. it will be mapped into the low 31 bit of
138# the address space (31 bit so sign extending doesn't matter)
139 echo -ne '\001\000\000\000' | dd of=qemu bs=1 seek=48 count=4 conv=notrunc
140endif
bellard31e31b82003-02-18 22:55:36 +0000141
bellard0824d6f2003-06-24 13:42:40 +0000142# must use static linking to avoid leaving stuff in virtual address space
bellard8c9b8612003-06-30 10:12:19 +0000143vl: vl.o block.o libqemu.a
bellard33e39632003-07-06 17:15:21 +0000144 $(CC) -pg -static -Wl,-T,i386-vl.ld -o $@ $^ $(LIBS)
145
146vlmkcow: vlmkcow.o
147 $(CC) -o $@ $^ $(LIBS)
bellard0824d6f2003-06-24 13:42:40 +0000148
bellard31e31b82003-02-18 22:55:36 +0000149depend: $(SRCS)
150 $(CC) -MM $(CFLAGS) $^ 1>.depend
151
bellard3ef693a2003-03-23 20:17:16 +0000152# libqemu
bellard612384d2003-03-22 17:31:19 +0000153
bellard3ef693a2003-03-23 20:17:16 +0000154libqemu.a: $(LIBOBJS)
bellard612384d2003-03-22 17:31:19 +0000155 rm -f $@
156 $(AR) rcs $@ $(LIBOBJS)
157
bellard367e86e2003-03-01 17:13:26 +0000158dyngen: dyngen.c
159 $(HOST_CC) -O2 -Wall -g $< -o $@
160
bellardde83cd02003-06-15 20:25:43 +0000161translate-$(TARGET_ARCH).o: translate-$(TARGET_ARCH).c gen-op-$(TARGET_ARCH).h opc-$(TARGET_ARCH).h cpu-$(TARGET_ARCH).h
bellard367e86e2003-03-01 17:13:26 +0000162
bellardde83cd02003-06-15 20:25:43 +0000163translate.o: translate.c op-$(TARGET_ARCH).h opc-$(TARGET_ARCH).h cpu-$(TARGET_ARCH).h
164
165op-$(TARGET_ARCH).h: op-$(TARGET_ARCH).o dyngen
bellard367e86e2003-03-01 17:13:26 +0000166 ./dyngen -o $@ $<
167
bellardde83cd02003-06-15 20:25:43 +0000168opc-$(TARGET_ARCH).h: op-$(TARGET_ARCH).o dyngen
bellard2d92f0b2003-05-28 00:24:44 +0000169 ./dyngen -c -o $@ $<
170
bellardde83cd02003-06-15 20:25:43 +0000171gen-op-$(TARGET_ARCH).h: op-$(TARGET_ARCH).o dyngen
172 ./dyngen -g -o $@ $<
173
174op-$(TARGET_ARCH).o: op-$(TARGET_ARCH).c
bellard927f6212003-03-02 19:39:42 +0000175 $(CC) $(OP_CFLAGS) $(DEFINES) -c -o $@ $<
bellard367e86e2003-03-01 17:13:26 +0000176
bellardde83cd02003-06-15 20:25:43 +0000177helper-$(TARGET_ARCH).o: helper-$(TARGET_ARCH).c
bellard9c5d1242003-06-09 15:33:05 +0000178 $(CC) $(HELPER_CFLAGS) $(DEFINES) -c -o $@ $<
179
bellarde477b8b2003-06-30 23:36:57 +0000180op-i386.o: op-i386.c opreg_template.h ops_template.h ops_template_mem.h
bellardde83cd02003-06-15 20:25:43 +0000181
182op-arm.o: op-arm.c op-arm-template.h
183
bellard31e31b82003-02-18 22:55:36 +0000184%.o: %.c
185 $(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
186
187clean:
bellard7d132992003-03-06 23:23:54 +0000188 $(MAKE) -C tests clean
bellard3ef693a2003-03-23 20:17:16 +0000189 rm -f *.o *.a *~ qemu dyngen TAGS
bellard31e31b82003-02-18 22:55:36 +0000190
bellard7d132992003-03-06 23:23:54 +0000191distclean: clean
192 rm -f config.mak config.h
193
bellard6b1534c2003-06-25 16:08:39 +0000194install: $(PROGS)
bellardd5a0b502003-06-27 12:02:03 +0000195 mkdir -p $(prefix)/bin
bellard6b1534c2003-06-25 16:08:39 +0000196 install -m 755 -s $(PROGS) $(prefix)/bin
bellard612384d2003-03-22 17:31:19 +0000197
bellard367e86e2003-03-01 17:13:26 +0000198# various test targets
bellard3ef693a2003-03-23 20:17:16 +0000199test speed: qemu
bellard367e86e2003-03-01 17:13:26 +0000200 make -C tests $@
bellard31e31b82003-02-18 22:55:36 +0000201
bellard367e86e2003-03-01 17:13:26 +0000202TAGS:
bellardb9adb4a2003-04-29 20:41:16 +0000203 etags *.[ch] tests/*.[ch]
bellard31e31b82003-02-18 22:55:36 +0000204
bellard3ef693a2003-03-23 20:17:16 +0000205# documentation
206qemu-doc.html: qemu-doc.texi
207 texi2html -monolithic -number $<
208
bellard586314f2003-03-03 15:02:29 +0000209FILES= \
bellardfd429f22003-03-30 20:59:46 +0000210README README.distrib COPYING COPYING.LIB TODO Changelog VERSION \
bellardde83cd02003-06-15 20:25:43 +0000211configure \
212dyngen.c dyngen.h dyngen-exec.h ioctls.h syscall_types.h \
213Makefile elf.h elfload.c main.c signal.c qemu.h \
214syscall.c syscall_defs.h vm86.c path.c mmap.c \
bellard6b1534c2003-06-25 16:08:39 +0000215i386.ld ppc.ld alpha.ld s390.ld sparc.ld arm.ld\
bellard8c9b8612003-06-30 10:12:19 +0000216vl.c i386-vl.ld vl.h block.c\
bellardde83cd02003-06-15 20:25:43 +0000217thunk.c cpu-exec.c translate.c cpu-all.h thunk.h exec.h\
218exec.c cpu-exec.c\
219cpu-i386.h op-i386.c helper-i386.c syscall-i386.h translate-i386.c \
220exec-i386.h ops_template.h op_string.h opreg_template.h \
221cpu-arm.h syscall-arm.h exec-arm.h op-arm.c translate-arm.c op-arm-template.h \
222dis-asm.h disas.c disas.h alpha-dis.c ppc-dis.c i386-dis.c sparc-dis.c \
223arm-dis.c \
224tests/Makefile \
225tests/test-i386.c tests/test-i386-shift.h tests/test-i386.h \
226tests/test-i386-muldiv.h tests/test-i386-code16.S tests/test-i386-vm86.S \
bellard322d0c62003-06-15 23:29:28 +0000227tests/hello-i386.c tests/hello-i386 \
bellardde83cd02003-06-15 20:25:43 +0000228tests/hello-arm.c tests/hello-arm \
229tests/sha1.c \
bellard3ef693a2003-03-23 20:17:16 +0000230tests/testsig.c tests/testclone.c tests/testthread.c \
bellardfd429f22003-03-30 20:59:46 +0000231tests/runcom.c tests/pi_10.com \
bellard1eb87252003-04-11 01:12:28 +0000232tests/test_path.c \
bellard3ef693a2003-03-23 20:17:16 +0000233qemu-doc.texi qemu-doc.html
bellard586314f2003-03-03 15:02:29 +0000234
bellard3ef693a2003-03-23 20:17:16 +0000235FILE=qemu-$(VERSION)
bellard586314f2003-03-03 15:02:29 +0000236
237tar:
238 rm -rf /tmp/$(FILE)
239 mkdir -p /tmp/$(FILE)
240 cp -P $(FILES) /tmp/$(FILE)
241 ( cd /tmp ; tar zcvf ~/$(FILE).tar.gz $(FILE) )
242 rm -rf /tmp/$(FILE)
243
bellardd691f662003-03-24 21:58:34 +0000244# generate a binary distribution including the test binary environnment
245BINPATH=/usr/local/qemu-i386
246
247tarbin:
bellard1eb87252003-04-11 01:12:28 +0000248 tar zcvf /tmp/qemu-$(VERSION)-i386-glibc21.tar.gz \
249 $(BINPATH)/etc $(BINPATH)/lib $(BINPATH)/bin $(BINPATH)/usr
250 tar zcvf /tmp/qemu-$(VERSION)-i386-wine.tar.gz \
251 $(BINPATH)/wine
bellardd691f662003-03-24 21:58:34 +0000252
bellard31e31b82003-02-18 22:55:36 +0000253ifneq ($(wildcard .depend),)
254include .depend
255endif