1include config.mak 2 3CFLAGS=-Wall -O2 -g 4LDFLAGS=-g 5LIBS= 6DEFINES=-DHAVE_BYTESWAP_H 7 8ifeq ($(ARCH),i386) 9CFLAGS+=-fomit-frame-pointer 10OP_CFLAGS=$(CFLAGS) -malign-functions=0 -mpreferred-stack-boundary=2 11endif 12 13ifeq ($(ARCH),ppc) 14OP_CFLAGS=$(CFLAGS) 15endif 16 17######################################################### 18 19DEFINES+=-D_GNU_SOURCE 20LDSCRIPT=$(ARCH).ld 21LIBS+=-ldl -lm 22 23# profiling code 24ifdef TARGET_GPROF 25LDFLAGS+=-p 26CFLAGS+=-p 27endif 28 29OBJS= elfload.o main.o thunk.o syscall.o 30OBJS+=translate-i386.o op-i386.o exec-i386.o 31# NOTE: the disassembler code is only needed for debugging 32OBJS+=i386-dis.o dis-buf.o 33SRCS = $(OBJS:.o=.c) 34 35all: gemu 36 37gemu: $(OBJS) 38 $(CC) -Wl,-T,$(LDSCRIPT) $(LDFLAGS) -o $@ $^ $(LIBS) 39 40depend: $(SRCS) 41 $(CC) -MM $(CFLAGS) $^ 1>.depend 42 43# new i386 emulator 44dyngen: dyngen.c 45 $(HOST_CC) -O2 -Wall -g $< -o $@ 46 47translate-i386.o: translate-i386.c op-i386.h cpu-i386.h 48 49op-i386.h: op-i386.o dyngen 50 ./dyngen -o $@ $< 51 52op-i386.o: op-i386.c opreg_template.h ops_template.h 53 $(CC) $(OP_CFLAGS) $(DEFINES) -c -o $@ $< 54 55%.o: %.c 56 $(CC) $(CFLAGS) $(DEFINES) -c -o $@ $< 57 58clean: 59 $(MAKE) -C tests clean 60 rm -f *.o *~ gemu dyngen TAGS 61 62distclean: clean 63 rm -f config.mak config.h 64 65# various test targets 66test speed: gemu 67 make -C tests $@ 68 69TAGS: 70 etags *.[ch] i386/*.[ch] 71 72FILES= \ 73COPYING.LIB dyngen.c ioctls.h ops_template.h syscall_types.h\ 74Makefile elf.h linux_bin.h segment.h thunk.c\ 75TODO elfload.c main.c signal.c thunk.h\ 76cpu-i386.h gemu.h op-i386.c syscall-i386.h translate-i386.c\ 77dis-asm.h gen-i386.h op-i386.h syscall.c\ 78dis-buf.c i386-dis.c opreg_template.h syscall_defs.h\ 79i386.ld ppc.ld exec-i386.h exec-i386.c configure VERSION \ 80tests/Makefile\ 81tests/test-i386.c tests/test-i386-shift.h tests/test-i386.h\ 82tests/test-i386-muldiv.h\ 83tests/test2.c tests/hello.c tests/sha1.c 84 85FILE=gemu-$(VERSION) 86 87tar: 88 rm -rf /tmp/$(FILE) 89 mkdir -p /tmp/$(FILE) 90 cp -P $(FILES) /tmp/$(FILE) 91 ( cd /tmp ; tar zcvf ~/$(FILE).tar.gz $(FILE) ) 92 rm -rf /tmp/$(FILE) 93 94ifneq ($(wildcard .depend),) 95include .depend 96endif 97