fix GP2X build
[libpicofe.git] / gp2x / Makefile
... / ...
CommitLineData
1export CROSS = arm-linux-\r
2\r
3# settings\r
4#mz80 = 1\r
5#debug_cyclone = 1\r
6asm_memory = 1\r
7asm_render = 1\r
8asm_ym2612 = 1\r
9asm_misc = 1\r
10asm_cdpico = 1\r
11asm_cdmemory = 1\r
12amalgamate = 0\r
13#profile = 1\r
14#use_musashi = 1\r
15use_sh2mame = 1\r
16#up = 1\r
17\r
18\r
19ifeq "$(debug_cyclone)" "1"\r
20use_cyclone = 1\r
21use_musashi = 1\r
22endif\r
23ifeq "$(use_musashi)" "1"\r
24asm_cdpico = 0\r
25asm_memory = 0\r
26asm_cdmemory = 0\r
27else\r
28use_cyclone = 1\r
29endif\r
30\r
31DEFINC = -I../.. -I. -DARM -D__GP2X__ -DIN_GP2X -DIN_EVDEV # -DBENCHMARK\r
32CFLAGS += -Wall -Winline\r
33ifeq ($(DEBUG),)\r
34CFLAGS += -O3 -fomit-frame-pointer -fstrict-aliasing -ffast-math\r
35else\r
36CFLAGS += -ggdb\r
37endif\r
38ifeq "$(profile)" "1"\r
39CFLAGS += -fprofile-generate\r
40endif\r
41ifeq "$(profile)" "2"\r
42CFLAGS += -fprofile-use\r
43endif\r
44CFLAGS += -mcpu=arm920t -mtune=arm920t\r
45SFLAGS = $(CFLAGS)\r
46ASFLAGS = -mcpu=arm920t -mfloat-abi=soft\r
47CC = $(CROSS)gcc\r
48STRIP = $(CROSS)strip\r
49AS = $(CROSS)as\r
50LD = $(CROSS)ld\r
51OBJCOPY = $(CROSS)objcopy\r
52\r
53# frontend\r
54OBJS += plat.o warm.o pollux_set.o soc.o soc_mmsp2.o soc_pollux.o emu.o in_gp2x.o\r
55# 940 core control\r
56OBJS += 940ctl.o\r
57\r
58# common\r
59OBJS += platform/common/emu.o platform/common/menu.o platform/common/fonts.o platform/common/config.o \\r
60 platform/common/arm_utils.o platform/common/arm_linux.o platform/common/readpng.o \\r
61 platform/common/mp3_helix.o platform/common/input.o platform/common/main.o \\r
62 platform/linux/sndout_oss.o platform/linux/plat.o platform/linux/in_evdev.o\r
63\r
64# Pico\r
65ifeq "$(amalgamate)" "1"\r
66OBJS += ../../picoAll.o\r
67else\r
68OBJS += pico/area.o pico/cart.o pico/memory.o pico/pico.o pico/sek.o pico/z80if.o \\r
69 pico/videoport.o pico/draw2.o pico/draw.o pico/mode4.o pico/sms.o \\r
70 pico/misc.o pico/eeprom.o pico/patch.o pico/debug.o\r
71# Pico - CD\r
72OBJS += pico/cd/pico.o pico/cd/memory.o pico/cd/sek.o pico/cd/LC89510.o \\r
73 pico/cd/cd_sys.o pico/cd/cd_file.o pico/cd/cue.o pico/cd/gfx_cd.o \\r
74 pico/cd/area.o pico/cd/misc.o pico/cd/pcm.o pico/cd/buffering.o\r
75endif\r
76# Pico - 32X\r
77OBJS += pico/32x/32x.o pico/32x/memory.o pico/32x/draw.o pico/32x/pwm.o\r
78# Pico - Pico\r
79OBJS += pico/pico/pico.o pico/pico/memory.o pico/pico/xpcm.o\r
80# Pico - carthw\r
81OBJS += pico/carthw/carthw.o pico/carthw/svp/svp.o pico/carthw/svp/memory.o \\r
82 pico/carthw/svp/ssp16.o pico/carthw/svp/compiler.o pico/carthw/svp/stub_arm.o\r
83\r
84# Pico - sound\r
85ifneq "$(amalgamate)" "1"\r
86OBJS += pico/sound/sound.o\r
87endif\r
88OBJS += pico/sound/mix_arm.o\r
89OBJS += pico/sound/sn76496.o pico/sound/ym2612.o\r
90# unzip\r
91OBJS += unzip/unzip.o unzip/unzip_stream.o\r
92# zlib\r
93OBJS += zlib/gzio.o zlib/inffast.o zlib/inflate.o zlib/inftrees.o zlib/trees.o \\r
94 zlib/deflate.o zlib/crc32.o zlib/adler32.o zlib/zutil.o zlib/compress.o\r
95# debug\r
96ifeq "$(debug_cyclone)" "1"\r
97OBJS += pico/DebugCPU.o cpu/musashi/m68kdasm.o\r
98endif\r
99# CPU cores\r
100ifeq "$(use_musashi)" "1"\r
101DEFINC += -DEMU_M68K\r
102OBJS += cpu/musashi/m68kops.o cpu/musashi/m68kcpu.o\r
103endif\r
104ifeq "$(use_cyclone)" "1"\r
105DEFINC += -DEMU_C68K\r
106OBJS += pico/m68kif_cyclone.o cpu/Cyclone/proj/Cyclone.o cpu/Cyclone/tools/idle.o\r
107endif\r
108ifeq "$(mz80)" "1"\r
109DEFINC += -D_USE_MZ80\r
110OBJS += cpu/mz80/mz80.o\r
111else\r
112DEFINC += -D_USE_DRZ80\r
113OBJS += cpu/DrZ80/drz80.o\r
114endif\r
115ifeq "$(use_sh2mame)" "1"\r
116OBJS += cpu/sh2mame/sh2pico.o\r
117else\r
118endif\r
119\r
120vpath %.c = ../..\r
121vpath %.s = ../..\r
122vpath %.S = ../..\r
123\r
124DIRS = platform platform/gp2x platform/linux platform/common pico pico/cd pico/pico pico/32x \\r
125 pico/sound pico/carthw/svp zlib unzip cpu cpu/musashi cpu/Cyclone/proj cpu/Cyclone/tools \\r
126 cpu/mz80 cpu/DrZ80 cpu/sh2mame\r
127\r
128\r
129all: mkdirs PicoDrive\r
130\r
131include ../common/common_arm.mak\r
132include ../common/revision.mak\r
133\r
134# partial linking helps profiled builds due to section merging\r
135PicoDrive.o : $(OBJS) ../common/helix/$(CROSS)helix-mp3.a\r
136 $(LD) -r -o $@ $^\r
137\r
138# still using static, dynamic linking slows Wiz 1-10%\r
139# also libm on F100 is not compatible\r
140PicoDrive : PicoDrive.o\r
141 @echo ">>>" $@\r
142 $(CC) -static -o $@ $(CFLAGS) $^ -lm -lpng -Wl,-Map=$@.map\r
143ifeq ($(DEBUG),)\r
144 $(STRIP) $@\r
145endif\r
146\r
147up: PicoDrive\r
148 @cp -v PicoDrive /mnt/gp2x/mnt/sd/emus/PicoDrive/\r
149\r
150clean: tidy\r
151 $(RM) PicoDrive\r
152tidy:\r
153 $(RM) $(OBJS)\r
154\r
155readme.txt: ../../tools/textfilter ../base_readme.txt\r
156 ../../tools/textfilter ../base_readme.txt $@ GP2X\r
157\r
158# ----------- release -----------\r
159ifneq ($(findstring rel,$(MAKECMDGOALS)),)\r
160ifeq ($(VER),)\r
161$(error need VER)\r
162endif\r
163endif\r
164CODE940 = code940/pico940_v3.bin\r
165\r
166rel: PicoDrive PicoDrive.gpe $(CODE940) readme.txt PicoDrive.png ../game_def.cfg \\r
167 warm_2.4.25.o warm_2.4.26-open2x.o warm_2.6.24.ko\r
168 zip -9 -j ../../PicoDrive_$(VER).zip $^\r
169 zip -9 -r ../../PicoDrive_$(VER).zip skin -i \*.png -i \*.txt\r
170 mkdir bin_to_cso_mp3\r
171 cp ../../tools/bin_to_cso_mp3/* bin_to_cso_mp3/\r
172 zip -9 -r ../../PicoDrive_$(VER).zip bin_to_cso_mp3\r
173 rm -rf bin_to_cso_mp3\r
174\r
175$(CODE940):\r
176 make -C code940/\r
177\r