pandora: fix readme and pxml version
[picodrive.git] / Makefile
index a503980..5cd200b 100644 (file)
--- a/Makefile
+++ b/Makefile
-# settings
-#use_fbdev = 1
-#fake_in_gp2x = 1
+$(LD) ?= $(CC)
+TARGET ?= picodrive
+ASAN ?= 0
+DEBUG ?= 0
+CFLAGS += -I.
+CYCLONE_CC ?= gcc
+CYCLONE_CXX ?= g++
+
+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
+
+# This is actually needed, believe me - one bit is used as a flag in some tables
+# If you really have to disable this, set NO_ALIGN_FUNCTIONS elsewhere.
+ifndef NO_ALIGN_FUNCTIONS
+CFLAGS += -falign-functions=2
+endif
+
+# profiling
+pprof ?= 0
+gperf ?= 0
+
+ifneq ("$(PLATFORM)", "libretro")
+       CFLAGS += -Wall -g
+ifneq ("$(PLATFORM)", "psp")
+ifneq ($(findstring gcc,$(shell $(CC) -v 2>&1)),)
+       CFLAGS += -ffunction-sections -fdata-sections
+       LDFLAGS += -Wl,--gc-sections
+endif
+endif
+
+ifeq "$(ASAN)" "1"
+       CFLAGS += -fsanitize=address -fsanitize=leak -fsanitize=bounds -fno-omit-frame-pointer -fno-common -O1 -g
+       LDLIBS += -fsanitize=address -fsanitize=leak -fsanitize=bounds -static-libasan
+else
+ifeq "$(DEBUG)" "0"
+       CFLAGS += -O3 -DNDEBUG
+else
+       CFLAGS += -O1
+endif
+endif
+       LD = $(CC)
+       OBJOUT ?= -o
+       LINKOUT ?= -o
+endif
+
+
+chkCCflag = $(shell n=/dev/null; echo $(1) | tr " " "\n" | while read f; do \
+           $(CC) $$f -x c -c $$n -o $$n 2>$$n && echo "_$$f" | tr -d _; done)
+
+ifeq ("$(PLATFORM)",$(filter "$(PLATFORM)","gp2x" "opendingux" "rpi1"))
+# very small caches, avoid optimization options making the binary much bigger
+CFLAGS += -fno-common -finline-limit=42 -fno-unroll-loops -ffast-math
+CFLAGS += $(call chkCCflag, -fno-stack-protector)
+ifneq ($(call chkCCflag, -fipa-ra),) # gcc >= 5
+CFLAGS += $(call chkCCflag, -flto -fipa-pta -fipa-ra)
+else
+# these improve execution speed on 32bit arm/mips with gcc pre-5 toolchains
+CFLAGS += $(call chkCCflag, -fno-caller-saves -fno-guess-branch-probability -fno-regmove)
+# very old gcc toolchains may not have these options
+CFLAGS += $(call chkCCflag, -fno-tree-loop-if-convert -fipa-pta -fno-ipa-cp)
+endif
+else
+ifneq ($(STATIC_LINKING), 1)
+CFLAGS += $(call chkCCflag, -flto)
+endif
+endif
 
-use_musashi = 1
-#use_fame = 1
-use_cz80 = 1
-#use_sh2drc = 1
-use_sh2mame = 1
+# revision info from repository if this not a tagged release
+ifeq "$(shell git describe --tags --exact-match HEAD 2>/dev/null)" ""
+GIT_REVISION ?= -$(shell git rev-parse --short HEAD || echo unknown)
+endif
+CFLAGS += -DREVISION=\"$(GIT_REVISION)\"
 
-#drc_debug = 3
-#drc_debug_interp = 1
-#profile = 1
+# default settings
+use_libchdr ?= 1
+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_cdmemory ?= 1
+asm_mix ?= 1
+asm_32xdraw ?= 1
+asm_32xmemory ?= 1
+else
+use_fame ?= 1
+use_cz80 ?= 1
+ifneq (,$(filter x86% i386% i686% mips% aarch% riscv% powerpc% ppc%, $(ARCH)))
+use_sh2drc ?= 1
+endif
+endif
 
 -include Makefile.local
 
