blob: 181986ae0376e6bd97304aa21207cfb237d49b08 [file] [log] [blame]
Joe Onoratoedb86c32012-07-25 14:28:40 -07001ifeq ($(BUILD_EMULATOR),true)
2
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -07003ifneq (,$(filter $(TARGET_ARCH),arm x86 mips))
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -08004LOCAL_PATH:= $(call my-dir)
5
Jun Nakajima334ab472011-02-02 23:49:59 -08006# determine the target cpu
7ifeq ($(TARGET_ARCH),arm)
8EMULATOR_TARGET_CPU := target-arm
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -07009endif
10ifeq ($(TARGET_ARCH),x86)
Jun Nakajima334ab472011-02-02 23:49:59 -080011EMULATOR_TARGET_CPU := target-i386
12endif
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -070013ifeq ($(TARGET_ARCH),mips)
14EMULATOR_TARGET_CPU := target-mips
15endif
Jun Nakajima334ab472011-02-02 23:49:59 -080016
David 'Digit' Turner34d16512010-05-18 17:02:33 -070017# determine the host tag to use
18QEMU_HOST_TAG := $(HOST_PREBUILT_TAG)
19ifneq ($(USE_MINGW),)
20 QEMU_HOST_TAG := windows
21endif
22
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080023# determine the location of platform-specific directories
24#
25CONFIG_DIRS := \
David 'Digit' Turner34d16512010-05-18 17:02:33 -070026 $(LOCAL_PATH)/android/config/$(QEMU_HOST_TAG)
27
28ifeq ($(BUILD_STANDALONE_EMULATOR),true)
29 CONFIG_DIRS := $(LOCAL_PATH)/objs $(CONFIG_DIRS)
30endif
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080031
32CONFIG_INCLUDES := $(CONFIG_DIRS:%=-I%)
33
David 'Digit' Turner0a349b82011-03-02 12:49:26 +010034MY_CC := $(HOST_CC)
35MY_CXX := $(HOST_CXX)
36MY_AR := $(HOST_AR)
Kenny Root095cd0f2009-09-19 18:32:44 -050037
Lars Poeschel33da99a2012-08-22 09:42:42 +020038MY_CFLAGS := $(CONFIG_INCLUDES) -O2 -g -fno-PIC -falign-functions=0 -fomit-frame-pointer
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080039
David 'Digit' Turner466f5482009-07-30 15:50:19 +020040# Overwrite configuration for debug builds.
41#
42ifeq ($(BUILD_DEBUG_EMULATOR),true)
Iliyan Malchevd00f7c42012-03-30 10:54:20 -070043 MY_CFLAGS := $(CONFIG_INCLUDES)
44 MY_CFLAGS += -O0 -g
45 MY_CFLAGS += -fno-PIC -falign-functions=0
David 'Digit' Turner466f5482009-07-30 15:50:19 +020046endif
47
David 'Digit' Turnerb95f8922009-08-21 23:10:16 -070048MY_LDLIBS :=
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080049
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080050ifeq ($(HOST_OS),freebsd)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -070051 MY_CFLAGS += -I /usr/local/include
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080052endif
53
54ifeq ($(HOST_OS),windows)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -070055 # we need Win32 features that are available since Windows 2000 Professional/Server (NT 5.0)
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080056 MY_CFLAGS += -DWINVER=0x501
Andrew Hsiehc7389bd2012-03-13 02:13:40 -070057 MY_CFLAGS += -D_WIN32
58 ifneq ($(BUILD_HOST_64bit),)
59 # Microsoft 64-bit compiler define both _WIN32 and _WIN64
60 MY_CFLAGS += -D_WIN64
61 # amd64-mingw32msvc- toolchain still name it vfw32. May change it once amd64-mingw32msvc-
62 # is stabilized
63 MY_LDLIBS += -lvfw32
64 else
65 MY_LDLIBS += -lvfw32
66 endif
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080067endif
68
69ifeq ($(HOST_ARCH),ppc)
70 MY_CFLAGS += -D__powerpc__
71endif
72
73ifeq ($(HOST_OS),darwin)
David 'Digit' Turner747f7d12011-01-06 22:24:26 +010074 MY_CFLAGS += -mdynamic-no-pic -D_DARWIN_C_SOURCE=1
David Turnerbba461c2009-06-03 10:48:15 -070075
SangWook Han08c1bde2012-07-26 08:06:58 +090076 MY_CFLAGS += -isysroot $(mac_sdk_root) -mmacosx-version-min=$(mac_sdk_version) -DMACOSX_DEPLOYMENT_TARGET=$(mac_sdk_version)
77 MY_LDLIBS += -isysroot $(mac_sdk_root) -Wl,-syslibroot,$(mac_sdk_root) -mmacosx-version-min=$(mac_sdk_version)
Andrew Hsiehc2f0b962012-08-09 18:21:33 +080078
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080079endif
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080080
81# BUILD_STANDALONE_EMULATOR is only defined when building with
82# the android-rebuild.sh script. The script will also provide
83# adequate values for HOST_CC
84#
85ifneq ($(BUILD_STANDALONE_EMULATOR),true)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -070086 # On Linux, use our custom 32-bit host toolchain (unless BUILD_HOST_64bit=1)
87 # which contains the relevant headers and 32-bit libraries for audio (The host 64-bit
88 # Lucid doesn't provide these anymore, only their 64-bit versions).
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010089 ifeq ($(HOST_OS),linux)
Andrew Hsiehd0f2ab62012-03-23 17:35:11 +080090 HOST_SDK_TOOLCHAIN_PREFIX := prebuilts/tools/gcc-sdk
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010091 # Don't do anything if the toolchain is not there
Andrew Hsiehd0f2ab62012-03-23 17:35:11 +080092 ifneq (,$(strip $(wildcard $(HOST_SDK_TOOLCHAIN_PREFIX)/gcc)))
93 MY_CC := $(HOST_SDK_TOOLCHAIN_PREFIX)/gcc
94 MY_CXX := $(HOST_SDK_TOOLCHAIN_PREFIX)/g++
95 MY_AR := $(HOST_SDK_TOOLCHAIN_PREFIX)/ar
96 endif # $(HOST_SDK_TOOLCHAIN_PREFIX)/gcc exists
David 'Digit' Turneraff94b82011-02-07 18:10:54 +010097 endif # HOST_OS == linux
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -080098
99 ifneq ($(USE_CCACHE),)
Ying Wang762d5de2012-01-09 11:53:58 -0800100 ccache := prebuilts/misc/$(HOST_PREBUILT_TAG)/ccache/ccache
David 'Digit' Turner4ed818f2011-03-12 13:05:15 +0100101 ccache := $(strip $(wildcard $(ccache)))
Ying Wang7bf9d7f2010-10-07 15:12:11 -0700102 ifneq ($(ccache),$(firstword $(MY_CC)))
103 MY_CC := $(ccache) $(MY_CC)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700104 MY_CXX := $(ccache) $(MY_CXX)
Ying Wang7bf9d7f2010-10-07 15:12:11 -0700105 endif
106 ccache :=
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800107 endif
Jesse Hall183e9272012-04-26 15:13:27 -0700108
109 QEMU_OPENGLES_INCLUDE := sdk/emulator/opengl/host/include
110 QEMU_OPENGLES_LIBS := $(HOST_OUT)
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800111endif
112
113
114ifneq ($(combo_target)$(TARGET_SIMULATOR),HOST_true)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700115 ifneq ($(BUILD_HOST_64bit),)
116 MY_CFLAGS += -m64
117 MY_LDLIBS += -m64
118 else
119 ifneq ($(HOST_ARCH),x86_64)
120 MY_CFLAGS += -m32
121 MY_LDLIBS += -m32
122 endif
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800123 endif
Andrew Hsieh632a0e12012-04-28 00:48:53 +0800124
125 ifneq ($(BUILD_HOST_static),)
126 MY_LDLIBS += -static
127 endif
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800128endif
129
David 'Digit' Turner4e024bb2010-09-22 14:19:28 +0200130# Enable warning, except those related to missing field initializers
131# (the QEMU coding style loves using these).
132#
133MY_CFLAGS += -Wall -Wno-missing-field-initializers
134
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100135# Needed to build fpu/softfloat-native.h properly
136MY_CFLAGS += -D_GNU_SOURCE=1
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800137
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100138# A useful function that can be used to start the declaration of a host
139# module. Avoids repeating the same stuff again and again.
140# Usage:
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800141#
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100142# $(call start-emulator-library, <module-name>)
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800143#
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100144# ... declarations
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800145#
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100146# $(call end-emulator-library)
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800147#
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100148start-emulator-library = \
149 $(eval include $(CLEAR_VARS)) \
150 $(eval LOCAL_NO_DEFAULT_COMPILER_FLAGS := true) \
151 $(eval LOCAL_CC := $(MY_CC)) \
David 'Digit' Turnerb580d262011-03-02 09:49:06 +0100152 $(eval LOCAL_CXX := $(MY_CXX)) \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100153 $(eval LOCAL_CFLAGS := $(MY_CFLAGS)) \
David 'Digit' Turnerb580d262011-03-02 09:49:06 +0100154 $(eval LOCAL_AR := $(MY_AR)) \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100155 $(eval LOCAL_LDLIBS := $(MY_LDLIBS)) \
David 'Digit' Turner317c9d52011-05-10 06:38:21 +0200156 $(eval LOCAL_MODULE := $1) \
David 'Digit' Turner42fc4492011-06-29 13:16:16 +0200157 $(eval LOCAL_MODULE_CLASS := STATIC_LIBRARIES)
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800158
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100159# Used with start-emulator-library
160end-emulator-library = \
David 'Digit' Turner42fc4492011-06-29 13:16:16 +0200161 $(eval include $(BUILD_HOST_STATIC_LIBRARY))
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800162
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100163# A variant of start-emulator-library to start the definition of a host
164# program instead. Use with end-emulator-program
David 'Digit' Turner088edf82011-05-09 15:59:28 +0200165start-emulator-program = \
166 $(call start-emulator-library,$1) \
David 'Digit' Turner42fc4492011-06-29 13:16:16 +0200167 $(eval LOCAL_MODULE_CLASS := EXECUTABLES)
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800168
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100169# A varient of end-emulator-library for host programs instead
170end-emulator-program = \
171 $(eval LOCAL_LDLIBS += $(QEMU_SYSTEM_LDLIBS)) \
172 $(eval include $(BUILD_HOST_EXECUTABLE))
Xavier Ducrohetfc8ed802011-02-09 18:04:23 -0800173
Vladimir Chtchetkineba1f57f2010-07-27 14:14:15 -0700174
Vladimir Chtchetkineba1f57f2010-07-27 14:14:15 -0700175# The common libraries
176#
177QEMU_SYSTEM_LDLIBS := -lm
178ifeq ($(HOST_OS),windows)
179 QEMU_SYSTEM_LDLIBS += -mno-cygwin -mwindows -mconsole
180endif
181
182ifeq ($(HOST_OS),freebsd)
183 QEMU_SYSTEM_LDLIBS += -L/usr/local/lib -lpthread -lX11 -lutil
184endif
185
186ifeq ($(HOST_OS),linux)
187 QEMU_SYSTEM_LDLIBS += -lutil -lrt
188endif
189
190ifeq ($(HOST_OS),windows)
Andrew Hsiehc7389bd2012-03-13 02:13:40 -0700191 # amd64-mingw32msvc- toolchain still name it ws2_32. May change it once amd64-mingw32msvc-
192 # is stabilized
Vladimir Chtchetkineba1f57f2010-07-27 14:14:15 -0700193 QEMU_SYSTEM_LDLIBS += -lwinmm -lws2_32 -liphlpapi
194else
195 QEMU_SYSTEM_LDLIBS += -lpthread
196endif
197
David 'Digit' Turner393c0f12010-07-28 12:20:56 -0700198ifeq ($(HOST_OS),darwin)
Vladimir Chtchetkine955a9972011-10-12 15:40:17 -0700199 QEMU_SYSTEM_LDLIBS += -Wl,-framework,Cocoa,-framework,QTKit,-framework,CoreVideo
Andrew Hsiehc2f0b962012-08-09 18:21:33 +0800200
201 # SDK 10.6+ doesn't have __dyld_func_lookup anymore. Dynamic library lookup symbols
202 # are instead resolved at runtime
203 OSX_VERSION_MAJOR := $(shell echo $(mac_sdk_version) | cut -d . -f 2)
204 OSX_VERSION_MAJOR_GREATER_THAN_OR_EQUAL_TO_6 := $(shell [ $(OSX_VERSION_MAJOR) -ge 6 ] && echo true)
205 ifeq ($(OSX_VERSION_MAJOR_GREATER_THAN_OR_EQUAL_TO_6),true)
Al Sutton49dd3f32012-01-04 15:19:05 -0800206 QEMU_SYSTEM_LDLIBS += -undefined dynamic_lookup
Al Suttonc3c9c6f2011-12-21 13:16:22 -0800207 endif
David 'Digit' Turner393c0f12010-07-28 12:20:56 -0700208endif
Vladimir Chtchetkineba1f57f2010-07-27 14:14:15 -0700209
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100210include $(LOCAL_PATH)/Makefile.common
211
Raphael Mollcdbea232012-05-04 15:04:27 -0700212ifeq ($(HOST_OS),windows)
213 # on Windows, link the icon file as well into the executable
214 # unfortunately, our build system doesn't help us much, so we need
215 # to use some weird pathnames to make this work...
216
217 # Locate windres executable
218 WINDRES := windres
219 ifneq ($(USE_MINGW),)
220 # When building the Windows emulator under Linux, use the MinGW one
221 WINDRES := i586-mingw32msvc-windres
222 endif
223
224 # Usage: $(eval $(call insert-windows-icon))
225 define insert-windows-icon
226 LOCAL_PREBUILT_OBJ_FILES += images/emulator_icon.o
227 endef
228
229# This seems to be the only way to add an object file that was not generated from
230# a C/C++/Java source file to our build system. and very unfortunately,
231# $(TOPDIR)/$(LOCALPATH) will always be prepended to this value, which forces
232# us to put the object file in the source directory.
233$(LOCAL_PATH)/images/emulator_icon.o: $(LOCAL_PATH)/images/android_icon.rc
234 $(WINDRES) $< -I $(LOCAL_PATH)/images -o $@
235endif
236
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100237# We want to build all variants of the emulator binaries. This makes
238# it easier to catch target-specific regressions during emulator development.
239EMULATOR_TARGET_ARCH := arm
240include $(LOCAL_PATH)/Makefile.target
241
242EMULATOR_TARGET_ARCH := x86
243include $(LOCAL_PATH)/Makefile.target
Vladimir Chtchetkineba1f57f2010-07-27 14:14:15 -0700244
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700245EMULATOR_TARGET_ARCH := mips
246include $(LOCAL_PATH)/Makefile.target
247
Xavier Ducrohetfc8ed802011-02-09 18:04:23 -0800248##############################################################################
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100249##############################################################################
250###
David 'Digit' Turner2d238fd2011-03-25 10:34:47 +0100251### emulator: LAUNCHER FOR TARGET-SPECIFIC EMULATOR
252###
253###
254$(call start-emulator-program, emulator)
255
256LOCAL_SRC_FILES := android/main-emulator.c
257LOCAL_STATIC_LIBRARIES := emulator-common
258
Raphael Mollcdbea232012-05-04 15:04:27 -0700259ifeq ($(HOST_OS),windows)
260$(eval $(call insert-windows-icon))
261endif
262
David 'Digit' Turner2d238fd2011-03-25 10:34:47 +0100263$(call end-emulator-program)
264
265##############################################################################
266##############################################################################
267###
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100268### emulator-ui: UI FRONT-END PROGRAM
269###
270###
271$(call start-emulator-program, emulator-ui)
The Android Open Source Project8b23a6c2009-03-03 19:30:32 -0800272
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100273LOCAL_STATIC_LIBRARIES := \
274 emulator-common \
275 emulator-libui \
276 emulator-common \
Xavier Ducrohetfc8ed802011-02-09 18:04:23 -0800277
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100278LOCAL_CFLAGS += -DCONFIG_STANDALONE_UI=1
Xavier Ducrohetfc8ed802011-02-09 18:04:23 -0800279
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100280LOCAL_CFLAGS += $(EMULATOR_COMMON_CFLAGS) $(EMULATOR_LIBUI_CFLAGS)
281LOCAL_LDLIBS += $(EMULATOR_COMMON_LDLIBS) $(EMULATOR_LIBUI_LDLIBS)
Xavier Ducrohetfc8ed802011-02-09 18:04:23 -0800282
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100283LOCAL_SRC_FILES := \
284 android/cmdline-option.c \
285 android/config.c \
286 android/help.c \
287 android/looper-generic.c \
288 android/snapshot.c \
289 android/main-common.c \
290 android/main.c \
David 'Digit' Turnercb88e792011-08-26 01:35:14 +0200291 android/opengles.c \
David 'Digit' Turnerf816a752011-06-23 18:40:11 +0200292 android/utils/setenv.c \
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100293 vl-android-ui.c \
294 android/protocol/core-connection.c \
295 android/protocol/attach-ui-impl.c \
296 android/protocol/fb-updates-impl.c \
297 android/protocol/ui-commands-impl.c \
298 android/protocol/core-commands-proxy.c \
299 android/protocol/user-events-proxy.c \
Xavier Ducrohetfc8ed802011-02-09 18:04:23 -0800300
David 'Digit' Turner42fc4492011-06-29 13:16:16 +0200301$(call gen-hw-config-defs,android/main-common.c)
302
Xavier Ducrohetfc8ed802011-02-09 18:04:23 -0800303LOCAL_SRC_FILES += $(SDLMAIN_SOURCES)
304
Xavier Ducrohetfc8ed802011-02-09 18:04:23 -0800305LOCAL_STATIC_LIBRARIES += $(SDL_STATIC_LIBRARIES)
306
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100307$(call end-emulator-program)
Xavier Ducrohetfc8ed802011-02-09 18:04:23 -0800308
David 'Digit' Turneraff94b82011-02-07 18:10:54 +0100309## VOILA!!
David 'Digit' Turnerf59442f2010-10-08 16:22:10 +0200310
Bhanu Chetlapalli741dc132012-05-08 17:16:03 -0700311endif # TARGET_ARCH == arm || TARGET_ARCH == x86 || TARGET_ARCH == mips
Joe Onoratoedb86c32012-07-25 14:28:40 -0700312endif # BUILD_EMULATOR