cd92f54b60dfdb5541330c82658390ff99d1f4c7
[picodrive.git] / platform / common / common.mak
1 ifdef drc_debug
2 use_fame = 1
3 use_cz80 = 1
4 use_cyclone = 0
5 use_drz80 = 0
6
7 asm_memory = 0
8 asm_render = 0
9 asm_ym2612 = 0
10 asm_misc = 0
11 asm_cdmemory = 0
12 asm_mix = 0
13 endif
14
15 ifeq "$(profile)" "1"
16 CFLAGS += -fprofile-generate
17 endif
18 ifeq "$(profile)" "2"
19 CFLAGS += -fprofile-use
20 endif
21 ifeq "$(pdb)" "1"
22 DEFINES += PDB
23 SRCS_COMMON += $(R)cpu/debug.c
24  ifeq "$(pdb_net)" "1"
25  DEFINES += PDB_NET
26  endif
27  ifeq "$(readline)" "1"
28  DEFINES += HAVE_READLINE
29  LDFLAGS += -lreadline
30  endif
31 endif
32 ifeq "$(cpu_cmp)" "1"
33 ifdef cpu_cmp_w
34 DEFINES += CPU_CMP_W
35 else
36 DEFINES += CPU_CMP_R
37 endif # cpu_cmp_w
38 endif
39 ifeq "$(pprof)" "1"
40 DEFINES += PPROF
41 SRCS_COMMON += $(R)platform/linux/pprof.c
42 endif
43
44 # ARM asm stuff
45 ifeq "$(ARCH)" "arm"
46 ifeq "$(asm_render)" "1"
47 DEFINES += _ASM_DRAW_C
48 SRCS_COMMON += $(R)pico/draw_arm.S $(R)pico/draw2_arm.S
49 endif
50 ifeq "$(asm_memory)" "1"
51 DEFINES += _ASM_MEMORY_C
52 SRCS_COMMON += $(R)pico/memory_arm.S
53 endif
54 ifeq "$(asm_ym2612)" "1"
55 DEFINES += _ASM_YM2612_C
56 SRCS_COMMON += $(R)pico/sound/ym2612_arm.s
57 endif
58 ifeq "$(asm_misc)" "1"
59 DEFINES += _ASM_MISC_C
60 SRCS_COMMON += $(R)pico/misc_arm.s
61 SRCS_COMMON += $(R)pico/cd/misc_arm.s
62 endif
63 ifeq "$(asm_cdmemory)" "1"
64 DEFINES += _ASM_CD_MEMORY_C
65 SRCS_COMMON += $(R)pico/cd/memory_arm.S
66 endif
67 ifeq "$(asm_32xdraw)" "1"
68 DEFINES += _ASM_32X_DRAW
69 SRCS_COMMON += $(R)pico/32x/draw_arm.s
70 endif
71 ifeq "$(asm_mix)" "1"
72 SRCS_COMMON += $(R)pico/sound/mix_arm.S
73 endif
74 endif # ARCH=arm
75
76 # === Pico core ===
77 # Pico
78 SRCS_COMMON += $(R)pico/pico.c $(R)pico/cart.c $(R)pico/memory.c \
79         $(R)pico/state.c $(R)pico/sek.c $(R)pico/z80if.c \
80         $(R)pico/videoport.c $(R)pico/draw2.c $(R)pico/draw.c \
81         $(R)pico/mode4.c $(R)pico/misc.c $(R)pico/eeprom.c \
82         $(R)pico/patch.c $(R)pico/debug.c $(R)pico/media.c
83 # SMS
84 ifneq "$(no_sms)" "1"
85 SRCS_COMMON += $(R)pico/sms.c
86 else
87 DEFINES += NO_SMS
88 endif
89 # CD
90 SRCS_COMMON += $(R)pico/cd/mcd.c $(R)pico/cd/memory.c $(R)pico/cd/sek.c \
91         $(R)pico/cd/cdc.c $(R)pico/cd/cdd.c $(R)pico/cd/cd_image.c \
92         $(R)pico/cd/cue.c $(R)pico/cd/gfx.c $(R)pico/cd/gfx_dma.c \
93         $(R)pico/cd/misc.c $(R)pico/cd/pcm.c
94 # 32X
95 ifneq "$(no_32x)" "1"
96 SRCS_COMMON += $(R)pico/32x/32x.c $(R)pico/32x/memory.c $(R)pico/32x/draw.c \
97         $(R)pico/32x/sh2soc.c $(R)pico/32x/pwm.c
98 else
99 DEFINES += NO_32X
100 endif
101 # Pico
102 SRCS_COMMON += $(R)pico/pico/pico.c $(R)pico/pico/memory.c $(R)pico/pico/xpcm.c
103 # carthw
104 SRCS_COMMON += $(R)pico/carthw/carthw.c
105 SRCS_COMMON += $(R)pico/carthw/eeprom_spi.c
106 # SVP
107 SRCS_COMMON += $(R)pico/carthw/svp/svp.c $(R)pico/carthw/svp/memory.c \
108         $(R)pico/carthw/svp/ssp16.c
109 ifeq "$(use_svpdrc)" "1"
110 DEFINES += _SVP_DRC
111 SRCS_COMMON += $(R)pico/carthw/svp/stub_arm.S
112 SRCS_COMMON += $(R)pico/carthw/svp/compiler.c
113 endif
114 # sound
115 SRCS_COMMON += $(R)pico/sound/sound.c
116 SRCS_COMMON += $(R)pico/sound/sn76496.c $(R)pico/sound/ym2612.c
117 ifneq "$(ARCH)$(asm_mix)" "arm1"
118 SRCS_COMMON += $(R)pico/sound/mix.c
119 endif
120
121 # === CPU cores ===
122 # --- M68k ---
123 ifeq "$(use_musashi)" "1"
124 DEFINES += EMU_M68K
125 SRCS_COMMON += $(R)cpu/musashi/m68kops.c $(R)cpu/musashi/m68kcpu.c
126 #SRCS_COMMON += $(R)cpu/musashi/m68kdasm.c
127 endif
128 ifeq "$(use_cyclone)" "1"
129 DEFINES += EMU_C68K
130 SRCS_COMMON += $(R)pico/m68kif_cyclone.s $(R)cpu/cyclone/Cyclone.s \
131         $(R)cpu/cyclone/tools/idle.s
132 endif
133 ifeq "$(use_fame)" "1"
134 DEFINES += EMU_F68K
135 SRCS_COMMON += $(R)cpu/fame/famec.c
136 endif
137
138 # --- Z80 ---
139 ifeq "$(use_drz80)" "1"
140 DEFINES += _USE_DRZ80
141 SRCS_COMMON += $(R)cpu/DrZ80/drz80.s
142 endif
143 #
144 ifeq "$(use_cz80)" "1"
145 DEFINES += _USE_CZ80
146 SRCS_COMMON += $(R)cpu/cz80/cz80.c
147 endif
148
149 # --- SH2 ---
150 SRCS_COMMON += $(R)cpu/drc/cmn.c
151 ifneq "$(no_32x)" "1"
152 SRCS_COMMON += $(R)cpu/sh2/sh2.c
153 #
154 ifeq "$(use_sh2drc)" "1"
155 DEFINES += DRC_SH2
156 SRCS_COMMON += $(R)cpu/sh2/compiler.c
157 ifdef drc_debug
158 DEFINES += DRC_DEBUG=$(drc_debug)
159 SRCS_COMMON += $(R)cpu/sh2/mame/sh2dasm.c
160 SRCS_COMMON += $(R)platform/libpicofe/linux/host_dasm.c
161 LDFLAGS += -lbfd -lopcodes -liberty
162 endif
163 endif # use_sh2drc
164 SRCS_COMMON += $(R)cpu/sh2/mame/sh2pico.c
165 endif # !no_32x
166
167 OBJS_COMMON := $(SRCS_COMMON:.c=.o)
168 OBJS_COMMON := $(OBJS_COMMON:.s=.o)
169 OBJS_COMMON := $(OBJS_COMMON:.S=.o)
170
171 ifneq ($(deps_set),yes)
172 ifeq "$(use_cyclone)" "1"
173 $(FR)pico/pico.c: $(FR)cpu/cyclone/Cyclone.h
174 endif
175
176 $(FR)cpu/cyclone/Cyclone.h:
177         @echo "Cyclone submodule is missing, please run 'git submodule update --init'"
178         @false
179
180 $(FR)cpu/cyclone/Cyclone.s: $(FR)cpu/cyclone_config.h
181         @echo building Cyclone...
182         @make -C $(R)cpu/cyclone/ CONFIG_FILE=../cyclone_config.h
183
184 $(FR)cpu/cyclone/Cyclone.s: $(FR)cpu/cyclone/*.cpp $(FR)cpu/cyclone/*.h
185
186 $(FR)cpu/musashi/m68kops.c:
187         @make -C $(R)cpu/musashi
188
189 deps_set = yes
190 endif # deps_set