-ifndef ARCH
-ARCH = x86
+# TODO this should somehow go to the platform directory?
+ifeq "$(PLATFORM)" "generic"
+PicoDrive.zip: $(TARGET)
+       $(RM) -rf .od_data
+       mkdir .od_data
+       cp -r platform/linux/skin .od_data
+       cp platform/game_def.cfg .od_data
+       $(STRIP) $< -o .od_data/picodrive
+       cd .od_data && zip -9 -r ../$@ *
+all: PicoDrive.zip
 endif
 
-CC ?= $(CROSS_COMPILE)gcc
+ifeq "$(PLATFORM)" "win32"
+PicoDrive.zip: $(TARGET)
+       $(RM) -rf .od_data
+       mkdir .od_data
+       cp -r platform/linux/skin .od_data
+       cp platform/game_def.cfg .od_data
+       $(STRIP) $< -o .od_data/PicoDrive.exe
+       cd .od_data && zip -9 -r ../$@ *
+all: PicoDrive.zip
+endif
 
-DEFINES = _UNZIP_SUPPORT IO_STATS IN_EVDEV
-CFLAGS += -ggdb -Wall -falign-functions=2
-CFLAGS += -I.
-CFLAGS += -Iplatform/linux/
-LDLIBS += -lm -lpng
+ifeq "$(PLATFORM)" "opendingux"
+.od_data: $(TARGET)
+       $(RM) -rf .od_data
+       mkdir .od_data
+       cp -r platform/opendingux/data/. .od_data
+       cp platform/game_def.cfg .od_data
+       $(STRIP) $< -o .od_data/picodrive
+.PHONY: .od_data
 
-all: PicoDrive
+ifneq (,$(filter %__DINGUX__, $(CFLAGS)))
+# "legacy" dingux without opk support
+PicoDrive-dge.zip: .od_data
+       rm -f .od_data/default.*.desktop
+       cd .od_data && zip -9 -r ../$@ *
+all: PicoDrive-dge.zip
+CFLAGS += -DSDL_SURFACE_SW # some legacy dinguces had bugs in HWSURFACE
+else
+ifneq (,$(filter %__MIYOO__, $(CFLAGS)))
+PicoDrive-miyoo.ipk: .od_data
+       rm -f .od_data/default.*.desktop .od_data/PicoDrive.dge
+       gm2xpkg -i platform/miyoo/pkg.cfg
+       mv picodrive.ipk $@
+       @gm2xpkg -c platform/miyoo/pkg.cfg >/dev/null 2>&1
+all: PicoDrive-miyoo.ipk
+else
+PicoDrive.opk: .od_data
+       rm -f .od_data/PicoDrive.dge
+       mksquashfs .od_data $@ -all-root -noappend -no-exports -no-xattrs
+all: PicoDrive.opk
+endif
+endif
 
