32x drc functional on ARM, random adjustments
[picodrive.git] / platform / gp2x / Makefile
index 54c806a..01e4e3b 100644 (file)
@@ -1,8 +1,4 @@
-\r
-# you may or may not need to change this\r
-#devkit_path = x:/stuff/dev/devkitgp2x/\r
 export CROSS = arm-linux-\r
-#CROSS = $(devkit_path)bin/arm-linux-\r
 \r
 # settings\r
 #mz80 = 1\r
@@ -14,27 +10,28 @@ asm_misc = 1
 asm_cdpico = 1\r
 asm_cdmemory = 1\r
 amalgamate = 0\r
-profile = 2\r
+#profile = 1\r
 #use_musashi = 1\r
-#up = 1\r
+use_sh2drc = 1\r
+drc_debug = 1\r
 \r
+-include Makefile.local\r
 \r
 ifeq "$(debug_cyclone)" "1"\r
 use_cyclone = 1\r
 use_musashi = 1\r
 endif\r
 ifeq "$(use_musashi)" "1"\r
+# due to CPU stop flag acces\r
 asm_cdpico = 0\r
-asm_memory = 0\r
 asm_cdmemory = 0\r
 else\r
 use_cyclone = 1\r
 endif\r
 \r
-DEFINC = -I../.. -I. -DARM -D__GP2X__ -DIN_GP2X -DIN_EVDEV # -DBENCHMARK\r
-CFLAGS += -Wall -Winline\r
+DEFINES += ARM __GP2X__ IN_GP2X IN_EVDEV # BENCHMARK\r
+CFLAGS += -Wall -Winline -I../.. -I.\r
 ifeq ($(DEBUG),)\r
-# -ftracer -fstrength-reduce # TODO measure impact\r
 CFLAGS += -O3 -fomit-frame-pointer -fstrict-aliasing -ffast-math\r
 else\r
 CFLAGS += -ggdb\r
@@ -46,8 +43,9 @@ ifeq "$(profile)" "2"
 CFLAGS += -fprofile-use\r
 endif\r
 CFLAGS += -mcpu=arm920t -mtune=arm920t\r
-SFLAGS = $(CFLAGS)\r
 ASFLAGS = -mcpu=arm920t -mfloat-abi=soft\r
+LDFLAGS += -lm -lpng\r
+\r
 CC = $(CROSS)gcc\r
 STRIP = $(CROSS)strip\r
 AS = $(CROSS)as\r
@@ -55,28 +53,30 @@ LD = $(CROSS)ld
 OBJCOPY = $(CROSS)objcopy\r
 \r
 # frontend\r
-OBJS += plat.o warm.o pollux_set.o soc.o soc_mmsp2.o soc_pollux.o emu.o in_gp2x.o\r
+OBJS += plat.o warm.o pollux_set.o soc.o soc_mmsp2.o soc_pollux.o soc_dummy.o emu.o in_gp2x.o\r
 # 940 core control\r
 OBJS += 940ctl.o\r
 \r
 # common\r
-OBJS += platform/common/emu.o platform/common/input.o platform/common/menu.o \\r
-       platform/common/fonts.o platform/common/config.o platform/common/arm_utils.o \\r
-       platform/common/arm_linux.o platform/common/readpng.o \\r
-       platform/common/mp3_helix.o platform/common/main.o \\r
+OBJS += platform/common/emu.o platform/common/menu.o platform/common/fonts.o platform/common/config.o \\r
+       platform/common/arm_utils.o platform/common/arm_linux.o platform/common/readpng.o \\r
+       platform/common/mp3_helix.o platform/common/input.o platform/common/main.o \\r
        platform/linux/sndout_oss.o platform/linux/plat.o platform/linux/in_evdev.o\r
 \r
 # Pico\r
 ifeq "$(amalgamate)" "1"\r
 OBJS += ../../picoAll.o\r
 else\r
-OBJS += pico/memory.o pico/videoport.o pico/draw.o pico/draw2.o pico/pico.o pico/sek.o \\r
-               pico/area.o pico/cart.o pico/misc.o pico/patch.o pico/debug.o\r
+OBJS += pico/area.o pico/cart.o pico/memory.o pico/pico.o pico/sek.o pico/z80if.o \\r
+       pico/videoport.o pico/draw2.o pico/draw.o pico/mode4.o pico/sms.o \\r
+       pico/misc.o pico/eeprom.o pico/patch.o pico/debug.o\r
 # Pico - CD\r
 OBJS += pico/cd/pico.o pico/cd/memory.o pico/cd/sek.o pico/cd/LC89510.o \\r
                pico/cd/cd_sys.o pico/cd/cd_file.o pico/cd/cue.o pico/cd/gfx_cd.o \\r
                pico/cd/area.o pico/cd/misc.o pico/cd/pcm.o pico/cd/buffering.o\r
 endif\r
+# Pico - 32X\r
+OBJS += pico/32x/32x.o pico/32x/memory.o pico/32x/draw.o pico/32x/pwm.o\r
 # Pico - Pico\r
 OBJS += pico/pico/pico.o pico/pico/memory.o pico/pico/xpcm.o\r
 # Pico - carthw\r
@@ -98,49 +98,64 @@ OBJS += zlib/gzio.o zlib/inffast.o zlib/inflate.o zlib/inftrees.o zlib/trees.o \
 ifeq "$(debug_cyclone)" "1"\r
 OBJS += pico/DebugCPU.o cpu/musashi/m68kdasm.o\r
 endif\r
