X-Git-Url: https://git.saurik.com/apple/ld64.git/blobdiff_plain/77cc3118ce7a3a70a0a7364d77ae1eb766a477e7..eaf282aaf65b222563e6b3db98e12d720fb161bf:/unit-tests/include/common.makefile diff --git a/unit-tests/include/common.makefile b/unit-tests/include/common.makefile index 70e05f8..f0cbbf1 100644 --- a/unit-tests/include/common.makefile +++ b/unit-tests/include/common.makefile @@ -6,19 +6,42 @@ SHELL = /bin/sh ARCH ?= $(shell arch) # set default to be all -VALID_ARCHS ?= "ppc ppc64 i386 x86_64 armv6" +VALID_ARCHS ?= "i386 x86_64 armv6" + MYDIR=$(shell cd ../../bin;pwd) +LD = ld +OBJECTDUMP = ObjectDump +MACHOCHECK = machocheck +OTOOL = xcrun otool +REBASE = rebase +DYLDINFO = dyldinfo -# if run within Xcode, add the just built tools to the command path ifdef BUILT_PRODUCTS_DIR + # if run within Xcode, add the just built tools to the command path PATH := ${BUILT_PRODUCTS_DIR}:${MYDIR}:${PATH} - COMPILER_PATH := ${BUILT_PRODUCTS_DIR}:${MYDIR}:${COMPILER_PATH} + COMPILER_PATH := ${BUILT_PRODUCTS_DIR}:${COMPILER_PATH} + LD_PATH = ${BUILT_PRODUCTS_DIR} + LD = ${BUILT_PRODUCTS_DIR}/ld + OBJECTDUMP = ${BUILT_PRODUCTS_DIR}/ObjectDump + MACHOCHECK = ${BUILT_PRODUCTS_DIR}/machocheck + REBASE = ${BUILT_PRODUCTS_DIR}/rebase + UNWINDDUMP = ${BUILT_PRODUCTS_DIR}/unwinddump + DYLDINFO = ${BUILT_PRODUCTS_DIR}/dyldinfo else ifneq "$(findstring /unit-tests/test-cases/, $(shell pwd))" "" - RELEASEDIR=$(shell cd ../../../build/Release;pwd) - PATH := ${RELEASEDIR}:${MYDIR}:${PATH} - COMPILER_PATH := ${RELEASEDIR}:${MYDIR}:${COMPILER_PATH} + # if run from Terminal inside unit-test directory + RELEASEADIR=$(shell cd ../../../build/Release-assert;pwd) + DEBUGDIR=$(shell cd ../../../build/Debug;pwd) + PATH := ${RELEASEADIR}:${RELEASEDIR}:${DEBUGDIR}:${MYDIR}:${PATH} + COMPILER_PATH := ${RELEASEADIR}:${RELEASEDIR}:${DEBUGDIR}:${COMPILER_PATH} + LD_PATH = ${DEBUGDIR} + LD = ${DEBUGDIR}/ld + OBJECTDUMP = ${DEBUGDIR}/ObjectDump + MACHOCHECK = ${DEBUGDIR}/machocheck + REBASE = ${DEBUGDIR}/rebase + UNWINDDUMP = ${DEBUGDIR}/unwinddump + DYLDINFO = ${DEBUGDIR}/dyldinfo else PATH := ${MYDIR}:${PATH}: COMPILER_PATH := ${MYDIR}:${COMPILER_PATH}: @@ -26,32 +49,91 @@ else endif export PATH export COMPILER_PATH +export GCC_EXEC_PREFIX=garbage -LD = ld -OBJECTDUMP = ObjectDump -MACHOCHECK = machocheck -OTOOL = otool +ifeq ($(ARCH),ppc) + SDKExtra = -isysroot /Developer/SDKs/MacOSX10.6.sdk +endif -CC = gcc-4.0 -arch ${ARCH} -CCFLAGS = -Wall -std=c99 +CC = $(shell xcrun -find clang) -arch ${ARCH} ${SDKExtra} -mmacosx-version-min=10.8 +CCFLAGS = -Wall ASMFLAGS = +VERSION_NEW_LINKEDIT = -mmacosx-version-min=10.6 +VERSION_OLD_LINKEDIT = -mmacosx-version-min=10.4 +LD_NEW_LINKEDIT = -macosx_version_min 10.6 + +CXX = $(shell xcrun -find clang++) -arch ${ARCH} ${SDKExtra} +CXXFLAGS = -Wall -stdlib=libc++ -CXX = g++-4.0 -arch ${ARCH} -CXXFLAGS = -Wall +IOS_SDK = $(shell xcodebuild -sdk iphoneos.internal -version Path 2>/dev/null) ifeq ($(ARCH),armv6) - LDFLAGS := -syslibroot /Developer/SDKs/Purple + LDFLAGS := -syslibroot $(IOS_SDK) override FILEARCH = arm + CC = $(shell xcrun -find clang) -arch ${ARCH} -ccc-install-dir ${LD_PATH} -miphoneos-version-min=5.0 -isysroot $(IOS_SDK) + CXX = $(shell xcrun -find clang++) -arch ${ARCH} -ccc-install-dir ${LD_PATH} -miphoneos-version-min=5.0 -isysroot $(IOS_SDK) + VERSION_NEW_LINKEDIT = -miphoneos-version-min=4.0 + VERSION_OLD_LINKEDIT = -miphoneos-version-min=3.0 + LD_SYSROOT = -syslibroot $(IOS_SDK) + LD_NEW_LINKEDIT = -ios_version_min 4.0 +else + FILEARCH = $(ARCH) +endif + +ifeq ($(ARCH),armv7) + LDFLAGS := -syslibroot $(IOS_SDK) + override FILEARCH = arm + CC = $(shell xcrun -find clang) -arch ${ARCH} -ccc-install-dir ${LD_PATH} -miphoneos-version-min=5.0 -isysroot $(IOS_SDK) + CXX = $(shell xcrun -find clang++) -arch ${ARCH} -ccc-install-dir ${LD_PATH} -miphoneos-version-min=5.0 -isysroot $(IOS_SDK) + VERSION_NEW_LINKEDIT = -miphoneos-version-min=4.0 + VERSION_OLD_LINKEDIT = -miphoneos-version-min=3.0 + LD_SYSROOT = -syslibroot $(IOS_SDK) + LD_NEW_LINKEDIT = -ios_version_min 4.0 else FILEARCH = $(ARCH) endif ifeq ($(ARCH),thumb) - LDFLAGS := -syslibroot /Developer/SDKs/Purple + LDFLAGS := -syslibroot $(IOS_SDK) CCFLAGS += -mthumb CXXFLAGS += -mthumb override ARCH = armv6 override FILEARCH = arm + CC = $(shell xcrun -find clang) -arch ${ARCH} -ccc-install-dir ${LD_PATH} -miphoneos-version-min=5.0 -isysroot $(IOS_SDK) + CXX = $(shell xcrun -find clang++) -arch ${ARCH} -ccc-install-dir ${LD_PATH} -miphoneos-version-min=5.0 -isysroot $(IOS_SDK) + VERSION_NEW_LINKEDIT = -miphoneos-version-min=4.0 + VERSION_OLD_LINKEDIT = -miphoneos-version-min=3.0 + LD_SYSROOT = -syslibroot $(IOS_SDK) + LD_NEW_LINKEDIT = -ios_version_min 4.0 +else + FILEARCH = $(ARCH) +endif + +ifeq ($(ARCH),thumb2) + LDFLAGS := -syslibroot $(IOS_SDK) + CCFLAGS += -mthumb + CXXFLAGS += -mthumb + override ARCH = armv7 + override FILEARCH = arm + CC = $(shell xcrun -find clang) -arch ${ARCH} -ccc-install-dir ${LD_PATH} -miphoneos-version-min=5.0 -isysroot $(IOS_SDK) + CXX = $(shell xcrun -find clang++) -arch ${ARCH} -ccc-install-dir ${LD_PATH} -miphoneos-version-min=5.0 -isysroot $(IOS_SDK) + VERSION_NEW_LINKEDIT = -miphoneos-version-min=4.0 + VERSION_OLD_LINKEDIT = -miphoneos-version-min=3.0 + LD_SYSROOT = -syslibroot $(IOS_SDK) + LD_NEW_LINKEDIT = -ios_version_min 4.0 +else + FILEARCH = $(ARCH) +endif + +ifeq ($(ARCH),arm64) + LDFLAGS := -syslibroot $(IOS_SDK) + CC = $(shell xcrun --sdk iphoneos.internal -find clang) -arch ${ARCH} -ccc-install-dir ${LD_PATH} -miphoneos-version-min=9.0 -isysroot $(IOS_SDK) + CXX = $(shell xcrun --sdk iphoneos.internal -find clang++) -arch ${ARCH} -ccc-install-dir ${LD_PATH} -miphoneos-version-min=9.0 -isysroot $(IOS_SDK) + VERSION_NEW_LINKEDIT = -miphoneos-version-min=7.0 + VERSION_OLD_LINKEDIT = -miphoneos-version-min=3.0 + LD_SYSROOT = -syslibroot $(IOS_SDK) + LD_NEW_LINKEDIT = -ios_version_min 7.0 + OTOOL = $(shell xcrun --sdk iphoneos.internal -find otool) else FILEARCH = $(ARCH) endif @@ -60,17 +142,17 @@ RM = rm RMFLAGS = -rf # utilites for Makefiles -PASS_IFF = pass-iff-exit-zero.pl +PASS_IFF = ${MYDIR}/pass-iff-exit-zero.pl PASS_IFF_SUCCESS = ${PASS_IFF} -PASS_IFF_EMPTY = pass-iff-no-stdin.pl -PASS_IFF_STDIN = pass-iff-stdin.pl -FAIL_IFF = fail-iff-exit-zero.pl +PASS_IFF_EMPTY = ${MYDIR}/pass-iff-no-stdin.pl +PASS_IFF_STDIN = ${MYDIR}/pass-iff-stdin.pl +FAIL_IFF = ${MYDIR}/fail-iff-exit-zero.pl FAIL_IFF_SUCCESS = ${FAIL_IFF} -PASS_IFF_ERROR = pass-iff-exit-non-zero.pl -FAIL_IF_ERROR = fail-if-exit-non-zero.pl -FAIL_IF_SUCCESS = fail-if-exit-zero.pl -FAIL_IF_EMPTY = fail-if-no-stdin.pl -FAIL_IF_STDIN = fail-if-stdin.pl +PASS_IFF_ERROR = ${MYDIR}/pass-iff-exit-non-zero.pl +FAIL_IF_ERROR = ${MYDIR}/fail-if-exit-non-zero.pl +FAIL_IF_SUCCESS = ${MYDIR}/fail-if-exit-zero.pl +FAIL_IF_EMPTY = ${MYDIR}/fail-if-no-stdin.pl +FAIL_IF_STDIN = ${MYDIR}/fail-if-stdin.pl PASS_IFF_GOOD_MACHO = ${PASS_IFF} ${MACHOCHECK} FAIL_IF_BAD_MACHO = ${FAIL_IF_ERROR} ${MACHOCHECK} FAIL_IF_BAD_OBJ = ${FAIL_IF_ERROR} ${OBJECTDUMP} >/dev/null