-# frontend
-OBJS += platform/linux/io.o platform/linux/emu.o platform/linux/blit.o \
-       platform/linux/log_io.o
+OBJS += platform/opendingux/inputmap.o
+use_inputmap ?= 1
+
+# OpenDingux is a generic platform, really.
+PLATFORM := generic
+endif
+ifeq ("$(PLATFORM)",$(filter "$(PLATFORM)","rpi1" "rpi2"))
+CFLAGS += -DHAVE_GLES -DRASPBERRY
+CFLAGS += -I/opt/vc/include/ -I/opt/vc/include/interface/vcos/pthreads/ -I/opt/vc/include/interface/vmcs_host/linux/
+LDFLAGS += -ldl -lbcm_host -L/opt/vc/lib
+# Stupid renaming occured in latest raspbian...
+ifneq (,$(wildcard /opt/vc/lib/libbrcmGLESv2.so))
+LDFLAGS += -lbrcmEGL -lbrcmGLESv2
+else
+LDFLAGS += -lEGL -lGLESv2 # on raspi GLESv1_CM is included in GLESv2
+endif
+OBJS += platform/linux/emu.o platform/linux/blit.o # FIXME
+OBJS += platform/common/plat_sdl.o platform/common/inputmap_kbd.o
+OBJS += platform/libpicofe/plat_sdl.o platform/libpicofe/in_sdl.o
+OBJS += platform/libpicofe/linux/plat.o
+USE_FRONTEND = 1
+endif
+ifeq "$(PLATFORM)" "generic"
+#ifeq (y,$(shell echo "\#include <GLES/gl.h>" | $(CC) -E -xc - >/dev/null 2>&1 && echo y))
+ifeq "$(HAVE_GLES)" "1"
+CFLAGS += -DHAVE_GLES
+LDFLAGS += -lEGL -lGLESv1_CM
+endif
+CFLAGS += -DSDL_OVERLAY_2X -DSDL_BUFFER_3X -DSDL_REDRAW_EVT
+OBJS += platform/linux/emu.o platform/linux/blit.o # FIXME
+ifeq "$(use_inputmap)" "1"
+OBJS += platform/common/plat_sdl.o platform/opendingux/inputmap.o
+else
+OBJS += platform/common/plat_sdl.o platform/common/inputmap_kbd.o
+endif
+OBJS += platform/libpicofe/plat_sdl.o platform/libpicofe/in_sdl.o
+OBJS += platform/libpicofe/linux/plat.o
+USE_FRONTEND = 1
+endif
+ifeq "$(PLATFORM)" "pandora"
+platform/common/menu_pico.o: CFLAGS += -DPANDORA
+platform/libpicofe/linux/plat.o: CFLAGS += -DPANDORA
+OBJS += platform/pandora/plat.o
+OBJS += platform/pandora/asm_utils.o
+OBJS += platform/common/arm_utils.o 
+OBJS += platform/libpicofe/linux/in_evdev.o
+OBJS += platform/libpicofe/linux/fbdev.o 
+OBJS += platform/libpicofe/linux/xenv.o
+OBJS += platform/libpicofe/linux/plat.o
+OBJS += platform/libpicofe/pandora/plat.o
+USE_FRONTEND = 1
+endif
+ifeq "$(PLATFORM)" "gp2x"
+OBJS += platform/common/arm_utils.o 
+OBJS += platform/libpicofe/linux/in_evdev.o
+OBJS += platform/libpicofe/linux/plat.o
+OBJS += platform/libpicofe/gp2x/in_gp2x.o
+OBJS += platform/libpicofe/gp2x/soc.o 
+OBJS += platform/libpicofe/gp2x/soc_mmsp2.o 
+OBJS += platform/libpicofe/gp2x/soc_pollux.o 
+OBJS += platform/libpicofe/gp2x/plat.o 
+OBJS += platform/libpicofe/gp2x/pollux_set.o 
+OBJS += platform/gp2x/940ctl.o 
+OBJS += platform/gp2x/plat.o 
+OBJS += platform/gp2x/emu.o 
+OBJS += platform/gp2x/vid_mmsp2.o 
+OBJS += platform/gp2x/vid_pollux.o 
+OBJS += platform/gp2x/warm.o 
+USE_FRONTEND = 1
+PLATFORM_MP3 ?= 1
+endif
+ifeq "$(PLATFORM)" "psp"
+CFLAGS += -DUSE_BGR565 -G8 # -DLPRINTF_STDIO -DFW15
+LDLIBS += -lpspgu -lpspge -lpsppower -lpspaudio -lpspdisplay -lpspaudiocodec
+LDLIBS += -lpspctrl
+platform/common/main.o: CFLAGS += -Dmain=pico_main
+OBJS += platform/psp/plat.o
+OBJS += platform/psp/emu.o
+OBJS += platform/psp/in_psp.o
+OBJS += platform/psp/psp.o
+OBJS += platform/psp/asm_utils.o
+OBJS += platform/psp/mp3.o
+USE_FRONTEND = 1
+endif
+ifeq "$(PLATFORM)" "ps2"
+CFLAGS += -DUSE_BGR555 # -DLOG_TO_FILE
+LDLIBS += -lpatches -lgskit -ldmakit -lps2_drivers
+OBJS += platform/ps2/plat.o
+OBJS += platform/ps2/emu.o
+OBJS += platform/ps2/in_ps2.o
+USE_FRONTEND = 1
+endif
+ifeq "$(PLATFORM)" "win32"
+CFLAGS += -DSDL_OVERLAY_2X -DSDL_BUFFER_3X -DSDL_REDRAW_EVT
+OBJS += platform/win32/plat.o
+OBJS += platform/linux/emu.o platform/linux/blit.o # FIXME
+OBJS += platform/common/plat_sdl.o platform/common/inputmap_kbd.o
+OBJS += platform/libpicofe/plat_sdl.o platform/libpicofe/in_sdl.o
+USE_FRONTEND = 1
+endif
+ifeq "$(PLATFORM)" "libretro"
+OBJS += platform/libretro/libretro.o
+ifneq ($(STATIC_LINKING), 1)
+CFLAGS += -DHAVE_ZLIB
+OBJS += platform/libretro/libretro-common/formats/png/rpng.o
+OBJS += platform/libretro/libretro-common/streams/trans_stream.o
+OBJS += platform/libretro/libretro-common/streams/trans_stream_pipe.o
+OBJS += platform/libretro/libretro-common/streams/trans_stream_zlib.o
+OBJS += platform/libretro/libretro-common/file/file_path_io.o
+OBJS += platform/libretro/libretro-common/file/file_path.o
+OBJS += platform/libretro/libretro-common/vfs/vfs_implementation.o
+OBJS += platform/libretro/libretro-common/time/rtime.o
+OBJS += platform/libretro/libretro-common/string/stdstring.o
+OBJS += platform/libretro/libretro-common/compat/compat_strcasestr.o
+OBJS += platform/libretro/libretro-common/encodings/encoding_utf.o
+OBJS += platform/libretro/libretro-common/compat/compat_strl.o
+ifeq "$(USE_LIBRETRO_VFS)" "1"
+OBJS += platform/libretro/libretro-common/compat/compat_posix_string.o
+OBJS += platform/libretro/libretro-common/compat/fopen_utf8.o
+OBJS += platform/libretro/libretro-common/streams/file_stream.o
+OBJS += platform/libretro/libretro-common/streams/file_stream_transforms.o
+endif
+endif
+ifeq "$(USE_LIBRETRO_VFS)" "1"
+OBJS += platform/libretro/libretro-common/memmap/memmap.o
+endif
+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/upscale.o \
+       platform/common/menu_pico.o platform/common/keyboard.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/fonts.o
+ifneq (,$(filter %HAVE_GLES, $(CFLAGS)))
+OBJS += platform/libpicofe/gl.o platform/libpicofe/gl_platform.o
+endif
+
+# 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 += platform/libpicofe/arm_linux.o
+endif
 
