split out more asm from build, disable is on iOS (for now?)
[picodrive.git] / Makefile
index a503980..1a6374f 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,12 +1,48 @@
-# settings
-#use_fbdev = 1
-#fake_in_gp2x = 1
+TARGET ?= PicoDrive
+CFLAGS += -Wall -ggdb -falign-functions=2
+CFLAGS += -I.
+# FIXME
+CFLAGS += -Iplatform/linux/
+ifndef DEBUG
+CFLAGS += -O2 -DNDEBUG
+endif
 
-use_musashi = 1
-#use_fame = 1
-use_cz80 = 1
-#use_sh2drc = 1
-use_sh2mame = 1
+all: config.mak target_
+
+ifndef NO_CONFIG_MAK
+ifneq ($(wildcard config.mak),)
+config.mak: ./configure
+       @echo $@ is out-of-date, running configure
+       @sed -n "/.*Configured with/s/[^:]*: //p" $@ | sh
+include config.mak
+else
+config.mak:
+       @echo "Please run ./configure before running make!"
+       @exit 1
+endif
+else # NO_CONFIG_MAK
+config.mak:
+endif
+
+# default settings
+ifeq "$(ARCH)" "arm"
+use_cyclone ?= 1
+use_drz80 ?= 1
+use_sh2drc ?= 1
+use_svpdrc ?= 1
+
+asm_memory ?= 1
+asm_render ?= 1
+asm_ym2612 ?= 1
+asm_misc ?= 1
+asm_cdpico ?= 1
+asm_cdmemory ?= 1
+asm_mix ?= 1
+else # if not arm
+use_fame ?= 1
+use_cz80 ?= 1
+use_sh2mame ?= 1
+endif
 
 #drc_debug = 3
 #drc_debug_interp = 1
@@ -14,48 +50,67 @@ use_sh2mame = 1
 
 -include Makefile.local
 
-ifndef ARCH
-ARCH = x86
+ifeq "$(use_musashi)" "1"
+# due to CPU stop flag access
+asm_cdpico = 0
+asm_cdmemory = 0
 endif
 
-CC ?= $(CROSS_COMPILE)gcc
-
-DEFINES = _UNZIP_SUPPORT IO_STATS IN_EVDEV
-CFLAGS += -ggdb -Wall -falign-functions=2
-CFLAGS += -I.
-CFLAGS += -Iplatform/linux/
-LDLIBS += -lm -lpng
-
-all: PicoDrive
-
 # frontend
-OBJS += platform/linux/io.o platform/linux/emu.o platform/linux/blit.o \
-       platform/linux/log_io.o
+ifeq "$(PLATFORM)" "generic"
+OBJS += platform/linux/emu.o platform/linux/blit.o # FIXME
+OBJS += platform/common/plat_sdl.o
+OBJS += platform/libpicofe/plat_sdl.o platform/libpicofe/in_sdl.o
+OBJS += platform/libpicofe/plat_dummy.o
+USE_FRONTEND = 1
+endif
+ifeq "$(PLATFORM)" "pandora"
+platform/common/menu_pico.o: CFLAGS += -DPANDORA
+OBJS += platform/pandora/plat.o
+OBJS += platform/pandora/asm_utils.o
+OBJS += platform/common/arm_utils.o 
+OBJS += platform/libpicofe/linux/fbdev.o 
+OBJS += platform/libpicofe/linux/xenv.o
+OBJS += platform/libpicofe/pandora/plat.o
+USE_FRONTEND = 1
+endif
+ifeq "$(PLATFORM)" "libretro"
+OBJS += platform/libretro.o 
+endif
+
+ifeq "$(USE_FRONTEND)" "1"
 
 # common
-OBJS += platform/common/main.o platform/common/emu.o platform/common/menu_pico.o \
-       platform/common/config.o
+OBJS += platform/common/main.o platform/common/emu.o \
+       platform/common/menu_pico.o platform/common/config_file.o
 
 # libpicofe
 OBJS += platform/libpicofe/input.o platform/libpicofe/readpng.o \
        platform/libpicofe/fonts.o platform/libpicofe/linux/in_evdev.o \
-       platform/libpicofe/linux/plat.o platform/libpicofe/linux/sndout_oss.o
+       platform/libpicofe/linux/plat.o
 
