blob: 47d7ddba04f23b02f89bfca423236291d4effe4c [file] [log] [blame]
David 'Digit' Turneraff94b82011-02-07 18:10:54 +01001# When building this project, we actually generate several components which
2# are the following:
3#
4# - the emulator-ui program (which is target-agnostic)
5# - the target-specific qemu-android-$ARCH programs (headless emulation engines)
6# - the "standalone" emulator programs (embed both UI and engine in a single
7# binary and process), i.e. "emulator" for ARM and "emulator-x86" for x86.
8#
9# This file defines static host libraries that will be used by at least two
10# of these components.
11#
12
13##############################################################################
14##############################################################################
15###
David 'Digit' Turner42fc4492011-06-29 13:16:16 +020016### gen-hw-config-defs: Generate hardware configuration definitions header
17###
18### The 'gen-hw-config.py' script is used to generate the hw-config-defs.h
19### header from the an .ini file like android/avd/hardware-properties.ini
20###
21### Due to the way the Android build system works, we need to regenerate
22### it for each module (the output will go into a module-specific directory).
23###
24### This defines a function that can be used inside a module definition
25###
26### $(call gen-hw-config-defs)
27###
28
29# First, define a rule to generate a dummy "emulator_hw_config_defs" module
30# which purpose is simply to host the generated header in its output directory.
31intermediates := $(call intermediates-dir-for,SHARED_LIBRARIES,emulator_hw_config_defs,true)
32
33QEMU_HARDWARE_PROPERTIES_INI := $(LOCAL_PATH)/android/avd/hardware-properties.ini
34QEMU_HW_CONFIG_DEFS_H := $(intermediates)/android/avd/hw-config-defs.h
35$(QEMU_HW_CONFIG_DEFS_H): PRIVATE_PATH := $(LOCAL_PATH)
David 'Digit' Turner66241a62011-07-06 00:31:59 +020036$(QEMU_HW_CONFIG_DEFS_H): PRIVATE_CUSTOM_TOOL = $(PRIVATE_PATH)/android/tools/gen-hw-config.py $< $@
David 'Digit' Turner42fc4492011-06-29 13:16:16 +020037$(QEMU_HW_CONFIG_DEFS_H): $(QEMU_HARDWARE_PROPERTIES_INI) $(LOCAL_PATH)/android/tools/gen-hw-config.py
38 $(hide) rm -f $@
39 $(transform-generated-source)
40
41QEMU_HW_CONFIG_DEFS_INCLUDES := $(intermediates)
42
43# Second, define a function that needs to be called inside each module that contains
44# a source file that includes the generated header file.
45gen-hw-config-defs = \
46 $(eval LOCAL_GENERATED_SOURCES += $(QEMU_HW_CONFIG_DEFS_H))\
47 $(eval LOCAL_C_INCLUDES += $(QEMU_HW_CONFIG_DEFS_INCLUDES))
48
49##############################################################################
50##############################################################################
51###
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010052### emulator-common: LIBRARY OF COMMON FUNCTIONS
53###
54### THESE ARE POTENTIALLY USED BY ALL COMPONENTS
55###
56
Andrew Hsiehc7389bd2012-03-13 02:13:40 -070057common_LOCAL_CFLAGS =
58common_LOCAL_SRC_FILES =
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010059
60EMULATOR_COMMON_CFLAGS :=
61
62# Needed by everything about the host
63EMULATOR_COMMON_CFLAGS += \
64 -I$(LOCAL_PATH)/android/config/$(QEMU_HOST_TAG)
65
66# add the build ID to the default macro definitions
67ifeq ($(BUILD_STANDALONE_EMULATOR),)
68EMULATOR_COMMON_CFLAGS += -DANDROID_BUILD_ID="$(strip $(BUILD_ID))-$(strip $(BUILD_NUMBER))"
69endif
70
71# For non-standalone builds, extract the major version number from the Android SDK
72# tools revision number.
73ifneq ($(BUILD_STANDALONE_EMULATOR),true)
74 ANDROID_SDK_TOOLS_REVISION := $(shell awk -F= '/Pkg.Revision/ { print $$2; }' sdk/files/tools_source.properties)
75endif
76
77ANDROID_SDK_TOOLS_REVISION := $(strip $(ANDROID_SDK_TOOLS_REVISION))
78ifdef ANDROID_SDK_TOOLS_REVISION
79 EMULATOR_COMMON_CFLAGS += -DANDROID_SDK_TOOLS_REVISION=$(ANDROID_SDK_TOOLS_REVISION)
80endif
81
82# Enable large-file support (i.e. make off_t a 64-bit value)
83ifeq ($(HOST_OS),linux)
84EMULATOR_COMMON_CFLAGS += -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE
85endif
86
Raphael Moll9e319a92012-11-28 13:48:25 -080087
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010088###########################################################
89# Zlib sources
90#
91ZLIB_DIR := distrib/zlib-1.2.3
92include $(LOCAL_PATH)/$(ZLIB_DIR)/sources.make
93EMULATOR_COMMON_CFLAGS += -I$(LOCAL_PATH)/$(ZLIB_DIR)
94
Andrew Hsiehc7389bd2012-03-13 02:13:40 -070095common_LOCAL_SRC_FILES += $(ZLIB_SOURCES)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010096
97###########################################################
David 'Digit' Turner1d1a2af2014-01-10 16:17:40 +010098# GLib sources
99#
David 'Digit' Turner99c07e72014-01-13 12:34:52 +0100100GLIB_DIR := distrib/mini-glib
David 'Digit' Turner1d1a2af2014-01-10 16:17:40 +0100101include $(LOCAL_PATH)/$(GLIB_DIR)/sources.make
102EMULATOR_COMMON_CFLAGS += -I$(GLIB_INCLUDE_DIR)
103
104common_LOCAL_SRC_FILES += $(GLIB_SOURCES)
105
106###########################################################
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100107# Android utility functions
108#
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700109common_LOCAL_SRC_FILES += \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100110 android/async-console.c \
111 android/async-utils.c \
112 android/charmap.c \
113 android/framebuffer.c \
David 'Digit' Turnerd413fa52013-12-14 23:35:20 +0100114 android/iolooper-select.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100115 android/keycode-array.c \
116 android/avd/hw-config.c \
117 android/avd/info.c \
David 'Digit' Turner2d238fd2011-03-25 10:34:47 +0100118 android/avd/util.c \
David 'Digit' Turnercc330d42013-12-14 23:26:42 +0100119 android/sockets.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100120 android/sync-utils.c \
David 'Digit' Turner11823982014-02-11 23:48:52 +0100121 android/base/files/PathUtils.cpp \
David 'Digit' Turner7a41eef2014-02-07 15:56:41 +0100122 android/base/Log.cpp \
David 'Digit' Turneref457d22014-02-07 18:46:49 +0100123 android/base/StringView.cpp \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100124 android/utils/assert.c \
125 android/utils/bufprint.c \
126 android/utils/debug.c \
David 'Digit' Turner816e53c2011-08-17 18:33:45 +0200127 android/utils/dll.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100128 android/utils/dirscanner.c \
David 'Digit' Turner52e99422014-02-03 17:11:18 +0100129 android/utils/eintr_wrapper.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100130 android/utils/filelock.c \
131 android/utils/ini.c \
David 'Digit' Turnerbbb81042011-03-17 14:48:44 +0100132 android/utils/intmap.c \
David 'Digit' Turner0a879bf2011-05-12 18:45:18 +0200133 android/utils/lineinput.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100134 android/utils/mapfile.c \
135 android/utils/misc.c \
136 android/utils/panic.c \
137 android/utils/path.c \
138 android/utils/reflist.c \
139 android/utils/refset.c \
140 android/utils/stralloc.c \
141 android/utils/system.c \
142 android/utils/tempfile.c \
143 android/utils/vector.c \
David 'Digit' Turner60d0a152014-01-22 01:09:57 +0100144 android/utils/win32_cmdline_quote.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100145
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700146common_LOCAL_CFLAGS += $(EMULATOR_COMMON_CFLAGS)
147
148
149## one for 32-bit
150$(call start-emulator-library, emulator-common)
151LOCAL_CFLAGS += $(common_LOCAL_CFLAGS)
152LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
David 'Digit' Turner42fc4492011-06-29 13:16:16 +0200153$(call gen-hw-config-defs)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100154$(call end-emulator-library)
155
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700156## another for 64-bit
David 'Digit' Turner8be0af82014-01-14 14:39:13 +0100157# NOTE: only linux and darwin is supported, because for Windows,
158# amd64-mingw32msvc-gcc doesn't work, see http://b/issue?id=5949152.
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700159ifneq ($(filter linux darwin,$(HOST_OS)),)
David 'Digit' Turner8be0af82014-01-14 14:39:13 +0100160 $(call start-emulator-library, emulator64-common)
161 LOCAL_CFLAGS += $(common_LOCAL_CFLAGS) -m64
162 LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
163 $(call gen-hw-config-defs)
164 $(call end-emulator-library)
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700165endif # HOST_OS == linux || darwin
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700166
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100167##############################################################################
168##############################################################################
169###
170### emulator-libui: LIBRARY OF UI-RELATED FUNCTIONS
171###
172### THESE ARE USED BY 'emulator-ui' AND THE STANDALONE PROGRAMS
173###
174
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700175common_LOCAL_CFLAGS =
176common_LOCAL_SRC_FILES =
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100177
Jesse Hall183e9272012-04-26 15:13:27 -0700178ifneq ($(QEMU_OPENGLES_INCLUDE),)
179 EMULATOR_LIBUI_CFLAGS := -I$(QEMU_OPENGLES_INCLUDE)
180endif
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100181
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700182common_LOCAL_CFLAGS += $(EMULATOR_COMMON_CFLAGS)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100183
184###########################################################
185# Libpng configuration
186#
187LIBPNG_DIR := distrib/libpng-1.2.19
188include $(LOCAL_PATH)/$(LIBPNG_DIR)/sources.make
189
190EMULATOR_LIBUI_CFLAGS += \
191 $(LIBPNG_CFLAGS) \
192 -I$(LOCAL_PATH)/$(LIBPNG_DIR)
193
David 'Digit' Turner1634ff52013-12-14 23:31:41 +0100194common_LOCAL_SRC_FILES += $(LIBPNG_SOURCES) android/loadpng.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100195
196##############################################################################
197# SDL-related definitions
198#
199
200# Build SDL from sources except in certain cases where we use
201# prebuilt libraries instead.
202#
203BUILD_SDL_FROM_SOURCES := true
204
205# On linux-x86, using the prebuilts avoid installing all the X11
206# development packages on our build servers.
207#
208ifeq ($(QEMU_HOST_TAG),linux-x86)
209 BUILD_SDL_FROM_SOURCES := false
210endif
211
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100212# If we're building with android-configure.sh && make, always build from
213# sources to catch regressions as soon as they happen.
214#
215ifeq ($(BUILD_STANDALONE_EMULATOR),true)
216 BUILD_SDL_FROM_SOURCES := true
217endif
218
219# Except if we used android-configure.sh --sdl-config=<script>
220#
David 'Digit' Turnera4026682011-08-24 12:54:01 +0200221ifneq ($(QEMU_SDL_CONFIG),)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100222 BUILD_SDL_FROM_SOURCES := false
David 'Digit' Turnera4026682011-08-24 12:54:01 +0200223 SDL_CONFIG := $(QEMU_SDL_CONFIG)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100224endif
225
226ifneq ($(BUILD_SDL_FROM_SOURCES),true)
227
Xavier Ducrohet20821322012-04-03 16:39:24 -0700228 SDL_CONFIG ?= prebuilts/tools/$(QEMU_HOST_TAG)/sdl/bin/sdl-config
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100229 SDL_CFLAGS := $(shell $(SDL_CONFIG) --cflags)
230
231 # We need to filter out the _GNU_SOURCE variable because it breaks recent
232 # releases of Cygwin when using the -mno-cygwin option. Moreover, we don't
233 # need this macro at all to build the Android emulator.
234 SDL_CFLAGS := $(filter-out -D_GNU_SOURCE=1,$(SDL_CFLAGS))
235 SDL_LDLIBS := $(filter-out %.a %.lib,$(shell $(SDL_CONFIG) --static-libs))
236
237 # Circular dependencies between libSDL and libSDLmain
238 # We repeat the libraries in the final link to work around it
239 SDL_STATIC_LIBRARIES := libSDL libSDLmain libSDL libSDLmain
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700240 SDL_STATIC_LIBRARIES_64 := lib64SDL lib64SDLmain lib64SDL lib64SDLmain
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100241
242else # BUILD_SDL_FROM_SOURCES
243
Jesse Hallc60b1142012-07-17 17:01:04 -0700244 SDL_DIR := distrib/sdl-1.2.15
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100245 include $(LOCAL_PATH)/$(SDL_DIR)/sources.make
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700246 common_LOCAL_SRC_FILES += $(SDL_SOURCES)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100247
248 EMULATOR_LIBUI_CFLAGS += \
249 -I$(LOCAL_PATH)/$(SDL_DIR)/include
250
251 SDL_STATIC_LIBRARIES :=
252
253endif # BUILD_SDL_FROM_SOURCES
254
255EMULATOR_LIBUI_CFLAGS += $(SDL_CFLAGS)
256EMULATOR_LIBUI_LDLIBS += $(SDL_LDLIBS)
257
258# The following is needed by SDL_LoadObject
259ifneq ($(HOST_OS),windows)
260 EMULATOR_LIBUI_LDLIBS += -ldl
261endif
262
263# the skin support sources
264#
265SKIN_SOURCES := rect.c \
266 region.c \
267 image.c \
268 trackball.c \
269 keyboard.c \
270 keyset.c \
271 file.c \
272 window.c \
273 scaler.c \
274 composer.c \
275 surface.c \
276
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700277common_LOCAL_SRC_FILES += $(SKIN_SOURCES:%=android/skin/%)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100278
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700279common_LOCAL_SRC_FILES += \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100280 android/user-config.c \
281 android/resource.c \
282 android/qemulator.c \
283 android/keycode.c \
284
285# enable MMX code for our skin scaler
286ifeq ($(HOST_ARCH),x86)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700287common_LOCAL_CFLAGS += -DUSE_MMX=1 -mmmx
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100288endif
289
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700290common_LOCAL_CFLAGS += $(EMULATOR_LIBUI_CFLAGS)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100291
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700292
293## one for 32-bit
294$(call start-emulator-library, emulator-libui)
295LOCAL_CFLAGS += $(common_LOCAL_CFLAGS)
296LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
297$(call gen-hw-config-defs)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100298$(call end-emulator-library)
299
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700300
301## another for 64-bit, see note in emulator64-common
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700302ifneq ($(filter linux darwin,$(HOST_OS)),)
David 'Digit' Turner8be0af82014-01-14 14:39:13 +0100303 $(call start-emulator-library, emulator64-libui)
304 LOCAL_CFLAGS += $(common_LOCAL_CFLAGS) -m64
305 LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
306 $(call gen-hw-config-defs)
307 $(call end-emulator-library)
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700308endif # HOST_OS == linux || darwin
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700309
310
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100311##############################################################################
312##############################################################################
313###
314### emulator-libqemu: TARGET-INDEPENDENT QEMU FUNCTIONS
315###
316### THESE ARE USED BY EVERYTHING EXCEPT 'emulator-ui'
317###
318
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700319common_LOCAL_CFLAGS =
320common_LOCAL_SRC_FILES =
321
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100322
323EMULATOR_LIBQEMU_CFLAGS :=
324
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700325common_LOCAL_CFLAGS += $(EMULATOR_COMMON_CFLAGS)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100326
327AUDIO_SOURCES := noaudio.c wavaudio.c wavcapture.c mixeng.c
328AUDIO_CFLAGS := -I$(LOCAL_PATH)/audio -DHAS_AUDIO
329AUDIO_LDLIBS :=
330
Raphael Moll9e319a92012-11-28 13:48:25 -0800331common_LOCAL_CFLAGS += -Wall $(GCC_W_NO_MISSING_FIELD_INITIALIZERS)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100332
333ifeq ($(HOST_OS),darwin)
334 CONFIG_COREAUDIO ?= yes
335 AUDIO_CFLAGS += -DHOST_BSD=1
336endif
337
338ifeq ($(HOST_OS),windows)
339 CONFIG_WINAUDIO ?= yes
340endif
341
342ifeq ($(HOST_OS),linux)
343 CONFIG_OSS ?= yes
344 CONFIG_ALSA ?= yes
345 CONFIG_PULSEAUDIO ?= yes
346 CONFIG_ESD ?= yes
347endif
348
349ifeq ($(HOST_OS),freebsd)
350 CONFIG_OSS ?= yes
351endif
352
353ifeq ($(CONFIG_COREAUDIO),yes)
354 AUDIO_SOURCES += coreaudio.c
355 AUDIO_CFLAGS += -DCONFIG_COREAUDIO
356 AUDIO_LDLIBS += -Wl,-framework,CoreAudio
357endif
358
359ifeq ($(CONFIG_WINAUDIO),yes)
360 AUDIO_SOURCES += winaudio.c
361 AUDIO_CFLAGS += -DCONFIG_WINAUDIO
362endif
363
364ifeq ($(CONFIG_PULSEAUDIO),yes)
365 AUDIO_SOURCES += paaudio.c audio_pt_int.c
366 AUDIO_CFLAGS += -DCONFIG_PULSEAUDIO
367endif
368
369ifeq ($(CONFIG_ALSA),yes)
370 AUDIO_SOURCES += alsaaudio.c audio_pt_int.c
371 AUDIO_CFLAGS += -DCONFIG_ALSA
372endif
373
374ifeq ($(CONFIG_ESD),yes)
375 AUDIO_SOURCES += esdaudio.c
376 AUDIO_CFLAGS += -DCONFIG_ESD
377endif
378
379ifeq ($(CONFIG_OSS),yes)
380 AUDIO_SOURCES += ossaudio.c
381 AUDIO_CFLAGS += -DCONFIG_OSS
382endif
383
384AUDIO_SOURCES := $(call sort,$(AUDIO_SOURCES:%=audio/%))
385
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700386common_LOCAL_CFLAGS += -Wno-sign-compare \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100387 -fno-strict-aliasing -W -Wall -Wno-unused-parameter \
388
389# this is very important, otherwise the generated binaries may
390# not link properly on our build servers
391ifeq ($(HOST_OS),linux)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700392common_LOCAL_CFLAGS += -fno-stack-protector
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100393endif
394
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700395common_LOCAL_SRC_FILES += $(AUDIO_SOURCES)
396common_LOCAL_SRC_FILES += \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100397 android/audio-test.c
398
399# other flags
400ifneq ($(HOST_OS),windows)
401 AUDIO_LDLIBS += -ldl
402else
403endif
404
405
406EMULATOR_LIBQEMU_CFLAGS += $(AUDIO_CFLAGS)
407EMULATOR_LIBQEMU_LDLIBS += $(AUDIO_LDLIBS)
408
Raphael Moll9e319a92012-11-28 13:48:25 -0800409common_LOCAL_CFLAGS += $(GCC_W_NO_MISSING_FIELD_INITIALIZERS)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100410
411# migration sources
412#
413ifeq ($(HOST_OS),windows)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700414 common_LOCAL_SRC_FILES += migration-dummy-android.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100415else
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700416 common_LOCAL_SRC_FILES += migration.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100417 migration-exec.c \
418 migration-tcp-android.c
419endif
420
421# misc. sources
422#
423CORE_MISC_SOURCES = \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100424 aio-android.c \
425 async.c \
426 bt-host.c \
427 bt-vhci.c \
428 buffered_file.c \
David 'Digit' Turner8354d2d2011-05-11 00:19:06 +0200429 iohandler.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100430 ioport.c \
David 'Digit' Turner3b2846a2011-05-11 01:34:40 +0200431 qemu-char.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100432 readline.c \
433 savevm.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100434 android/boot-properties.c \
David 'Digit' Turnere1e03df2013-12-15 00:42:21 +0100435 android/cbuffer.c \
436 android/charpipe.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100437 android/config.c \
438 android/core-init-utils.c \
439 android/gps.c \
440 android/hw-kmsg.c \
441 android/hw-lcd.c \
442 android/hw-events.c \
443 android/hw-control.c \
444 android/hw-sensors.c \
445 android/hw-qemud.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100446 android/looper-qemu.c \
David 'Digit' Turnerc0ac7332011-05-02 15:05:35 +0200447 android/hw-pipe-net.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100448 android/qemu-setup.c \
David 'Digit' Turner6e2eb782013-12-15 00:54:21 +0100449 android/qemu-tcpdump.c \
David 'Digit' Turnercc330d42013-12-14 23:26:42 +0100450 android/shaper.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100451 android/snapshot.c \
Vladimir Chtchetkine9d36fe72012-03-26 10:29:20 -0700452 android/async-socket-connector.c \
Vladimir Chtchetkinea7383ef2012-03-29 07:34:07 -0700453 android/async-socket.c \
Vladimir Chtchetkinec8aa2c52012-04-05 16:22:55 -0700454 android/sdk-controller-socket.c \
Vladimir Chtchetkinedb611d52011-11-01 17:35:07 -0700455 android/sensors-port.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100456 android/utils/timezone.c \
Vladimir Chtchetkinec646f5e2011-09-03 15:17:13 -0700457 android/camera/camera-format-converters.c \
Vladimir Chtchetkined86c7242011-12-09 15:45:46 -0800458 android/camera/camera-service.c \
459 android/adb-server.c \
Vladimir Chtchetkinedb450d72012-01-12 13:37:40 -0800460 android/adb-qemud.c \
Vladimir Chtchetkine8dd31e82012-02-15 17:16:04 -0800461 android/snaphost-android.c \
462 android/multitouch-screen.c \
463 android/multitouch-port.c \
David 'Digit' Turner84569132013-12-13 17:34:07 +0100464 android/utils/jpeg-compress.c \
David 'Digit' Turnercc330d42013-12-14 23:26:42 +0100465 net/net-android.c \
David 'Digit' Turner1c31e3e2013-12-14 20:07:17 +0100466 qobject/qerror.c \
467 ui/console.c \
468 ui/d3des.c \
David 'Digit' Turnerd7088e92013-12-17 09:25:19 +0100469 ui/input.c \
David 'Digit' Turner1c31e3e2013-12-14 20:07:17 +0100470 ui/vnc-android.c \
David 'Digit' Turner37dc41a2013-12-14 14:45:51 +0100471 util/acl.c \
472 util/aes.c \
David 'Digit' Turnere90d6652013-12-14 14:55:12 +0100473 util/cutils.c \
474 util/module.c \
475 util/notify.c \
David 'Digit' Turner84569132013-12-13 17:34:07 +0100476 util/osdep.c \
David 'Digit' Turner1c31e3e2013-12-14 20:07:17 +0100477 util/path.c \
478 util/qemu-config.c \
479 util/qemu-error.c \
480 util/qemu-option.c \
481 util/qemu-sockets-android.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100482
483ifeq ($(HOST_ARCH),x86)
David 'Digit' Turnercc33b2d2013-12-15 00:09:42 +0100484 CORE_MISC_SOURCES += disas/i386.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100485endif
486ifeq ($(HOST_ARCH),x86_64)
David 'Digit' Turnercc33b2d2013-12-15 00:09:42 +0100487 CORE_MISC_SOURCES += disas/i386.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100488endif
489ifeq ($(HOST_ARCH),ppc)
David 'Digit' Turnercc33b2d2013-12-15 00:09:42 +0100490 CORE_MISC_SOURCES += disas/ppc.c \
David 'Digit' Turner37dc41a2013-12-14 14:45:51 +0100491 util/cache-utils.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100492endif
493
494ifeq ($(HOST_OS),linux)
David 'Digit' Turnerd471c922013-12-17 09:52:48 +0100495 CORE_MISC_SOURCES += hw/usb/usb-linux.c \
David 'Digit' Turner1c31e3e2013-12-14 20:07:17 +0100496 util/qemu-thread.c \
Vladimir Chtchetkine4ed09fd2011-08-18 09:42:40 -0700497 android/camera/camera-capture-linux.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100498else
David 'Digit' Turnerd471c922013-12-17 09:52:48 +0100499 CORE_MISC_SOURCES += hw/usb/usb-dummy-android.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100500endif
501
502ifeq ($(HOST_OS),windows)
Vladimir Chtchetkine4ed09fd2011-08-18 09:42:40 -0700503 CORE_MISC_SOURCES += tap-win32.c \
504 android/camera/camera-capture-windows.c
505
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100506else
507 CORE_MISC_SOURCES += posix-aio-compat.c
508endif
509
Vladimir Chtchetkineb92b3032011-09-12 15:29:32 -0700510ifeq ($(HOST_OS),darwin)
Vladimir Chtchetkine955a9972011-10-12 15:40:17 -0700511 CORE_MISC_SOURCES += android/camera/camera-capture-mac.m
Vladimir Chtchetkineb92b3032011-09-12 15:29:32 -0700512endif
513
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700514common_LOCAL_SRC_FILES += $(CORE_MISC_SOURCES)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100515
516# Required
Lars Poeschel33da99a2012-08-22 09:42:42 +0200517common_LOCAL_CFLAGS += -D_XOPEN_SOURCE=600 -D_BSD_SOURCE=1 -I$(LOCAL_PATH)/distrib/jpeg-6b
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100518
519SLIRP_SOURCES := \
520 bootp.c \
521 cksum.c \
522 debug.c \
523 if.c \
524 ip_icmp.c \
525 ip_input.c \
526 ip_output.c \
527 mbuf.c \
528 misc.c \
529 sbuf.c \
530 slirp.c \
531 socket.c \
532 tcp_input.c \
533 tcp_output.c \
534 tcp_subr.c \
535 tcp_timer.c \
536 tftp.c \
537 udp.c
538
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700539common_LOCAL_SRC_FILES += $(SLIRP_SOURCES:%=slirp-android/%)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100540EMULATOR_LIBQEMU_CFLAGS += -I$(LOCAL_PATH)/slirp-android
541
542# socket proxy support
543#
544PROXY_SOURCES := \
545 proxy_common.c \
546 proxy_http.c \
547 proxy_http_connector.c \
548 proxy_http_rewriter.c \
549
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700550common_LOCAL_SRC_FILES += $(PROXY_SOURCES:%=proxy/%)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100551EMULATOR_LIBQEMU_CFLAGS += -I$(LOCAL_PATH)/proxy
552
553# include telephony stuff
554#
555TELEPHONY_SOURCES := \
556 android_modem.c \
557 modem_driver.c \
558 gsm.c \
559 sim_card.c \
560 sysdeps_qemu.c \
561 sms.c \
562 remote_call.c
563
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700564common_LOCAL_SRC_FILES += $(TELEPHONY_SOURCES:%=telephony/%)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100565EMULATOR_LIBQEMU_CFLAGS += -I$(LOCAL_PATH)/telephony
566
567# sources inherited from upstream, but not fully
568# integrated into android emulator
569#
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700570common_LOCAL_SRC_FILES += \
David 'Digit' Turner1c31e3e2013-12-14 20:07:17 +0100571 qobject/json-lexer.c \
572 qobject/json-parser.c \
573 qobject/json-streamer.c \
574 qobject/qjson.c \
575 qobject/qbool.c \
576 qobject/qdict.c \
577 qobject/qfloat.c \
578 qobject/qint.c \
579 qobject/qlist.c \
580 qobject/qstring.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100581
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100582ifeq ($(QEMU_TARGET_XML_SOURCES),)
583 QEMU_TARGET_XML_SOURCES := arm-core arm-neon arm-vfp arm-vfp3
584 QEMU_TARGET_XML_SOURCES := $(QEMU_TARGET_XML_SOURCES:%=$(LOCAL_PATH)/gdb-xml/%.xml)
585endif
586
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700587common_LOCAL_CFLAGS += $(EMULATOR_LIBQEMU_CFLAGS)
588
589
590## one for 32-bit
591$(call start-emulator-library, emulator-libqemu)
592# gdbstub-xml.c contains C-compilable arrays corresponding to the content
593# of $(LOCAL_PATH)/gdb-xml/, and is generated with the 'feature_to_c.sh' script.
594#
595intermediates = $(call intermediates-dir-for,STATIC_LIBRARIES,$(LOCAL_MODULE),true)
596QEMU_GDBSTUB_XML_C = $(intermediates)/gdbstub-xml.c
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100597$(QEMU_GDBSTUB_XML_C): PRIVATE_PATH := $(LOCAL_PATH)
598$(QEMU_GDBSTUB_XML_C): PRIVATE_SOURCES := $(TARGET_XML_SOURCES)
599$(QEMU_GDBSTUB_XML_C): PRIVATE_CUSTOM_TOOL = $(PRIVATE_PATH)/feature_to_c.sh $@ $(QEMU_TARGET_XML_SOURCES)
600$(QEMU_GDBSTUB_XML_C): $(QEMU_TARGET_XML_SOURCES) $(LOCAL_PATH)/feature_to_c.sh
601 $(hide) rm -f $@
602 $(transform-generated-source)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100603LOCAL_GENERATED_SOURCES += $(QEMU_GDBSTUB_XML_C)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700604LOCAL_CFLAGS += $(common_LOCAL_CFLAGS) -I$(intermediates)
605LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
606$(call gen-hw-config-defs)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100607$(call end-emulator-library)
608
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700609
610## another for 64-bit, see note in emulator64-common
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700611ifneq ($(filter linux darwin,$(HOST_OS)),)
David 'Digit' Turner8be0af82014-01-14 14:39:13 +0100612 $(call start-emulator-library, emulator64-libqemu)
613 # gdbstub-xml.c contains C-compilable arrays corresponding to the content
614 # of $(LOCAL_PATH)/gdb-xml/, and is generated with the 'feature_to_c.sh' script.
615 #
616 intermediates = $(call intermediates-dir-for,STATIC_LIBRARIES,$(LOCAL_MODULE),true)
617 QEMU_GDBSTUB_XML_C = $(intermediates)/gdbstub-xml.c
618 $(QEMU_GDBSTUB_XML_C): PRIVATE_PATH := $(LOCAL_PATH)
619 $(QEMU_GDBSTUB_XML_C): PRIVATE_SOURCES := $(TARGET_XML_SOURCES)
620 $(QEMU_GDBSTUB_XML_C): PRIVATE_CUSTOM_TOOL = $(PRIVATE_PATH)/feature_to_c.sh $@ $(QEMU_TARGET_XML_SOURCES)
621 $(QEMU_GDBSTUB_XML_C): $(QEMU_TARGET_XML_SOURCES) $(LOCAL_PATH)/feature_to_c.sh
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700622 $(hide) rm -f $@
623 $(transform-generated-source)
David 'Digit' Turner8be0af82014-01-14 14:39:13 +0100624 LOCAL_GENERATED_SOURCES += $(QEMU_GDBSTUB_XML_C)
625 LOCAL_CFLAGS += $(common_LOCAL_CFLAGS) -I$(intermediates) -m64
626 LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
627 $(call gen-hw-config-defs)
628 $(call end-emulator-library)
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700629endif # HOST_OS == linux || darwin
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700630
631
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100632# Block sources, we must compile them with each executable because they
633# are only referenced by the rest of the code using constructor functions.
634# If their object files are put in a static library, these are never compiled
635# into the final linked executable that uses them.
636#
637# Normally, one would solve thus using LOCAL_WHOLE_STATIC_LIBRARIES, but
638# the Darwin linker doesn't support -Wl,--whole-archive or equivalent :-(
639#
640BLOCK_SOURCES += \
641 block.c \
642 blockdev.c \
643 block/qcow.c \
644 block/qcow2.c \
645 block/qcow2-refcount.c \
646 block/qcow2-snapshot.c \
647 block/qcow2-cluster.c \
648 block/cloop.c \
649 block/dmg.c \
650 block/vvfat.c \
651 block/raw.c
652
653ifeq ($(HOST_OS),windows)
654 BLOCK_SOURCES += block/raw-win32.c
655else
656 BLOCK_SOURCES += block/raw-posix.c
657endif
658
659BLOCK_CFLAGS += $(EMULATOR_COMMON_CFLAGS)
David 'Digit' Turnercef730b2014-02-04 01:02:30 +0100660BLOCK_CFLAGS += -DCONFIG_BDRV_WHITELIST=\"\"
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100661
Lars Poeschel33da99a2012-08-22 09:42:42 +0200662##############################################################################
663##############################################################################
664###
665### emulator-libjpeg: TARGET-INDEPENDENT QEMU FUNCTIONS
666###
667### THESE ARE USED BY EVERYTHING EXCEPT 'emulator-ui'
668###
669
670common_LOCAL_CFLAGS =
671common_LOCAL_SRC_FILES =
672
673###########################################################
674# Jpeg configuration
675#
676LIBJPEG_DIR := distrib/jpeg-6b
677include $(LOCAL_PATH)/$(LIBJPEG_DIR)/sources.make
678
679common_LOCAL_SRC_FILES += $(LIBJPEG_SOURCES)
680
681common_LOCAL_CFLAGS += \
682 $(LIBJPEG_CFLAGS) \
683 -I$(LOCAL_PATH)/$(LIBJPEG_DIR)
684
685## one for 32-bit
686$(call start-emulator-library, emulator-libjpeg)
687LOCAL_CFLAGS += $(common_LOCAL_CFLAGS)
688LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
689$(call end-emulator-library)
690
691
692## another for 64-bit, see note in emulator64-common
Andrew Hsieh6eb25c72012-08-24 08:18:22 +0800693ifneq ($(filter linux darwin,$(HOST_OS)),)
David 'Digit' Turner8be0af82014-01-14 14:39:13 +0100694 $(call start-emulator-library, emulator64-libjpeg)
695 LOCAL_CFLAGS += $(common_LOCAL_CFLAGS) -m64
696 LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
697 $(call end-emulator-library)
Lars Poeschel33da99a2012-08-22 09:42:42 +0200698endif # HOST_OS == linux
699
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100700
701##############################################################################
702##############################################################################
703###
David 'Digit' Turner8be0af82014-01-14 14:39:13 +0100704### emulator-libelff: TARGET-INDEPENDENT ELF/DWARF PARSER
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100705###
706### THESE ARE USED BY EVERYTHING EXCEPT 'emulator-ui', BUT WE CANNOT PUT
707### THEM IN emulator-libqemu SINCE THE SOURCES ARE C++
708###
709
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700710common_LOCAL_CFLAGS =
711common_LOCAL_SRC_FILES =
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100712
713ELFF_CFLAGS := -I$(LOCAL_PATH)/elff
714ELFF_LDLIBS := -lstdc++
715
716ELFF_SOURCES := \
717 dwarf_cu.cc \
718 dwarf_die.cc \
719 dwarf_utils.cc \
720 elf_alloc.cc \
721 elf_file.cc \
722 elf_mapped_section.cc \
723 elff_api.cc \
724
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700725common_LOCAL_SRC_FILES += $(ELFF_SOURCES:%=elff/%)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100726
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700727common_LOCAL_CFLAGS += \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100728 -fno-exceptions \
729 $(ELFF_CFLAGS) \
730
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700731
732## one for 32-bit
733$(call start-emulator-library, emulator-libelff)
734LOCAL_CPP_EXTENSION := .cc
735LOCAL_CFLAGS += $(common_LOCAL_CFLAGS)
736LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100737$(call end-emulator-library)
738
739
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700740## another for 64-bit, see note in emulator64-common
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700741ifneq ($(filter linux darwin,$(HOST_OS)),)
David 'Digit' Turner8be0af82014-01-14 14:39:13 +0100742 $(call start-emulator-library, emulator64-libelff)
743 LOCAL_CPP_EXTENSION := .cc
744 LOCAL_CFLAGS += $(common_LOCAL_CFLAGS) -m64
745 LOCAL_SRC_FILES += $(common_LOCAL_SRC_FILES)
746 $(call end-emulator-library)
Andrew Hsieh83df59c2012-07-24 16:06:28 -0700747endif # HOST_OS == linux || darwin
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700748
749
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100750##############################################################################
751##############################################################################
752###
753### gen-hx-header: Generate headers from .hx file with "hxtool" script.
754###
755### The 'hxtool' script is used to generate header files from an input
756### file with the .hx suffix. I.e. foo.hx --> foo.h
757###
758### Due to the way the Android build system works, we need to regenerate
759### it for each module (the output will go into a module-specific directory).
760###
761### This defines a function that can be used inside a module definition
762###
David 'Digit' Turner088edf82011-05-09 15:59:28 +0200763### $(call gen-hx-header,<input>,<output>,<source-files>)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100764###
765### Where: <input> is the input file, with a .hx suffix (e.g. foo.hx)
David 'Digit' Turner088edf82011-05-09 15:59:28 +0200766### <output> is the output file, with a .h or .def suffix
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100767### <source-files> is a list of source files that include the header
768###
769
770
771gen-hx-header = $(eval $(call gen-hx-header-ev,$1,$2,$3))
772
773define gen-hx-header-ev
David 'Digit' Turner42fc4492011-06-29 13:16:16 +0200774intermediates := $$(call intermediates-dir-for,$$(LOCAL_MODULE_CLASS),$$(LOCAL_MODULE),true)
David 'Digit' Turner317c9d52011-05-10 06:38:21 +0200775
David 'Digit' Turner088edf82011-05-09 15:59:28 +0200776QEMU_HEADER_H := $$(intermediates)/$$2
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100777$$(QEMU_HEADER_H): PRIVATE_PATH := $$(LOCAL_PATH)
778$$(QEMU_HEADER_H): PRIVATE_CUSTOM_TOOL = $$(PRIVATE_PATH)/hxtool -h < $$< > $$@
779$$(QEMU_HEADER_H): $$(LOCAL_PATH)/$$1 $$(LOCAL_PATH)/hxtool
780 $$(transform-generated-source)
781
782LOCAL_GENERATED_SOURCES += $$(QEMU_HEADER_H)
David 'Digit' Turner088edf82011-05-09 15:59:28 +0200783LOCAL_C_INCLUDES += $$(intermediates)
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100784endef
785