diff -r fd16c54261b3 -r 489c9b5090e2 hotspot/build/windows/build.make --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hotspot/build/windows/build.make Sat Dec 01 00:00:00 2007 +0000 @@ -0,0 +1,309 @@ +# +# Copyright 1998-2007 Sun Microsystems, Inc. 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. +# +# 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, +# CA 95054 USA or visit www.sun.com if you need additional information or +# have any questions. +# +# + +# Note: this makefile is invoked both from build.bat and from the J2SE +# control workspace in exactly the same manner; the required +# environment variables (Variant, WorkSpace, BootStrapDir, BuildUser, HOTSPOT_BUILD_VERSION) +# are passed in as command line arguments. + +# SA components are built if BUILD_WIN_SA=1 is specified. +# See notes in README. This produces files: +# 1. sa-jdi.jar - This is built before building jvm.dll +# 2. sawindbg[_g].dll - Native library for SA - This is built after jvm.dll +# - Also, .lib, .map, .pdb. +# +# Please refer to ./makefiles/sa.make + +# If we haven't set an ARCH yet use x86 +# create.bat and build.bat will set it, if used. +!ifndef ARCH +ARCH=x86 +!endif + + +# Must be one of these values (if value comes in from env, can't trust it) +!if "$(ARCH)" != "x86" +!if "$(ARCH)" != "ia64" +ARCH=x86 +!endif +!endif + +# At this point we should be certain that ARCH has a definition +# now determine the BUILDARCH +# + +# the default BUILDARCH +BUILDARCH=i486 + +# Allow control workspace to force Itanium or AMD64 builds with LP64 +ARCH_TEXT= +!ifdef LP64 +!if "$(LP64)" == "1" +ARCH_TEXT=64-Bit +!if "$(ARCH)" == "x86" +BUILDARCH=amd64 +!else +BUILDARCH=ia64 +!endif +!endif +!endif + +!if "$(BUILDARCH)" != "amd64" +!if "$(BUILDARCH)" != "ia64" +!ifndef CC_INTERP +FORCE_TIERED=1 +!endif +!endif +!endif + +!if "$(BUILDARCH)" == "amd64" +Platform_arch=x86 +Platform_arch_model=x86_64 +!endif +!if "$(BUILDARCH)" == "i486" +Platform_arch=x86 +Platform_arch_model=x86_32 +!endif + +# Supply these from the command line or the environment +# It doesn't make sense to default this one +Variant= +# It doesn't make sense to default this one +WorkSpace= + +variantDir = windows_$(BUILDARCH)_$(Variant) + +realVariant=$(Variant) +VARIANT_TEXT=Core +!if "$(Variant)" == "compiler1" +VARIANT_TEXT=Client +!elseif "$(Variant)" == "compiler2" +!ifdef FORCE_TIERED +VARIANT_TEXT=Server +realVariant=tiered +!else +VARIANT_TEXT=Server +!endif +!elseif "$(Variant)" == "tiered" +VARIANT_TEXT=Tiered +!elseif "$(Variant)" == "kernel" +VARIANT_TEXT=Kernel +!endif + +######################################################################### +# Parameters for VERSIONINFO resource for jvm[_g].dll. +# These can be overridden via the nmake.exe command line. +# They are overridden by RE during the control builds. +# +!include "$(WorkSpace)/make/hotspot_version" + +# Define HOTSPOT_VM_DISTRO based on settings in build/hotspot_distro +# or build/closed/hotspot_distro. +!ifndef HOTSPOT_VM_DISTRO +!if exists($(WorkSpace)\build\closed) +!include $(WorkSpace)\build\closed\hotspot_distro +!else +!include $(WorkSpace)\build\hotspot_distro +!endif +!endif + +# Following the Web Start / Plugin model here.... +# We can have update versions like "01a", but Windows requires +# we use only integers in the file version field. So: +# JDK_UPDATE_VER = JDK_UPDATE_VERSION * 10 + EXCEPTION_VERSION +# +JDK_UPDATE_VER=0 +JDK_BUILD_NUMBER=0 + +HS_FILEDESC=$(HOTSPOT_VM_DISTRO) $(ARCH_TEXT) $(VARIANT_TEXT) VM + +# JDK ProductVersion: +# 1.5.0_-b will have DLL version 5.0.wx*10.yz +# Thus, 1.5.0_10-b04 will be 5.0.100.4 +# 1.6.0-b01 will be 6.0.0.1 +# 1.6.0_01a-b02 will be 6.0.11.2 +# +# JDK_* variables are defined in make/hotspot_version or on command line +# +JDK_VER=$(JDK_MINOR_VER),$(JDK_MICRO_VER),$(JDK_UPDATE_VER),$(JDK_BUILD_NUMBER) +JDK_DOTVER=$(JDK_MINOR_VER).$(JDK_MICRO_VER).$(JDK_UPDATE_VER).$(JDK_BUILD_NUMBER) +!if "$(JRE_RELEASE_VERSION)" == "" +JRE_RELEASE_VER=$(JDK_MAJOR_VER).$(JDK_MINOR_VER).$(JDK_MICRO_VER) +!else +JRE_RELEASE_VER=$(JRE_RELEASE_VERSION) +!endif +!if "$(JDK_MKTG_VERSION)" == "" +JDK_MKTG_VERSION=$(JDK_MINOR_VER).$(JDK_MICRO_VER) +!endif + +# Hotspot Express VM FileVersion: +# 10.0-b will have DLL version 10.0.0.yz (need 4 numbers). +# +# HS_* variables are defined in make/hotspot_version +# +HS_VER=$(HS_MAJOR_VER),$(HS_MINOR_VER),0,$(HS_BUILD_NUMBER) +HS_DOTVER=$(HS_MAJOR_VER).$(HS_MINOR_VER).0.$(HS_BUILD_NUMBER) + +!if "$(HOTSPOT_RELEASE_VERSION)" == "" +HOTSPOT_RELEASE_VERSION=$(HS_MAJOR_VER).$(HS_MINOR_VER)-b$(HS_BUILD_NUMBER) +!endif + +!if "$(HOTSPOT_BUILD_VERSION)" == "" +HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION) +!else +HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION)-$(HOTSPOT_BUILD_VERSION) +!endif + +# End VERSIONINFO parameters + + +# We don't support SA on ia64, and we can't +# build it if we are using a version of Vis Studio +# older than .Net 2003. +# SA_INCLUDE and SA_LIB are hold-overs from a previous +# implementation in which we could build SA using +# Debugging Tools For Windows, in which the .h/.lib files +# and the .dlls are in different places than +# they are for Vis Studio .Net 2003. +# If that code ever needs to be resurrected, these vars +# can be set here. They are used in makefiles/sa.make. + +checkSA:: + +!if "$(BUILD_WIN_SA)" != "1" +checkSA:: + @echo Not building SA: BUILD_WIN_SA != 1 + +!elseif "$(ARCH)" == "ia64" +BUILD_WIN_SA = 0 +checkSA:: + @echo Not building SA: ARCH = ia64 + +!elseif exist("$(MSVCDIR)\PlatformSDK\Include\dbgeng.h") +# These don't have to be set because the default +# setting of INCLUDE and LIB already contain the needed dirs. +SA_INCLUDE = +SA_LIB = + +!elseif exist("$(SYSTEMROOT)\..\Program Files\Microsoft SDK\include\dbgeng.h") +# These don't have to be set because the default +# setting of INCLUDE and LIB already contain the needed dirs. +SA_INCLUDE = +SA_LIB = + +!else +checkSA:: + @echo . + @echo ERROR: Can't build SA because dbgeng.h does not exist here: + @echo $(MSVCDIR)\PlatformSDK\Include\dbgeng.h + @echo nor here: + @echo $(SYSTEMROOT)\..\Program Files\Microsoft SDK\include\dbgeng.h + @echo You must use Vis. Studio .Net 2003 on Win 32, and you must + @echo have the Microsoft SDK installed on Win amd64. + @echo You can disable building of SA by specifying BUILD_WIN_SA = 0 + @echo . && false +!endif # ! "$(BUILD_WIN_SA)" != "1" + +######################################################################### + +# With the jvm_g.dll now being named jvm.dll, we can't build both and place +# the dll's in the same directory, so we only build one at a time, +# re-directing the output to different output directories (done by user +# of this makefile). +# +defaultTarget: product + +# The product or release build is an optimized build, and is the default + +# note that since all the build targets depend on local.make that BUILDARCH +# and Platform_arch and Platform_arch_model will get set in local.make +# and there is no need to pass them thru here on the command line +# +product release optimized: checks $(variantDir) $(variantDir)\local.make sanity + cd $(variantDir) + nmake -nologo -f $(WorkSpace)\build\windows\makefiles\top.make BUILD_FLAVOR=product ARCH=$(ARCH) + +# The debug or jvmg (all the same thing) is an optional build +debug jvmg: checks $(variantDir) $(variantDir)\local.make sanity + cd $(variantDir) + nmake -nologo -f $(WorkSpace)\build\windows\makefiles\top.make BUILD_FLAVOR=debug ARCH=$(ARCH) +fastdebug: checks $(variantDir) $(variantDir)\local.make sanity + cd $(variantDir) + nmake -nologo -f $(WorkSpace)\build\windows\makefiles\top.make BUILD_FLAVOR=fastdebug ARCH=$(ARCH) + +develop: checks $(variantDir) $(variantDir)\local.make sanity + cd $(variantDir) + nmake -nologo -f $(WorkSpace)\build\windows\makefiles\top.make BUILD_FLAVOR=product DEVELOP=1 ARCH=$(ARCH) + +sanity: + @ echo; + @ cd $(variantDir) + @ nmake -nologo -f $(WorkSpace)\build\windows\makefiles\sanity.make + @ cd .. + @ echo; + +clean: checkVariant + - rm -r -f $(variantDir) + +$(variantDir): + mkdir $(variantDir) + +$(variantDir)\local.make: checks + @ echo # Generated file > $@ + @ echo Variant=$(realVariant) >> $@ + @ echo WorkSpace=$(WorkSpace) >> $@ + @ echo BootStrapDir=$(BootStrapDir) >> $@ + @ if "$(USERNAME)" NEQ "" echo BuildUser=$(USERNAME) >> $@ + @ echo HS_VER=$(HS_VER) >> $@ + @ echo HS_DOTVER=$(HS_DOTVER) >> $@ + @ echo HS_COMPANY=$(COMPANY_NAME) >> $@ + @ echo HS_FILEDESC=$(HS_FILEDESC) >> $@ + @ echo HOTSPOT_VM_DISTRO=$(HOTSPOT_VM_DISTRO) >> $@ + @ echo HS_COPYRIGHT=$(HOTSPOT_VM_COPYRIGHT) >> $@ + @ echo HS_NAME=$(PRODUCT_NAME) $(JDK_MKTG_VERSION) >> $@ + @ echo HS_BUILD_VER=$(HS_BUILD_VER) >> $@ + @ echo BUILD_WIN_SA=$(BUILD_WIN_SA) >> $@ + @ echo SA_BUILD_VERSION=$(HS_BUILD_VER) >> $@ + @ echo SA_INCLUDE=$(SA_INCLUDE) >> $@ + @ echo SA_LIB=$(SA_LIB) >> $@ + @ echo JDK_VER=$(JDK_VER) >> $@ + @ echo JDK_DOTVER=$(JDK_DOTVER) >> $@ + @ echo JRE_RELEASE_VER=$(JRE_RELEASE_VER) >> $@ + @ echo BUILDARCH=$(BUILDARCH) >> $@ + @ echo Platform_arch=$(Platform_arch) >> $@ + @ echo Platform_arch_model=$(Platform_arch_model) >> $@ + @ sh $(WorkSpace)/build/windows/get_msc_ver.sh >> $@ + +checks: checkVariant checkWorkSpace checkSA + +checkVariant: + @ if "$(Variant)"=="" echo Need to specify "Variant=[tiered|compiler2|compiler1|kernel|core]" && false + @ if "$(Variant)" NEQ "tiered" if "$(Variant)" NEQ "compiler2" if "$(Variant)" NEQ "compiler1" if "$(Variant)" NEQ "kernel" if "$(Variant)" NEQ "core" \ + echo Need to specify "Variant=[tiered|compiler2|compiler1|kernel|core]" && false + +checkWorkSpace: + @ if "$(WorkSpace)"=="" echo Need to specify "WorkSpace=..." && false + +checkBuildID: + @ if "$(BuildID)"=="" echo Need to specify "BuildID=..." && false