xref: /openbmc/qemu/Makefile (revision 367e86e8476d6373a00d0e56a29b03c4b8f3e2ee)
1766a487aSbellardARCH=i386
2766a487aSbellard#ARCH=ppc
3*367e86e8SbellardHOST_CC=gcc
4766a487aSbellard
5766a487aSbellardifeq ($(ARCH),i386)
6*367e86e8SbellardCFLAGS=-Wall -O2 -g -fomit-frame-pointer
731e31b8aSbellardLDFLAGS=-g
8766a487aSbellardLIBS=
9766a487aSbellardCC=gcc
10766a487aSbellardDEFINES=-DHAVE_BYTESWAP_H
11766a487aSbellardendif
12766a487aSbellard
13766a487aSbellardifeq ($(ARCH),ppc)
14766a487aSbellardGCC_LIBS_DIR=/usr/netgem/tools/lib/gcc-lib/powerpc-linux/2.95.2
15766a487aSbellardDIST=/home/fbe/nsv/dist/hw/n6-dtt
16766a487aSbellardCC=powerpc-linux-gcc -msoft-float
17766a487aSbellardCFLAGS=-Wall -pipe -O2 -mcpu=405 -mbig -nostdinc -g -I$(GCC_LIBS_DIR)/include -I$(DIST)/include
18766a487aSbellardLIBS_DIR=$(DIST)/lib
19766a487aSbellardCRT1=$(LIBS_DIR)/crt1.o
20766a487aSbellardCRTI=$(LIBS_DIR)/crti.o
21766a487aSbellardCRTN=$(LIBS_DIR)/crtn.o
22766a487aSbellardCRTBEGIN=$(GCC_LIBS_DIR)/crtbegin.o
23766a487aSbellardCRTEND=$(GCC_LIBS_DIR)/crtend.o
24766a487aSbellardLDFLAGS=-static -g -nostdlib $(CRT1) $(CRTI) $(CRTBEGIN)
25766a487aSbellardLIBS=-L$(LIBS_DIR) -ltinyc -lgcc $(CRTEND) $(CRTN)
26766a487aSbellardDEFINES=-Dsocklen_t=int
27766a487aSbellardendif
28766a487aSbellard
29766a487aSbellard#########################################################
30766a487aSbellard
31*367e86e8SbellardDEFINES+=-D_GNU_SOURCE -DGEMU -DDOSEMU -DNO_TRACE_MSGS
32*367e86e8SbellardDEFINES+=-DCONFIG_PREFIX=\"/usr/local\"
33766a487aSbellardLDSCRIPT=$(ARCH).ld
34*367e86e8SbellardLIBS+=-ldl
3531e31b8aSbellard
3631e31b8aSbellardOBJS= i386/fp87.o i386/interp_main.o i386/interp_modrm.o i386/interp_16_32.o \
3731e31b8aSbellard      i386/interp_32_16.o i386/interp_32_32.o i386/emu-utils.o \
3831e31b8aSbellard      i386/dis8086.o i386/emu-ldt.o
39*367e86e8SbellardOBJS+=translate-i386.o op-i386.o
4031e31b8aSbellardOBJS+= elfload.o main.o thunk.o syscall.o
4131e31b8aSbellardSRCS = $(OBJS:.o=.c)
4231e31b8aSbellard
4331e31b8aSbellardall: gemu
4431e31b8aSbellard
4531e31b8aSbellardgemu: $(OBJS)
46*367e86e8Sbellard	$(CC) -Wl,-T,$(LDSCRIPT) $(LDFLAGS) -o $@ $^ $(LIBS)
4731e31b8aSbellard
4831e31b8aSbellarddepend: $(SRCS)
4931e31b8aSbellard	$(CC) -MM $(CFLAGS) $^ 1>.depend
5031e31b8aSbellard
51*367e86e8Sbellard# old i386 emulator
52*367e86e8Sbellardi386/interp_32_32.o: i386/interp_32_32.c i386/interp_gen.h
53*367e86e8Sbellard
54*367e86e8Sbellardi386/interp_gen.h: i386/gencode
55*367e86e8Sbellard	./i386/gencode > $@
56*367e86e8Sbellard
57*367e86e8Sbellardi386/gencode: i386/gencode.c
58*367e86e8Sbellard	$(CC) -O2 -Wall -g $< -o $@
59*367e86e8Sbellard
60*367e86e8Sbellard# new i386 emulator
61*367e86e8Sbellarddyngen: dyngen.c
62*367e86e8Sbellard	$(HOST_CC) -O2 -Wall -g $< -o $@
63*367e86e8Sbellard
64*367e86e8Sbellardtranslate-i386.o: translate-i386.c op-i386.h cpu-i386.h
65*367e86e8Sbellard
66*367e86e8Sbellardop-i386.h: op-i386.o dyngen
67*367e86e8Sbellard	./dyngen -o $@ $<
68*367e86e8Sbellard
69*367e86e8Sbellardop-i386.o: op-i386.c opreg_template.h ops_template.h
70*367e86e8Sbellard	$(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
71*367e86e8Sbellard
7231e31b8aSbellard%.o: %.c
7331e31b8aSbellard	$(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
7431e31b8aSbellard
7531e31b8aSbellardclean:
76*367e86e8Sbellard	rm -f *.o *~ i386/*.o i386/*~ gemu TAGS
7731e31b8aSbellard
78*367e86e8Sbellard# various test targets
79*367e86e8Sbellardtest speed: gemu
80*367e86e8Sbellard	make -C tests $@
8131e31b8aSbellard
82*367e86e8SbellardTAGS:
83*367e86e8Sbellard	etags *.[ch] i386/*.[ch]
8431e31b8aSbellard
8531e31b8aSbellardifneq ($(wildcard .depend),)
8631e31b8aSbellardinclude .depend
8731e31b8aSbellardendif
88