20 -include Makefile.local
\r
22 ifeq "$(debug_cyclone)" "1"
\r
26 ifeq "$(use_musashi)" "1"
\r
27 # due to CPU stop flag acces
\r
33 DEFINES += ARM __GP2X__ IN_GP2X IN_EVDEV # BENCHMARK
\r
34 CFLAGS += -Wall -Winline -I../.. -I.
\r
36 CFLAGS += -O3 -fomit-frame-pointer -fstrict-aliasing -ffast-math
\r
40 ifeq "$(profile)" "1"
\r
41 CFLAGS += -fprofile-generate
\r
43 ifeq "$(profile)" "2"
\r
44 CFLAGS += -fprofile-use
\r
46 CFLAGS += -mcpu=arm920t -mtune=arm920t
\r
47 ASFLAGS = -mcpu=arm920t -mfloat-abi=soft
\r
48 LDFLAGS += -lm -lpng
\r
51 STRIP = $(CROSS)strip
\r
54 OBJCOPY = $(CROSS)objcopy
\r
57 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
62 OBJS += platform/common/emu.o platform/common/menu.o platform/common/fonts.o platform/common/config.o \
\r
63 platform/common/arm_utils.o platform/common/arm_linux.o platform/common/readpng.o \
\r
64 platform/common/mp3_helix.o platform/common/input.o platform/common/main.o \
\r
65 platform/linux/sndout_oss.o platform/linux/plat.o platform/linux/in_evdev.o
\r
68 ifeq "$(amalgamate)" "1"
\r
69 OBJS += ../../picoAll.o
\r
71 OBJS += pico/area.o pico/cart.o pico/memory.o pico/pico.o pico/sek.o pico/z80if.o \
\r
72 pico/videoport.o pico/draw2.o pico/draw.o pico/mode4.o pico/sms.o \
\r
73 pico/misc.o pico/eeprom.o pico/patch.o pico/debug.o
\r
75 OBJS += pico/cd/pico.o pico/cd/memory.o pico/cd/sek.o pico/cd/LC89510.o \
\r
76 pico/cd/cd_sys.o pico/cd/cd_file.o pico/cd/cue.o pico/cd/gfx_cd.o \
\r
77 pico/cd/area.o pico/cd/misc.o pico/cd/pcm.o pico/cd/buffering.o
\r
80 OBJS += pico/32x/32x.o pico/32x/memory.o pico/32x/draw.o pico/32x/pwm.o
\r
82 OBJS += pico/pico/pico.o pico/pico/memory.o pico/pico/xpcm.o
\r
84 OBJS += pico/carthw/carthw.o pico/carthw/svp/svp.o pico/carthw/svp/memory.o \
\r
85 pico/carthw/svp/ssp16.o pico/carthw/svp/compiler.o pico/carthw/svp/stub_arm.o
\r
88 ifneq "$(amalgamate)" "1"
\r
89 OBJS += pico/sound/sound.o
\r
91 OBJS += pico/sound/mix_arm.o
\r
92 OBJS += pico/sound/sn76496.o pico/sound/ym2612.o
\r
94 OBJS += unzip/unzip.o unzip/unzip_stream.o
\r
96 OBJS += zlib/gzio.o zlib/inffast.o zlib/inflate.o zlib/inftrees.o zlib/trees.o \
\r
97 zlib/deflate.o zlib/crc32.o zlib/adler32.o zlib/zutil.o zlib/compress.o
\r
99 CFLAGS += $(addprefix -D,$(DEFINES))
\r
105 DIRS = platform platform/gp2x platform/linux platform/common pico pico/cd pico/pico pico/32x \
\r
106 pico/sound pico/carthw/svp zlib unzip cpu cpu/musashi cpu/Cyclone/proj cpu/Cyclone/tools \
\r
107 cpu/mz80 cpu/DrZ80 cpu/sh2/mame cpu/drc
\r
110 all: mkdirs PicoDrive
\r
112 include ../common/common.mak
\r
113 include ../common/common_arm.mak
\r
114 include ../common/revision.mak
\r
116 # partial linking helps profiled builds due to section merging
\r
117 PicoDrive.o : $(OBJS) ../common/helix/$(CROSS)helix-mp3.a
\r
120 # still using static, dynamic linking slows Wiz 1-10%
\r
121 # also libm on F100 is not compatible
\r
122 PicoDrive : PicoDrive.o
\r
124 $(CC) -static -o $@ $(CFLAGS) $^ $(LDFLAGS) -Wl,-Map=$@.map
\r
130 @cp -v PicoDrive /mnt/gp2x/mnt/sd/emus/PicoDrive/
\r
137 readme.txt: ../../tools/textfilter ../base_readme.txt
\r
138 ../../tools/textfilter ../base_readme.txt $@ GP2X
\r
140 # ----------- release -----------
\r
141 ifneq ($(findstring rel,$(MAKECMDGOALS)),)
\r
146 CODE940 = code940/pico940_v3.bin
\r
148 rel: PicoDrive PicoDrive.gpe $(CODE940) readme.txt PicoDrive.png ../game_def.cfg \
\r
149 warm_2.4.25.o warm_2.4.26-open2x.o warm_2.6.24.ko
\r
150 zip -9 -j ../../PicoDrive_$(VER).zip $^
\r
151 zip -9 -r ../../PicoDrive_$(VER).zip skin -i \*.png -i \*.txt
\r
152 mkdir bin_to_cso_mp3
\r
153 cp ../../tools/bin_to_cso_mp3/* bin_to_cso_mp3/
\r
154 zip -9 -r ../../PicoDrive_$(VER).zip bin_to_cso_mp3
\r
155 rm -rf bin_to_cso_mp3
\r