-OBJS += platform/libpicofe/plat_dummy.o
-
-ifeq "$(use_fbdev)" "1"
-DEFINES += FBDEV
-OBJS += fbdev.o
-else
-LDLIBS += -lpthread
-LDLIBS += -lX11
+# libpicofe - sound
+OBJS += platform/libpicofe/sndout.o
+ifneq ($(findstring oss,$(SOUND_DRIVERS)),)
+platform/libpicofe/sndout.o: CFLAGS += -DHAVE_OSS
+OBJS += platform/libpicofe/linux/sndout_oss.o
+endif
+ifneq ($(findstring alsa,$(SOUND_DRIVERS)),)
+platform/libpicofe/sndout.o: CFLAGS += -DHAVE_ALSA
+OBJS += platform/libpicofe/linux/sndout_alsa.o
+endif
+ifneq ($(findstring sdl,$(SOUND_DRIVERS)),)
+platform/libpicofe/sndout.o: CFLAGS += -DHAVE_SDL
+OBJS += platform/libpicofe/sndout_sdl.o
 endif
 
 ifeq "$(ARCH)" "arm"
-OBJS += pico/carthw/svp/stub_arm.o
+OBJS += platform/libpicofe/arm_linux.o
 endif
-OBJS += pico/sound/mix.o
-OBJS += pico/carthw/svp/compiler.o
+
+endif # USE_FRONTEND
+
+OBJS += platform/common/mp3_dummy.o
 
 # zlib
 OBJS += zlib/gzio.o zlib/inffast.o zlib/inflate.o zlib/inftrees.o zlib/trees.o \
@@ -63,15 +118,59 @@ OBJS += zlib/gzio.o zlib/inffast.o zlib/inflate.o zlib/inftrees.o zlib/trees.o \
 # unzip
 OBJS += unzip/unzip.o unzip/unzip_stream.o
 
+
 include platform/common/common.mak
 
+OBJS += $(OBJS_COMMON)
 CFLAGS += $(addprefix -D,$(DEFINES))
 
+target_: $(TARGET)
+
 clean:
-       $(RM) PicoDrive $(OBJS)
+       $(RM) $(TARGET) $(OBJS)
 
-PicoDrive : $(OBJS)
-       $(CC) $(CFLAGS) $^ $(LDFLAGS) $(LDLIBS) -Wl,-Map=PicoDrive.map -o $@
+$(TARGET): $(OBJS)
+       $(CC) -o $@ $(CFLAGS) $^ $(LDFLAGS) $(LDLIBS) -Wl,-Map=$(TARGET).map
 
 pprof: platform/linux/pprof.c
        $(CC) -O2 -ggdb -DPPROF -DPPROF_TOOL -I../../ -I. $^ -o $@
+
+tools/textfilter: tools/textfilter.c
+       make -C tools/ textfilter
+
+.s.o:
+       $(CC) $(CFLAGS) -c $< -o $@
+
+# random deps
+pico/carthw/svp/compiler.o : cpu/drc/emit_$(ARCH).c
+cpu/sh2/compiler.o : cpu/drc/emit_$(ARCH).c
+cpu/sh2/mame/sh2pico.o : cpu/sh2/mame/sh2.c
+pico/pico.o pico/cd/pico.o : pico/pico_cmn.c pico/pico_int.h
+pico/memory.o pico/cd/memory.o : pico/pico_int.h pico/memory.h
+cpu/fame/famec.o: cpu/fame/famec.c cpu/fame/famec_opcodes.h
+
+# ----------- release -----------
+
+VER ?= $(shell head -n 1 platform/common/version.h | \
+       sed 's/.*"\(.*\)\.\(.*\)".*/\1\2/g')
+
+ifeq "$(PLATFORM)" "pandora"
+
+PND_MAKE ?= $(HOME)/dev/pnd/src/pandora-libraries/testdata/scripts/pnd_make.sh
+
+/tmp/readme.txt: tools/textfilter platform/base_readme.txt
+       tools/textfilter platform/base_readme.txt $@ PANDORA
+
+/tmp/PicoDrive.pxml: platform/pandora/PicoDrive.pxml.template
+       platform/pandora/make_pxml.sh $^ $@
+
+rel: PicoDrive platform/pandora/PicoDrive.run platform/pandora/picorestore \
+       pico/carthw.cfg /tmp/readme.txt platform/pandora/skin \
+       platform/pandora/PicoDrive.png platform/pandora/PicoDrive_p.png \
+       /tmp/PicoDrive.pxml
+       rm -rf out
+       mkdir out
+       cp -r $^ out/
+       $(PND_MAKE) -p PicoDrive_$(VER).pnd -d out -x out/PicoDrive.pxml -i out/PicoDrive.png -c
+
+endif