-OBJS += platform/libpicofe/plat_dummy.o
+endif # USE_FRONTEND
 
-ifeq "$(use_fbdev)" "1"
-DEFINES += FBDEV
-OBJS += fbdev.o
+ifneq "$(PLATFORM)" "psp"
+OBJS += platform/common/mp3.o platform/common/mp3_sync.o
+ifeq "$(PLATFORM_MP3)" "1"
+OBJS += platform/common/mp3_helix.o
+else ifeq "$(HAVE_LIBAVCODEC)" "1"
+OBJS += platform/common/mp3_libavcodec.o
 else
-LDLIBS += -lpthread
-LDLIBS += -lX11
+#OBJS += platform/common/mp3_minimp3.o
+OBJS += platform/common/mp3_drmp3.o
+endif
 endif
 
-ifeq "$(ARCH)" "arm"
-OBJS += pico/carthw/svp/stub_arm.o
+ifeq (1,$(use_libchdr))
+CFLAGS += -DUSE_LIBCHDR
+
+# chdr
+CHDR = pico/cd/libchdr
+CHDR_OBJS += $(CHDR)/src/libchdr_chd.o $(CHDR)/src/libchdr_cdrom.o
+CHDR_OBJS += $(CHDR)/src/libchdr_flac.o
+CHDR_OBJS += $(CHDR)/src/libchdr_bitstream.o $(CHDR)/src/libchdr_huffman.o
+
+LZMA = $(CHDR)/deps/lzma-24.05
+LZMA_OBJS += $(LZMA)/src/CpuArch.o $(LZMA)/src/Alloc.o $(LZMA)/src/LzmaEnc.o
+LZMA_OBJS += $(LZMA)/src/Sort.o $(LZMA)/src/LzmaDec.o $(LZMA)/src/LzFind.o
+LZMA_OBJS += $(LZMA)/src/Delta.o
+$(LZMA_OBJS): CFLAGS += -DZ7_ST -Wno-unused
+
+ZSTD = $(CHDR)/deps/zstd-1.5.6/lib
+ZSTD_OBJS += $(ZSTD)/common/entropy_common.o $(ZSTD)/common/error_private.o
+ZSTD_OBJS += $(ZSTD)/common/fse_decompress.o $(ZSTD)/common/xxhash.o
+ZSTD_OBJS += $(ZSTD)/common/zstd_common.o
+ZSTD_OBJS += $(ZSTD)/decompress/huf_decompress.o
+ifneq (,$(filter x86%, $(ARCH)))
+ZSTD_OBJS += $(ZSTD)/decompress/huf_decompress_amd64.o
 endif
