2009-03-04 04:28:35 +01:00
|
|
|
LOCAL_PATH:= $(call my-dir)
|
|
|
|
include $(CLEAR_VARS)
|
|
|
|
|
|
|
|
LOCAL_SRC_FILES:= \
|
|
|
|
arch/$(TARGET_ARCH)/begin.S \
|
|
|
|
linker.c \
|
2010-12-16 19:52:02 +01:00
|
|
|
linker_environ.c \
|
2010-01-20 21:36:51 +01:00
|
|
|
linker_format.c \
|
2009-03-04 04:28:35 +01:00
|
|
|
rt.c \
|
|
|
|
dlfcn.c \
|
2011-07-17 21:32:43 +02:00
|
|
|
debugger.c
|
2009-03-04 04:28:35 +01:00
|
|
|
|
2009-11-06 02:36:37 +01:00
|
|
|
ifeq ($(TARGET_ARCH),sh)
|
|
|
|
# SH-4A series virtual address range from 0x00000000 to 0x7FFFFFFF.
|
|
|
|
LINKER_TEXT_BASE := 0x70000100
|
|
|
|
else
|
2010-01-25 19:24:50 +01:00
|
|
|
# This is aligned to 4K page boundary so that both GNU ld and gold work. Gold
|
2010-01-25 20:09:31 +01:00
|
|
|
# actually produces a correct binary with starting address 0xB0000100 but the
|
2010-01-25 19:24:50 +01:00
|
|
|
# extra objcopy step to rename symbols causes the resulting binary to be misaligned
|
|
|
|
# and unloadable. Increasing the alignment adds an extra 3840 bytes in padding
|
|
|
|
# but switching to gold saves about 1M of space.
|
|
|
|
LINKER_TEXT_BASE := 0xB0001000
|
2009-11-06 02:36:37 +01:00
|
|
|
endif
|
2009-03-04 04:28:35 +01:00
|
|
|
|
|
|
|
# The maximum size set aside for the linker, from
|
|
|
|
# LINKER_TEXT_BASE rounded down to a megabyte.
|
|
|
|
LINKER_AREA_SIZE := 0x01000000
|
|
|
|
|
|
|
|
LOCAL_LDFLAGS := -Wl,-Ttext,$(LINKER_TEXT_BASE)
|
|
|
|
|
|
|
|
LOCAL_CFLAGS += -DPRELINK
|
|
|
|
LOCAL_CFLAGS += -DLINKER_TEXT_BASE=$(LINKER_TEXT_BASE)
|
|
|
|
LOCAL_CFLAGS += -DLINKER_AREA_SIZE=$(LINKER_AREA_SIZE)
|
|
|
|
|
2010-01-20 21:36:51 +01:00
|
|
|
# Set LINKER_DEBUG to either 1 or 0
|
|
|
|
#
|
|
|
|
LOCAL_CFLAGS += -DLINKER_DEBUG=0
|
|
|
|
|
2009-03-04 04:28:35 +01:00
|
|
|
# we need to access the Bionic private header <bionic_tls.h>
|
2009-09-30 01:12:31 +02:00
|
|
|
# in the linker; duplicate the HAVE_ARM_TLS_REGISTER definition
|
|
|
|
# from the libc build
|
|
|
|
ifeq ($(TARGET_ARCH)-$(ARCH_ARM_HAVE_TLS_REGISTER),arm-true)
|
|
|
|
LOCAL_CFLAGS += -DHAVE_ARM_TLS_REGISTER
|
|
|
|
endif
|
2009-03-04 04:28:35 +01:00
|
|
|
LOCAL_CFLAGS += -I$(LOCAL_PATH)/../libc/private
|
|
|
|
|
|
|
|
ifeq ($(TARGET_ARCH),arm)
|
|
|
|
LOCAL_CFLAGS += -DANDROID_ARM_LINKER
|
|
|
|
else
|
|
|
|
ifeq ($(TARGET_ARCH),x86)
|
|
|
|
LOCAL_CFLAGS += -DANDROID_X86_LINKER
|
|
|
|
else
|
2009-11-06 02:36:37 +01:00
|
|
|
ifeq ($(TARGET_ARCH),sh)
|
|
|
|
LOCAL_CFLAGS += -DANDROID_SH_LINKER
|
|
|
|
else
|
|
|
|
$(error Unsupported TARGET_ARCH $(TARGET_ARCH))
|
|
|
|
endif
|
2009-03-04 04:28:35 +01:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
LOCAL_MODULE:= linker
|
|
|
|
|
2010-06-11 03:29:33 +02:00
|
|
|
LOCAL_STATIC_LIBRARIES := libc_nomalloc
|
2009-03-04 04:28:35 +01:00
|
|
|
|
|
|
|
#LOCAL_FORCE_STATIC_EXECUTABLE := true # not necessary when not including BUILD_EXECUTABLE
|
|
|
|
|
|
|
|
#
|
|
|
|
# include $(BUILD_EXECUTABLE)
|
|
|
|
#
|
|
|
|
# Instead of including $(BUILD_EXECUTABLE), we execute the steps to create an executable by
|
|
|
|
# hand, as we want to insert an extra step that is not supported by the build system, and
|
|
|
|
# is probably specific the linker only, so there's no need to modify the build system for
|
|
|
|
# the purpose.
|
|
|
|
|
|
|
|
LOCAL_MODULE_CLASS := EXECUTABLES
|
|
|
|
LOCAL_MODULE_SUFFIX := $(TARGET_EXECUTABLE_SUFFIX)
|
|
|
|
|
|
|
|
|
|
|
|
include $(BUILD_SYSTEM)/dynamic_binary.mk
|
|
|
|
|
|
|
|
$(linked_module): $(TARGET_CRTBEGIN_STATIC_O) $(all_objects) $(all_libraries) $(TARGET_CRTEND_O)
|
|
|
|
$(transform-o-to-static-executable)
|
|
|
|
@echo "target PrefixSymbols: $(PRIVATE_MODULE) ($@)"
|
|
|
|
$(hide) $(TARGET_OBJCOPY) --prefix-symbols=__dl_ $@
|
|
|
|
|
|
|
|
#
|
|
|
|
# end of BUILD_EXECUTABLE hack
|
|
|
|
#
|
|
|
|
|
|
|
|
# we don't want crtbegin.o (because we have begin.o), so unset it
|
|
|
|
# just for this module
|
|
|
|
$(LOCAL_BUILT_MODULE): TARGET_CRTBEGIN_STATIC_O :=
|
|
|
|
# This line is not strictly necessary because the dynamic linker is built
|
2010-12-16 19:52:02 +01:00
|
|
|
# as a static executable, but it won't hurt if in the future we start
|
2009-03-04 04:28:35 +01:00
|
|
|
# building the linker as a dynamic one.
|
|
|
|
$(LOCAL_BUILT_MODULE): TARGET_CRTBEGIN_DYNAMIC_O :=
|