add configure, revive pnd build, unify/refactor things
[picodrive.git] / Makefile
index f0fdc5a..8e1a030 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,12 +1,51 @@
-# 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
+
+asm_memory = 1
+#asm_render = 1
+asm_ym2612 = 1
+asm_misc = 1
+asm_cdpico = 1
+asm_cdmemory = 1
+else # if not arm
+ifneq "$(ARCH)" "x86_64"
+# no 64bit support
+use_fame ?= 1
+else
+use_musashi ?= 1
+endif
+use_cz80 ?= 1
+use_sh2mame ?= 1
+endif
 
 #drc_debug = 3
 #drc_debug_interp = 1
@@ -14,55 +53,60 @@ use_sh2mame = 1
 
 -include Makefile.local
 
-ifndef ARCH
-ARCH = x86
+ifeq "$(use_musashi)" "1"
+# due to CPU stop flag acces
+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
-
-# tmp
-CFLAGS += `sdl-config --cflags` -DHAVE_SDL
-LDLIBS += `sdl-config --libs`
-
-all: PicoDrive
-
-# frontend
-OBJS += platform/linux/emu.o platform/linux/blit.o \
-       platform/linux/log_io.o
-
 # common
-OBJS += platform/common/main.o platform/common/emu.o platform/common/menu_pico.o \
-       platform/common/config_file.o platform/common/plat_sdl.o \
-       platform/common/mp3_dummy.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/plat_sdl.o platform/libpicofe/in_sdl.o \
-       platform/libpicofe/sndout.o platform/libpicofe/sndout_sdl.o
+       platform/libpicofe/linux/plat.o
 
-OBJS += platform/libpicofe/plat_dummy.o
+# 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 "$(use_fbdev)" "1"
-DEFINES += FBDEV
-OBJS += fbdev.o
-else
-LDLIBS += -lpthread
-LDLIBS += -lX11
+# frontend
+OBJS += platform/common/mp3_dummy.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
+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
 endif
 
 ifeq "$(ARCH)" "arm"
-OBJS += pico/carthw/svp/stub_arm.o
-endif
+OBJS += platform/libpicofe/arm_linux.o
+OBJS += pico/sound/mix_arm.o
+else
 OBJS += pico/sound/mix.o
-OBJS += pico/carthw/svp/compiler.o
+endif
 
 # zlib
 OBJS += zlib/gzio.o zlib/inffast.o zlib/inflate.o zlib/inftrees.o zlib/trees.o \
@@ -70,15 +114,42 @@ 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
 
-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 $@
+
+# ----------- 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