sparc64 support (Blue Swirl)

git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1254 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
bellard 2005-01-30 22:43:42 +00:00
parent c1135f6152
commit 64b3ab2439
3 changed files with 23 additions and 7 deletions

View File

@ -4,6 +4,9 @@ TARGET_BASE_ARCH:=$(TARGET_ARCH)
ifeq ($(TARGET_ARCH), x86_64) ifeq ($(TARGET_ARCH), x86_64)
TARGET_BASE_ARCH:=i386 TARGET_BASE_ARCH:=i386
endif endif
ifeq ($(TARGET_ARCH), sparc64)
TARGET_BASE_ARCH:=sparc
endif
TARGET_PATH=$(SRC_PATH)/target-$(TARGET_BASE_ARCH) TARGET_PATH=$(SRC_PATH)/target-$(TARGET_BASE_ARCH)
VPATH=$(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw:$(SRC_PATH)/audio VPATH=$(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw:$(SRC_PATH)/audio
DEFINES=-I. -I$(TARGET_PATH) -I$(SRC_PATH) DEFINES=-I. -I$(TARGET_PATH) -I$(SRC_PATH)
@ -102,6 +105,13 @@ endif
endif # ARCH = x86_64 endif # ARCH = x86_64
endif # TARGET_ARCH = sparc endif # TARGET_ARCH = sparc
ifeq ($(TARGET_ARCH), sparc64)
ifdef CONFIG_SOFTMMU
PROGS+=$(QEMU_SYSTEM)
endif
endif # TARGET_ARCH = sparc64
endif # !CONFIG_USER_ONLY endif # !CONFIG_USER_ONLY
ifdef CONFIG_STATIC ifdef CONFIG_STATIC
@ -245,7 +255,7 @@ ifeq ($(TARGET_ARCH), ppc)
LIBOBJS+= op_helper.o helper.o LIBOBJS+= op_helper.o helper.o
endif endif
ifeq ($(TARGET_ARCH), sparc) ifeq ($(TARGET_BASE_ARCH), sparc)
LIBOBJS+= op_helper.o helper.o LIBOBJS+= op_helper.o helper.o
endif endif
@ -266,7 +276,7 @@ endif
ifeq ($(findstring ppc, $(TARGET_ARCH) $(ARCH)),ppc) ifeq ($(findstring ppc, $(TARGET_ARCH) $(ARCH)),ppc)
LIBOBJS+=ppc-dis.o LIBOBJS+=ppc-dis.o
endif endif
ifeq ($(findstring sparc, $(TARGET_ARCH) $(ARCH)),sparc) ifeq ($(findstring sparc, $(TARGET_BASE_ARCH) $(ARCH)),sparc)
LIBOBJS+=sparc-dis.o LIBOBJS+=sparc-dis.o
endif endif
ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm) ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
@ -323,7 +333,7 @@ VL_OBJS+= ppc.o ide.o ne2000.o pckbd.o vga.o $(SOUND_HW) dma.o $(AUDIODRV)
VL_OBJS+= mc146818rtc.o serial.o i8259.o i8254.o fdc.o m48t59.o VL_OBJS+= mc146818rtc.o serial.o i8259.o i8254.o fdc.o m48t59.o
VL_OBJS+= ppc_prep.o ppc_chrp.o cuda.o adb.o openpic.o mixeng.o VL_OBJS+= ppc_prep.o ppc_chrp.o cuda.o adb.o openpic.o mixeng.o
endif endif
ifeq ($(TARGET_ARCH), sparc) ifeq ($(TARGET_BASE_ARCH), sparc)
VL_OBJS+= sun4m.o tcx.o lance.o iommu.o m48t08.o magic-load.o slavio_intctl.o slavio_timer.o slavio_serial.o fdc.o VL_OBJS+= sun4m.o tcx.o lance.o iommu.o m48t08.o magic-load.o slavio_intctl.o slavio_timer.o slavio_serial.o fdc.o
endif endif
ifdef CONFIG_GDBSTUB ifdef CONFIG_GDBSTUB
@ -399,7 +409,7 @@ ifeq ($(TARGET_ARCH), arm)
op.o: op.c op_template.h op.o: op.c op_template.h
endif endif
ifeq ($(TARGET_ARCH), sparc) ifeq ($(TARGET_BASE_ARCH), sparc)
op.o: op.c op_template.h op_mem.h op.o: op.c op_template.h op_mem.h
endif endif

10
configure vendored
View File

@ -190,10 +190,10 @@ fi
if test -z "$target_list" ; then if test -z "$target_list" ; then
# these targets are portable # these targets are portable
target_list="i386-softmmu ppc-softmmu sparc-softmmu x86_64-softmmu" target_list="i386-softmmu ppc-softmmu sparc-softmmu x86_64-softmmu sparc64-softmmu"
# the following are Linux specific # the following are Linux specific
if [ "$linux" = "yes" ] ; then if [ "$linux" = "yes" ] ; then
target_list="i386-user i386 arm-user armeb-user sparc-user ppc-user $target_list" target_list="i386-user i386 arm-user armeb-user sparc-user ppc-user sparc64-user $target_list"
fi fi
fi fi
@ -500,6 +500,7 @@ target_cpu=`echo $target | cut -d '-' -f 1`
target_bigendian="no" target_bigendian="no"
[ "$target_cpu" = "armeb" ] && target_bigendian=yes [ "$target_cpu" = "armeb" ] && target_bigendian=yes
[ "$target_cpu" = "sparc" ] && target_bigendian=yes [ "$target_cpu" = "sparc" ] && target_bigendian=yes
[ "$target_cpu" = "sparc64" ] && target_bigendian=yes
[ "$target_cpu" = "ppc" ] && target_bigendian=yes [ "$target_cpu" = "ppc" ] && target_bigendian=yes
target_softmmu="no" target_softmmu="no"
if expr $target : '.*-softmmu' > /dev/null ; then if expr $target : '.*-softmmu' > /dev/null ; then
@ -544,6 +545,11 @@ elif test "$target_cpu" = "sparc" ; then
echo "TARGET_ARCH=sparc" >> $config_mak echo "TARGET_ARCH=sparc" >> $config_mak
echo "#define TARGET_ARCH \"sparc\"" >> $config_h echo "#define TARGET_ARCH \"sparc\"" >> $config_h
echo "#define TARGET_SPARC 1" >> $config_h echo "#define TARGET_SPARC 1" >> $config_h
elif test "$target_cpu" = "sparc64" ; then
echo "TARGET_ARCH=sparc64" >> $config_mak
echo "#define TARGET_ARCH \"sparc64\"" >> $config_h
echo "#define TARGET_SPARC 1" >> $config_h
echo "#define TARGET_SPARC64 1" >> $config_h
elif test "$target_cpu" = "ppc" ; then elif test "$target_cpu" = "ppc" ; then
echo "TARGET_ARCH=ppc" >> $config_mak echo "TARGET_ARCH=ppc" >> $config_mak
echo "#define TARGET_ARCH \"ppc\"" >> $config_h echo "#define TARGET_ARCH \"ppc\"" >> $config_h

View File

@ -153,7 +153,7 @@ const argtype *thunk_convert(void *dst, const void *src,
} }
break; break;
#else #else
#error unsupported conversion #warning unsupported conversion
#endif #endif
case TYPE_ARRAY: case TYPE_ARRAY:
{ {