X-Git-Url: https://git.saurik.com/apple/ld64.git/blobdiff_plain/2f2f92e40575142405a1caa9bcf847f7ad011c92..60ce07c1e7dbeedd94a57ba21c14ff07c4ada4db:/unit-tests/include/common.makefile diff --git a/unit-tests/include/common.makefile b/unit-tests/include/common.makefile old mode 100755 new mode 100644 index 70e05f8..642e491 --- a/unit-tests/include/common.makefile +++ b/unit-tests/include/common.makefile @@ -6,19 +6,40 @@ 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 = 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} + 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))" "" + # if run from Terminal inside unit-test directory RELEASEDIR=$(shell cd ../../../build/Release;pwd) - PATH := ${RELEASEDIR}:${MYDIR}:${PATH} - COMPILER_PATH := ${RELEASEDIR}:${MYDIR}:${COMPILER_PATH} + RELEASEADIR=$(shell cd ../../../build/Release-assert;pwd) + DEBUGDIR=$(shell cd ../../../build/Debug;pwd) + PATH := ${RELEASEADIR}:${RELEASEDIR}:${DEBUGDIR}:${MYDIR}:${PATH} + COMPILER_PATH := ${RELEASEADIR}:${RELEASEDIR}:${DEBUGDIR}:${MYDIR}:${COMPILER_PATH} + 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}: @@ -27,27 +48,36 @@ endif export PATH export COMPILER_PATH -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} +CC = cc -arch ${ARCH} ${SDKExtra} CCFLAGS = -Wall -std=c99 ASMFLAGS = -CXX = g++-4.0 -arch ${ARCH} +CXX = c++ -arch ${ARCH} ${SDKExtra} CXXFLAGS = -Wall ifeq ($(ARCH),armv6) - LDFLAGS := -syslibroot /Developer/SDKs/Purple + SDKExtra = -isysroot /Developer/SDKs/Extra + LDFLAGS := -syslibroot /Developer/SDKs/Extra + override FILEARCH = arm +else + FILEARCH = $(ARCH) +endif + +ifeq ($(ARCH),armv7) + SDKExtra = -isysroot /Developer/SDKs/Extra + LDFLAGS := -syslibroot /Developer/SDKs/Extra override FILEARCH = arm else FILEARCH = $(ARCH) endif ifeq ($(ARCH),thumb) - LDFLAGS := -syslibroot /Developer/SDKs/Purple + SDKExtra = -isysroot /Developer/SDKs/Extra + LDFLAGS := -syslibroot /Developer/SDKs/Extra CCFLAGS += -mthumb CXXFLAGS += -mthumb override ARCH = armv6 @@ -56,21 +86,34 @@ else FILEARCH = $(ARCH) endif +ifeq ($(ARCH),thumb2) + SDKExtra = -isysroot /Developer/SDKs/Extra + LDFLAGS := -syslibroot /Developer/SDKs/Extra + CCFLAGS += -mthumb + CXXFLAGS += -mthumb + override ARCH = armv7 + override FILEARCH = arm + CC = /Volumes/Leopard/Developer/Platforms/iPhoneOS.platform/usr/bin/gcc-4.2 -arch ${ARCH} +else + FILEARCH = $(ARCH) +endif + + 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