-OBJS += pico/sound/mix.o
-OBJS += pico/carthw/svp/compiler.o
+ZSTD_OBJS += $(ZSTD)/decompress/zstd_ddict.o
+ZSTD_OBJS += $(ZSTD)/decompress/zstd_decompress_block.o
+ZSTD_OBJS += $(ZSTD)/decompress/zstd_decompress.o
+$(ZSTD_OBJS) $(CHDR_OBJS): CFLAGS += -I$(ZSTD) -Wno-unused
 
+OBJS += $(CHDR_OBJS) $(ZSTD_OBJS)
+ifneq ($(STATIC_LINKING), 1)
+OBJS += $(LZMA_OBJS)
+endif
+# ouf... prepend includes to overload headers available in the toolchain
+CFLAGS := -I$(LZMA)/include -I$(CHDR)/include $(CFLAGS)
+endif
+
+ifeq "$(PLATFORM_ZLIB)" "1"
 # zlib
 OBJS += zlib/gzio.o zlib/inffast.o zlib/inflate.o zlib/inftrees.o zlib/trees.o \
        zlib/deflate.o zlib/crc32.o zlib/adler32.o zlib/zutil.o zlib/compress.o zlib/uncompr.o
+CFLAGS += -Izlib
+endif
 # unzip
-OBJS += unzip/unzip.o unzip/unzip_stream.o
+OBJS += unzip/unzip.o
+
 
 include platform/common/common.mak
 
+OBJS += $(OBJS_COMMON)
 CFLAGS += $(addprefix -D,$(DEFINES))
 
+ifneq (,$(findstring sdl,$(OBJS)))
+CFLAGS += -DUSE_SDL
+endif
+
+ifneq ($(findstring gcc,$(CC)),)
+ifneq ($(findstring SunOS,$(shell uname -a)),SunOS)
+ifneq ($(findstring clang,$(shell $(CC) -v 2>&1)),)
+LDFLAGS += -Wl,-map,$(TARGET).map
+else
+LDFLAGS += -Wl,-Map=$(TARGET).map
+endif
+endif
+endif
+
+target_: $(TARGET)
+
 clean:
-       $(RM) PicoDrive $(OBJS)
+       $(RM) $(TARGET) $(OBJS) pico/pico_int_offs.h
+       $(MAKE) -C cpu/cyclone clean
+       $(MAKE) -C cpu/musashi clean
+       $(MAKE) -C tools clean
+       $(RM) -r .od_data
 
-PicoDrive : $(OBJS)
-       $(CC) $(CFLAGS) $^ $(LDFLAGS) $(LDLIBS) -Wl,-Map=PicoDrive.map -o $@
+$(TARGET): $(OBJS)
+
+ifeq ($(STATIC_LINKING_LINK), 1)
+       $(AR) rcs $@ $^
+else
+       $(LD) $(LINKOUT)$@ $^ $(CFLAGS) $(LDFLAGS) $(LDLIBS)
+endif
+
+ifeq "$(PLATFORM)" "psp"
+PSPSDK ?= $(shell psp-config --pspsdk-path)
+TARGET = PicoDrive
+PSP_EBOOT_TITLE = PicoDrive
+PSP_EBOOT_ICON = platform/psp/data/icon.png
+LIBS += -lpng -lm -lz -lpspgu -lpsppower -lpspaudio -lpsprtc -lpspaudiocodec
+EXTRA_TARGETS = EBOOT.PBP
+include $(PSPSDK)/lib/build.mak
+# TODO image generation
+endif
 
 pprof: platform/linux/pprof.c
