2003-02-19 07:35:48 +08:00
|
|
|
ARCH=i386
|
|
|
|
#ARCH=ppc
|
2003-03-02 01:13:26 +08:00
|
|
|
HOST_CC=gcc
|
2003-02-19 07:35:48 +08:00
|
|
|
|
|
|
|
ifeq ($(ARCH),i386)
|
2003-03-02 01:13:26 +08:00
|
|
|
CFLAGS=-Wall -O2 -g -fomit-frame-pointer
|
2003-02-19 06:55:36 +08:00
|
|
|
LDFLAGS=-g
|
2003-02-19 07:35:48 +08:00
|
|
|
LIBS=
|
|
|
|
CC=gcc
|
|
|
|
DEFINES=-DHAVE_BYTESWAP_H
|
2003-03-03 03:39:42 +08:00
|
|
|
OP_CFLAGS=$(CFLAGS) -malign-functions=0 -mpreferred-stack-boundary=2
|
2003-02-19 07:35:48 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(ARCH),ppc)
|
|
|
|
GCC_LIBS_DIR=/usr/netgem/tools/lib/gcc-lib/powerpc-linux/2.95.2
|
|
|
|
DIST=/home/fbe/nsv/dist/hw/n6-dtt
|
|
|
|
CC=powerpc-linux-gcc -msoft-float
|
|
|
|
CFLAGS=-Wall -pipe -O2 -mcpu=405 -mbig -nostdinc -g -I$(GCC_LIBS_DIR)/include -I$(DIST)/include
|
|
|
|
LIBS_DIR=$(DIST)/lib
|
|
|
|
CRT1=$(LIBS_DIR)/crt1.o
|
|
|
|
CRTI=$(LIBS_DIR)/crti.o
|
|
|
|
CRTN=$(LIBS_DIR)/crtn.o
|
|
|
|
CRTBEGIN=$(GCC_LIBS_DIR)/crtbegin.o
|
|
|
|
CRTEND=$(GCC_LIBS_DIR)/crtend.o
|
|
|
|
LDFLAGS=-static -g -nostdlib $(CRT1) $(CRTI) $(CRTBEGIN)
|
|
|
|
LIBS=-L$(LIBS_DIR) -ltinyc -lgcc $(CRTEND) $(CRTN)
|
|
|
|
DEFINES=-Dsocklen_t=int
|
2003-03-03 03:39:42 +08:00
|
|
|
OP_CFLAGS=$(CFLAGS)
|
2003-02-19 07:35:48 +08:00
|
|
|
endif
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
|
2003-03-03 22:32:43 +08:00
|
|
|
DEFINES+=-D_GNU_SOURCE
|
2003-03-02 01:13:26 +08:00
|
|
|
DEFINES+=-DCONFIG_PREFIX=\"/usr/local\"
|
2003-02-19 07:35:48 +08:00
|
|
|
LDSCRIPT=$(ARCH).ld
|
2003-03-03 03:39:42 +08:00
|
|
|
LIBS+=-ldl -lm
|
2003-03-03 23:02:29 +08:00
|
|
|
VERSION=0.1
|
2003-02-19 06:55:36 +08:00
|
|
|
|
2003-03-03 23:02:29 +08:00
|
|
|
OBJS= elfload.o main.o thunk.o syscall.o
|
2003-03-02 01:13:26 +08:00
|
|
|
OBJS+=translate-i386.o op-i386.o
|
2003-03-03 22:32:43 +08:00
|
|
|
# NOTE: the disassembler code is only needed for debugging
|
|
|
|
OBJS+=i386-dis.o dis-buf.o
|
2003-02-19 06:55:36 +08:00
|
|
|
SRCS = $(OBJS:.o=.c)
|
|
|
|
|
|
|
|
all: gemu
|
|
|
|
|
|
|
|
gemu: $(OBJS)
|
2003-03-02 01:13:26 +08:00
|
|
|
$(CC) -Wl,-T,$(LDSCRIPT) $(LDFLAGS) -o $@ $^ $(LIBS)
|
2003-02-19 06:55:36 +08:00
|
|
|
|
|
|
|
depend: $(SRCS)
|
|
|
|
$(CC) -MM $(CFLAGS) $^ 1>.depend
|
|
|
|
|
2003-03-02 01:13:26 +08: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-03 03:39:42 +08:00
|
|
|
$(CC) $(OP_CFLAGS) $(DEFINES) -c -o $@ $<
|
2003-03-02 01:13:26 +08:00
|
|
|
|
2003-02-19 06:55:36 +08:00
|
|
|
%.o: %.c
|
|
|
|
$(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
|
|
|
|
|
|
|
|
clean:
|
2003-03-03 23:02:29 +08:00
|
|
|
rm -f *.o *~ gemu dyngen TAGS
|
2003-02-19 06:55:36 +08:00
|
|
|
|
2003-03-02 01:13:26 +08:00
|
|
|
# various test targets
|
|
|
|
test speed: gemu
|
|
|
|
make -C tests $@
|
2003-02-19 06:55:36 +08:00
|
|
|
|
2003-03-02 01:13:26 +08:00
|
|
|
TAGS:
|
|
|
|
etags *.[ch] i386/*.[ch]
|
2003-02-19 06:55:36 +08:00
|
|
|
|
2003-03-03 23:02:29 +08: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\
|
|
|
|
cpu-i386.h gemu.h op-i386.c syscall-i386.h translate-i386.c\
|
|
|
|
dis-asm.h gen-i386.h op-i386.h syscall.c\
|
|
|
|
dis-buf.c i386-dis.c opreg_template.h syscall_defs.h\
|
|
|
|
i386.ld ppc.ld\
|
|
|
|
tests/test-i386.c tests/test-i386-shift.h tests/test-i386.h\
|
2003-03-04 09:14:13 +08:00
|
|
|
tests/test-i386-muldiv.h\
|
2003-03-03 23:02:29 +08:00
|
|
|
tests/test2.c tests/hello.c tests/sha1.c tests/test1.c
|
|
|
|
|
|
|
|
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 06:55:36 +08:00
|
|
|
ifneq ($(wildcard .depend),)
|
|
|
|
include .depend
|
|
|
|
endif
|