aboutsummaryrefslogtreecommitdiffstats
path: root/Makefile.android
diff options
context:
space:
mode:
Diffstat (limited to 'Makefile.android')
-rw-r--r--Makefile.android190
1 files changed, 122 insertions, 68 deletions
diff --git a/Makefile.android b/Makefile.android
index a35a334..d51a6d2 100644
--- a/Makefile.android
+++ b/Makefile.android
@@ -9,12 +9,18 @@ CONFIG_DIRS := \
CONFIG_INCLUDES := $(CONFIG_DIRS:%=-I%)
-MY_CFLAGS := $(CONFIG_INCLUDES)
+MY_CFLAGS := $(CONFIG_INCLUDES)
+MY_LDFLAGS :=
+
# this is needed to build the emulator on 64-bit Linux systems
ifeq ($(HOST_OS),linux)
MY_CFLAGS += -Wa,--32
endif
+ifeq ($(HOST_OS),freebsd)
+ MY_CFLAGS += -Wa,--32 -I /usr/local/include
+endif
+
ifeq ($(HOST_OS),windows)
MY_CFLAGS += -D_WIN32 -mno-cygwin
# we need Win32 features that are available since Windows 2000 Professional/Server (NT 5.0)
@@ -44,8 +50,8 @@ endif
ifneq ($(combo_target)$(TARGET_SIMULATOR),HOST_true)
-my_32bit_cflags += -m32
-my_32bit_ldflags += -m32
+ MY_CFLAGS += -m32
+ MY_LDFLAGS += -m32
endif
include $(CLEAR_VARS)
@@ -58,8 +64,8 @@ include $(CLEAR_VARS)
#
LOCAL_NO_DEFAULT_COMPILER_FLAGS := true
LOCAL_CC := $(MY_CC)
-LOCAL_CFLAGS := $(my_32bit_cflags) $(MY_CFLAGS) $(LOCAL_CFLAGS)
-LOCAL_LDFLAGS := $(my_32bit_ldflags)
+LOCAL_CFLAGS := $(MY_CFLAGS) $(LOCAL_CFLAGS)
+LOCAL_LDFLAGS := $(MY_LDFLAGS)
LOCAL_SRC_FILES := dyngen.c
ifeq ($(HOST_OS),windows)
@@ -137,10 +143,9 @@ include $(CLEAR_VARS)
LOCAL_NO_DEFAULT_COMPILER_FLAGS := true
LOCAL_CC := $(MY_CC)
LOCAL_MODULE := emulator-arm
-LOCAL_LDFLAGS := $(my_32bit_ldflags)
+LOCAL_LDFLAGS := $(MY_LDFLAGS)
-LOCAL_CFLAGS := $(my_32bit_cflags) \
- -fno-PIC -fomit-frame-pointer -Wno-sign-compare
+LOCAL_CFLAGS := -fno-PIC -fomit-frame-pointer -Wno-sign-compare
LOCAL_CFLAGS := $(MY_CFLAGS) $(LOCAL_CFLAGS)
ifeq ($(HOST_OS),darwin)
@@ -188,6 +193,109 @@ include $(BUILD_HOST_STATIC_LIBRARY)
endif # BUILD_ARM_LIBRARY
##############################################################################
+# SDL-related definitions
+#
+
+SDL_CONFIG ?= prebuilt/$(HOST_PREBUILT_TAG)/sdl/bin/sdl-config
+SDL_CFLAGS := $(shell $(SDL_CONFIG) --cflags)
+
+# We need to filter out the _GNU_SOURCE variable because it breaks recent
+# releases of Cygwin when using the -mno-cygwin option. Moreover, we don't
+# need this macro at all to build the Android emulator.
+SDL_CFLAGS := $(filter-out -D_GNU_SOURCE=1,$(SDL_CFLAGS))
+SDL_LDLIBS := $(filter-out %.a %.lib,$(shell $(SDL_CONFIG) --static-libs))
+
+
+##############################################################################
+# determine audio sources, build the prebuilt audio-library if needed
+#
+
+# determine AUDIO sources based on current configuration
+#
+AUDIO_SOURCES := audio.c noaudio.c wavaudio.c sdlaudio.c wavcapture.c mixeng.c
+AUDIO_CFLAGS := -I$(LOCAL_PATH)/audio -DHAS_AUDIO
+AUDIO_LDLIBS :=
+
+ifeq ($(HOST_OS),darwin)
+ CONFIG_COREAUDIO ?= yes
+endif
+
+ifeq ($(HOST_OS),windows)
+ CONFIG_WINAUDIO ?= yes
+endif
+
+ifeq ($(HOST_OS),linux)
+ CONFIG_OSS ?= yes
+ CONFIG_ALSA ?= yes
+ CONFIG_ESD ?= yes
+endif
+
+ifeq ($(CONFIG_COREAUDIO),yes)
+ AUDIO_SOURCES += coreaudio.c
+ AUDIO_CFLAGS += -DCONFIG_COREAUDIO
+ AUDIO_LDLIBS += -Wl,-framework,CoreAudio
+endif
+
+ifeq ($(CONFIG_WINAUDIO),yes)
+ AUDIO_SOURCES += winaudio.c
+ AUDIO_CFLAGS += -DCONFIG_WINAUDIO
+endif
+
+ifeq ($(CONFIG_ALSA),yes)
+ AUDIO_SOURCES += alsaaudio.c audio_pt_int.c
+ AUDIO_CFLAGS += -DCONFIG_ALSA
+endif
+
+ifeq ($(CONFIG_ESD),yes)
+ AUDIO_SOURCES += esdaudio.c
+ AUDIO_CFLAGS += -DCONFIG_ESD
+endif
+
+ifeq ($(CONFIG_OSS),yes)
+ AUDIO_SOURCES += ossaudio.c
+ AUDIO_CFLAGS += -DCONFIG_OSS
+endif
+
+AUDIO_SOURCES := $(AUDIO_SOURCES:%=audio/%)
+
+# determine whether we're going to use the prebuilt
+# audio library (this is useful on Linux to avoid requiring
+# all sound-related development packages to be installed on
+# the build and developer machines.
+#
+QEMU_AUDIO_LIB :=
+
+ifneq ($(BUILD_STANDALONE_EMULATOR),true)
+ QEMU_AUDIO_LIB := $(wildcard \
+ prebuilt/$(HOST_PREBUILT_TAG)/emulator/libqemu-audio.a)
+endif
+
+ifeq ($(BUILD_QEMU_AUDIO_LIB),true)
+ include $(CLEAR_VARS)
+ LOCAL_NO_DEFAULT_COMPILER_FLAGS := true
+ LOCAL_CC := $(MY_CC)
+ LOCAL_MODULE := libqemu-audio
+ LOCAL_LDFLAGS := $(MY_LDFLAGS)
+
+ LOCAL_CFLAGS := -fno-PIC -fomit-frame-pointer -Wno-sign-compare \
+ -fno-strict-aliasing -g -W -Wall -Wno-unused-parameter \
+ -O2 \
+ -I$(LOCAL_PATH) \
+ -I$(LOCAL_PATH)/target-arm \
+ -I$(LOCAL_PATH)/fpu \
+
+ LOCAL_CFLAGS := $(MY_CFLAGS) $(LOCAL_CFLAGS) $(AUDIO_CFLAGS)
+
+ LOCAL_CFLAGS += $(SDL_CFLAGS)
+
+ LOCAL_SRC_FILES += $(AUDIO_SOURCES)
+
+ include $(BUILD_HOST_STATIC_LIBRARY)
+ QEMU_AUDIO_LIB := $(LOCAL_BUILT_MODULE)
+
+endif # !QEMU_AUDIO_LIB
+
+##############################################################################
# now build the emulator itself
#
include $(CLEAR_VARS)
@@ -196,13 +304,12 @@ LOCAL_NO_DEFAULT_COMPILER_FLAGS := true
LOCAL_CC := $(MY_CC)
LOCAL_MODULE := emulator
LOCAL_STATIC_LIBRARIES := $(EMULATOR_OP_LIBRARIES) emulator-arm
-LOCAL_LDFLAGS := $(my_32bit_ldflags)
+LOCAL_LDFLAGS := $(MY_LDFLAGS)
# don't remove the -fno-strict-aliasing, or you'll break things
# (e.g. slirp2/network support)
#
-LOCAL_CFLAGS := $(my_32bit_cflags) \
- -fno-PIC -fomit-frame-pointer -Wno-sign-compare \
+LOCAL_CFLAGS := -fno-PIC -fomit-frame-pointer -Wno-sign-compare \
-fno-strict-aliasing -g -W -Wall -Wno-unused-parameter
LOCAL_CFLAGS := $(MY_CFLAGS) $(LOCAL_CFLAGS)
@@ -282,57 +389,12 @@ LOCAL_CFLAGS += -I$(LOCAL_PATH)/telephony
# ./android-rebuild.sh
# distrib/update-audio.sh
#
-QEMU_AUDIO_LIB := $(wildcard \
- prebuilt/$(HOST_PREBUILT_TAG)/emulator/libqemu-audio.a)
-
ifeq ($(QEMU_AUDIO_LIB),)
- AUDIO_SOURCES := audio.c noaudio.c wavaudio.c sdlaudio.c wavcapture.c mixeng.c
-
- ifeq ($(HOST_OS),darwin)
- CONFIG_COREAUDIO ?= yes
- endif
-
- ifeq ($(HOST_OS),windows)
- CONFIG_WINAUDIO ?= yes
- endif
-
- ifeq ($(HOST_OS),linux)
- CONFIG_OSS ?= yes
- CONFIG_ALSA ?= yes
- CONFIG_ESD ?= yes
- endif
-
- ifeq ($(CONFIG_COREAUDIO),yes)
- AUDIO_SOURCES += coreaudio.c
- LOCAL_CFLAGS += -DCONFIG_COREAUDIO
- LOCAL_LDLIBS += -Wl,-framework,CoreAudio
- endif
-
- ifeq ($(CONFIG_WINAUDIO),yes)
- AUDIO_SOURCES += winaudio.c
- LOCAL_CFLAGS += -DCONFIG_WINAUDIO
- endif
-
- ifeq ($(CONFIG_ALSA),yes)
- AUDIO_SOURCES += alsaaudio.c audio_pt_int.c
- LOCAL_CFLAGS += -DCONFIG_ALSA
- endif
-
- ifeq ($(CONFIG_ESD),yes)
- AUDIO_SOURCES += esdaudio.c
- LOCAL_CFLAGS += -DCONFIG_ESD
- endif
-
- ifeq ($(CONFIG_OSS),yes)
- AUDIO_SOURCES += ossaudio.c
- LOCAL_CFLAGS += -DCONFIG_OSS
- endif
-
- LOCAL_SRC_FILES += $(AUDIO_SOURCES:%=audio/%)
+ LOCAL_SRC_FILES += $(AUDIO_SOURCES)
endif # !QEMU_AUDIO_LIB
-LOCAL_CFLAGS += -I$(LOCAL_PATH)/audio
-LOCAL_CFLAGS += -DHAS_AUDIO
+LOCAL_CFLAGS += $(AUDIO_CFLAGS)
+LOCAL_LDLIBS += $(AUDIO_LDLIBS)
# include emulated hardware source files
#
@@ -453,16 +515,8 @@ endif
# add SDL-specific flags
#
-SDL_CONFIG ?= prebuilt/$(HOST_PREBUILT_TAG)/sdl/bin/sdl-config
-SDL_CFLAGS := $(shell $(SDL_CONFIG) --cflags)
-
-# We need to filter out the _GNU_SOURCE variable because it breaks recent
-# releases of Cygwin when using the -mno-cygwin option. Moreover, we don't
-# need this macro at all to build the Android emulator.
-SDL_CFLAGS := $(filter-out -D_GNU_SOURCE=1,$(SDL_CFLAGS))
-
LOCAL_CFLAGS += $(SDL_CFLAGS)
-LOCAL_LDLIBS += $(filter-out %.a %.lib,$(shell $(SDL_CONFIG) --static-libs))
+LOCAL_LDLIBS += $(SDL_LDLIBS)
LOCAL_STATIC_LIBRARIES += libSDL libSDLmain
# on Windows, link the icon file as well into the executable