-# drz80/mz80\r
+# CPU cores\r
+ifeq "$(use_musashi)" "1"\r
+DEFINES += EMU_M68K\r
+OBJS += cpu/musashi/m68kops.o cpu/musashi/m68kcpu.o\r
+endif\r
+ifeq "$(use_cyclone)" "1"\r
+DEFINES += EMU_C68K\r
+OBJS += pico/m68kif_cyclone.o cpu/Cyclone/proj/Cyclone.o cpu/Cyclone/tools/idle.o\r
+endif\r
 ifeq "$(mz80)" "1"\r
-DEFINC += -D_USE_MZ80\r
+DEFINES += _USE_MZ80\r
 OBJS += cpu/mz80/mz80.o\r
 else\r
-DEFINC += -D_USE_DRZ80\r
+DEFINES += _USE_DRZ80\r
 OBJS += cpu/DrZ80/drz80.o\r
 endif\r
-ifeq "$(use_musashi)" "1"\r
-DEFINC += -DEMU_M68K\r
-OBJS += cpu/musashi/m68kops.o cpu/musashi/m68kcpu.o\r
+OBJS += cpu/sh2/sh2.o\r
+ifeq "$(use_sh2drc)" "1"\r
+DEFINES += DRC_SH2 DRC_TMP\r
+OBJS += cpu/sh2/mame/sh2pico.o\r
+OBJS += cpu/sh2/compiler.o\r
+OBJS += cpu/sh2/stub_arm.o\r
+ifdef drc_debug\r
+DEFINES += DRC_DEBUG=$(drc_debug)\r
+OBJS += cpu/sh2/mame/sh2dasm.o\r
+OBJS += platform/linux/host_dasm.o\r
+LDFLAGS += -lbfd -lopcodes -liberty\r
 endif\r
-ifeq "$(use_cyclone)" "1"\r
-DEFINC += -DEMU_C68K\r
-OBJS += cpu/Cyclone/proj/Cyclone.o cpu/Cyclone/tools/idle.o\r
+else\r
+OBJS += cpu/sh2/mame/sh2pico.o\r
 endif\r
+OBJS += cpu/drc/cmn.o\r
+\r
+CFLAGS += $(addprefix -D,$(DEFINES))\r
 \r
 vpath %.c = ../..\r
 vpath %.s = ../..\r
 vpath %.S = ../..\r
-DIRS = platform platform/gp2x platform/linux platform/common pico pico/cd pico/pico pico/sound \\r
-       pico/carthw/svp zlib unzip cpu cpu/musashi cpu/Cyclone/proj cpu/Cyclone/tools cpu/mz80 cpu/DrZ80\r
 \r
+DIRS = platform platform/gp2x platform/linux platform/common pico pico/cd pico/pico pico/32x \\r
+       pico/sound pico/carthw/svp zlib unzip cpu cpu/musashi cpu/Cyclone/proj cpu/Cyclone/tools \\r
+       cpu/mz80 cpu/DrZ80 cpu/sh2/mame cpu/drc\r
 \r
-all: mkdirs PicoDrive_dyn PicoDrive_sta\r
+\r
+all: mkdirs PicoDrive\r
 \r
 include ../common/common_arm.mak\r
+include ../common/revision.mak\r
 \r
+# partial linking helps profiled builds due to section merging\r
 PicoDrive.o : $(OBJS) ../common/helix/$(CROSS)helix-mp3.a\r
        $(LD) -r -o $@ $^\r
 \r
-PicoDrive_dyn : PicoDrive.o\r
-       @echo ">>>" $@\r
-       $(CC) -o $@ $(CFLAGS) $^ -Wl,-Bstatic -lm -Wl,-Bdynamic -lpng -Wl,-Map=$@.map\r
-ifeq ($(DEBUG),)\r
-       $(STRIP) $@\r
-endif\r
-#      $(CC) -o $@ $(CFLAGS) $^ -lm -lpng -Wl,-Map=$@.map\r
-#      $(CC) -o $@ $(CFLAGS) $^ -Wl,-Bstatic -lm -Wl,-Bdynamic -lpng -Wl,-Map=$@.map\r
-\r
-PicoDrive_sta : PicoDrive.o\r
+# still using static, dynamic linking slows Wiz 1-10%\r
+# also libm on F100 is not compatible\r
+PicoDrive : PicoDrive.o\r
        @echo ">>>" $@\r
-       $(CC) -static -o $@ $(CFLAGS) $^ -lm -lpng -Wl,-Map=$@.map\r
+       $(CC) -static -o $@ $(CFLAGS) $^ $(LDFLAGS) -Wl,-Map=$@.map\r
 ifeq ($(DEBUG),)\r
        $(STRIP) $@\r
 endif\r
@@ -162,15 +177,17 @@ ifeq ($(VER),)
 $(error need VER)\r
 endif\r
 endif\r
+CODE940 = code940/pico940_v3.bin\r
 \r
-rel: PicoDrive PicoDrive.gpe code940/pico940_v3.bin readme.txt PicoDrive.man.txt PicoDrive.png ../game_def.cfg\r
-       zip -9 -j ../../PicoDrive_$(VER).zip $^ mmuhack.o\r
+rel: PicoDrive PicoDrive.gpe $(CODE940) readme.txt PicoDrive.png ../game_def.cfg \\r
+               warm_2.4.25.o warm_2.4.26-open2x.o warm_2.6.24.ko\r
+       zip -9 -j ../../PicoDrive_$(VER).zip $^\r
        zip -9 -r ../../PicoDrive_$(VER).zip skin -i \*.png -i \*.txt\r
        mkdir bin_to_cso_mp3\r
        cp ../../tools/bin_to_cso_mp3/* bin_to_cso_mp3/\r
        zip -9 -r ../../PicoDrive_$(VER).zip bin_to_cso_mp3\r
        rm -rf bin_to_cso_mp3\r
 \r
-code940/code940.bin:\r
+$(CODE940):\r
        make -C code940/\r
 \r