2003-03-07 02:23:54 +03:00
|
|
|
include config.mak
|
2003-02-19 02:35:48 +03:00
|
|
|
|
2003-03-07 02:23:54 +03:00
|
|
|
CFLAGS=-Wall -O2 -g
|
2003-02-19 01:55:36 +03:00
|
|
|
LDFLAGS=-g
|
2003-02-19 02:35:48 +03:00
|
|
|
LIBS=
|
|
|
|
DEFINES=-DHAVE_BYTESWAP_H
|
2003-03-07 02:23:54 +03:00
|
|
|
|
|
|
|
ifeq ($(ARCH),i386)
|
|
|
|
CFLAGS+=-fomit-frame-pointer
|
2003-03-18 23:41:34 +03:00
|
|
|
OP_CFLAGS=$(CFLAGS) -mpreferred-stack-boundary=2
|
|
|
|
ifeq ($(GCC_MAJOR),3)
|
|
|
|
OP_CFLAGS+= -falign-functions=0
|
|
|
|
else
|
|
|
|
OP_CFLAGS+= -malign-functions=0
|
|
|
|
endif
|
2003-02-19 02:35:48 +03:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(ARCH),ppc)
|
2003-03-02 22:39:42 +03:00
|
|
|
OP_CFLAGS=$(CFLAGS)
|
2003-02-19 02:35:48 +03:00
|
|
|
endif
|
|
|
|
|
2003-03-18 23:41:34 +03:00
|
|
|
ifeq ($(GCC_MAJOR),3)
|
|
|
|
# very important to generate a return at the end of every operation
|
|
|
|
OP_CFLAGS+=-fno-reorder-blocks -fno-optimize-sibling-calls
|
|
|
|
endif
|
|
|
|
|
2003-02-19 02:35:48 +03:00
|
|
|
#########################################################
|
|
|
|
|
2003-03-03 17:32:43 +03:00
|
|
|
DEFINES+=-D_GNU_SOURCE
|
2003-02-19 02:35:48 +03:00
|
|
|
LDSCRIPT=$(ARCH).ld
|
2003-03-02 22:39:42 +03:00
|
|
|
LIBS+=-ldl -lm
|
2003-03-07 02:23:54 +03:00
|
|
|
|
|
|
|
# profiling code
|
|
|
|
ifdef TARGET_GPROF
|
|
|
|
LDFLAGS+=-p
|
2003-03-19 03:00:28 +03:00
|
|
|
main.o: CFLAGS+=-p
|
2003-03-07 02:23:54 +03:00
|
|
|
endif
|
2003-02-19 01:55:36 +03:00
|
|
|
|
2003-03-03 18:02:29 +03:00
|
|
|
OBJS= elfload.o main.o thunk.o syscall.o
|
2003-03-07 02:23:54 +03:00
|
|
|
OBJS+=translate-i386.o op-i386.o exec-i386.o
|
2003-03-03 17:32:43 +03:00
|
|
|
# NOTE: the disassembler code is only needed for debugging
|
|
|
|
OBJS+=i386-dis.o dis-buf.o
|
2003-02-19 01:55:36 +03:00
|
|
|
SRCS = $(OBJS:.o=.c)
|
|
|
|
|
|
|
|
all: gemu
|
|
|
|
|
|
|
|
gemu: $(OBJS)
|
2003-03-01 20:13:26 +03:00
|
|
|
$(CC) -Wl,-T,$(LDSCRIPT) $(LDFLAGS) -o $@ $^ $(LIBS)
|
2003-02-19 01:55:36 +03:00
|
|
|
|
|
|
|
depend: $(SRCS)
|
|
|
|
$(CC) -MM $(CFLAGS) $^ 1>.depend
|
|
|
|
|
2003-03-01 20:13:26 +03:00
|
|
|
# new i386 emulator
|
|
|
|
dyngen: dyngen.c
|
|
|
|
$(HOST_CC) -O2 -Wall -g $< -o $@
|
|
|
|
|
|
|
|
translate-i386.o: translate-i386.c op-i386.h cpu-i386.h
|
|
|
|
|
|
|
|
op-i386.h: op-i386.o dyngen
|
|
|
|
./dyngen -o $@ $<
|
|
|
|
|
|
|
|
op-i386.o: op-i386.c opreg_template.h ops_template.h
|
2003-03-02 22:39:42 +03:00
|
|
|
$(CC) $(OP_CFLAGS) $(DEFINES) -c -o $@ $<
|
2003-03-01 20:13:26 +03:00
|
|
|
|
2003-02-19 01:55:36 +03:00
|
|
|
%.o: %.c
|
|
|
|
$(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
|
|
|
|
|
|
|
|
clean:
|
2003-03-07 02:23:54 +03:00
|
|
|
$(MAKE) -C tests clean
|
2003-03-03 18:02:29 +03:00
|
|
|
rm -f *.o *~ gemu dyngen TAGS
|
2003-02-19 01:55:36 +03:00
|
|
|
|
2003-03-07 02:23:54 +03:00
|
|
|
distclean: clean
|
|
|
|
rm -f config.mak config.h
|
|
|
|
|
2003-03-01 20:13:26 +03:00
|
|
|
# various test targets
|
|
|
|
test speed: gemu
|
|
|
|
make -C tests $@
|
2003-02-19 01:55:36 +03:00
|
|
|
|
2003-03-01 20:13:26 +03:00
|
|
|
TAGS:
|
|
|
|
etags *.[ch] i386/*.[ch]
|
2003-02-19 01:55:36 +03:00
|
|
|
|
2003-03-03 18:02:29 +03:00
|
|
|
FILES= \
|
|
|
|
COPYING.LIB dyngen.c ioctls.h ops_template.h syscall_types.h\
|
|
|
|
Makefile elf.h linux_bin.h segment.h thunk.c\
|
|
|
|
TODO elfload.c main.c signal.c thunk.h\
|
2003-03-19 03:05:32 +03:00
|
|
|
cpu-i386.h gemu.h op-i386.c opc-i386.h syscall-i386.h translate-i386.c\
|
2003-03-03 18:02:29 +03:00
|
|
|
dis-asm.h gen-i386.h op-i386.h syscall.c\
|
|
|
|
dis-buf.c i386-dis.c opreg_template.h syscall_defs.h\
|
2003-03-07 02:23:54 +03:00
|
|
|
i386.ld ppc.ld exec-i386.h exec-i386.c configure VERSION \
|
2003-03-06 01:24:48 +03:00
|
|
|
tests/Makefile\
|
2003-03-03 18:02:29 +03:00
|
|
|
tests/test-i386.c tests/test-i386-shift.h tests/test-i386.h\
|
2003-03-04 04:14:13 +03:00
|
|
|
tests/test-i386-muldiv.h\
|
2003-03-21 01:33:23 +03:00
|
|
|
tests/test2.c tests/hello.c tests/hello tests/sha1.c
|
2003-03-03 18:02:29 +03:00
|
|
|
|
|
|
|
FILE=gemu-$(VERSION)
|
|
|
|
|
|
|
|
tar:
|
|
|
|
rm -rf /tmp/$(FILE)
|
|
|
|
mkdir -p /tmp/$(FILE)
|
|
|
|
cp -P $(FILES) /tmp/$(FILE)
|
|
|
|
( cd /tmp ; tar zcvf ~/$(FILE).tar.gz $(FILE) )
|
|
|
|
rm -rf /tmp/$(FILE)
|
|
|
|
|
2003-02-19 01:55:36 +03:00
|
|
|
ifneq ($(wildcard .depend),)
|
|
|
|
include .depend
|
|
|
|
endif
|