blob: 45e351265f9393b391d9e86f61e3f39f54c06ed4 [file] [log] [blame]
David 'Digit' Turneraff94b82011-02-07 18:10:54 +01001# This file is included several times to build target-specific
2# modules for the Android emulator. It will be called several times
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -07003# for arm, x86 and mips
David 'Digit' Turneraff94b82011-02-07 18:10:54 +01004#
5
6ifndef EMULATOR_TARGET_ARCH
7$(error EMULATOR_TARGET_ARCH is not defined!)
8endif
9
10EMULATOR_TARGET_CPU := $(EMULATOR_TARGET_ARCH)
11ifeq ($(EMULATOR_TARGET_CPU),x86)
12 EMULATOR_TARGET_CPU := i386
13endif
14
15##############################################################################
16##############################################################################
17###
18### emulator-target-$CPU: target-specific emulation code.
19###
20### Used by both the core and standalone programs.
21###
22
23# Common compiler flags for all target-dependent libraries
24EMULATOR_TARGET_CFLAGS := \
25 -I$(LOCAL_PATH)/android/config/$(HOST_PREBUILT_TAG) \
26 -I$(LOCAL_PATH)/android/config/target-$(EMULATOR_TARGET_ARCH) \
27 -I$(LOCAL_PATH)/target-$(EMULATOR_TARGET_CPU) \
28 -I$(LOCAL_PATH)/fpu \
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -070029 -DNEED_CPU_H
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010030
31TCG_TARGET := $(HOST_ARCH)
David 'Digit' Turnerf1d9bf12011-05-11 18:19:41 +020032ifeq ($(HOST_ARCH),x86)
33 TCG_TARGET := i386
34endif
35ifeq ($(HOST_ARCH),x86_64)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010036 TCG_TARGET := i386
37endif
38
39EMULATOR_TARGET_CFLAGS += \
40 -I$(LOCAL_PATH)/tcg \
41 -I$(LOCAL_PATH)/tcg/$(TCG_TARGET) \
42 -DTARGET_ARCH=\"$(EMULATOR_TARGET_ARCH)\"
43
44
Andrew Hsiehc7389bd2012-03-13 02:13:40 -070045common_LOCAL_CFLAGS =
46common_LOCAL_SRC_FILES =
47
David 'Digit' Turner1d1a2af2014-01-10 16:17:40 +010048common_LOCAL_CFLAGS += -I$(GLIB_INCLUDE_DIR)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010049
50# The following is to ensure that "config.h" will map to a target-specific
51# configuration file header.
Andrew Hsiehc7389bd2012-03-13 02:13:40 -070052common_LOCAL_CFLAGS += $(EMULATOR_TARGET_CFLAGS)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010053
Andrew Hsiehc7389bd2012-03-13 02:13:40 -070054common_LOCAL_SRC_FILES += \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010055 tcg/tcg.c \
Octavian Purdila9f9deaf2013-11-08 19:00:56 +020056 tcg-runtime.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010057
58##############################################################################
59# Emulated hardware devices.
60#
61
62HW_SOURCES := \
David 'Digit' Turner4b6bb762013-12-17 10:26:45 +010063 bt/core.c \
64 bt/hci.c \
65 bt/hid.c \
66 bt/l2cap.c \
67 bt/sdp.c \
David 'Digit' Turner4023ec82013-12-17 11:35:40 +010068 block/cdrom.c \
David 'Digit' Turner2ec695a2013-12-17 10:03:39 +010069 core/irq.c \
David 'Digit' Turner10745422013-12-17 10:05:40 +010070 core/qdev.c \
David 'Digit' Turner291300f2013-12-17 10:06:47 +010071 core/sysbus.c \
David 'Digit' Turnerf7c8d822013-12-17 14:02:11 +010072 core/dma.c \
David 'Digit' Turnerf0665422013-12-17 10:47:09 +010073 android/goldfish/audio.c \
74 android/goldfish/device.c \
75 android/goldfish/events_device.c \
76 android/goldfish/fb.c \
77 android/goldfish/battery.c \
78 android/goldfish/mmc.c \
79 android/goldfish/memlog.c \
80 android/goldfish/nand.c \
81 android/goldfish/pipe.c \
82 android/goldfish/tty.c \
83 android/goldfish/vmem.c \
David 'Digit' Turner7977bd62013-12-17 11:17:24 +010084 pci/pci.c \
David 'Digit' Turnerbe5c9712013-12-17 13:56:10 +010085 scsi/scsi-disk.c \
David 'Digit' Turner704463f2013-12-17 11:33:57 +010086 usb/dev-hid.c \
87 usb/dev-hub.c \
88 usb/dev-storage.c \
89 usb/hcd-ohci.c \
90 usb/core.c \
David 'Digit' Turnere2f74052013-12-17 11:29:40 +010091 watchdog/watchdog.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010092
David 'Digit' Turner42fc4492011-06-29 13:16:16 +020093
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010094ifeq ($(EMULATOR_TARGET_ARCH),arm)
David 'Digit' Turnerd1298762013-12-17 10:22:24 +010095HW_SOURCES += \
David 'Digit' Turnerea066692013-12-17 14:03:28 +010096 android/android_arm.c \
David 'Digit' Turnerd1298762013-12-17 10:22:24 +010097 arm/pic.c \
98 arm/boot.c \
David 'Digit' Turnerf0665422013-12-17 10:47:09 +010099 android/goldfish/interrupt.c \
100 android/goldfish/switch.c \
101 android/goldfish/timer.c \
102 android/goldfish/trace.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100103
104# The following sources must be compiled with the final executables
105# because they contain device_init() or machine_init() statements.
David 'Digit' Turnerebf1de02013-12-17 13:57:47 +0100106HW_OBJ_SOURCES := hw/net/smc91c111.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100107HW_OBJ_CFLAGS := $(EMULATOR_TARGET_CFLAGS)
108
David 'Digit' Turnercc33b2d2013-12-15 00:09:42 +0100109common_LOCAL_SRC_FILES += disas/arm.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100110
111# smc91c111.c requires <zlib.h>
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700112common_LOCAL_CFLAGS += $(ZLIB_CFLAGS)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100113endif
114
David 'Digit' Turner764a3c92011-05-05 12:40:49 +0200115# required to ensure we properly initialize virtual audio hardware
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700116common_LOCAL_CFLAGS += -DHAS_AUDIO
David 'Digit' Turner764a3c92011-05-05 12:40:49 +0200117
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100118ifeq ($(EMULATOR_TARGET_ARCH),x86)
119HW_SOURCES += \
David 'Digit' Turner3fbb6562013-12-17 10:08:21 +0100120 intc/apic.c \
David 'Digit' Turner91335252013-12-17 13:52:01 +0100121 intc/i8259.c \
David 'Digit' Turner6d7b5292013-12-17 13:53:17 +0100122 timer/mc146818rtc.c \
David 'Digit' Turnerbfa4dab2013-12-17 11:19:22 +0100123 pci-host/piix.c \
David 'Digit' Turner6459c4a2013-12-17 10:31:05 +0100124 timer/i8254.c \
David 'Digit' Turner7b769262013-12-17 13:54:37 +0100125 input/pckbd.c \
David 'Digit' Turner1079fa72013-12-17 13:55:27 +0100126 intc/ioapic.c \
David 'Digit' Turner4ecc3dd2013-12-17 11:16:00 +0100127 input/ps2.c \
David 'Digit' Turner343e9282013-12-17 13:56:48 +0100128 i386/smbios.c \
David 'Digit' Turnera367a102013-12-17 11:36:33 +0100129 nvram/fw_cfg.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100130
131# The following sources must be compiled with the final executables
132# because they contain device_init() or machine_init() statements.
133HW_OBJ_SOURCES := \
David 'Digit' Turner08405982013-12-17 11:35:00 +0100134 hw/net/ne2000.c \
David 'Digit' Turnerbb228542013-12-17 13:53:59 +0100135 hw/i386/pc.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100136
137HW_OBJ_CFLAGS := $(EMULATOR_TARGET_CFLAGS)
138
139endif
140
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700141ifeq ($(EMULATOR_TARGET_ARCH),mips)
142HW_SOURCES += \
David 'Digit' Turnerea066692013-12-17 14:03:28 +0100143 android/android_mips.c \
David 'Digit' Turneraf0fc432013-12-17 14:00:52 +0100144 mips/mips_pic.c \
David 'Digit' Turnerf0665422013-12-17 10:47:09 +0100145 android/goldfish/interrupt.c \
146 android/goldfish/switch.c \
147 android/goldfish/timer.c \
148 android/goldfish/trace.c \
David 'Digit' Turneraf0fc432013-12-17 14:00:52 +0100149 mips/cputimer.c \
150 mips/mips_int.c
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700151
152# The following sources must be compiled with the final executables
153# because they contain device_init() or machine_init() statements.
David 'Digit' Turnerebf1de02013-12-17 13:57:47 +0100154HW_OBJ_SOURCES := hw/net/smc91c111.c
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700155HW_OBJ_CFLAGS := $(EMULATOR_TARGET_CFLAGS)
156
David 'Digit' Turnercc33b2d2013-12-15 00:09:42 +0100157common_LOCAL_SRC_FILES += disas/mips.c
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700158
159# smc91c111.c requires <zlib.h>
160LOCAL_CFLAGS += $(ZLIB_CFLAGS)
161ifeq ($(ARCH_HAS_BIGENDIAN),true)
162 LOCAL_CFLAGS += -DTARGET_WORDS_BIGENDIAN
163endif
164
165endif
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700166common_LOCAL_SRC_FILES += $(HW_SOURCES:%=hw/%)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100167
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700168common_LOCAL_SRC_FILES += \
David 'Digit' Turner2a0488a2013-12-17 11:22:12 +0100169 backends/msmouse.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100170 cpu-exec.c \
David 'Digit' Turner3dc53fc2014-01-17 01:23:40 +0100171 cputlb.c \
David 'Digit' Turner317c9d52011-05-10 06:38:21 +0200172 exec.c \
David 'Digit' Turnerf9077a82014-02-10 23:10:47 +0100173 main-loop.c \
David 'Digit' Turneraa1180c2014-01-28 06:08:00 +0100174 monitor-android.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100175 translate-all.c \
David 'Digit' Turner13209b92013-12-17 09:54:09 +0100176 android/varint.c \
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700177 softmmu_outside_jit.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100178
179##############################################################################
180# CPU-specific emulation.
181#
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700182common_LOCAL_CFLAGS += -fno-PIC -fomit-frame-pointer -Wno-sign-compare
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100183
184ifeq ($(HOST_ARCH),ppc)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700185 common_LOCAL_CFLAGS += -D__powerpc__
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100186endif
187
188ifeq ($(EMULATOR_TARGET_ARCH),arm)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700189common_LOCAL_SRC_FILES += \
David 'Digit' Turner82a591c2013-12-17 09:10:58 +0100190 target-arm/arm-semi.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100191 target-arm/op_helper.c \
192 target-arm/iwmmxt_helper.c \
193 target-arm/neon_helper.c \
194 target-arm/helper.c \
David 'Digit' Turner288208c2011-05-11 19:37:35 +0200195 target-arm/helper-android.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100196 target-arm/translate.c \
197 target-arm/machine.c \
David 'Digit' Turnercd0c34b2013-12-17 10:19:44 +0100198 hw/arm/armv7m.c \
199 hw/arm/armv7m_nvic.c
David 'Digit' Turnere2288402014-01-09 18:35:14 +0100200endif # EMULATOR_TARGET_ARCH == arm
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100201
202ifeq ($(EMULATOR_TARGET_ARCH), x86)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700203common_LOCAL_SRC_FILES += \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100204 target-i386/op_helper.c \
205 target-i386/helper.c \
206 target-i386/translate.c \
207 target-i386/machine.c \
208
Jun Nakajimae4a3c782011-12-17 19:22:12 -0800209ifeq ($(HOST_OS),darwin)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700210common_LOCAL_SRC_FILES += \
Jun Nakajimae4a3c782011-12-17 19:22:12 -0800211 target-i386/hax-all.c \
212 target-i386/hax-darwin.c
213endif
214
215ifeq ($(HOST_OS),windows)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700216common_LOCAL_SRC_FILES += \
Jun Nakajimae4a3c782011-12-17 19:22:12 -0800217 target-i386/hax-all.c \
218 target-i386/hax-windows.c
219endif
David 'Digit' Turnere2288402014-01-09 18:35:14 +0100220endif # EMULATOR_TARGET_ARCH == x86
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100221
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700222ifeq ($(EMULATOR_TARGET_ARCH), mips)
223common_LOCAL_SRC_FILES += \
224 target-mips/op_helper.c \
225 target-mips/helper.c \
226 target-mips/translate.c \
227 target-mips/machine.c
David 'Digit' Turnere2288402014-01-09 18:35:14 +0100228endif # EMULATOR_TARGET_ARCH == mips
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700229
230common_LOCAL_SRC_FILES += fpu/softfloat.c
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700231
Jun Nakajima1321c762011-03-04 17:17:45 -0800232# compile KVM only if target is x86 on x86 Linux
David 'Digit' Turner36597752011-05-20 01:18:01 +0200233QEMU_KVM_TAG := $(QEMU_HOST_TAG)-$(EMULATOR_TARGET_ARCH)
234QEMU_DO_KVM := $(if $(filter linux-x86-x86 linux-x86_64-x86,$(QEMU_KVM_TAG)),true,false)
235ifeq ($(QEMU_DO_KVM),true)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700236 common_LOCAL_SRC_FILES += \
David 'Digit' Turner36597752011-05-20 01:18:01 +0200237 target-i386/kvm.c \
Jun Nakajimabb0140b2011-05-27 18:24:21 -0700238 target-i386/kvm-gs-restore.c \
David 'Digit' Turner36597752011-05-20 01:18:01 +0200239 kvm-all.c \
240 kvm-android.c
Jun Nakajima1321c762011-03-04 17:17:45 -0800241endif
242
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100243##############################################################################
244# Memory-access checking support.
245# Memory access checker uses information collected by instrumented code in
246# libc.so in order to keep track of memory blocks allocated from heap. Memory
247# checker then uses this information to make sure that every access to allocated
248# memory is within allocated block. This information also allows detecting
249# memory leaks and attempts to free/realloc invalid pointers.
250#
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700251common_LOCAL_CFLAGS += \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100252 -I$(LOCAL_PATH)/memcheck \
253 -I$(LOCAL_PATH)/elff
254
255MCHK_SOURCES := \
256 memcheck.c \
257 memcheck_proc_management.c \
258 memcheck_malloc_map.c \
259 memcheck_mmrange_map.c \
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700260 memcheck_util.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100261
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700262common_LOCAL_SRC_FILES += $(MCHK_SOURCES:%=memcheck/%)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100263
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700264common_LOCAL_SRC_FILES += \
David 'Digit' Turnerae3098a2011-05-11 16:01:57 +0200265 cpus.c \
266 arch_init.c
267
David 'Digit' Turner088edf82011-05-09 15:59:28 +0200268# What a mess, os-posix.c depends on the exact values of options
269# which are target specific.
270ifeq ($(HOST_OS),windows)
David 'Digit' Turner1c31e3e2013-12-14 20:07:17 +0100271 common_LOCAL_SRC_FILES += os-win32.c util/oslib-win32.c
David 'Digit' Turner088edf82011-05-09 15:59:28 +0200272else
David 'Digit' Turner1c31e3e2013-12-14 20:07:17 +0100273 common_LOCAL_SRC_FILES += os-posix.c util/oslib-posix.c
David 'Digit' Turner088edf82011-05-09 15:59:28 +0200274endif
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100275
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700276
277## one for 32-bit
278$(call start-emulator-library, emulator-target-$(EMULATOR_TARGET_CPU))
279LOCAL_CFLAGS += $(common_LOCAL_CFLAGS)
280LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
281$(call gen-hw-config-defs)
282$(call gen-hx-header,qemu-options.hx,qemu-options.def,os-posix.c os-win32.c)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100283$(call end-emulator-library)
284
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700285## another for 64-bit, see note in file Makefile.common emulator64-common
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700286ifneq ($(filter linux darwin,$(HOST_OS)),)
David 'Digit' Turnerf6f50072014-01-14 14:39:13 +0100287 $(call start-emulator-library, emulator64-target-$(EMULATOR_TARGET_CPU))
288 LOCAL_CFLAGS += $(common_LOCAL_CFLAGS) -m64
289 LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
290 $(call gen-hw-config-defs)
291 $(call gen-hx-header,qemu-options.hx,qemu-options.def,os-posix.c os-win32.c)
292 $(call end-emulator-library)
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700293endif # HOST_OS == linux || darwin
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700294
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100295##############################################################################
296##############################################################################
297###
298### emulator-$ARCH: Standalone emulator program
299###
300###
301
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700302common_LOCAL_LDLIBS =
303common_LOCAL_CFLAGS =
304common_LOCAL_SRC_FILES =
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100305
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700306
307common_LOCAL_STATIC_LIBRARIES := \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100308 emulator-libui \
309 emulator-libqemu \
310 emulator-target-$(EMULATOR_TARGET_CPU) \
311 emulator-libelff \
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700312 emulator-common
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100313
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700314common_LOCAL_LDLIBS += \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100315 $(EMULATOR_COMMON_LDLIBS) \
316 $(EMULATOR_LIBQEMU_LDLIBS) \
317 $(EMULATOR_LIBUI_LDLIBS) \
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700318 $(ELFF_LDLIBS)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100319
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700320common_LOCAL_CFLAGS += \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100321 $(EMULATOR_TARGET_CFLAGS) \
322 $(EMULATOR_COMMON_CFLAGS) \
323 $(EMULATOR_LIBQEMU_CFLAGS) \
324 $(EMULATOR_LIBUI_CFLAGS)
325
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700326common_LOCAL_SRC_FILES := \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100327 audio/audio.c \
328 disas.c \
329 dma-helpers.c \
330 gdbstub.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100331 qemu-timer.c \
David 'Digit' Turnerf9077a82014-02-10 23:10:47 +0100332 log-rotate-android.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100333 vl-android.c \
334 android/cmdline-option.c \
335 android/console.c \
336 android/display.c \
337 android/display-core.c \
338 android/help.c \
339 android/main-common.c \
340 android/main.c \
David 'Digit' Turnercb88e792011-08-26 01:35:14 +0200341 android/opengles.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100342 android/protocol/core-commands-qemu.c \
343 android/protocol/ui-commands-qemu.c \
David 'Digit' Turnerd4e803c2013-12-14 23:45:50 +0100344 android/user-events-qemu.c \
David 'Digit' Turner70a98202013-12-17 09:30:04 +0100345 hw/core/loader.c \
David 'Digit' Turner852088c2013-12-14 23:04:12 +0100346 ui/keymaps.c \
David 'Digit' Turnera18ede02014-02-06 14:30:48 +0100347 util/qemu-timer-common.c \
David 'Digit' Turner1befd342014-01-15 17:56:45 +0100348 util/iov.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100349
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100350
351# The following files cannot be in static libraries because they contain
352# constructor functions that are otherwise stripped by the final linker
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700353common_LOCAL_SRC_FILES += $(HW_OBJ_SOURCES)
354common_LOCAL_CFLAGS += $(HW_OBJ_CFLAGS)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100355
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700356common_LOCAL_SRC_FILES += $(BLOCK_SOURCES)
357common_LOCAL_CFLAGS += $(BLOCK_CFLAGS)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100358
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700359common_LOCAL_SRC_FILES += $(SDLMAIN_SOURCES)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100360
361# Generate a completely static executable if needed.
362# Note that this means no sound and graphics on Linux.
363#
Andrew Hsieh632a0e12012-04-28 00:48:53 +0800364ifneq ($(strip $(CONFIG_STATIC_EXECUTABLE)$(BUILD_HOST_static)),)
David 'Digit' Turner1634ff52013-12-14 23:31:41 +0100365 common_LOCAL_SRC_FILES += android/dynlink-static.c
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700366 common_LOCAL_LDLIBS += -static
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100367endif
368
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700369## one for 32-bit
370$(call start-emulator-program, emulator-$(EMULATOR_TARGET_ARCH))
371LOCAL_STATIC_LIBRARIES += \
372 emulator-libui \
373 emulator-libqemu \
374 emulator-target-$(EMULATOR_TARGET_CPU) \
Lars Poeschel33da99a2012-08-22 09:42:42 +0200375 emulator-libjpeg \
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700376 emulator-libelff \
377 emulator-common \
378 $(SDL_STATIC_LIBRARIES)
379LOCAL_LDLIBS += $(common_LOCAL_LDLIBS)
380LOCAL_CFLAGS += $(common_LOCAL_CFLAGS)
381LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700382$(call gen-hx-header,qemu-options.hx,qemu-options.def,vl-android.c qemu-options.h)
383$(call gen-hw-config-defs)
Raphael Mollcdbea232012-05-04 15:04:27 -0700384
385ifeq ($(HOST_OS),windows)
386$(eval $(call insert-windows-icon))
387endif
388
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100389$(call end-emulator-program)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700390
391
392## another for 64-bit, see note in file Makefile.common emulator64-common
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700393ifneq ($(filter linux darwin,$(HOST_OS)),)
David 'Digit' Turnerf6f50072014-01-14 14:39:13 +0100394 $(call start-emulator-program, emulator64-$(EMULATOR_TARGET_ARCH))
395 LOCAL_STATIC_LIBRARIES += \
396 emulator64-libui \
397 emulator64-libqemu \
398 emulator64-target-$(EMULATOR_TARGET_CPU) \
399 emulator64-libjpeg \
400 emulator64-libelff \
401 emulator64-common \
402 $(SDL_STATIC_LIBRARIES_64)
403 LOCAL_LDLIBS += $(common_LOCAL_LDLIBS) -m64
404 LOCAL_CFLAGS += $(common_LOCAL_CFLAGS) -m64
405 LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
David 'Digit' Turnerf6f50072014-01-14 14:39:13 +0100406 $(call gen-hx-header,qemu-options.hx,qemu-options.def,vl-android.c qemu-options.h)
407 $(call gen-hw-config-defs)
408 $(call end-emulator-program)
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700409endif # HOST_OS == linux || darwin
Raphael Mollcdbea232012-05-04 15:04:27 -0700410