提交 01fb3741 编写于 作者: O ohair

6649270: Change by-default openjdk building in control/make/makefile to use open source tree

Summary: Change build rules to allow for openjdk builds by default when building the closed or production build.
Reviewed-by: xdono
上级 4f2eb7c5
...@@ -42,6 +42,17 @@ ifndef CONTROL_TOPDIR ...@@ -42,6 +42,17 @@ ifndef CONTROL_TOPDIR
fi) fi)
endif endif
# Openjdk sources (only used if SKIP_OPENJDK_BUILD!=true)
OPENJDK_SOURCETREE=$(TOPDIR)/openjdk
OPENJDK_BUILDDIR:=$(shell \
if [ -r $(OPENJDK_SOURCETREE)/control/make/Makefile ]; then \
echo "$(OPENJDK_SOURCETREE)/control/make"; \
elif [ -r $(OPENJDK_SOURCETREE)/Makefile ]; then \
echo "$(OPENJDK_SOURCETREE)"; \
else \
echo "."; \
fi)
ifndef JDK_TOPDIR ifndef JDK_TOPDIR
JDK_TOPDIR=$(TOPDIR)/jdk JDK_TOPDIR=$(TOPDIR)/jdk
endif endif
...@@ -81,12 +92,28 @@ include ./make/deploy-rules.gmk ...@@ -81,12 +92,28 @@ include ./make/deploy-rules.gmk
all:: setup build all:: setup build
setup: setup: openjdk_check
$(MKDIR) -p $(OUTPUTDIR)/j2sdk-image $(MKDIR) -p $(OUTPUTDIR)/j2sdk-image
$(MKDIR) -p $(ABS_OUTPUTDIR)/j2sdk-image $(MKDIR) -p $(ABS_OUTPUTDIR)/j2sdk-image
$(MKDIR) -p $(OUTPUTDIR)-fastdebug/j2sdk-image $(MKDIR) -p $(OUTPUTDIR)-fastdebug/j2sdk-image
$(MKDIR) -p $(ABS_OUTPUTDIR)-fastdebug/j2sdk-image $(MKDIR) -p $(ABS_OUTPUTDIR)-fastdebug/j2sdk-image
# Check on whether we really can build the openjdk, need source etc.
openjdk_check:
ifneq ($(SKIP_OPENJDK_BUILD), true)
@$(ECHO) " "
@$(ECHO) "================================================="
@if [ ! -r $(OPENJDK_BUILDDIR)/Makefile ] ; then \
$(ECHO) "ERROR: No openjdk source tree available at: $(OPENJDK_BUILDDIR)"; \
exit 1; \
else \
$(ECHO) "OpenJDK will be built after JDK is built"; \
$(ECHO) " OPENJDK_BUILDDIR=$(OPENJDK_BUILDDIR)"; \
fi
@$(ECHO) "================================================="
@$(ECHO) " "
endif
build:: sanity build:: sanity
clobber:: clobber::
...@@ -190,46 +217,64 @@ ifneq ($(SKIP_COMPARE_IMAGES), true) ...@@ -190,46 +217,64 @@ ifneq ($(SKIP_COMPARE_IMAGES), true)
all :: compare-image all :: compare-image
endif endif
ifeq ($(SKIP_OPENJDK_BUILD), false) ifneq ($(SKIP_OPENJDK_BUILD), true)
all :: openjdk_build
endif
# If we have bundle rules, we have a chance here to do a complete cycle
# build, of production and open build.
# FIXUP: We should create the openjdk source bundle and build that?
# But how do we reliable create or get at a formal openjdk source tree?
# The one we have needs to be trimmed of built bits and closed dirs.
# The repositories might not be available.
# The openjdk source bundle is probably not available.
ifneq ($(SKIP_OPENJDK_BUILD), true)
ifeq ($(BUILD_JDK), true) ifeq ($(BUILD_JDK), true)
ifeq ($(BUNDLE_RULES_AVAILABLE), true) ifeq ($(BUNDLE_RULES_AVAILABLE), true)
# If we have bundle rules, we have a chance here to do a complete cycle
# build, of closed and open build. OPENJDK_PLUGS=$(ABS_OUTPUTDIR)/$(OPENJDK_BINARY_PLUGS_INAME)
# FIXUP: We should create the openjdk source bundle and build that? OPENJDK_OUTPUTDIR=$(ABS_OUTPUTDIR)/open-output
ABS_OPENJDK_PLUGS=$(ABS_OUTPUTDIR)/$(OPENJDK_BINARY_PLUGS_INAME) OPENJDK_BUILD_NAME \
ABS_OPENJDK_OUTPUTDIR=$(ABS_OUTPUTDIR)/openjdk = openjdk-$(JDK_MINOR_VERSION)-$(BUILD_NUMBER)-$(PLATFORM)-$(ARCH)-$(BUNDLE_DATE)
OPENJDK_BUILD_NAME_PREFIX \ OPENJDK_BUILD_BINARY_ZIP=$(ABS_BIN_BUNDLEDIR)/$(OPENJDK_BUILD_NAME).zip
= $(J2SDK_NAME)-$(JDK_MKTG_UNDERSCORE_VERSION)-$(MILESTONE) BUILT_IMAGE=$(ABS_OUTPUTDIR)/j2sdk-image
OPENJDK_BUILD_NAME_SUFFIX \ ifeq ($(PLATFORM)$(ARCH_DATA_MODEL),solaris64)
= $(BUILD_NUMBER)-$(PLATFORM)-$(ARCH)-$(BUNDLE_DATE) OPENJDK_BOOTDIR=$(BOOTDIR)
OPENJDK_BUILD_NAME \ OPENJDK_IMPORTJDK=$(JDK_IMPORT_PATH)
= $(OPENJDK_BUILD_NAME_PREFIX)-openjdk-$(OPENJDK_BUILD_NAME_SUFFIX) else
OPENJDK_BUILD_BINARY_ZIP \ OPENJDK_BOOTDIR=$(BUILT_IMAGE)
= $(ABS_BIN_BUNDLEDIR)/$(OPENJDK_BUILD_NAME).zip OPENJDK_IMPORTJDK=$(BUILT_IMAGE)
all :: openjdk-build endif
openjdk-build:
openjdk_build:
@$(ECHO) " " @$(ECHO) " "
@$(ECHO) "=================================================" @$(ECHO) "================================================="
@$(ECHO) "Starting openjdk build" @$(ECHO) "Starting openjdk build"
@$(ECHO) " Using: ALT_JDK_DEVTOOLS_DIR=$(JDK_DEVTOOLS_DIR)"
@$(ECHO) "=================================================" @$(ECHO) "================================================="
@$(ECHO) " " @$(ECHO) " "
$(RM) -r $(ABS_OPENJDK_OUTPUTDIR) $(RM) -r $(OPENJDK_OUTPUTDIR)
$(MKDIR) -p $(ABS_OPENJDK_OUTPUTDIR) $(MKDIR) -p $(OPENJDK_OUTPUTDIR)
$(MAKE) OPENJDK=true \ ($(CD) $(OPENJDK_BUILDDIR) && $(MAKE) \
BUILD_LANGTOOLS=$(BUILD_LANGTOOLS) \ OPENJDK=true \
BUILD_CORBA=$(BUILD_CORBA) \ ALT_JDK_DEVTOOLS_DIR=$(JDK_DEVTOOLS_DIR) \
BUILD_JAXP=$(BUILD_JAXP) \ ALT_OUTPUTDIR=$(OPENJDK_OUTPUTDIR) \
BUILD_JAXWS=$(BUILD_JAXWS) \ ALT_BINARY_PLUGS_PATH=$(OPENJDK_PLUGS) \
BUILD_HOTSPOT=$(BUILD_HOTSPOT) \ ALT_BOOTDIR=$(OPENJDK_BOOTDIR) \
ALT_OUTPUTDIR=$(ABS_OPENJDK_OUTPUTDIR) \ ALT_JDK_IMPORT_PATH=$(OPENJDK_IMPORTJDK) \
ALT_BINARY_PLUGS_PATH=$(ABS_OUTPUTDIR)/$(OPENJDK_BINARY_PLUGS_INAME) \ product_build )
ALT_BOOTDIR=$(ABS_OUTPUTDIR)/j2sdk-image \
ALT_JDK_IMPORT_PATH=$(ABS_OUTPUTDIR)/j2sdk-image \
product_build
$(RM) $(OPENJDK_BUILD_BINARY_ZIP) $(RM) $(OPENJDK_BUILD_BINARY_ZIP)
( $(CD) $(ABS_OPENJDK_OUTPUTDIR)/j2sdk-image && \ ( $(CD) $(OPENJDK_OUTPUTDIR)/j2sdk-image && \
$(ZIPEXE) -q -r $(OPENJDK_BUILD_BINARY_ZIP) .) $(ZIPEXE) -q -r $(OPENJDK_BUILD_BINARY_ZIP) .)
$(RM) -r $(ABS_OPENJDK_OUTPUTDIR) $(RM) -r $(OPENJDK_OUTPUTDIR)
@$(ECHO) " "
@$(ECHO) "================================================="
@$(ECHO) "Finished openjdk build"
@$(ECHO) " Binary Bundle: $(OPENJDK_BUILD_BINARY_ZIP)"
@$(ECHO) "================================================="
@$(ECHO) " "
endif endif
endif endif
endif endif
...@@ -432,11 +477,11 @@ endif ...@@ -432,11 +477,11 @@ endif
# Cycle build. Build the jdk, use it to build the jdk again. # Cycle build. Build the jdk, use it to build the jdk again.
################################################################ ################################################################
ABS_BOOTJDK_OUTPUTDIR=$(ABS_OUTPUTDIR)/bootjdk ABS_BOOTDIR_OUTPUTDIR=$(ABS_OUTPUTDIR)/bootjdk
boot_cycle: boot_cycle:
$(MAKE) ALT_OUTPUTDIR=$(ABS_BOOTJDK_OUTPUTDIR) product_build $(MAKE) ALT_OUTPUTDIR=$(ABS_BOOTDIR_OUTPUTDIR) product_build
$(MAKE) ALT_BOOTDIR=$(ABS_BOOTJDK_OUTPUTDIR)/j2sdk-image product_build $(MAKE) ALT_BOOTDIR=$(ABS_BOOTDIR_OUTPUTDIR)/j2sdk-image product_build
################################################################ ################################################################
# JPRT rule to build # JPRT rule to build
......
...@@ -151,8 +151,6 @@ ifdef OPENJDK ...@@ -151,8 +151,6 @@ ifdef OPENJDK
else else
ifndef SKIP_OPENJDK_BUILD ifndef SKIP_OPENJDK_BUILD
SKIP_OPENJDK_BUILD = false SKIP_OPENJDK_BUILD = false
# FIXUP: until freetype fixed on linux and solaris rmi build fixed
SKIP_OPENJDK_BUILD = true
endif endif
endif endif
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册