d2b1e20c7d
Reviewed-by: dholmes
720 lines
25 KiB
Plaintext
720 lines
25 KiB
Plaintext
#
|
|
# Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved.
|
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
#
|
|
# This code is free software; you can redistribute it and/or modify it
|
|
# under the terms of the GNU General Public License version 2 only, as
|
|
# published by the Free Software Foundation. Oracle designates this
|
|
# particular file as subject to the "Classpath" exception as provided
|
|
# by Oracle in the LICENSE file that accompanied this code.
|
|
#
|
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
# version 2 for more details (a copy is included in the LICENSE file that
|
|
# accompanied this code).
|
|
#
|
|
# You should have received a copy of the GNU General Public License version
|
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
#
|
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
# or visit www.oracle.com if you need additional information or have any
|
|
# questions.
|
|
#
|
|
|
|
#
|
|
# Definitions for Windows.
|
|
#
|
|
|
|
# Default for COMPILER_WARNINGS_FATAL on Windows (C++ compiler warnings)
|
|
# Level: Default is 3, 0 means none, 4 is the most but may be unreliable
|
|
# Some makefiles may have set this to 0 to turn off warnings completely,
|
|
# which also effectively creates a COMPILER_WARNINGS_FATAL=false situation.
|
|
# Program.gmk may turn this down to 2 (building .exe's).
|
|
# Windows 64bit platforms are less likely to be warning free.
|
|
# Historically, Windows 32bit builds should be mostly warning free.
|
|
# VS2010 introduced a large number of security warnings that are off by
|
|
# default but will be turned back on with SHOW_ALL_WARNINGS=true.
|
|
ifndef COMPILER_WARNING_LEVEL
|
|
COMPILER_WARNING_LEVEL=3
|
|
endif
|
|
ifndef COMPILER_WARNINGS_FATAL
|
|
COMPILER_WARNINGS_FATAL=false
|
|
endif
|
|
ifndef SHOW_ALL_WARNINGS
|
|
SHOW_ALL_WARNINGS = false
|
|
endif
|
|
|
|
# Windows should use parallel compilation for best build times
|
|
ifndef COMPILE_APPROACH
|
|
COMPILE_APPROACH = normal
|
|
endif
|
|
|
|
# Indication that we are doing an incremental build.
|
|
# This may trigger the creation of make depend files.
|
|
# (This may not be working on windows yet, always force to false.)
|
|
override INCREMENTAL_BUILD = false
|
|
|
|
# WARNING: This is extremely touch stuff, between CYGWIN vs. MKS and all
|
|
# variations of MKS and CYGWIN releases, and 32bit vs 64bit,
|
|
# this file can give you nightmares.
|
|
#
|
|
# Notes:
|
|
# Keep all paths in the windows "mixed" style except CYGWIN UNXIXCOMMAND_PATH.
|
|
# Use of PrefixPath is critical, some variables must end with / (see NOTE).
|
|
# Use of quotes is critical due to possible spaces in paths coming from
|
|
# the environment variables, be careful.
|
|
# First convert \ to / with subst, keep it quoted due to blanks, then
|
|
# use cygpath -s or dosname -s to get the short non-blank name.
|
|
# If the MKS is old and doesn't have a dosname -s, you will be forced
|
|
# to set ALT variables with the short non-space directory names.
|
|
# If dosname doesn't appear to work, we won't use it.
|
|
# The dosname utility also wants to accept stdin if it is not supplied
|
|
# any path on the command line, this is really dangerous when using
|
|
# make variables that can easily become empty, so I use:
|
|
# echo $1 | dosname -s instead of dosname -s $1
|
|
# to prevent dosname from hanging up the make process when $1 is empty.
|
|
# The cygpath utility does not have this problem.
|
|
# The ALT values should never really have spaces or use \.
|
|
# Suspect these environment variables to have spaces and/or \ characters:
|
|
# SYSTEMROOT, SystemRoot, WINDIR, windir, PROGRAMFILES, ProgramFiles,
|
|
# DXSDK_DIR, MSTOOLS, Mstools, MSSDK, MSSdk, VCnnCOMNTOOLS,
|
|
# MSVCDIR, MSVCDir.
|
|
# So use $(subst \,/,) on them first adding quotes and placing them in
|
|
# their own variable assigned with :=, then use FullPath.
|
|
#
|
|
|
|
ifdef USING_CYGWIN
|
|
# Macro to effectively do a toupper without an exec
|
|
define ToUpper
|
|
$(subst a,A,$(subst b,B,$(subst c,C,$(subst d,D,$(subst e,E,$(subst f,F,\
|
|
$(subst g,G,$(subst h,H,$(subst i,I,$(subst j,J,$(subst k,K,$(subst l,L,\
|
|
$(subst m,M,$(subst n,N,$(subst o,O,$(subst p,P,$(subst q,Q,$(subst r,R,\
|
|
$(subst s,S,$(subst t,T,$(subst u,U,$(subst v,V,$(subst w,W,$(subst x,X,\
|
|
$(subst y,Y,$(subst z,Z,$1))))))))))))))))))))))))))
|
|
endef
|
|
# All possible drive letters
|
|
drives=a b c d e f g h i j k l m n o p q r s t v u w x y z
|
|
# Convert /cygdrive/ paths to the mixed style without an exec of cygpath
|
|
# Must be a path with no spaces. /cygdrive/letter is always lowercase
|
|
# and letter:/ is always uppercase coming from cygpath.
|
|
define MixedPath
|
|
$(patsubst /%,$(CYGWIN_HOME)/%,$(sort $(filter-out /cygdrive/%,$(foreach drive,$(drives),$(patsubst /cygdrive/$(drive)/%,$(call ToUpper,$(drive)):/%,$1)))))
|
|
endef
|
|
# Use FullPath to get C:/ style non-spaces path. Never ends with a /!
|
|
# We assume cygpath is available in the search path
|
|
# NOTE: Use of 'pwd' with CYGWIN will not get you a mixed style path!
|
|
define FullPath
|
|
$(if $(word 2,$1),$(shell $(CYGPATH_CMD) $1 2> $(DEV_NULL)),$(call MixedPath,$(realpath $(subst ",,$1))))
|
|
endef
|
|
define OptFullPath
|
|
$(shell if [ "$1" != "" -a -d "$1" ]; then $(CYGPATH_CMD) "$1" 2> $(DEV_NULL); else echo "$1"; fi)
|
|
endef
|
|
else
|
|
# Temporary until we upgrade to MKS 8.7, MKS pwd returns mixed mode path
|
|
define FullPath
|
|
$(shell cd $1 2> $(DEV_NULL) && pwd)
|
|
endef
|
|
define OptFullPath
|
|
$(shell if [ "$1" != "" -a -d "$1" ]; then (cd $1 && pwd); else echo "$1"; fi)
|
|
endef
|
|
endif
|
|
|
|
# System drive
|
|
ifdef SYSTEMDRIVE
|
|
_system_drive =$(SYSTEMDRIVE)
|
|
else
|
|
ifdef SystemDrive
|
|
_system_drive =$(SystemDrive)
|
|
endif
|
|
endif
|
|
_system_drive:=$(call CheckValue,_system_drive,C:)
|
|
|
|
# UNIXCOMMAND_PATH: path to where the most common Unix commands are.
|
|
# NOTE: Must end with / so that it could be empty, allowing PATH usage.
|
|
# With cygwin, just use this as is don't use FullPath on it.
|
|
ifdef ALT_UNIXCOMMAND_PATH
|
|
ifdef USING_CYGWIN
|
|
UNIXCOMMAND_PATH :=$(call PrefixPath,$(ALT_UNIXCOMMAND_PATH))
|
|
else
|
|
xALT_UNIXCOMMAND_PATH :="$(subst \,/,$(ALT_UNIXCOMMAND_PATH))"
|
|
fxALT_UNIXCOMMAND_PATH :=$(call FullPath,$(xALT_UNIXCOMMAND_PATH))
|
|
UNIXCOMMAND_PATH :=$(call PrefixPath,$(fxALT_UNIXCOMMAND_PATH))
|
|
endif
|
|
else
|
|
ifdef USING_CYGWIN
|
|
UNIXCOMMAND_PATH :=$(call PrefixPath,/usr/bin)
|
|
else
|
|
ifdef ROOTDIR
|
|
xROOTDIR :="$(subst \,/,$(ROOTDIR))"
|
|
_rootdir :=$(call FullPath,$(xROOTDIR))
|
|
else
|
|
xROOTDIR :="$(_system_drive)/mksnt"
|
|
_rootdir :=$(call FullPath,$(xROOTDIR))
|
|
endif
|
|
ifneq ($(_rootdir),)
|
|
UNIXCOMMAND_PATH :=$(call PrefixPath,$(_rootdir)/mksnt)
|
|
endif
|
|
endif
|
|
endif
|
|
UNIXCOMMAND_PATH:=$(call AltCheckSpaces,UNIXCOMMAND_PATH)
|
|
|
|
# Get version of MKS or CYGWIN
|
|
ifndef USING_CYGWIN
|
|
_MKS_VER :=$(shell $(MKSINFO) 2>&1 | $(GREP) Release | $(TAIL) -1 | $(SED) -e 's@.*\(Release.*\)@\1@')
|
|
MKS_VER :=$(call GetVersion,$(_MKS_VER))
|
|
# At this point, we can re-define FullPath to use DOSNAME_CMD
|
|
CHECK_MKS87:=$(call CheckVersions,$(MKS_VER),8.7)
|
|
TRY_DOSNAME:=false
|
|
ifeq ($(CHECK_MKS87),same)
|
|
TRY_DOSNAME:=true
|
|
endif
|
|
# Newer should be ok
|
|
ifeq ($(CHECK_MKS87),newer)
|
|
TRY_DOSNAME:=true
|
|
endif
|
|
ifeq ($(TRY_DOSNAME),true)
|
|
ifeq ($(shell $(UNIXCOMMAND_PATH)dosname -s $(_system_drive)/ 2> $(DEV_NULL)),$(_system_drive)/)
|
|
_DOSNAME=$(UNIXCOMMAND_PATH)dosname
|
|
DOSNAME_CMD:=$(_DOSNAME) -s
|
|
define FullPath
|
|
$(subst //,/,$(shell echo $1 | $(DOSNAME_CMD) 2> $(DEV_NULL)))
|
|
endef
|
|
endif # test dosname -s
|
|
endif # TRY_DOSNAME
|
|
endif # MKS
|
|
|
|
# We try to get references to what we need via the default component
|
|
# environment variables, or what was used historically.
|
|
|
|
# Process Windows values into FullPath values, these paths may have \ chars
|
|
|
|
# System root
|
|
ifdef SYSTEMROOT
|
|
xSYSTEMROOT :="$(subst \,/,$(SYSTEMROOT))"
|
|
_system_root :=$(call FullPath,$(xSYSTEMROOT))
|
|
else
|
|
ifdef SystemRoot
|
|
xSYSTEMROOT :="$(subst \,/,$(SystemRoot))"
|
|
_system_root :=$(call FullPath,$(xSYSTEMROOT))
|
|
else
|
|
ifdef WINDIR
|
|
xWINDIR :="$(subst \,/,$(WINDIR))"
|
|
_system_root :=$(call FullPath,$(xWINDIR))
|
|
else
|
|
ifdef windir
|
|
xWINDIR :="$(subst \,/,$(windir))"
|
|
_system_root :=$(call FullPath,$(xWINDIR))
|
|
endif
|
|
endif
|
|
endif
|
|
endif
|
|
_system_root:=$(call CheckValue,_system_root,$(_system_drive)/WINNT)
|
|
|
|
# Program Files directory
|
|
ifdef PROGRAMFILES
|
|
xPROGRAMFILES :="$(subst \,/,$(PROGRAMFILES))"
|
|
else
|
|
ifeq ($(ARCH_DATA_MODEL), 32)
|
|
xPROGRAMFILES :="$(_system_drive)/Program Files"
|
|
else
|
|
xPROGRAMFILES :="$(_system_drive)/Program Files (x86)"
|
|
endif
|
|
endif
|
|
ifeq ($(ARCH_DATA_MODEL), 32)
|
|
_program_files :=$(call FullPath,$(xPROGRAMFILES))
|
|
_program_files32 :=$(_program_files)
|
|
else
|
|
ifdef PROGRAMW6432
|
|
xPROGRAMW6432 :="$(subst \,/,$(PROGRAMW6432))"
|
|
else
|
|
xPROGRAMW6432 :="$(_system_drive)/Program Files"
|
|
endif
|
|
_program_files :=$(call FullPath,$(xPROGRAMW6432))
|
|
_program_files32 :=$(call FullPath,$(xPROGRAMFILES))
|
|
ifneq ($(word 1,$(_program_files32)),$(_program_files32))
|
|
_program_files32:=
|
|
endif
|
|
endif
|
|
ifneq ($(word 1,$(_program_files)),$(_program_files))
|
|
_program_files:=
|
|
endif
|
|
|
|
# DirectX SDK
|
|
ifdef ALT_DXSDK_DRIVE
|
|
_dx_sdk_dir =$(ALT_DXSDK_DRIVE):/DXSDK
|
|
else
|
|
ifdef DXSDK_DIR
|
|
xDXSDK_DIR :="$(subst \,/,$(DXSDK_DIR))"
|
|
else
|
|
xDXSDK_DIR :="$(_system_drive)/DXSDK"
|
|
endif
|
|
_dx_sdk_dir :=$(call FullPath,$(xDXSDK_DIR))
|
|
endif
|
|
|
|
# Use of the Visual Studio compilers requires certain env variables be set:
|
|
# PATH should include the path to cl.exe
|
|
# INCLUDE should be defined
|
|
# LIB should be defined
|
|
# LIBPATH should be defined
|
|
# VS100COMNTOOLS should be defined
|
|
# WINDOWSSDKDIR should be defined
|
|
# The 7.0a path is from VS2010 Pro, the 7.1 path is the standalone SDK.
|
|
# For 64bit either will work for us.
|
|
# If a developer chooses to install the standalone SDK in some other
|
|
# location, then they need to set WINDOWSSDKDIR.
|
|
#
|
|
# Compilers for 64bit may be from the free SDK, or Visual Studio Professional.
|
|
# The free Express compilers don't contain 64 bit compilers, which is why
|
|
# you instead need the SDK.
|
|
# Release enginering will use VS2010 Pro, so the frequency of testing of
|
|
# SDK based builds will depend entirely on individual usage.
|
|
|
|
# We only need to do this once
|
|
ifndef VS2010_EXISTS
|
|
# The 2 key paths we need are WINDOWSSDKDIR and VS100COMNTOOLS.
|
|
# If not defined try to see if default location exists.
|
|
# If defined make sure that the path has no spaces.
|
|
# Finally, export path with no spaces so logic minimizes FullPath calls.
|
|
ifndef WINDOWSSDKDIR
|
|
# The 7.0a SDK is the second choice.
|
|
xWINDOWSSDKDIR :="$(_program_files32)/Microsoft SDKs/Windows/v7.0a/"
|
|
fWINDOWSSDKDIR :=$(call FullPath,$(xWINDOWSSDKDIR))
|
|
# The 7.1 SDK is the second choice.
|
|
ifeq ($(fWINDOWSSDKDIR),)
|
|
xWINDOWSSDKDIR :="$(_program_files32)/Microsoft SDKs/Windows/v7.1/"
|
|
fWINDOWSSDKDIR :=$(call FullPath,$(xWINDOWSSDKDIR))
|
|
endif
|
|
else
|
|
ifneq ($(word 2,$(WINDOWSSDKDIR)),)
|
|
xWINDOWSSDKDIR :="$(subst \,/,$(WINDOWSSDKDIR))"
|
|
fWINDOWSSDKDIR :=$(call FullPath,$(xWINDOWSSDKDIR))
|
|
else
|
|
fWINDOWSSDKDIR :=$(WINDOWSSDKDIR)
|
|
endif
|
|
endif
|
|
ifneq ($(fWINDOWSSDKDIR),)
|
|
WINDOWSSDKDIR :=$(fWINDOWSSDKDIR)/
|
|
endif
|
|
ifndef VS100COMNTOOLS
|
|
xVS100COMNTOOLS :="$(_program_files32)/Microsoft Visual Studio 10.0/Common7/Tools/"
|
|
fVS100COMNTOOLS :=$(call FullPath,$(xVS100COMNTOOLS))
|
|
else
|
|
xVS100COMNTOOLS :="$(subst \,/,$(VS100COMNTOOLS))"
|
|
ifneq ($(word 2,$(VS100COMNTOOLS)),)
|
|
fVS100COMNTOOLS :=$(call FullPath,$(xVS100COMNTOOLS))
|
|
else
|
|
fVS100COMNTOOLS :=$(xVS100COMNTOOLS)
|
|
endif
|
|
endif
|
|
ifneq ($(fVS100COMNTOOLS),)
|
|
VS100COMNTOOLS :=$(fVS100COMNTOOLS)/
|
|
endif
|
|
# Check to see that both exist
|
|
ifeq ($(WINDOWSSDKDIR),)
|
|
_vs2010_message := No WINDOWSSDKDIR found on system. $(_vs2010_message)
|
|
VS2010_EXISTS := false
|
|
endif
|
|
ifeq ($(VS100COMNTOOLS),)
|
|
_vs2010_message := No VS100COMNTOOLS found on system. $(_vs2010_message)
|
|
VS2010_EXISTS := false
|
|
endif
|
|
ifeq ($(VS2010_EXISTS),false)
|
|
x:=$(warning WARNING: No VS2010 available. $(_vs2010_message))
|
|
VS100COMNTOOLS :=
|
|
WINDOWSSDKDIR :=
|
|
else
|
|
VS2010_EXISTS := true
|
|
_msvc_dir :=$(VS100COMNTOOLS)/../../Vc
|
|
endif
|
|
export VS2010_EXISTS
|
|
export VS100COMNTOOLS
|
|
export WINDOWSSDKDIR
|
|
endif
|
|
|
|
ifneq ($(VS2010_EXISTS),true)
|
|
x:=$(error ERROR: No VS2010 found on system.)
|
|
endif
|
|
|
|
# VS2010 Compiler root directory
|
|
_msvc_dir :=$(VS100COMNTOOLS)/../../Vc
|
|
# SDK root directory
|
|
_ms_sdk :=$(WINDOWSSDKDIR)
|
|
# Compiler bin directory and redist directory
|
|
ifeq ($(ARCH_DATA_MODEL), 32)
|
|
_compiler_bin :=$(_msvc_dir)/Bin
|
|
_redist_sdk :=$(call FullPath,$(_msvc_dir)/redist/x86/Microsoft.VC100.CRT)
|
|
endif
|
|
ifeq ($(ARCH_DATA_MODEL), 64)
|
|
_compiler_bin :=$(_msvc_dir)/bin/amd64
|
|
_redist_sdk :=$(call FullPath,$(_msvc_dir)/redist/x64/Microsoft.VC100.CRT)
|
|
endif
|
|
ifeq ($(_redist_sdk),)
|
|
_redist_sdk :=$(_system_root)/system32
|
|
endif
|
|
|
|
# Location on system where jdk installs might be
|
|
ifneq ($(_program_files),)
|
|
USRJDKINSTANCES_PATH =$(_program_files)/Java
|
|
else
|
|
USRJDKINSTANCES_PATH =$(_system_drive)/
|
|
endif
|
|
|
|
# SLASH_JAVA: location of all network accessable files
|
|
# NOTE: Do not use FullPath on this because it's often a drive letter and
|
|
# plain drive letters are ambiguous, so just use this 'as is'.
|
|
ifdef ALT_SLASH_JAVA
|
|
xALT_SLASH_JAVA :="$(subst \,/,$(ALT_SLASH_JAVA))"
|
|
SLASH_JAVA :=$(xALT_SLASH_JAVA)
|
|
else
|
|
ifdef ALT_JDK_JAVA_DRIVE
|
|
SLASH_JAVA =$(JDK_JAVA_DRIVE)
|
|
else
|
|
SLASH_JAVA =J:
|
|
endif
|
|
endif
|
|
SLASH_JAVA:=$(call AltCheckSpaces,SLASH_JAVA)
|
|
SLASH_JAVA:=$(call AltCheckValue,SLASH_JAVA)
|
|
|
|
# JDK_DEVTOOLS_DIR: common path for all the java devtools
|
|
ifdef ALT_JDK_DEVTOOLS_DIR
|
|
xALT_JDK_DEVTOOLS_DIR :="$(subst \,/,$(ALT_JDK_DEVTOOLS_DIR))"
|
|
JDK_DEVTOOLS_DIR :=$(call FullPath,$(xALT_JDK_DEVTOOLS_DIR))
|
|
else
|
|
JDK_DEVTOOLS_DIR =$(SLASH_JAVA)/devtools
|
|
endif
|
|
JDK_DEVTOOLS_DIR:=$(call AltCheckSpaces,JDK_DEVTOOLS_DIR)
|
|
JDK_DEVTOOLS_DIR:=$(call AltCheckValue,JDK_DEVTOOLS_DIR)
|
|
|
|
# COMPILER_PATH: path to where the compiler and tools are installed.
|
|
# NOTE: Must end with / so that it could be empty, allowing PATH usage.
|
|
ifdef ALT_COMPILER_PATH
|
|
xALT_COMPILER_PATH :="$(subst \,/,$(ALT_COMPILER_PATH))"
|
|
fxALT_COMPILER_PATH :=$(call FullPath,$(xALT_COMPILER_PATH))
|
|
COMPILER_PATH :=$(call PrefixPath,$(fxALT_COMPILER_PATH))
|
|
else
|
|
COMPILER_PATH :=$(call PrefixPath,$(_compiler_bin))
|
|
endif
|
|
COMPILER_PATH :=$(call AltCheckSpaces,COMPILER_PATH)
|
|
|
|
# MSDEVTOOLS_PATH: path to where the additional MS Compiler tools are.
|
|
# NOTE: Must end with / so that it could be empty, allowing PATH usage.
|
|
ifdef ALT_MSDEVTOOLS_PATH
|
|
xALT_MSDEVTOOLS_PATH :="$(subst \,/,$(ALT_MSDEVTOOLS_PATH))"
|
|
fxALT_MSDEVTOOLS_PATH :=$(call FullPath,$(xALT_MSDEVTOOLS_PATH))
|
|
MSDEVTOOLS_PATH :=$(call PrefixPath,$(fxALT_MSDEVTOOLS_PATH))
|
|
else
|
|
ifeq ($(ARCH_DATA_MODEL), 64)
|
|
ifdef MSTOOLS
|
|
xMSTOOLS :="$(subst \,/,$(MSTOOLS))"
|
|
_ms_tools :=$(call FullPath,$(xMSTOOLS))
|
|
else
|
|
ifdef Mstools
|
|
xMSTOOLS :="$(subst \,/,$(Mstools))"
|
|
_ms_tools :=$(call FullPath,$(xMSTOOLS))
|
|
else
|
|
_ms_tools :=
|
|
endif
|
|
endif
|
|
ifneq ($(_ms_tools),)
|
|
_ms_tools_bin :=$(_ms_tools)/Bin
|
|
else
|
|
# Assumes compiler bin is .../Bin/win64/x86/AMD64, rc.exe is 3 levels up
|
|
_ms_tools_bin :=$(_compiler_bin)/../../..
|
|
endif
|
|
else
|
|
_ms_tools_bin :=$(_compiler_bin)
|
|
endif
|
|
MSDEVTOOLS_PATH :=$(call PrefixPath,$(_ms_tools_bin))
|
|
endif
|
|
MSDEVTOOLS_PATH:=$(call AltCheckSpaces,MSDEVTOOLS_PATH)
|
|
|
|
# DEVTOOLS_PATH: for other tools required for building (such as zip, etc.)
|
|
# NOTE: Must end with / so that it could be empty, allowing PATH usage.
|
|
ifdef ALT_DEVTOOLS_PATH
|
|
xALT_DEVTOOLS_PATH :="$(subst \,/,$(ALT_DEVTOOLS_PATH))"
|
|
fxALT_DEVTOOLS_PATH :=$(call FullPath,$(xALT_DEVTOOLS_PATH))
|
|
DEVTOOLS_PATH :=$(call PrefixPath,$(fxALT_DEVTOOLS_PATH))
|
|
else
|
|
ifdef USING_CYGWIN
|
|
DEVTOOLS_PATH :=$(UNIXCOMMAND_PATH)
|
|
else
|
|
xDEVTOOLS_PATH :="$(_system_drive)/utils"
|
|
fxDEVTOOLS_PATH :=$(call FullPath,$(xDEVTOOLS_PATH))
|
|
DEVTOOLS_PATH :=$(call PrefixPath,$(fxDEVTOOLS_PATH))
|
|
endif
|
|
endif
|
|
DEVTOOLS_PATH:=$(call AltCheckSpaces,DEVTOOLS_PATH)
|
|
|
|
# _BOOTDIR1: First choice for a Bootstrap JDK, previous released JDK.
|
|
# _BOOTDIR2: Second choice
|
|
# The _BOOTDIR3 is defind optionally.
|
|
ifndef ALT_BOOTDIR
|
|
_BOOTDIR1 =$(_system_drive)/jdk$(PREVIOUS_JDK_VERSION)
|
|
_BOOTDIR2 =$(USRJDKINSTANCES_PATH)/jdk$(PREVIOUS_JDK_VERSION)
|
|
_BOOTDIR3 =$(SLASH_JAVA)/re/jdk/$(PREVIOUS_JDK_VERSION)/archive/fcs/binaries/$(PLATFORM)-$(ARCH)
|
|
endif
|
|
|
|
# Everybody needs the MSVCRNN runtime starting with VS2010
|
|
_NEEDS_MSVCRNN = true
|
|
|
|
ifeq ($(_NEEDS_MSVCRNN), true)
|
|
# MSVCRNN_DLL_PATH: location of msvcrnn.dll that will be re-distributed
|
|
ifdef ALT_MSVCRNN_DLL_PATH
|
|
xALT_MSVCRNN_DLL_PATH :="$(subst \,/,$(ALT_MSVCRNN_DLL_PATH))"
|
|
MSVCRNN_DLL_PATH :=$(call FullPath,$(xALT_MSVCRNN_DLL_PATH))
|
|
else
|
|
MSVCRNN_DLL_PATH :=$(_redist_sdk)
|
|
endif
|
|
MSVCRNN_DLL_PATH :=$(call AltCheckSpaces,MSVCRNN_DLL_PATH)
|
|
MSVCRNN_DLL_PATH:=$(call AltCheckValue,MSVCRNN_DLL_PATH)
|
|
endif
|
|
|
|
# DXSDK_PATH: path to Microsoft DirectX SDK Include and Lib
|
|
ifdef ALT_DXSDK_PATH
|
|
xALT_DXSDK_PATH :="$(subst \,/,$(ALT_DXSDK_PATH))"
|
|
DXSDK_PATH :=$(call FullPath,$(xALT_DXSDK_PATH))
|
|
else
|
|
_DXSDK_PATH1 :=$(_dx_sdk_dir)
|
|
_DXSDK_PATH2 :=$(JDK_DEVTOOLS_DIR)/windows/dxsdk
|
|
DXSDK_PATH :=$(call DirExists,$(_DXSDK_PATH1),$(_DXSDK_PATH2),$(_dx_sdk_dir))
|
|
endif
|
|
DXSDK_PATH :=$(call AltCheckSpaces,DXSDK_PATH)
|
|
DXSDK_PATH:=$(call AltCheckValue,DXSDK_PATH)
|
|
|
|
# DXSDK_INCLUDE_PATH: path to Microsoft DirectX SDK Include
|
|
ifdef ALT_DXSDK_INCLUDE_PATH
|
|
xALT_DXSDK_INCLUDE_PATH :="$(subst \,/,$(ALT_DXSDK_INCLUDE_PATH))"
|
|
DXSDK_INCLUDE_PATH :=$(call FullPath,$(xALT_DXSDK_INCLUDE_PATH))
|
|
else
|
|
DXSDK_INCLUDE_PATH =$(subst //,/,$(DXSDK_PATH)/Include)
|
|
endif
|
|
|
|
# DXSDK_LIB_PATH: path to Microsoft DirectX SDK Lib
|
|
ifdef ALT_DXSDK_LIB_PATH
|
|
xALT_DXSDK_LIB_PATH :="$(subst \,/,$(ALT_DXSDK_LIB_PATH))"
|
|
DXSDK_LIB_PATH :=$(call FullPath,$(xALT_DXSDK_LIB_PATH))
|
|
else
|
|
ifeq ($(ARCH_DATA_MODEL), 64)
|
|
# 64bit libs are located in "Lib/x64" subdir
|
|
DXSDK_LIB_PATH =$(subst //,/,$(DXSDK_PATH)/Lib/x64)
|
|
else
|
|
DXSDK_LIB_PATH =$(subst //,/,$(DXSDK_PATH)/Lib)
|
|
endif
|
|
endif
|
|
|
|
# DEPLOY_MSSDK: Microsoft SDK for this platform (for deploy)
|
|
ifdef ALT_DEPLOY_MSSDK
|
|
xALT_DEPLOY_MSSDK :="$(subst \,/,$(ALT_DEPLOY_MSSDK))"
|
|
DEPLOY_MSSDK :=$(call FullPath,$(xALT_DEPLOY_MSSDK))
|
|
else
|
|
DEPLOY_MSSDK :=$(_ms_sdk)
|
|
endif
|
|
DEPLOY_MSSDK:=$(call AltCheckSpaces,DEPLOY_MSSDK)
|
|
|
|
# INSTALL_MSSDK: Microsoft Installer SDK for this platform (for install)
|
|
ifdef ALT_INSTALL_MSSDK
|
|
xALT_INSTALL_MSSDK :="$(subst \,/,$(ALT_INSTALL_MSSDK))"
|
|
INSTALL_MSSDK :=$(call FullPath,$(xALT_INSTALL_MSSDK))
|
|
else
|
|
INSTALL_MSSDK :=$(_ms_sdk)
|
|
endif
|
|
INSTALL_MSSDK:=$(call AltCheckSpaces,INSTALL_MSSDK)
|
|
|
|
# WSCRIPT: path to wscript.exe (used in creating install bundles)
|
|
ifdef ALT_WSCRIPT
|
|
xALT_WSCRIPT :="$(subst \,/,$(ALT_WSCRIPT))"
|
|
WSCRIPT =$(xALT_WSCRIPT)
|
|
else
|
|
_WSCRIPT1 :=$(_system_root)/system32/wscript.exe
|
|
_WSCRIPT2 :=$(DEVTOOLS_PATH)wscript.exe
|
|
WSCRIPT :=$(call FileExists,$(_WSCRIPT1),$(_WSCRIPT2))
|
|
endif
|
|
WSCRIPT:=$(call AltCheckSpaces,WSCRIPT)
|
|
# batch mode no modal dialogs on errors, please.
|
|
WSCRIPT += -B
|
|
|
|
# CSCRIPT: path to cscript.exe (used in creating install bundles)
|
|
ifdef ALT_CSCRIPT
|
|
xALT_CSCRIPT :="$(subst \,/,$(ALT_CSCRIPT))"
|
|
CSCRIPT =$(xALT_CSCRIPT)
|
|
else
|
|
_CSCRIPT1 :=$(_system_root)/system32/cscript.exe
|
|
_CSCRIPT2 :=$(DEVTOOLS_PATH)cscript.exe
|
|
CSCRIPT :=$(call FileExists,$(_CSCRIPT1),$(_CSCRIPT2))
|
|
endif
|
|
CSCRIPT:=$(call AltCheckSpaces,CSCRIPT)
|
|
|
|
# CABARC: path to cabarc.exe (used in creating install bundles)
|
|
ifdef ALT_CABARC
|
|
xALT_CABARC :="$(subst \,/,$(ALT_CABARC))"
|
|
CABARC =$(xALT_CABARC)
|
|
else
|
|
_CABARC1 :=$(_system_root)/system32/cabarc.exe
|
|
_CABARC2 :=$(DEVTOOLS_PATH)cabarc.exe
|
|
CABARC :=$(call FileExists,$(_CABARC1),$(_CABARC2))
|
|
endif
|
|
CABARC:=$(call AltCheckSpaces,CABARC)
|
|
|
|
# MSICERT: path to msicert.exe (used in creating install bundles)
|
|
ifdef ALT_MSICERT
|
|
xALT_MSICERT :="$(subst \,/,$(ALT_MSICERT))"
|
|
MSICERT =$(xALT_MSICERT)
|
|
else
|
|
_MSICERT1 :=$(INSTALL_MSSDK)/Bin/msicert.exe
|
|
_MSICERT2 :=$(DEVTOOLS_PATH)msicert.exe
|
|
MSICERT :=$(call FileExists,$(_MSICERT1),$(_MSICERT2))
|
|
endif
|
|
MSICERT:=$(call AltCheckSpaces,MSICERT)
|
|
|
|
# Import JDK images allow for partial builds, components not built are
|
|
# imported (or copied from) these import areas when needed.
|
|
|
|
# BUILD_JDK_IMPORT_PATH: location of JDK install trees to import for
|
|
# multiple platforms, e.g. windows-i586, solaris-sparc, linux-586, etc.
|
|
ifdef ALT_BUILD_JDK_IMPORT_PATH
|
|
BUILD_JDK_IMPORT_PATH :=$(call FullPath,$(ALT_BUILD_JDK_IMPORT_PATH))
|
|
else
|
|
BUILD_JDK_IMPORT_PATH = $(PROMOTED_BUILD_BINARIES)
|
|
endif
|
|
BUILD_JDK_IMPORT_PATH:=$(call AltCheckSpaces,BUILD_JDK_IMPORT_PATH)
|
|
BUILD_JDK_IMPORT_PATH:=$(call AltCheckValue,BUILD_JDK_IMPORT_PATH)
|
|
|
|
# JDK_IMPORT_PATH: location of previously built JDK (this version) to import
|
|
ifdef ALT_JDK_IMPORT_PATH
|
|
JDK_IMPORT_PATH :=$(call FullPath,$(ALT_JDK_IMPORT_PATH))
|
|
else
|
|
JDK_IMPORT_PATH = $(BUILD_JDK_IMPORT_PATH)/$(PLATFORM)-$(ARCH)$(_JDK_IMPORT_VARIANT)
|
|
endif
|
|
JDK_IMPORT_PATH:=$(call AltCheckSpaces,JDK_IMPORT_PATH)
|
|
JDK_IMPORT_PATH:=$(call AltCheckValue,JDK_IMPORT_PATH)
|
|
|
|
# HOTSPOT_IMPORT_PATH: location of hotspot pre-built files
|
|
ifdef ALT_HOTSPOT_IMPORT_PATH
|
|
HOTSPOT_IMPORT_PATH :=$(call FullPath,$(ALT_HOTSPOT_IMPORT_PATH))
|
|
else
|
|
# Default locations include the current $OUTPUTDIR, RE Promotions,
|
|
# and a JDK. Please be aware the JDK does not include a Kernel VM.
|
|
_HOTSPOT_IMPORT_PATH1 = $(OUTPUTDIR)/hotspot/import
|
|
_HOTSPOT_IMPORT_PATH2 = $(PROMOTED_BUILD_DISTDIR)/hotspot/import
|
|
_HOTSPOT_IMPORT_PATH3 = $(JDK_IMPORT_PATH)
|
|
HOTSPOT_IMPORT_PATH := $(call DirExists,$(_HOTSPOT_IMPORT_PATH1),$(_HOTSPOT_IMPORT_PATH2),$(_HOTSPOT_IMPORT_PATH3))
|
|
endif
|
|
HOTSPOT_IMPORT_PATH:=$(call AltCheckSpaces,HOTSPOT_IMPORT_PATH)
|
|
HOTSPOT_IMPORT_PATH:=$(call AltCheckValue,HOTSPOT_IMPORT_PATH)
|
|
|
|
# HOTSPOT_CLIENT_PATH: location of client jvm library file.
|
|
ifeq ($(ARCH_DATA_MODEL), 32)
|
|
ifdef ALT_HOTSPOT_CLIENT_PATH
|
|
HOTSPOT_CLIENT_PATH :=$(call FullPath,$(ALT_HOTSPOT_CLIENT_PATH))
|
|
else
|
|
HOTSPOT_CLIENT_PATH =$(HOTSPOT_IMPORT_PATH)/$(ARCH_VM_SUBDIR)/client
|
|
endif
|
|
HOTSPOT_CLIENT_PATH:=$(call AltCheckSpaces,HOTSPOT_CLIENT_PATH)
|
|
HOTSPOT_CLIENT_PATH:=$(call AltCheckValue,HOTSPOT_CLIENT_PATH)
|
|
endif
|
|
|
|
# HOTSPOT_SERVER_PATH: location of server jvm library file.
|
|
ifdef ALT_HOTSPOT_SERVER_PATH
|
|
HOTSPOT_SERVER_PATH :=$(call FullPath,$(ALT_HOTSPOT_SERVER_PATH))
|
|
else
|
|
HOTSPOT_SERVER_PATH =$(HOTSPOT_IMPORT_PATH)/$(ARCH_VM_SUBDIR)/server
|
|
endif
|
|
HOTSPOT_SERVER_PATH:=$(call AltCheckSpaces,HOTSPOT_SERVER_PATH)
|
|
HOTSPOT_SERVER_PATH:=$(call AltCheckValue,HOTSPOT_SERVER_PATH)
|
|
|
|
# HOTSPOT_LIB_PATH: location of jvm.lib file.
|
|
ifdef ALT_HOTSPOT_LIB_PATH
|
|
xALT_HOTSPOT_LIB_PATH :="$(subst \,/,$(ALT_HOTSPOT_LIB_PATH))"
|
|
HOTSPOT_LIB_PATH :=$(call FullPath,$(xALT_HOTSPOT_LIB_PATH))
|
|
else
|
|
HOTSPOT_LIB_PATH =$(HOTSPOT_IMPORT_PATH)/lib
|
|
endif
|
|
HOTSPOT_LIB_PATH:=$(call AltCheckSpaces,HOTSPOT_LIB_PATH)
|
|
HOTSPOT_LIB_PATH:=$(call AltCheckValue,HOTSPOT_LIB_PATH)
|
|
|
|
# Special define for checking the binaries
|
|
|
|
# All windows dll and exe files should have been built with /NXCOMPAT
|
|
# and be setup for dynamic base addresses.
|
|
# In addition, we should not be dependent on certain dll files that
|
|
# we do not or cannot redistribute.
|
|
|
|
# List of filenames we should NOT be dependent on
|
|
ifeq ($(MFC_DEBUG),true)
|
|
BANNED_DLLS=msvcp100[.]dll
|
|
else
|
|
BANNED_DLLS=msvcp100[.]dll|msvcr100d[.]dll|msvcrtd[.]dll
|
|
endif
|
|
|
|
# Check for /safeseh (only used on 32bit)
|
|
define binary_file_safeseh_verification # binary_file
|
|
( \
|
|
$(ECHO) "Checking for /SAFESEH usage in: $1" && \
|
|
if [ "`$(DUMPBIN) /loadconfig $1 | $(EGREP) -i 'Safe Exception Handler Table'`" = "" ] ; then \
|
|
$(ECHO) "ERROR: Did not find 'Safe Exception Handler Table' in loadconfig: $1" ; \
|
|
$(DUMPBIN) /loadconfig $1 ; \
|
|
exit 6 ; \
|
|
fi ; \
|
|
)
|
|
endef
|
|
|
|
# Check for /NXCOMPAT usage
|
|
define binary_file_nxcompat_verification # binary_file
|
|
( \
|
|
$(ECHO) "Checking for /NXCOMPAT usage in: $1" && \
|
|
if [ "`$(DUMPBIN) /headers $1 | $(EGREP) -i 'NX compatible'`" = "" ] ; then \
|
|
$(ECHO) "ERROR: Did not find 'NX compatible' in headers: $1" ; \
|
|
$(DUMPBIN) /headers $1 ; \
|
|
exit 7 ; \
|
|
fi ; \
|
|
)
|
|
endef
|
|
|
|
# Check for /DYNAMICBASE usage
|
|
define binary_file_dynamicbase_verification # binary_file
|
|
( \
|
|
$(ECHO) "Checking for /DYNAMICBASE usage in: $1" && \
|
|
if [ "`$(DUMPBIN) /headers $1 | $(EGREP) -i 'Dynamic base'`" = "" ] ; then \
|
|
$(ECHO) "ERROR: Did not find 'Dynamic base' in headers: $1" ; \
|
|
$(DUMPBIN) /headers $1 ; \
|
|
exit 8 ; \
|
|
fi ; \
|
|
)
|
|
endef
|
|
|
|
# Check for banned dll usage
|
|
define binary_file_dll_verification # binary_file
|
|
( \
|
|
$(ECHO) "Checking for banned dependencies in: $1" && \
|
|
if [ "`$(DUMPBIN) /dependents $1 | $(EGREP) -i '$(BANNED_DLLS)'`" != "" ] ; then \
|
|
$(ECHO) "ERROR: Found use of $(BANNED_DLLS)"; \
|
|
$(DUMPBIN) /dependents $1 ; \
|
|
exit 9 ; \
|
|
fi ; \
|
|
)
|
|
endef
|
|
|
|
# Macro to check it's input file for properly built executables.
|
|
# Relies on process exit code. Different for 32bit vs 64bit.
|
|
ifeq ($(ARCH_DATA_MODEL),32)
|
|
define binary_file_verification # binary_file
|
|
( \
|
|
$(call binary_file_safeseh_verification,$1); \
|
|
$(call binary_file_nxcompat_verification,$1); \
|
|
$(call binary_file_dynamicbase_verification,$1); \
|
|
$(call binary_file_dll_verification,$1); \
|
|
)
|
|
endef
|
|
else
|
|
define binary_file_verification # binary_file
|
|
( \
|
|
$(call binary_file_nxcompat_verification,$1); \
|
|
$(call binary_file_dynamicbase_verification,$1); \
|
|
$(call binary_file_dll_verification,$1); \
|
|
)
|
|
endef
|
|
endif
|
|
|