-       $(CC) -O2 -ggdb -DPPROF -DPPROF_TOOL -I../../ -I. $^ -o $@
+       $(CC) $(CFLAGS) -O2 -ggdb -DPPROF -DPPROF_TOOL -I../../ -I. $^ -o $@ $(LDFLAGS) $(LDLIBS)
+
+pico/pico_int_offs.h: tools/mkoffsets.sh
+       make -C tools/ XCC="$(CC)" XCFLAGS="$(CFLAGS) -UUSE_LIBRETRO_VFS" XPLATFORM="$(platform)"
+
+%.o: %.c
+       $(CC) -c $(OBJOUT)$@ $< $(CFLAGS)
+
+.s.o:
+       $(CC) $(CFLAGS) -c $< -o $@
+
+.S.o:
+       $(CC) $(CFLAGS) -c $< -o $@
+
+# special flags - perhaps fix this someday instead?
+pico/draw.o: CFLAGS += -fno-strict-aliasing
+pico/draw2.o: CFLAGS += -fno-strict-aliasing
+pico/mode4.o: CFLAGS += -fno-strict-aliasing
+pico/cd/memory.o: CFLAGS += -fno-strict-aliasing
+pico/cd/cd_file.o: CFLAGS += -fno-strict-aliasing
+pico/cd/pcm.o: CFLAGS += -fno-strict-aliasing
+pico/cd/LC89510.o: CFLAGS += -fno-strict-aliasing
+pico/cd/gfx_cd.o: CFLAGS += -fno-strict-aliasing
+ifeq (1,$(use_sh2drc))
+ifneq (,$(findstring -flto,$(CFLAGS)))
+# if using the DRC, memory and sh2soc directly use the DRC register for SH2 SR
+# to avoid saving and reloading it. However, this collides with the use of LTO.
+pico/32x/memory.o: CFLAGS += -fno-lto
+pico/32x/sh2soc.o: CFLAGS += -fno-lto
+cpu/sh2/compiler.o: CFLAGS += -fno-lto
+endif
+ifneq (,$(filter mips64%, $(ARCH))$(filter %mips32r2, $(CFLAGS)))
+CFLAGS += -DMIPS_USE_SYNCI # mips32r2 clear_cache uses SYNCI instead of a syscall
+endif
+endif
+
+# fame needs ~2GB of RAM to compile on gcc 4.8
+# on x86, this is reduced by ~300MB when debug info is off (but not on ARM)
+# not using O3 and -fno-expensive-optimizations seems to also help, but you may
+# want to remove this stuff for better performance if your compiler can handle it
+ifeq "$(DEBUG)" "0"
+ifeq (,$(findstring msvc,$(platform)))
+cpu/fame/famec.o: CFLAGS += -g0 -O2 -fno-expensive-optimizations
+else
+cpu/fame/famec.o: CFLAGS += -Od
+endif
+endif
+
+tools/make_carthw_c:
+       make -C tools make_carthw_c
+pico/carthw_cfg.c: pico/carthw.cfg tools/make_carthw_c
+       tools/make_carthw_c $< $@
+
+# preprocessed asm files most probably include the offsets file
+$(filter %.S,$(SRCS_COMMON)): pico/pico_int_offs.h
+
+# random deps - TODO remove this and compute dependcies automatically
+pico/carthw/svp/compiler.o : cpu/drc/emit_arm.c
+cpu/sh2/compiler.o : cpu/drc/emit_arm.c cpu/drc/emit_arm64.c cpu/drc/emit_ppc.c
+cpu/sh2/compiler.o : cpu/drc/emit_x86.c cpu/drc/emit_mips.c cpu/drc/emit_riscv.c
+cpu/sh2/mame/sh2pico.o : cpu/sh2/mame/sh2.c
+pico/pico.o pico/cd/mcd.o pico/32x/32x.o : pico/pico_cmn.c
+pico/memory.o pico/cd/memory.o pico/32x/memory.o : pico/memory.h
+$(shell grep -rl pico_int.h pico) : pico/pico_int.h
+# pico/cart.o : pico/carthw_cfg.c
+cpu/fame/famec.o: cpu/fame/famec.c cpu/fame/famec_opcodes.h
+platform/common/menu_pico.o: platform/libpicofe/menu.c