blob: b007f40dde9b99d01cd1ae02beb9d4131a99aba0 [file] [log] [blame]
bellard766a4872003-02-18 23:35:48 +00001ARCH=i386
2#ARCH=ppc
bellard367e86e2003-03-01 17:13:26 +00003HOST_CC=gcc
bellard766a4872003-02-18 23:35:48 +00004
5ifeq ($(ARCH),i386)
bellard367e86e2003-03-01 17:13:26 +00006CFLAGS=-Wall -O2 -g -fomit-frame-pointer
bellard31e31b82003-02-18 22:55:36 +00007LDFLAGS=-g
bellard766a4872003-02-18 23:35:48 +00008LIBS=
9CC=gcc
10DEFINES=-DHAVE_BYTESWAP_H
bellard927f6212003-03-02 19:39:42 +000011OP_CFLAGS=$(CFLAGS) -malign-functions=0 -mpreferred-stack-boundary=2
bellard766a4872003-02-18 23:35:48 +000012endif
13
14ifeq ($(ARCH),ppc)
15GCC_LIBS_DIR=/usr/netgem/tools/lib/gcc-lib/powerpc-linux/2.95.2
16DIST=/home/fbe/nsv/dist/hw/n6-dtt
17CC=powerpc-linux-gcc -msoft-float
18CFLAGS=-Wall -pipe -O2 -mcpu=405 -mbig -nostdinc -g -I$(GCC_LIBS_DIR)/include -I$(DIST)/include
19LIBS_DIR=$(DIST)/lib
20CRT1=$(LIBS_DIR)/crt1.o
21CRTI=$(LIBS_DIR)/crti.o
22CRTN=$(LIBS_DIR)/crtn.o
23CRTBEGIN=$(GCC_LIBS_DIR)/crtbegin.o
24CRTEND=$(GCC_LIBS_DIR)/crtend.o
25LDFLAGS=-static -g -nostdlib $(CRT1) $(CRTI) $(CRTBEGIN)
26LIBS=-L$(LIBS_DIR) -ltinyc -lgcc $(CRTEND) $(CRTN)
27DEFINES=-Dsocklen_t=int
bellard927f6212003-03-02 19:39:42 +000028OP_CFLAGS=$(CFLAGS)
bellard766a4872003-02-18 23:35:48 +000029endif
30
31#########################################################
32
bellard0ecfa992003-03-03 14:32:43 +000033DEFINES+=-D_GNU_SOURCE
bellard367e86e2003-03-01 17:13:26 +000034DEFINES+=-DCONFIG_PREFIX=\"/usr/local\"
bellard766a4872003-02-18 23:35:48 +000035LDSCRIPT=$(ARCH).ld
bellard927f6212003-03-02 19:39:42 +000036LIBS+=-ldl -lm
bellard31e31b82003-02-18 22:55:36 +000037
bellard0ecfa992003-03-03 14:32:43 +000038#DEFINES+= -DGEMU -DDOSEMU -DNO_TRACE_MSGS
39#OBJS= i386/fp87.o i386/interp_main.o i386/interp_modrm.o i386/interp_16_32.o \
40# i386/interp_32_16.o i386/interp_32_32.o i386/emu-utils.o \
41# i386/dis8086.o i386/emu-ldt.o
bellard367e86e2003-03-01 17:13:26 +000042OBJS+=translate-i386.o op-i386.o
bellard31e31b82003-02-18 22:55:36 +000043OBJS+= elfload.o main.o thunk.o syscall.o
bellard0ecfa992003-03-03 14:32:43 +000044# NOTE: the disassembler code is only needed for debugging
45OBJS+=i386-dis.o dis-buf.o
bellard31e31b82003-02-18 22:55:36 +000046SRCS = $(OBJS:.o=.c)
47
48all: gemu
49
50gemu: $(OBJS)
bellard367e86e2003-03-01 17:13:26 +000051 $(CC) -Wl,-T,$(LDSCRIPT) $(LDFLAGS) -o $@ $^ $(LIBS)
bellard31e31b82003-02-18 22:55:36 +000052
53depend: $(SRCS)
54 $(CC) -MM $(CFLAGS) $^ 1>.depend
55
bellard367e86e2003-03-01 17:13:26 +000056# old i386 emulator
57i386/interp_32_32.o: i386/interp_32_32.c i386/interp_gen.h
58
59i386/interp_gen.h: i386/gencode
60 ./i386/gencode > $@
61
62i386/gencode: i386/gencode.c
63 $(CC) -O2 -Wall -g $< -o $@
64
65# new i386 emulator
66dyngen: dyngen.c
67 $(HOST_CC) -O2 -Wall -g $< -o $@
68
69translate-i386.o: translate-i386.c op-i386.h cpu-i386.h
70
71op-i386.h: op-i386.o dyngen
72 ./dyngen -o $@ $<
73
74op-i386.o: op-i386.c opreg_template.h ops_template.h
bellard927f6212003-03-02 19:39:42 +000075 $(CC) $(OP_CFLAGS) $(DEFINES) -c -o $@ $<
bellard367e86e2003-03-01 17:13:26 +000076
bellard31e31b82003-02-18 22:55:36 +000077%.o: %.c
78 $(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
79
80clean:
bellard367e86e2003-03-01 17:13:26 +000081 rm -f *.o *~ i386/*.o i386/*~ gemu TAGS
bellard31e31b82003-02-18 22:55:36 +000082
bellard367e86e2003-03-01 17:13:26 +000083# various test targets
84test speed: gemu
85 make -C tests $@
bellard31e31b82003-02-18 22:55:36 +000086
bellard367e86e2003-03-01 17:13:26 +000087TAGS:
88 etags *.[ch] i386/*.[ch]
bellard31e31b82003-02-18 22:55:36 +000089
90ifneq ($(wildcard .depend),)
91include .depend
92endif