xref: /openbmc/qemu/Makefile (revision 9c5d1246)
17d13299dSbellardinclude config.mak
2766a487aSbellard
37d13299dSbellardCFLAGS=-Wall -O2 -g
431e31b8aSbellardLDFLAGS=-g
5766a487aSbellardLIBS=
6766a487aSbellardDEFINES=-DHAVE_BYTESWAP_H
7*9c5d1246SbellardHELPER_CFLAGS=$(CFLAGS)
87d13299dSbellard
97d13299dSbellardifeq ($(ARCH),i386)
107d13299dSbellardCFLAGS+=-fomit-frame-pointer
11ca735206SbellardOP_CFLAGS=$(CFLAGS) -mpreferred-stack-boundary=2
12ca735206Sbellardifeq ($(GCC_MAJOR),3)
13ca735206SbellardOP_CFLAGS+= -falign-functions=0
14ca735206Sbellardelse
15ca735206SbellardOP_CFLAGS+= -malign-functions=0
16ca735206Sbellardendif
172d92f0b8Sbellardifdef TARGET_GPROF
182d92f0b8SbellardLDFLAGS+=-Wl,-T,i386.ld
192d92f0b8Sbellardelse
2027c75a9aSbellard# WARNING: this LDFLAGS is _very_ tricky : qemu is an ELF shared object
2127c75a9aSbellard# that the kernel ELF loader considers as an executable. I think this
2227c75a9aSbellard# is the simplest way to make it self virtualizable!
2327c75a9aSbellardLDFLAGS+=-Wl,-shared
24766a487aSbellardendif
252d92f0b8Sbellardendif
26766a487aSbellard
27766a487aSbellardifeq ($(ARCH),ppc)
28927f621eSbellardOP_CFLAGS=$(CFLAGS)
2927c75a9aSbellardLDFLAGS+=-Wl,-T,ppc.ld
30766a487aSbellardendif
31766a487aSbellard
32fd429f2fSbellardifeq ($(ARCH),s390)
33fd429f2fSbellardOP_CFLAGS=$(CFLAGS)
3427c75a9aSbellardLDFLAGS+=-Wl,-T,s390.ld
35fd429f2fSbellardendif
36fd429f2fSbellard
37ae228531Sbellardifeq ($(ARCH),sparc)
38ae228531SbellardCFLAGS+=-m32 -ffixed-g1 -ffixed-g2 -ffixed-g3 -ffixed-g6
39ae228531SbellardLDFLAGS+=-m32
40ae228531SbellardOP_CFLAGS=$(CFLAGS) -fno-delayed-branch -ffixed-i0
41*9c5d1246SbellardHELPER_CFLAGS=$(CFLAGS) -ffixed-i0 -mflat
42*9c5d1246SbellardLDFLAGS+=-Wl,-T,sparc.ld
43ae228531Sbellardendif
44ae228531Sbellard
45ae228531Sbellardifeq ($(ARCH),sparc64)
46ae228531SbellardCFLAGS+=-m64 -ffixed-g1 -ffixed-g2 -ffixed-g3 -ffixed-g6
47ae228531SbellardLDFLAGS+=-m64
48ae228531SbellardOP_CFLAGS=$(CFLAGS) -fno-delayed-branch -ffixed-i0
49ae228531Sbellardendif
50ae228531Sbellard
51d6cdca95Sbellardifeq ($(ARCH),alpha)
52a993ba85Sbellard# -msmall-data is not used because we want two-instruction relocations
53a993ba85Sbellard# for the constant constructions
54a993ba85SbellardOP_CFLAGS=-Wall -O2 -g
55d6cdca95Sbellard# Ensure there's only a single GP
5682d19dafSbellardCFLAGS += -msmall-data
57d6cdca95SbellardLDFLAGS+=-Wl,-T,alpha.ld
58d6cdca95Sbellardendif
59d6cdca95Sbellard
60d6cdca95Sbellardifeq ($(ARCH),ia64)
61d6cdca95SbellardOP_CFLAGS=$(CFLAGS)
62d6cdca95Sbellardendif
63d6cdca95Sbellard
64*9c5d1246Sbellardifeq ($(ARCH),arm)
65*9c5d1246SbellardOP_CFLAGS=$(CFLAGS) -mno-sched-prolog
66*9c5d1246SbellardLDFLAGS+=-Wl,-T,arm.ld
67*9c5d1246Sbellardendif
68*9c5d1246Sbellard
69ca735206Sbellardifeq ($(GCC_MAJOR),3)
70ca735206Sbellard# very important to generate a return at the end of every operation
71ca735206SbellardOP_CFLAGS+=-fno-reorder-blocks -fno-optimize-sibling-calls
72ca735206Sbellardendif
73ca735206Sbellard
74766a487aSbellard#########################################################
75766a487aSbellard
760ecfa993SbellardDEFINES+=-D_GNU_SOURCE
773ef693a0SbellardLIBS+=-lm
787d13299dSbellard
797d13299dSbellard# profiling code
807d13299dSbellardifdef TARGET_GPROF
817d13299dSbellardLDFLAGS+=-p
82dc99065bSbellardmain.o: CFLAGS+=-p
837d13299dSbellardendif
8431e31b8aSbellard
8554936004SbellardOBJS= elfload.o main.o syscall.o mmap.o signal.o vm86.o path.o
863ef693a0SbellardSRCS:= $(OBJS:.o=.c)
873ef693a0SbellardOBJS+= libqemu.a
88612384d7Sbellard
8982d19dafSbellardLIBOBJS+=thunk.o translate-i386.o op-i386.o helper-i386.o exec-i386.o exec.o
90aa05ae6fSbellard
910ecfa993Sbellard# NOTE: the disassembler code is only needed for debugging
92*9c5d1246SbellardLIBOBJS+=disas.o i386-dis.o
93aa05ae6fSbellardifeq ($(ARCH),alpha)
94aa05ae6fSbellardLIBOBJS+=alpha-dis.o
95aa05ae6fSbellardendif
96aa05ae6fSbellardifeq ($(ARCH),ppc)
97aa05ae6fSbellardLIBOBJS+=ppc-dis.o
98aa05ae6fSbellardendif
99*9c5d1246Sbellardifeq ($(ARCH),sparc)
100*9c5d1246SbellardLIBOBJS+=sparc-dis.o
101*9c5d1246Sbellardendif
102*9c5d1246Sbellardifeq ($(ARCH),arm)
103*9c5d1246SbellardLIBOBJS+=arm-dis.o
104*9c5d1246Sbellardendif
10531e31b8aSbellard
106d6cdca95Sbellardifeq ($(ARCH),ia64)
107d6cdca95SbellardOBJS += ia64-syscall.o
108d6cdca95Sbellardendif
109d6cdca95Sbellard
1103ef693a0Sbellardall: qemu qemu-doc.html
11131e31b8aSbellard
1123ef693a0Sbellardqemu: $(OBJS)
11327c75a9aSbellard	$(CC) $(LDFLAGS) -o $@ $^  $(LIBS)
114a993ba85Sbellardifeq ($(ARCH),alpha)
115a993ba85Sbellard# Mark as 32 bit binary, i. e. it will be mapped into the low 31 bit of
116a993ba85Sbellard# the address space (31 bit so sign extending doesn't matter)
117a993ba85Sbellard	echo -ne '\001\000\000\000' | dd of=qemu bs=1 seek=48 count=4 conv=notrunc
118a993ba85Sbellardendif
11931e31b8aSbellard
12031e31b8aSbellarddepend: $(SRCS)
12131e31b8aSbellard	$(CC) -MM $(CFLAGS) $^ 1>.depend
12231e31b8aSbellard
1233ef693a0Sbellard# libqemu
124612384d7Sbellard
1253ef693a0Sbellardlibqemu.a: $(LIBOBJS)
126612384d7Sbellard	rm -f $@
127612384d7Sbellard	$(AR) rcs $@ $(LIBOBJS)
128612384d7Sbellard
129367e86e8Sbellarddyngen: dyngen.c
130367e86e8Sbellard	$(HOST_CC) -O2 -Wall -g $< -o $@
131367e86e8Sbellard
1322d92f0b8Sbellardtranslate-i386.o: translate-i386.c op-i386.h opc-i386.h cpu-i386.h
133367e86e8Sbellard
134367e86e8Sbellardop-i386.h: op-i386.o dyngen
135367e86e8Sbellard	./dyngen -o $@ $<
136367e86e8Sbellard
1372d92f0b8Sbellardopc-i386.h: op-i386.o dyngen
1382d92f0b8Sbellard	./dyngen -c -o $@ $<
1392d92f0b8Sbellard
140367e86e8Sbellardop-i386.o: op-i386.c opreg_template.h ops_template.h
141927f621eSbellard	$(CC) $(OP_CFLAGS) $(DEFINES) -c -o $@ $<
142367e86e8Sbellard
143*9c5d1246Sbellardhelper-i386.o: helper-i386.c
144*9c5d1246Sbellard	$(CC) $(HELPER_CFLAGS) $(DEFINES) -c -o $@ $<
145*9c5d1246Sbellard
14631e31b8aSbellard%.o: %.c
14731e31b8aSbellard	$(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
14831e31b8aSbellard
14931e31b8aSbellardclean:
1507d13299dSbellard	$(MAKE) -C tests clean
1513ef693a0Sbellard	rm -f *.o  *.a *~ qemu dyngen TAGS
15231e31b8aSbellard
1537d13299dSbellarddistclean: clean
1547d13299dSbellard	rm -f config.mak config.h
1557d13299dSbellard
1563ef693a0Sbellardinstall: qemu
1573ef693a0Sbellard	install -m 755 -s qemu $(prefix)/bin
158612384d7Sbellard
159367e86e8Sbellard# various test targets
1603ef693a0Sbellardtest speed: qemu
161367e86e8Sbellard	make -C tests $@
16231e31b8aSbellard
163367e86e8SbellardTAGS:
164b9adb4a6Sbellard	etags *.[ch] tests/*.[ch]
16531e31b8aSbellard
1663ef693a0Sbellard# documentation
1673ef693a0Sbellardqemu-doc.html: qemu-doc.texi
1683ef693a0Sbellard	texi2html -monolithic -number $<
1693ef693a0Sbellard
170586314f2SbellardFILES= \
171fd429f2fSbellardREADME README.distrib COPYING COPYING.LIB TODO Changelog VERSION \
172*9c5d1246Sbellarddyngen.c dyngen.h ioctls.h ops_template.h op_string.h  syscall_types.h\
17309bfb054SbellardMakefile     elf.h       thunk.c\
174aa05ae6fSbellardelfload.c   main.c            signal.c        thunk.h exec.h\
17582d19dafSbellardcpu-i386.h qemu.h op-i386.c helper-i386.c syscall-i386.h  translate-i386.c\
17676c8b771Sbellardsyscall.c opreg_template.h  syscall_defs.h vm86.c\
177*9c5d1246Sbellarddis-asm.h disas.c disas.h alpha-dis.c ppc-dis.c i386-dis.c sparc-dis.c arm-dis.c\
178*9c5d1246Sbellardppc.ld alpha.ld s390.ld sparc.ld arm.ld exec-i386.h exec-i386.c path.c exec.c mmap.c configure \
17977f8dd5aSbellardtests/Makefile\
180586314f2Sbellardtests/test-i386.c tests/test-i386-shift.h tests/test-i386.h\
181612384d7Sbellardtests/test-i386-muldiv.h tests/test-i386-code16.S\
182612384d7Sbellardtests/hello.c tests/hello tests/sha1.c \
1833ef693a0Sbellardtests/testsig.c tests/testclone.c tests/testthread.c \
184fd429f2fSbellardtests/runcom.c tests/pi_10.com \
1851eb87257Sbellardtests/test_path.c \
1863ef693a0Sbellardqemu-doc.texi qemu-doc.html
187586314f2Sbellard
1883ef693a0SbellardFILE=qemu-$(VERSION)
189586314f2Sbellard
190586314f2Sbellardtar:
191586314f2Sbellard	rm -rf /tmp/$(FILE)
192586314f2Sbellard	mkdir -p /tmp/$(FILE)
193586314f2Sbellard	cp -P $(FILES) /tmp/$(FILE)
194586314f2Sbellard	( cd /tmp ; tar zcvf ~/$(FILE).tar.gz $(FILE) )
195586314f2Sbellard	rm -rf /tmp/$(FILE)
196586314f2Sbellard
197d691f669Sbellard# generate a binary distribution including the test binary environnment
198d691f669SbellardBINPATH=/usr/local/qemu-i386
199d691f669Sbellard
200d691f669Sbellardtarbin:
2011eb87257Sbellard	tar zcvf /tmp/qemu-$(VERSION)-i386-glibc21.tar.gz \
2021eb87257Sbellard                 $(BINPATH)/etc $(BINPATH)/lib $(BINPATH)/bin $(BINPATH)/usr
2031eb87257Sbellard	tar zcvf /tmp/qemu-$(VERSION)-i386-wine.tar.gz \
2041eb87257Sbellard                 $(BINPATH)/wine
205d691f669Sbellard
20631e31b8aSbellardifneq ($(wildcard .depend),)
20731e31b8aSbellardinclude .depend
20831e31b8aSbellardendif
209