Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8
提交
86e06fa9
D
dragonwell8
项目概览
openanolis
/
dragonwell8
通知
5
Star
3
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
86e06fa9
编写于
8月 06, 2008
作者:
O
ohair
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6728161: Add SKIP_BOOT_CYCLE feature to create boot jdk and use it during build
Reviewed-by: tbell
上级
310b6966
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
197 addition
and
105 deletion
+197
-105
Makefile
Makefile
+189
-100
make/Defs-internal.gmk
make/Defs-internal.gmk
+3
-0
make/jprt.config
make/jprt.config
+4
-4
make/jprt.gmk
make/jprt.gmk
+1
-1
未找到文件。
Makefile
浏览文件 @
86e06fa9
...
...
@@ -49,27 +49,17 @@ ifndef JDK_MAKE_SHARED_DIR
JDK_MAKE_SHARED_DIR
=
$(JDK_TOPDIR)
/make/common/shared
endif
include
$(JDK_MAKE_SHARED_DIR)/Defs-control.gmk
include
./make/Defs-internal.gmk
# For start and finish echo lines
TITLE_TEXT
=
Control
$(PLATFORM)
$(ARCH)
$(RELEASE)
DAYE_STAMP
=
`
$(DATE)
'+%y-%m-%d %H:%M'
`
START_ECHO
=
echo
"
$(TITLE_TEXT)
$@
build started:
$(DATE_STAMP)
"
FINISH_ECHO
=
echo
"
$(TITLE_TEXT)
$@
build finished:
$(DATE_STAMP)
"
all
::
@
$(ECHO)
$(PLATFORM)
$(ARCH)
$(RELEASE)
build started:
`
$(DATE)
'+%y-%m-%d %H:%M'
`
$(MKDIR)
-p
$(OUTPUTDIR)
default
:
all
# Rules for sanity checks
include
$(JDK_MAKE_SHARED_DIR)/Defs-control.gmk
include
./make/Defs-internal.gmk
include
./make/sanity-rules.gmk
dev
:
dev-build
dev-build
:
$(MAKE)
DEV_ONLY
=
true
all
dev-sanity
:
$(MAKE)
DEV_ONLY
=
true
sanity
dev-clobber
:
$(MAKE)
DEV_ONLY
=
true
clobber
# Rules for various components
include
./make/hotspot-rules.gmk
include
./make/langtools-rules.gmk
include
./make/corba-rules.gmk
...
...
@@ -80,68 +70,101 @@ include ./make/install-rules.gmk
include
./make/sponsors-rules.gmk
include
./make/deploy-rules.gmk
all
::
setup build
# What "all" means
all
::
@
$(START_ECHO)
setup
:
openjdk_check
$(MKDIR)
-p
$(OUTPUTDIR)
/j2sdk-image
all
::
openjdk_check sanity all_product_build
ifeq
($(SKIP_FASTDEBUG_BUILD), false)
all
::
fastdebug_build
endif
ifeq
($(SKIP_DEBUG_BUILD), false)
all
::
debug_build
endif
# Check on whether we really can build the openjdk, need source etc.
openjdk_check
:
FRC
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)
" "
all
::
openjdk_build
endif
build
::
sanity
all
::
@
$(FINISH_ECHO)
# Everything for a full product build
all_product_build
::
@
$(START_ECHO)
clobber
::
ifeq
($(SKIP_PRODUCT_BUILD), false)
all_product_build
::
product_build
ifeq
($(BUILD_INSTALL), true)
all_product_build
::
$(INSTALL)
clobber
::
install-clobber
endif
ifeq
($(BUILD_SPONSORS), true)
all_product_build
::
$(SPONSORS)
clobber
::
sponsors-clobber
endif
ifneq
($(SKIP_COMPARE_IMAGES), true)
all_product_build
::
compare-image
endif
endif
all_product_build
::
@
$(FINISH_ECHO)
# Generis build of basic repo series
generic_build_repo_series
::
$(MKDIR)
-p
$(OUTPUTDIR)
$(MKDIR)
-p
$(OUTPUTDIR)
/j2sdk-image
ifeq
($(BUILD_LANGTOOLS), true)
build
::
langtools
generic_build_repo_series
::
langtools
clobber
::
langtools-clobber
endif
ifeq
($(BUILD_CORBA), true)
build
::
corba
generic_build_repo_series
::
corba
clobber
::
corba-clobber
endif
ifeq
($(BUILD_JAXP), true)
build
::
jaxp
generic_build_repo_series
::
jaxp
clobber
::
jaxp-clobber
endif
ifeq
($(BUILD_JAXWS), true)
build
::
jaxws
generic_build_repo_series
::
jaxws
clobber
::
jaxws-clobber
endif
ifeq
($(BUILD_HOTSPOT), true)
build
::
$(HOTSPOT)
generic_build_repo_series
::
$(HOTSPOT)
clobber
::
hotspot-clobber
endif
ifeq
($(BUILD_JDK), true)
build
::
$(JDK_JAVA_EXE)
generic_build_repo_series
::
$(JDK_JAVA_EXE)
clobber
::
jdk-clobber
endif
ifeq
($(BUILD_DEPLOY), true)
build
::
$(DEPLOY)
generic_build_repo_series
::
$(DEPLOY)
clobber
::
deploy-clobber
endif
#
# Generic debug build, fastdebug or debug. Needs special handling.
ifeq
($(BUILD_JDK), true)
ifeq
($(BUNDLE_RULES_AVAILABLE), true)
generic_build_repo_series
::
openjdk-binary-plugs-bundles
endif
endif
# The debug build, fastdebug or debug. Needs special handling.
# Note that debug builds do NOT do INSTALL steps, but must be done
# after the product build and before the INSTALL step of the product build.
#
...
...
@@ -155,57 +178,109 @@ endif
# look for INSTALL_DEBUG_NAME in the install rules.
#
COMMON_DEBUG_FLAGS
=
\
DEBUG_NAME
=
$(DEBUG_NAME)
\
ALT_OUTPUTDIR
=
$(ABS_OUTPUTDIR)
-
$(DEBUG_NAME)
\
NO_DOCS
=
true
product_build
:
setup
@
$(ECHO)
$@
build started:
`
$(DATE)
'+%y-%m-%d %H:%M'
`
$(MAKE)
SKIP_FASTDEBUG_BUILD
=
true
SKIP_DEBUG_BUILD
=
true
all
@
$(ECHO)
$@
build finished:
`
$(DATE)
'+%y-%m-%d %H:%M'
`
generic_debug_build
:
@
$(ECHO)
$@
build started:
`
$(DATE)
'+%y-%m-%d %H:%M'
`
$(MAKE)
$(COMMON_DEBUG_FLAGS)
setup build
@
$(ECHO)
$@
build finished:
`
$(DATE)
'+%y-%m-%d %H:%M'
`
# Location of fresh bootdir output
ABS_BOOTDIR_OUTPUTDIR
=
$(ABS_OUTPUTDIR)
/bootjdk
FRESH_BOOTDIR
=
$(ABS_BOOTDIR_OUTPUTDIR)
/j2sdk-image
FRESH_DEBUG_BOOTDIR
=
$(ABS_BOOTDIR_OUTPUTDIR)
-
$(DEBUG_NAME)
/j2sdk-image
create_fresh_product_bootdir
:
FRC
@
$(START_ECHO)
$(MAKE)
ALT_OUTPUTDIR
=
$(ABS_BOOTDIR_OUTPUTDIR)
\
NO_DOCS
=
true
\
BOOT_CYCLE_SETTINGS
=
\
build_product_image
@
$(FINISH_ECHO)
create_fresh_debug_bootdir
:
FRC
@
$(START_ECHO)
$(MAKE)
ALT_OUTPUTDIR
=
$(ABS_BOOTDIR_OUTPUTDIR)
\
NO_DOCS
=
true
\
BOOT_CYCLE_DEBUG_SETTINGS
=
\
build_debug_image
@
$(FINISH_ECHO)
create_fresh_fastdebug_bootdir
:
FRC
@
$(START_ECHO)
$(MAKE)
ALT_OUTPUTDIR
=
$(ABS_BOOTDIR_OUTPUTDIR)
\
NO_DOCS
=
true
\
BOOT_CYCLE_DEBUG_SETTINGS
=
\
build_fastdebug_image
@
$(FINISH_ECHO)
# Create boot image?
ifeq
($(SKIP_BOOT_CYCLE),false)
ifneq
($(PLATFORM)$(ARCH_DATA_MODEL),solaris64)
DO_BOOT_CYCLE
=
true
endif
endif
debug_build
:
setup
$(MAKE)
DEBUG_NAME
=
debug generic_debug_build
ifeq
($(DO_BOOT_CYCLE),true)
# Create the bootdir to use in the build
product_build
::
create_fresh_product_bootdir
debug_build
::
create_fresh_debug_bootdir
fastdebug_build
::
create_fresh_fastdebug_bootdir
# Define variables to be used now for the boot jdk
BOOT_CYCLE_SETTINGS
=
\
ALT_BOOTDIR
=
$(FRESH_BOOTDIR)
\
ALT_JDK_IMPORT_PATH
=
$(FRESH_BOOTDIR)
BOOT_CYCLE_DEBUG_SETTINGS
=
\
ALT_BOOTDIR
=
$(FRESH_DEBUG_BOOTDIR)
\
ALT_JDK_IMPORT_PATH
=
$(FRESH_DEBUG_BOOTDIR)
fastdebug_build
:
setup
$(MAKE)
DEBUG_NAME
=
fastdebug generic_debug_build
else
ifeq
($(SKIP_FASTDEBUG_BUILD), false)
all
::
fastdebug_build
endif
# Use the supplied ALT_BOOTDIR as the boot
BOOT_CYCLE_SETTINGS
=
BOOT_CYCLE_DEBUG_SETTINGS
=
ifeq
($(SKIP_DEBUG_BUILD), false)
all
::
debug_build
endif
ifeq
($(BUILD_JDK), true)
ifeq
($(BUNDLE_RULES_AVAILABLE), true)
all
::
openjdk-binary-plugs-bundles
endif
endif
build_product_image
:
@
$(START_ECHO)
$(MAKE)
\
SKIP_FASTDEBUG_BUILD
=
true
\
SKIP_DEBUG_BUILD
=
true
\
$(BOOT_CYCLE_SETTINGS)
\
generic_build_repo_series
@
$(FINISH_ECHO)
ifeq
($(BUILD_INSTALL), true)
all
::
$(INSTALL)
clobber
::
install-clobber
endif
generic_debug_build
:
@
$(START_ECHO)
$(MAKE)
\
ALT_OUTPUTDIR
=
$(ABS_OUTPUTDIR)
-
$(DEBUG_NAME)
\
DEBUG_NAME
=
$(DEBUG_NAME)
\
NO_DOCS
=
true
\
$(BOOT_CYCLE_DEBUG_SETTINGS)
\
generic_build_repo_series
@
$(FINISH_ECHO)
build_debug_image
:
$(MAKE)
DEBUG_NAME
=
debug generic_debug_build
ifeq
($(BUILD_SPONSORS), true)
all
::
$(SPONSORS)
clobber
::
sponsors-clobber
endif
build_fastdebug_image
:
$(MAKE)
DEBUG_NAME
=
fastdebug generic_debug_build
ifneq
($(SKIP_COMPARE_IMAGES), true)
all
::
compare-image
endif
# Build final image
product_build
::
build_product_image
debug_build
::
build_debug_image
fastdebug_build
::
build_fastdebug_image
# Check on whether we really can build the openjdk, need source etc.
openjdk_check
:
FRC
ifneq
($(SKIP_OPENJDK_BUILD), true)
all
::
openjdk_build
@
$(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
# If we have bundle rules, we have a chance here to do a complete cycle
...
...
@@ -235,6 +310,7 @@ else
endif
openjdk_build
:
@
$(START_ECHO)
@
$(ECHO)
" "
@
$(ECHO)
"================================================="
@
$(ECHO)
"Starting openjdk build"
...
...
@@ -245,6 +321,7 @@ openjdk_build:
$(MKDIR)
-p
$(OPENJDK_OUTPUTDIR)
(
$(CD)
$(OPENJDK_BUILDDIR)
&&
$(MAKE)
\
OPENJDK
=
true
\
NO_DOCS
=
true
\
ALT_JDK_DEVTOOLS_DIR
=
$(JDK_DEVTOOLS_DIR)
\
ALT_OUTPUTDIR
=
$(OPENJDK_OUTPUTDIR)
\
ALT_BINARY_PLUGS_PATH
=
$(OPENJDK_PLUGS)
\
...
...
@@ -261,6 +338,7 @@ openjdk_build:
@
$(ECHO)
" Binary Bundle:
$(OPENJDK_BUILD_BINARY_ZIP)
"
@
$(ECHO)
"================================================="
@
$(ECHO)
" "
@
$(FINISH_ECHO)
endif
endif
...
...
@@ -274,8 +352,18 @@ clobber::
clean
:
clobber
all
::
@
$(ECHO)
Control build finished:
`
$(DATE)
'+%y-%m-%d %H:%M'
`
#
# Dev builds
#
dev
:
dev-build
dev-build
:
$(MAKE)
DEV_ONLY
=
true
all
dev-sanity
:
$(MAKE)
DEV_ONLY
=
true
sanity
dev-clobber
:
$(MAKE)
DEV_ONLY
=
true
clobber
#
# Quick jdk verification build
...
...
@@ -460,16 +548,6 @@ ifeq ($(BUNDLE_RULES_AVAILABLE), true)
include
$(BUNDLE_RULES)
endif
################################################################
# Cycle build. Build the jdk, use it to build the jdk again.
################################################################
ABS_BOOTDIR_OUTPUTDIR
=
$(ABS_OUTPUTDIR)
/bootjdk
boot_cycle
:
$(MAKE)
ALT_OUTPUTDIR
=
$(ABS_BOOTDIR_OUTPUTDIR)
product_build
$(MAKE)
ALT_BOOTDIR
=
$(ABS_BOOTDIR_OUTPUTDIR)
/j2sdk-image product_build
################################################################
# JPRT rule to build
################################################################
...
...
@@ -480,9 +558,20 @@ include ./make/jprt.gmk
# PHONY
################################################################
.PHONY
:
all build what clobber insane
\
fastdebug_build debug_build product_build setup
\
dev dev-build dev-sanity dev-clobber
.PHONY
:
all
\
generic_build_repo_series
\
what clobber insane
\
dev dev-build dev-sanity dev-clobber
\
product_build
\
fastdebug_build
\
debug_build
\
build_product_image
\
build_debug_image
\
build_fastdebug_image
\
create_fresh_product_bootdir
\
create_fresh_debug_bootdir
\
create_fresh_fastdebug_bootdir
\
generic_debug_build
# Force target
FRC
:
...
...
make/Defs-internal.gmk
浏览文件 @
86e06fa9
...
...
@@ -159,6 +159,9 @@ else
SKIP_OPENJDK_BUILD = true
endif
endif
ifndef SKIP_PRODUCT_BUILD
SKIP_PRODUCT_BUILD = false
endif
# Solaris 64 bit builds are not complete enough to ever do this
ifeq ($(PLATFORM)$(ARCH_DATA_MODEL),solaris64)
...
...
make/jprt.config
浏览文件 @
86e06fa9
...
...
@@ -115,13 +115,13 @@ dirMustExist "${jdk_import}" ALT_JDK_IMPORT_PATH
dirMustExist
"${ANT_HOME}"
ANT_HOME
dirMustExist
"${FINDBUGS_HOME}"
FINDBUGS_HOME
# If ALT_PREVIOUS_
JDK
_IMAGE not defined, set it to the bootdir area for
# If ALT_PREVIOUS_
RELEASE
_IMAGE not defined, set it to the bootdir area for
# any possible image comparisons.
# We assume bootdir is a previous jdk release image, valid for comparison
# reasons.
if
[
"${ALT_PREVIOUS_
JDK
_IMAGE}"
=
""
] ;
then
ALT_PREVIOUS_
JDK
_IMAGE
=
"${bootdir}"
export
ALT_PREVIOUS_
JDK
_IMAGE
if
[
"${ALT_PREVIOUS_
RELEASE
_IMAGE}"
=
""
] ;
then
ALT_PREVIOUS_
RELEASE
_IMAGE
=
"${bootdir}"
export
ALT_PREVIOUS_
RELEASE
_IMAGE
fi
# Use the JDK import for now (FIXME: use the binary plugs?)
...
...
make/jprt.gmk
浏览文件 @
86e06fa9
...
...
@@ -36,7 +36,7 @@ DEFAULT_BUILD_FLAVOR=product
JPRT_ARCHIVE_BUNDLE=$(ABS_OUTPUTDIR)/$(DEFAULT_BUILD_FLAVOR)-bundle.zip
JPRT_ARCHIVE_INSTALL_BUNDLE=$(ABS_OUTPUTDIR)/$(DEFAULT_BUILD_FLAVOR)-install-bundle.zip
jprt_build_product: product_build
jprt_build_product:
all_
product_build
( $(CD) $(OUTPUTDIR)/j2sdk-image && \
$(ZIPEXE) -q -r $(JPRT_ARCHIVE_BUNDLE) . )
ifdef HAVE_JPRT_SAVE_BUNDLES
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录