author | lana |
Thu, 08 Sep 2016 22:14:00 +0000 | |
changeset 40799 | f25e9a37e03f |
parent 39938 | 8d5f6d6b8a24 |
child 41171 | 407480ec6872 |
permissions | -rw-r--r-- |
14111 | 1 |
# |
35747 | 2 |
# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. |
14111 | 3 |
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
# |
|
5 |
# This code is free software; you can redistribute it and/or modify it |
|
6 |
# under the terms of the GNU General Public License version 2 only, as |
|
7 |
# published by the Free Software Foundation. Oracle designates this |
|
8 |
# particular file as subject to the "Classpath" exception as provided |
|
9 |
# by Oracle in the LICENSE file that accompanied this code. |
|
10 |
# |
|
11 |
# This code is distributed in the hope that it will be useful, but WITHOUT |
|
12 |
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
13 |
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
14 |
# version 2 for more details (a copy is included in the LICENSE file that |
|
15 |
# accompanied this code). |
|
16 |
# |
|
17 |
# You should have received a copy of the GNU General Public License version |
|
18 |
# 2 along with this work; if not, write to the Free Software Foundation, |
|
19 |
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
20 |
# |
|
21 |
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
|
22 |
# or visit www.oracle.com if you need additional information or have any |
|
23 |
# questions. |
|
24 |
# |
|
25 |
||
25854 | 26 |
################################################################################ |
27 |
# This is the main makefile containing most actual top level targets. It needs |
|
28 |
# to be called with a SPEC file defined. |
|
29662 | 29 |
################################################################################ |
25854 | 30 |
|
31 |
# Declare default target |
|
32 |
default: |
|
14111 | 33 |
|
29662 | 34 |
ifeq ($(wildcard $(SPEC)),) |
35 |
$(error Main.gmk needs SPEC set to a proper spec.gmk) |
|
36 |
endif |
|
37 |
||
14111 | 38 |
# Now load the spec |
39 |
include $(SPEC) |
|
40 |
||
29662 | 41 |
include $(SRC_ROOT)/make/MainSupport.gmk |
25854 | 42 |
|
20363 | 43 |
# Load the vital tools for all the makefiles. |
21759 | 44 |
include $(SRC_ROOT)/make/common/MakeBase.gmk |
26116
f051bd253364
8055095: Improve "do nothing" incremental build performance after modularized source code integration
erikj
parents:
26115
diff
changeset
|
45 |
include $(SRC_ROOT)/make/common/Modules.gmk |
14111 | 46 |
|
25854 | 47 |
# Declare ALL_TARGETS as an immediate variable. This variable is a list of all |
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
48 |
# valid top level targets. It's used to declare them all as PHONY and to |
25854 | 49 |
# generate the -only targets. |
50 |
ALL_TARGETS := |
|
51 |
||
22714
a752920c4317
8034191: Move relevant parts of build system to new closed repo
ihse
parents:
22031
diff
changeset
|
52 |
# Hook to include the corresponding custom file, if present. |
a752920c4317
8034191: Move relevant parts of build system to new closed repo
ihse
parents:
22031
diff
changeset
|
53 |
$(eval $(call IncludeCustomExtension, , Main.gmk)) |
14111 | 54 |
|
25854 | 55 |
# All modules for the current target platform. |
34116
b746e382da18
8142336: Convert the SA agent build to modular build-infra makefiles
erikj
parents:
33722
diff
changeset
|
56 |
ALL_MODULES := $(call FindAllModules) |
25854 | 57 |
|
58 |
################################################################################ |
|
59 |
################################################################################ |
|
60 |
# |
|
61 |
# Recipes for all targets. Only recipes, dependencies are declared later. |
|
62 |
# |
|
63 |
################################################################################ |
|
64 |
||
65 |
################################################################################ |
|
66 |
# Interim/build tools targets, compiling tools used during the build |
|
67 |
||
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
68 |
# When creating a BUILDJDK, the buildtools and interim targets have already |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
69 |
# been built and should not be built again. |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
70 |
ifneq ($(CREATING_BUILDJDK), true) |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
71 |
buildtools-langtools: |
27560 | 72 |
+($(CD) $(LANGTOOLS_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Tools.gmk) |
73 |
||
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
74 |
interim-langtools: |
25854 | 75 |
+($(CD) $(LANGTOOLS_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileInterim.gmk) |
76 |
||
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
77 |
interim-rmic: |
25854 | 78 |
+($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileInterimRmic.gmk) |
79 |
||
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
80 |
interim-cldrconverter: |
31948 | 81 |
+($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CopyInterimCLDRConverter.gmk) |
82 |
||
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
83 |
buildtools-jdk: |
35008 | 84 |
+($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileTools.gmk) |
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
85 |
endif |
25854 | 86 |
|
32806 | 87 |
ALL_TARGETS += buildtools-langtools interim-langtools \ |
31948 | 88 |
interim-rmic interim-cldrconverter buildtools-jdk |
25854 | 89 |
|
90 |
################################################################################ |
|
91 |
# Special targets for certain modules |
|
92 |
||
93 |
import-hotspot: |
|
94 |
+($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Import.gmk) |
|
14111 | 95 |
|
25854 | 96 |
unpack-sec: |
97 |
+($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f UnpackSecurity.gmk) |
|
98 |
||
33562
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
99 |
generate-exported-symbols: |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
100 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f BuildStatic.gmk) |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
101 |
|
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
102 |
ALL_TARGETS += import-hotspot unpack-sec generate-exported-symbols |
14111 | 103 |
|
25854 | 104 |
################################################################################ |
105 |
# Gensrc targets, generating source before java compilation can be done |
|
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
106 |
# |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
107 |
# When creating a BUILDJDK, the java targets have already been built and copied |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
108 |
# into the buildjdk so no need to generate sources. |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
109 |
ifneq ($(CREATING_BUILDJDK), true) |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
110 |
$(eval $(call DeclareRecipesForPhase, GENSRC, \ |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
111 |
TARGET_SUFFIX := gensrc, \ |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
112 |
FILE_PREFIX := Gensrc, \ |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
113 |
MAKE_SUBDIR := gensrc, \ |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
114 |
CHECK_MODULES := $(ALL_MODULES), \ |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
115 |
MULTIPLE_MAKEFILES := true)) |
14111 | 116 |
|
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
117 |
JDK_GENSRC_TARGETS := $(filter %-gensrc-jdk, $(GENSRC_TARGETS)) |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
118 |
LANGTOOLS_GENSRC_TARGETS := $(filter %-gensrc-langtools, $(GENSRC_TARGETS)) |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
119 |
CORBA_GENSRC_TARGETS := $(filter %-gensrc-corba, $(GENSRC_TARGETS)) |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
120 |
HOTSPOT_GENSRC_TARGETS := $(filter %-gensrc-hotspot, $(GENSRC_TARGETS)) |
15053
64278cb83950
8005549: build-infra: Merge NewMakefile.gmk and common/makefiles/Makefile
erikj
parents:
14466
diff
changeset
|
121 |
|
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
122 |
GENSRC_MODULEINFO_MODULES := $(ALL_MODULES) |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
123 |
GENSRC_MODULEINFO_TARGETS := $(addsuffix -gensrc-moduleinfo, \ |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
124 |
$(GENSRC_MODULEINFO_MODULES)) |
36506 | 125 |
|
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
126 |
GENSRC_MODULES := $(GENSRC_MODULEINFO_MODULES) |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
127 |
GENSRC_TARGETS += $(sort $(GENSRC_MODULEINFO_TARGETS) \ |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
128 |
$(addsuffix -gensrc, $(GENSRC_MODULES))) |
36506 | 129 |
|
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
130 |
define DeclareModuleInfoRecipe |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
131 |
$1-gensrc-moduleinfo: |
36506 | 132 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) \ |
133 |
-f GensrcModuleInfo.gmk MODULE=$1) |
|
134 |
||
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
135 |
$1-gensrc: $1-gensrc-moduleinfo |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
136 |
endef |
36506 | 137 |
|
38844
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
138 |
$(foreach m, $(GENSRC_MODULEINFO_MODULES), $(eval $(call DeclareModuleInfoRecipe,$m))) |
8af6df8a3613
8159047: Disable redundant build steps when creating buildjdk
erikj
parents:
38546
diff
changeset
|
139 |
endif |
36506 | 140 |
|
25854 | 141 |
ALL_TARGETS += $(GENSRC_TARGETS) |
142 |
||
143 |
################################################################################ |
|
144 |
# Generate data targets |
|
27560 | 145 |
$(eval $(call DeclareRecipesForPhase, GENDATA, \ |
146 |
TARGET_SUFFIX := gendata, \ |
|
147 |
FILE_PREFIX := Gendata, \ |
|
148 |
MAKE_SUBDIR := gendata, \ |
|
149 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
150 |
USE_WRAPPER := true)) |
|
25854 | 151 |
|
152 |
ALL_TARGETS += $(GENDATA_TARGETS) |
|
153 |
||
154 |
################################################################################ |
|
155 |
# Copy files targets |
|
27560 | 156 |
$(eval $(call DeclareRecipesForPhase, COPY, \ |
157 |
TARGET_SUFFIX := copy, \ |
|
158 |
FILE_PREFIX := Copy, \ |
|
159 |
MAKE_SUBDIR := copy, \ |
|
160 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
33045
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
161 |
USE_WRAPPER := true, \ |
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
162 |
MULTIPLE_MAKEFILES := true)) |
25854 | 163 |
|
36506 | 164 |
ALL_COPY_MODULES += $(COPY_MODULES) |
165 |
ALL_COPY_TARGETS += $(COPY_TARGETS) |
|
166 |
||
167 |
IMPORT_COPY_MODULES := $(call FindImportedModules) |
|
168 |
IMPORT_COPY_TARGETS := $(addsuffix -copy, $(IMPORT_COPY_MODULES)) |
|
169 |
ALL_COPY_MODULES += $(IMPORT_COPY_MODULES) |
|
170 |
ALL_COPY_TARGETS += $(IMPORT_COPY_TARGETS) |
|
171 |
||
172 |
define DeclareImportCopyRecipe |
|
173 |
$1-copy: |
|
174 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) \ |
|
175 |
-f CopyImportModules.gmk MODULE=$1) |
|
176 |
endef |
|
177 |
||
178 |
$(foreach m, $(IMPORT_COPY_MODULES), $(eval $(call DeclareImportCopyRecipe,$m))) |
|
179 |
||
180 |
ALL_TARGETS += $(ALL_COPY_TARGETS) |
|
15395
e5d837c6e999
8007093: build-infra: Make should fail if spec is older than configure files
erikj
parents:
15060
diff
changeset
|
181 |
|
25854 | 182 |
################################################################################ |
183 |
# Targets for compiling all java modules. Nashorn is treated separately. |
|
36506 | 184 |
JAVA_MODULES := $(ALL_MODULES) |
25854 | 185 |
JAVA_TARGETS := $(addsuffix -java, $(JAVA_MODULES)) |
14111 | 186 |
|
25854 | 187 |
define DeclareCompileJavaRecipe |
188 |
$1-java: |
|
34102
c0a98357f847
8143141: Bring in minor build changes from the jigsaw/jake forest
erikj
parents:
33722
diff
changeset
|
189 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) \ |
c0a98357f847
8143141: Bring in minor build changes from the jigsaw/jake forest
erikj
parents:
33722
diff
changeset
|
190 |
-f CompileJavaModules.gmk MODULE=$1) |
25854 | 191 |
endef |
192 |
||
193 |
$(foreach m, $(filter-out jdk.scripting.nashorn, $(JAVA_MODULES)), \ |
|
194 |
$(eval $(call DeclareCompileJavaRecipe,$m))) |
|
195 |
||
196 |
# Build nashorn. Needs to be compiled separately from the rest of the modules |
|
197 |
# due to nasgen. |
|
198 |
jdk.scripting.nashorn-java: |
|
34102
c0a98357f847
8143141: Bring in minor build changes from the jigsaw/jake forest
erikj
parents:
33722
diff
changeset
|
199 |
+($(CD) $(NASHORN_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) \ |
c0a98357f847
8143141: Bring in minor build changes from the jigsaw/jake forest
erikj
parents:
33722
diff
changeset
|
200 |
-f BuildNashorn.gmk compile) |
14111 | 201 |
|
25854 | 202 |
ALL_TARGETS += $(JAVA_TARGETS) |
203 |
||
204 |
################################################################################ |
|
205 |
# Targets for running rmic. |
|
27560 | 206 |
$(eval $(call DeclareRecipesForPhase, RMIC, \ |
207 |
TARGET_SUFFIX := rmic, \ |
|
208 |
FILE_PREFIX := Rmic, \ |
|
209 |
MAKE_SUBDIR := rmic, \ |
|
210 |
CHECK_MODULES := $(ALL_MODULES))) |
|
25854 | 211 |
|
212 |
ALL_TARGETS += $(RMIC_TARGETS) |
|
213 |
||
214 |
################################################################################ |
|
215 |
# Targets for compiling native libraries |
|
27560 | 216 |
$(eval $(call DeclareRecipesForPhase, LIBS, \ |
217 |
TARGET_SUFFIX := libs, \ |
|
218 |
FILE_PREFIX := Lib, \ |
|
219 |
MAKE_SUBDIR := lib, \ |
|
220 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
221 |
USE_WRAPPER := true)) |
|
14111 | 222 |
|
27560 | 223 |
ALL_TARGETS += $(LIBS_TARGETS) |
14111 | 224 |
|
25854 | 225 |
################################################################################ |
226 |
# Targets for compiling native executables |
|
27560 | 227 |
$(eval $(call DeclareRecipesForPhase, LAUNCHER, \ |
228 |
TARGET_SUFFIX := launchers, \ |
|
229 |
FILE_PREFIX := Launcher, \ |
|
230 |
MAKE_SUBDIR := launcher, \ |
|
231 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
232 |
USE_WRAPPER := true)) |
|
25854 | 233 |
|
234 |
ALL_TARGETS += $(LAUNCHER_TARGETS) |
|
235 |
||
236 |
################################################################################ |
|
237 |
# Build hotspot target |
|
14111 | 238 |
|
14378
0ef5d942b98e
8002028: build-infra: need no-hotspot partial build
tbell
parents:
14111
diff
changeset
|
239 |
ifeq ($(BUILD_HOTSPOT),true) |
37960 | 240 |
hotspot: |
241 |
+($(CD) $(HOTSPOT_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f BuildHotspot.gmk) |
|
14378
0ef5d942b98e
8002028: build-infra: need no-hotspot partial build
tbell
parents:
14111
diff
changeset
|
242 |
endif |
14111 | 243 |
|
37402 | 244 |
hotspot-ide-project: |
37960 | 245 |
+($(CD) $(HOTSPOT_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ide/CreateVSProject.gmk) |
37402 | 246 |
|
247 |
ALL_TARGETS += hotspot hotspot-ide-project |
|
15903 | 248 |
|
25854 | 249 |
################################################################################ |
250 |
# Build demos and samples targets |
|
14111 | 251 |
|
31310 | 252 |
demos-jdk: |
25854 | 253 |
+($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileDemos.gmk) |
14111 | 254 |
|
31310 | 255 |
samples-jdk: |
25854 | 256 |
+($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CopySamples.gmk) |
14111 | 257 |
|
31310 | 258 |
ALL_TARGETS += demos-jdk samples-jdk |
14111 | 259 |
|
25854 | 260 |
################################################################################ |
36506 | 261 |
# Jigsaw specific data and analysis targets. |
262 |
||
263 |
generate-summary: |
|
264 |
+($(CD) $(JDK_TOPDIR)/make && $(MAKE) -f GenerateModuleSummary.gmk) |
|
265 |
||
266 |
ALL_TARGETS += generate-summary |
|
267 |
||
268 |
################################################################################ |
|
269 |
# Strip binaries targets |
|
270 |
||
271 |
STRIP_MODULES := $(sort $(LIBS_MODULES) $(LAUNCHER_MODULES) $(COPY_MODULES) \ |
|
272 |
$(GENDATA_MODULES)) |
|
273 |
STRIP_TARGETS := $(addsuffix -strip, $(STRIP_MODULES)) |
|
274 |
||
275 |
define DeclareStripRecipe |
|
276 |
$1-strip: |
|
277 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f StripBinaries.gmk \ |
|
278 |
MODULE=$1) |
|
279 |
endef |
|
280 |
||
281 |
$(foreach m, $(STRIP_MODULES), $(eval $(call DeclareStripRecipe,$m))) |
|
282 |
||
283 |
ALL_TARGETS += $(STRIP_TARGETS) |
|
284 |
||
285 |
################################################################################ |
|
286 |
# Jmod targets |
|
287 |
||
288 |
JMOD_MODULES := $(ALL_MODULES) |
|
289 |
JMOD_TARGETS := $(addsuffix -jmod, $(JMOD_MODULES)) |
|
290 |
||
291 |
define DeclareJmodRecipe |
|
292 |
$1-jmod: |
|
293 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f CreateJmods.gmk \ |
|
294 |
MODULE=$1) |
|
295 |
endef |
|
296 |
||
297 |
$(foreach m, $(JMOD_MODULES), $(eval $(call DeclareJmodRecipe,$m))) |
|
298 |
||
299 |
ALL_TARGETS += $(JMOD_TARGETS) |
|
300 |
||
301 |
################################################################################ |
|
302 |
# Images targets |
|
14111 | 303 |
|
39110
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
304 |
# Stores the tips for each repository. This file is be used when constructing |
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
305 |
# the jdk image and can be used to track the exact sources used to build that |
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
306 |
# image. |
27560 | 307 |
source-tips: $(SUPPORT_OUTPUTDIR)/source_tips |
308 |
$(SUPPORT_OUTPUTDIR)/source_tips: FRC |
|
35008 | 309 |
$(call MakeDir, $(@D)) |
39110
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
310 |
$(call GetSourceTips) |
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
311 |
|
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
312 |
create-hgtip-files: |
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
313 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f CreateHgtipFiles.gmk) |
14111 | 314 |
|
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
315 |
BOOTCYCLE_TARGET := product-images |
25854 | 316 |
bootcycle-images: |
37980
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
317 |
ifneq ($(COMPILE_TYPE), cross) |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
318 |
$(call LogWarn, Boot cycle build step 2: Building a new JDK image using previously built image) |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
319 |
+$(MAKE) -f $(SRC_ROOT)/make/Init.gmk PARALLEL_TARGETS=$(BOOTCYCLE_TARGET) \ |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
320 |
JOBS= SPEC=$(dir $(SPEC))bootcycle-spec.gmk main |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
321 |
else |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
322 |
$(call LogWarn, Boot cycle build disabled when cross compiling) |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
323 |
endif |
27560 | 324 |
|
325 |
zip-security: |
|
326 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f ZipSecurity.gmk) |
|
327 |
||
328 |
zip-source: |
|
329 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f ZipSource.gmk) |
|
330 |
||
331 |
jrtfs-jar: |
|
332 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f JrtfsJar.gmk) |
|
333 |
||
334 |
jimages: |
|
335 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Images.gmk jimages) |
|
336 |
||
337 |
profiles: |
|
338 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Images.gmk profiles) |
|
339 |
||
31310 | 340 |
mac-bundles-jdk: |
27560 | 341 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f MacBundles.gmk) |
342 |
||
39110
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
343 |
ALL_TARGETS += source-tips create-hgtip-files bootcycle-images zip-security \ |
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
344 |
zip-source jrtfs-jar jimages profiles mac-bundles-jdk |
25854 | 345 |
|
346 |
################################################################################ |
|
347 |
# Docs targets |
|
348 |
||
349 |
docs-javadoc: |
|
350 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Javadoc.gmk docs) |
|
351 |
||
352 |
docs-jvmtidoc: |
|
353 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Javadoc.gmk jvmtidocs) |
|
354 |
||
37649
3809534d4531
8154841: Let different Jib profiles have different default make targets
erikj
parents:
37407
diff
changeset
|
355 |
zip-docs: |
37034
b63fd4af003e
8154313: Generated javadoc scattered all over the place
neugens
parents:
37031
diff
changeset
|
356 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Javadoc.gmk zip-docs) |
b63fd4af003e
8154313: Generated javadoc scattered all over the place
neugens
parents:
37031
diff
changeset
|
357 |
|
37649
3809534d4531
8154841: Let different Jib profiles have different default make targets
erikj
parents:
37407
diff
changeset
|
358 |
ALL_TARGETS += docs-javadoc docs-jvmtidoc zip-docs |
25854 | 359 |
|
360 |
################################################################################ |
|
36506 | 361 |
# Cross compilation support |
362 |
||
37770 | 363 |
ifeq ($(CREATING_BUILDJDK), true) |
36506 | 364 |
# This target is only called by the recursive call below. |
37770 | 365 |
create-buildjdk-interim-image-helper: interim-image jdk.jlink-launchers \ |
366 |
java.base-copy jdk.jdeps-launchers |
|
36506 | 367 |
endif |
368 |
||
369 |
create-buildjdk-copy: |
|
370 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f CreateBuildJdkCopy.gmk) |
|
371 |
||
37770 | 372 |
create-buildjdk-interim-image: |
36506 | 373 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Main.gmk \ |
374 |
$@-helper \ |
|
375 |
SPEC=$(dir $(SPEC))buildjdk-spec.gmk \ |
|
376 |
HOTSPOT_SPEC=$(dir $(SPEC))buildjdk-spec.gmk \ |
|
377 |
CREATING_BUILDJDK=true) |
|
378 |
||
37770 | 379 |
ALL_TARGETS += create-buildjdk-copy create-buildjdk-interim-image |
380 |
||
381 |
################################################################################ |
|
382 |
# The interim-image is a small jlinked image that is used to generate artifacts |
|
383 |
# at build time for use when linking the real images. |
|
384 |
||
385 |
interim-image: |
|
386 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f InterimImage.gmk) |
|
387 |
||
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
388 |
ifeq ($(ENABLE_GENERATE_CLASSLIST), true) |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
389 |
generate-classlist: |
37770 | 390 |
+($(CD) $(JDK_TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f GenerateClasslist.gmk) |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
391 |
endif |
37770 | 392 |
|
393 |
ALL_TARGETS += interim-image generate-classlist |
|
36506 | 394 |
|
395 |
################################################################################ |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
396 |
# Build tests |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
397 |
# |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
398 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
399 |
prepare-test-image: |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
400 |
$(MKDIR) -p $(TEST_IMAGE_DIR) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
401 |
$(ECHO) > $(TEST_IMAGE_DIR)/Readme.txt 'JDK test image' |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
402 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
403 |
build-test-hotspot-jtreg-native: |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
404 |
+($(CD) $(HOTSPOT_TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNative.gmk \ |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
405 |
build-test-hotspot-jtreg-native) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
406 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
407 |
test-image-hotspot-jtreg-native: |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
408 |
+($(CD) $(HOTSPOT_TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNative.gmk \ |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
409 |
test-image-hotspot-jtreg-native) |
25854 | 410 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
411 |
build-test-jdk-jtreg-native: |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
412 |
+($(CD) $(JDK_TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNative.gmk \ |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
413 |
build-test-jdk-jtreg-native) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
414 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
415 |
test-image-jdk-jtreg-native: |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
416 |
+($(CD) $(JDK_TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNative.gmk \ |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
417 |
test-image-jdk-jtreg-native) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
418 |
|
37967
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
419 |
ifeq ($(BUILD_GTEST), true) |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
420 |
test-image-hotspot-gtest: |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
421 |
+($(CD) $(HOTSPOT_TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f GtestImage.gmk) |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
422 |
endif |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
423 |
|
32562
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
424 |
build-test-lib: |
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
425 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f BuildTestLib.gmk) |
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
426 |
|
37035
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
427 |
ifeq ($(BUILD_FAILURE_HANDLER), true) |
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
428 |
# Builds the failure handler jtreg extension |
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
429 |
build-test-failure-handler: |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
430 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) \ |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
431 |
-f BuildFailureHandler.gmk build) |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
432 |
|
37035
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
433 |
# Runs the tests for the failure handler jtreg extension |
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
434 |
test-failure-handler: |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
435 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) \ |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
436 |
-f BuildFailureHandler.gmk test) |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
437 |
|
37035
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
438 |
# Copies the failure handler jtreg extension into the test image |
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
439 |
test-image-failure-handler: |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
440 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) \ |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
441 |
-f BuildFailureHandler.gmk images) |
37035
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
442 |
endif |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
443 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
444 |
ALL_TARGETS += prepare-test-image build-test-hotspot-jtreg-native \ |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
445 |
test-image-hotspot-jtreg-native build-test-jdk-jtreg-native \ |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
446 |
test-image-jdk-jtreg-native build-test-lib build-test-failure-handler \ |
37967
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
447 |
test-failure-handler test-image-failure-handler test-image-hotspot-gtest |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
448 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
449 |
################################################################################ |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
450 |
# Run tests |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
451 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
452 |
# Run tests specified by $(TEST), or the default test set. |
25854 | 453 |
test: |
37974 | 454 |
$(call RunTests, $(TEST), $(JDK_IMAGE_DIR)) |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
455 |
|
33566
fc0dc6b3c02d
8139271: Add top-level Makefile target to run hotspots jtreg tests
ehelin
parents:
33565
diff
changeset
|
456 |
test-hotspot-jtreg: |
37974 | 457 |
$(call RunTests, "hotspot_all", $(JDK_IMAGE_DIR)) |
33566
fc0dc6b3c02d
8139271: Add top-level Makefile target to run hotspots jtreg tests
ehelin
parents:
33565
diff
changeset
|
458 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
459 |
test-hotspot-jtreg-native: |
37974 | 460 |
$(call RunTests, "hotspot_native_sanity", $(JDK_IMAGE_DIR)) |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
461 |
|
33565
ac22b6bd7ecb
8139256: Add Makefile target to run internal VM tests
ehelin
parents:
33564
diff
changeset
|
462 |
test-hotspot-internal: |
37974 | 463 |
$(call RunTests, "hotspot_internal", $(JDK_OUTPUTDIR)) |
464 |
||
465 |
test-hotspot-gtest: |
|
466 |
$(call RunTests, "hotspot_gtest", $(JDK_OUTPUTDIR)) |
|
33565
ac22b6bd7ecb
8139256: Add Makefile target to run internal VM tests
ehelin
parents:
33564
diff
changeset
|
467 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
468 |
test-jdk-jtreg-native: |
37974 | 469 |
$(call RunTests, "jdk_native_sanity", $(JDK_IMAGE_DIR)) |
25854 | 470 |
|
471 |
test-make: |
|
472 |
($(CD) $(SRC_ROOT)/test/make && $(MAKE) $(MAKE_ARGS) -f TestMake.gmk $(TEST_TARGET)) |
|
473 |
||
33566
fc0dc6b3c02d
8139271: Add top-level Makefile target to run hotspots jtreg tests
ehelin
parents:
33565
diff
changeset
|
474 |
ALL_TARGETS += test test-hotspot-jtreg test-hotspot-jtreg-native \ |
37974 | 475 |
test-hotspot-internal test-hotspot-gtest test-jdk-jtreg-native test-make |
25854 | 476 |
|
477 |
################################################################################ |
|
37972 | 478 |
# Bundles |
479 |
||
480 |
product-bundles: |
|
481 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk product-bundles) |
|
482 |
||
483 |
test-bundles: |
|
484 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk test-bundles) |
|
485 |
||
486 |
docs-bundles: |
|
487 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk docs-bundles) |
|
488 |
||
489 |
ALL_TARGETS += product-bundles test-bundles docs-bundles |
|
490 |
||
491 |
################################################################################ |
|
25854 | 492 |
# Install targets |
493 |
||
494 |
install: |
|
495 |
+($(CD) $(SRC_ROOT)/make && $(MAKE) $(MAKE_ARGS) -f Install.gmk) |
|
496 |
||
497 |
ALL_TARGETS += install |
|
498 |
||
499 |
################################################################################ |
|
500 |
# |
|
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
501 |
# Dependency declarations between targets. |
25854 | 502 |
# |
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
503 |
# These are declared in two groups. First all dependencies between targets that |
25854 | 504 |
# have recipes above as these dependencies may be disabled. Then the aggregator |
505 |
# targets that do not have recipes of their own, which will never have their |
|
506 |
# dependencies disabled. |
|
507 |
# |
|
508 |
################################################################################ |
|
509 |
# Targets with recipes above |
|
510 |
||
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
511 |
# If running an *-only target, parallel execution and dependencies between |
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
512 |
# recipe targets are disabled. This makes it possible to run a select set of |
25854 | 513 |
# recipe targets in order. It's the responsibility of the user to make sure |
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
514 |
# all prerequisites are fulfilled. |
25854 | 515 |
ifneq ($(findstring -only, $(MAKECMDGOALS)), ) |
516 |
.NOTPARALLEL: |
|
517 |
else |
|
27560 | 518 |
$(LANGTOOLS_GENSRC_TARGETS): buildtools-langtools |
519 |
||
25854 | 520 |
interim-langtools: $(LANGTOOLS_GENSRC_TARGETS) |
521 |
||
31948 | 522 |
buildtools-jdk: interim-langtools interim-cldrconverter |
25854 | 523 |
|
524 |
$(CORBA_GENSRC_TARGETS): interim-langtools |
|
525 |
||
33045
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
526 |
$(HOTSPOT_GENSRC_TARGETS): interim-langtools |
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
527 |
|
27560 | 528 |
$(JDK_GENSRC_TARGETS): interim-langtools buildtools-jdk |
25854 | 529 |
|
36506 | 530 |
$(GENSRC_MODULEINFO_TARGETS): buildtools-jdk |
531 |
||
27560 | 532 |
$(GENDATA_TARGETS): interim-langtools buildtools-jdk |
25854 | 533 |
|
534 |
interim-rmic: interim-langtools |
|
535 |
||
32806 | 536 |
$(RMIC_TARGETS): interim-langtools interim-rmic |
25854 | 537 |
|
31310 | 538 |
$(JAVA_TARGETS): interim-langtools |
539 |
||
37402 | 540 |
hotspot-ide-project: hotspot exploded-image |
541 |
||
25854 | 542 |
import-hotspot: hotspot |
543 |
||
33562
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
544 |
generate-exported-symbols: java.base-libs jdk.jdwp.agent-libs |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
545 |
|
27560 | 546 |
$(LIBS_TARGETS): import-hotspot |
25854 | 547 |
|
548 |
$(LAUNCHER_TARGETS): java.base-libs |
|
549 |
||
33562
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
550 |
ifeq ($(STATIC_BUILD), true) |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
551 |
$(LAUNCHER_TARGETS): generate-exported-symbols |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
552 |
endif |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
553 |
|
26115
7a9dc384f3c8
8055188: General cleanup of minor issues from source restructure
erikj
parents:
25883
diff
changeset
|
554 |
# The demos are currently linking to libjvm and libjava, just like all other |
7a9dc384f3c8
8055188: General cleanup of minor issues from source restructure
erikj
parents:
25883
diff
changeset
|
555 |
# jdk libs, even though they don't need to. To avoid warnings, make sure they |
7a9dc384f3c8
8055188: General cleanup of minor issues from source restructure
erikj
parents:
25883
diff
changeset
|
556 |
# aren't built until after libjava and libjvm are available to link to. |
31310 | 557 |
demos-jdk: $(JAVA_TARGETS) |
25854 | 558 |
|
559 |
# Declare dependency from <module>-java to <module>-gensrc |
|
560 |
$(foreach m, $(GENSRC_MODULES), $(eval $m-java: $m-gensrc)) |
|
561 |
||
562 |
# Declare dependencies between java modules |
|
563 |
$(foreach m, $(JAVA_MODULES), \ |
|
564 |
$(eval $m-java: $(addsuffix -java, $(filter $(JAVA_MODULES), \ |
|
565 |
$(call FindDepsForModule,$m))))) |
|
566 |
||
567 |
# Declare dependencies between <module>-rmic to <module>-java |
|
568 |
$(foreach m, $(RMIC_MODULES), $(eval $m-rmic: $m-java)) |
|
569 |
||
570 |
# Declare dependencies from <module>-lib to <module>-java |
|
37770 | 571 |
# Skip modules that do not have java source. |
572 |
# When creating a BUILDJDK, the java compilation has already been done by the |
|
573 |
# normal build and copied in. |
|
36506 | 574 |
ifneq ($(CREATING_BUILDJDK), true) |
37770 | 575 |
$(foreach m, $(filter $(JAVA_MODULES), $(LIBS_MODULES)), $(eval $m-libs: $m-java)) |
36506 | 576 |
endif |
25854 | 577 |
|
578 |
# Declare dependencies from all other <module>-lib to java.base-lib |
|
27560 | 579 |
$(foreach t, $(filter-out java.base-libs, $(LIBS_TARGETS)), \ |
25854 | 580 |
$(eval $t: java.base-libs)) |
581 |
||
29851
81a61a04e2fe
8076182: Open Source Java Access Bridge - Create Patch for JEP C127 8055831
ptbrunet
parents:
29305
diff
changeset
|
582 |
# jdk.accessibility depends on java.desktop |
81a61a04e2fe
8076182: Open Source Java Access Bridge - Create Patch for JEP C127 8055831
ptbrunet
parents:
29305
diff
changeset
|
583 |
jdk.accessibility-libs: java.desktop-libs |
81a61a04e2fe
8076182: Open Source Java Access Bridge - Create Patch for JEP C127 8055831
ptbrunet
parents:
29305
diff
changeset
|
584 |
|
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
585 |
# This dependency needs to be explicitly declared. jdk.jdi-gensrc generates a |
27560 | 586 |
# header file used by jdk.jdwp.agent-libs. The jdk.jdwp.agent-gensrc is a |
587 |
# virtual target. |
|
588 |
jdk.jdwp.agent-libs: jdk.jdwp.agent-gensrc |
|
589 |
||
26672
528d9d6614e5
8047933: Race between jdk/make/scripts/genExceptions.sh and com.sun.tools.javadoc.Main
erikj
parents:
26398
diff
changeset
|
590 |
# The swing beans need to have java base properly generated to avoid errors |
528d9d6614e5
8047933: Race between jdk/make/scripts/genExceptions.sh and com.sun.tools.javadoc.Main
erikj
parents:
26398
diff
changeset
|
591 |
# in javadoc. |
27560 | 592 |
java.desktop-gensrc-jdk: java.base-gensrc |
26672
528d9d6614e5
8047933: Race between jdk/make/scripts/genExceptions.sh and com.sun.tools.javadoc.Main
erikj
parents:
26398
diff
changeset
|
593 |
|
35028
d1a03d533057
8146660: Resolve merge issue in resulting from sun.misc.VM move to jdk.internal.misc
amurillo
parents:
34491
diff
changeset
|
594 |
# The annotation processing for jdk.vm.ci needs java.base classes from the |
d1a03d533057
8146660: Resolve merge issue in resulting from sun.misc.VM move to jdk.internal.misc
amurillo
parents:
34491
diff
changeset
|
595 |
# current JDK. |
35747 | 596 |
jdk.vm.ci-gensrc-hotspot: java.base-java |
35028
d1a03d533057
8146660: Resolve merge issue in resulting from sun.misc.VM move to jdk.internal.misc
amurillo
parents:
34491
diff
changeset
|
597 |
|
25854 | 598 |
# Explicitly add dependencies for special targets |
599 |
java.base-java: unpack-sec |
|
600 |
||
33045
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
601 |
# The copy target copies files generated by gensrc |
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
602 |
java.base-copy-hotspot: java.base-gensrc-hotspot |
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
603 |
|
30742 | 604 |
jdk.jdeps-gendata: java rmic |
26132
11df1233e1e8
8055856: checkdeps build target doesn't work for cross-compilation builds
mchung
parents:
26128
diff
changeset
|
605 |
|
36506 | 606 |
# Declare dependencies from <module>-strip to libs, launchers, gendata and copy |
607 |
$(foreach m, $(LIBS_MODULES), $(eval $m-strip: $m-libs)) |
|
608 |
$(foreach m, $(LAUNCHER_MODULES), $(eval $m-strip: $m-launchers)) |
|
609 |
$(foreach m, $(GENDATA_MODULES), $(eval $m-strip: $m-gendata)) |
|
610 |
$(foreach m, $(COPY_MODULES), $(eval $m-strip: $m-copy)) |
|
611 |
||
37764
63e0379dd186
8154956: Module system implementation refresh (4/2016)
alanb
parents:
37407
diff
changeset
|
612 |
# Declare dependencies between jmod targets. Only java.base jmod needs access |
63e0379dd186
8154956: Module system implementation refresh (4/2016)
alanb
parents:
37407
diff
changeset
|
613 |
# to the other jmods to be built. |
37770 | 614 |
# When creating a BUILDJDK, we don't need to add hashes to java.base, thus |
615 |
# we don't need to depend on all other jmods |
|
616 |
ifneq ($(CREATING_BUILDJDK), true) |
|
37975
551c5d86de79
8155786: Determine modules depending on upgradeable modules directly and indirectly
erikj
parents:
37974
diff
changeset
|
617 |
java.base-jmod: $(filter-out java.base-jmod \ |
551c5d86de79
8155786: Determine modules depending on upgradeable modules directly and indirectly
erikj
parents:
37974
diff
changeset
|
618 |
$(addsuffix -jmod, $(call FindAllUpgradeableModules)), $(JMOD_TARGETS)) |
37770 | 619 |
endif |
36506 | 620 |
|
621 |
# Declare dependencies from <module>-jmod to all other module targets |
|
622 |
$(foreach m, $(STRIP_MODULES), $(eval $m-jmod: $m-strip)) |
|
37770 | 623 |
# When creating a BUILDJDK, the java compilation has already been done by the |
624 |
# normal build and copied in. |
|
625 |
ifneq ($(CREATING_BUILDJDK), true) |
|
626 |
$(foreach m, $(JAVA_MODULES), $(eval $m-jmod: $m-java)) |
|
627 |
endif |
|
36506 | 628 |
$(foreach m, $(GENDATA_MODULES), $(eval $m-jmod: $m-gendata)) |
629 |
$(foreach m, $(RMIC_MODULES), $(eval $m-jmod: $m-rmic)) |
|
630 |
$(foreach m, $(LIBS_MODULES), $(eval $m-jmod: $m-libs)) |
|
631 |
$(foreach m, $(LAUNCHER_MODULES), $(eval $m-jmod: $m-launchers)) |
|
632 |
$(foreach m, $(COPY_MODULES), $(eval $m-jmod: $m-copy)) |
|
633 |
||
634 |
# Jmods cannot be created until we have the jlink tool ready to run, which requires |
|
635 |
# all java modules to be compiled and jdk.jlink-launchers. |
|
39188
cdb1013defd0
8160423: Serieal build is broken because of missing dependencies for jmod
simonis
parents:
39110
diff
changeset
|
636 |
# And we also need to copy jvm.cfg (done in java.base-copy) and tzdb.dat (done in |
cdb1013defd0
8160423: Serieal build is broken because of missing dependencies for jmod
simonis
parents:
39110
diff
changeset
|
637 |
# java.base-gendata) to the appropriate location otherwise jimage, jlink and jmod won't start. |
cdb1013defd0
8160423: Serieal build is broken because of missing dependencies for jmod
simonis
parents:
39110
diff
changeset
|
638 |
$(JMOD_TARGETS): java.base-libs java.base-copy java.base-gendata jdk.jlink-launchers |
37770 | 639 |
# When creating a BUILDJDK, the java compilation has already been done by the |
640 |
# normal build and copied in. |
|
641 |
ifneq ($(CREATING_BUILDJDK), true) |
|
642 |
$(JMOD_TARGETS): java |
|
643 |
endif |
|
36506 | 644 |
|
645 |
ifeq ($(CREATE_BUILDJDK), true) |
|
37770 | 646 |
# Avoid calling create-buildjdk from within a create-buildjdk call |
647 |
ifneq ($(CREATING_BUILDJDK), true) |
|
648 |
$(JMOD_TARGETS): create-buildjdk |
|
649 |
endif |
|
36506 | 650 |
endif |
651 |
||
27560 | 652 |
zip-security: java.base-java java.security.jgss-java java.security.jgss-libs \ |
653 |
$(filter jdk.crypto%, $(JAVA_TARGETS)) |
|
25854 | 654 |
|
27560 | 655 |
zip-source: gensrc rmic |
656 |
||
36506 | 657 |
jrtfs-jar: interim-langtools |
25854 | 658 |
|
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
659 |
ifeq ($(ENABLE_GENERATE_CLASSLIST), true) |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
660 |
ifeq ($(CREATE_BUILDJDK), true) |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
661 |
# If creating a buildjdk, the interim image needs to be based on that. |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
662 |
generate-classlist: create-buildjdk |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
663 |
else ifeq ($(EXTERNAL_BUILDJDK), false) |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
664 |
# If an external buildjdk has been provided, we skip generating an |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
665 |
# interim-image and just use the external buildjdk for generating |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
666 |
# classlist. |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
667 |
generate-classlist: interim-image |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
668 |
endif |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
669 |
generate-classlist: buildtools-jdk |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
670 |
|
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
671 |
jimages: generate-classlist |
37770 | 672 |
endif |
673 |
||
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
674 |
jimages: jmods zip-source source-tips demos samples jrtfs-jar |
25854 | 675 |
|
36506 | 676 |
profiles: jmods zip-source source-tips jrtfs-jar |
25854 | 677 |
|
31310 | 678 |
mac-bundles-jdk: jimages |
25854 | 679 |
|
27560 | 680 |
bootcycle-images: jimages |
25854 | 681 |
|
36506 | 682 |
docs-javadoc: $(GENSRC_TARGETS) rmic |
25854 | 683 |
|
684 |
docs-jvmtidoc: hotspot |
|
685 |
||
37649
3809534d4531
8154841: Let different Jib profiles have different default make targets
erikj
parents:
37407
diff
changeset
|
686 |
zip-docs: docs-javadoc docs-jvmtidoc |
3809534d4531
8154841: Let different Jib profiles have different default make targets
erikj
parents:
37407
diff
changeset
|
687 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
688 |
test: jimages test-image |
25854 | 689 |
|
37770 | 690 |
create-buildjdk-copy: jdk.jlink-java java.base-gendata \ |
691 |
$(addsuffix -java, $(INTERIM_IMAGE_MODULES)) |
|
36506 | 692 |
|
37770 | 693 |
create-buildjdk-interim-image: create-buildjdk-copy |
694 |
||
695 |
interim-image: $(addsuffix -jmod, $(INTERIM_IMAGE_MODULES)) |
|
25854 | 696 |
|
28600
09dd1740f176
8069261: Create make dependencies on make variable values
erikj
parents:
28285
diff
changeset
|
697 |
test-make: clean-test-make |
09dd1740f176
8069261: Create make dependencies on make variable values
erikj
parents:
28285
diff
changeset
|
698 |
|
33436 | 699 |
build-test-lib: java |
700 |
||
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
701 |
build-test-failure-handler: interim-langtools |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
702 |
|
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
703 |
test-failure-handler: build-test-failure-handler |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
704 |
|
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
705 |
test-image-failure-handler: build-test-failure-handler |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
706 |
|
39938
8d5f6d6b8a24
8144278: [TESTBUG] hotspot/runtime/StackGuardPages/testme.sh should use native library build support
gthornbr
parents:
39386
diff
changeset
|
707 |
build-test-hotspot-jtreg-native: buildtools-jdk import-hotspot |
29159
7fed45c53518
8074072: Race condition in build since JDK-8072842 can cause failed builds on Solaris
erikj
parents:
29156
diff
changeset
|
708 |
|
7fed45c53518
8074072: Race condition in build since JDK-8072842 can cause failed builds on Solaris
erikj
parents:
29156
diff
changeset
|
709 |
build-test-jdk-jtreg-native: buildtools-jdk |
7fed45c53518
8074072: Race condition in build since JDK-8072842 can cause failed builds on Solaris
erikj
parents:
29156
diff
changeset
|
710 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
711 |
test-image-hotspot-jtreg-native: build-test-hotspot-jtreg-native |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
712 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
713 |
test-image-jdk-jtreg-native: build-test-jdk-jtreg-native |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
714 |
|
37967
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
715 |
test-image-hotspot-gtest: hotspot |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
716 |
|
33565
ac22b6bd7ecb
8139256: Add Makefile target to run internal VM tests
ehelin
parents:
33564
diff
changeset
|
717 |
test-hotspot-internal: exploded-image |
ac22b6bd7ecb
8139256: Add Makefile target to run internal VM tests
ehelin
parents:
33564
diff
changeset
|
718 |
|
33566
fc0dc6b3c02d
8139271: Add top-level Makefile target to run hotspots jtreg tests
ehelin
parents:
33565
diff
changeset
|
719 |
test-hotspot-jtreg: jimages test-image |
fc0dc6b3c02d
8139271: Add top-level Makefile target to run hotspots jtreg tests
ehelin
parents:
33565
diff
changeset
|
720 |
|
37974 | 721 |
test-hotspot-gtest: exploded-image test-image-hotspot-gtest |
722 |
||
33722
f82c74b7f2db
8143036: Make install target does not depend on images
erikj
parents:
33571
diff
changeset
|
723 |
install: product-images |
f82c74b7f2db
8143036: Make install target does not depend on images
erikj
parents:
33571
diff
changeset
|
724 |
|
37972 | 725 |
product-bundles: product-images |
726 |
||
727 |
test-bundles: test-image |
|
728 |
||
729 |
docs-bundles: docs-image |
|
730 |
||
36506 | 731 |
generate-summary: jmods |
732 |
||
25854 | 733 |
endif |
734 |
||
735 |
################################################################################ |
|
736 |
# Virtual targets without recipes |
|
737 |
||
32806 | 738 |
buildtools: buildtools-langtools interim-langtools interim-rmic \ |
27560 | 739 |
buildtools-jdk |
740 |
||
25854 | 741 |
gensrc: $(GENSRC_TARGETS) |
742 |
||
743 |
gendata: $(GENDATA_TARGETS) |
|
744 |
||
36506 | 745 |
copy: $(ALL_COPY_TARGETS) |
25854 | 746 |
|
747 |
java: $(JAVA_TARGETS) |
|
748 |
||
749 |
rmic: $(RMIC_TARGETS) |
|
750 |
||
27560 | 751 |
libs: $(LIBS_TARGETS) |
25854 | 752 |
|
753 |
launchers: $(LAUNCHER_TARGETS) |
|
754 |
||
36506 | 755 |
jmods: $(JMOD_TARGETS) |
756 |
||
757 |
strip-binaries: $(STRIP_TARGETS) |
|
758 |
||
27560 | 759 |
# Explicitly declare dependency for virtual target jdk.jdwp.agent-gensrc which |
760 |
# is actually handled by jdk.jdi-gensrc |
|
761 |
jdk.jdwp.agent-gensrc: jdk.jdi-gensrc |
|
25854 | 762 |
|
763 |
# Declare dependencies from <module> to all the individual targets specific |
|
34102
c0a98357f847
8143141: Bring in minor build changes from the jigsaw/jake forest
erikj
parents:
33722
diff
changeset
|
764 |
# to that module <module>-*, that are needed for the exploded image. |
25854 | 765 |
$(foreach m, $(GENSRC_MODULES), $(eval $m: $m-gensrc)) |
766 |
$(foreach m, $(JAVA_MODULES), $(eval $m: $m-java)) |
|
767 |
$(foreach m, $(GENDATA_MODULES), $(eval $m: $m-gendata)) |
|
768 |
$(foreach m, $(RMIC_MODULES), $(eval $m: $m-rmic)) |
|
27560 | 769 |
$(foreach m, $(LIBS_MODULES), $(eval $m: $m-libs)) |
25854 | 770 |
$(foreach m, $(LAUNCHER_MODULES), $(eval $m: $m-launchers)) |
36506 | 771 |
$(foreach m, $(ALL_COPY_MODULES), $(eval $m: $m-copy)) |
31310 | 772 |
demos: demos-jdk |
773 |
||
774 |
samples: samples-jdk |
|
775 |
||
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
776 |
# The "exploded image" is a locally runnable JDK in $(BUILD_OUTPUT)/jdk. |
34102
c0a98357f847
8143141: Bring in minor build changes from the jigsaw/jake forest
erikj
parents:
33722
diff
changeset
|
777 |
exploded-image: $(ALL_MODULES) |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
778 |
|
37770 | 779 |
create-buildjdk: create-buildjdk-copy create-buildjdk-interim-image |
36506 | 780 |
|
31310 | 781 |
mac-bundles: mac-bundles-jdk |
782 |
||
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
783 |
# The $(BUILD_OUTPUT)/images directory contain the resulting deliverables, |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
784 |
# and in line with this, our targets for creating these are named *-image[s]. |
25854 | 785 |
|
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
786 |
# This target builds the product images, e.g. the JRE and JDK image |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
787 |
# (and possibly other, more specific versions) |
36506 | 788 |
product-images: jimages demos samples zip-security exploded-image |
789 |
||
37770 | 790 |
# The module summary cannot be run when: |
791 |
# * Cross compiling and building a partial BUILDJDK for the build host |
|
792 |
# * An external buildjdk has been supplied since it may not match the |
|
793 |
# module selection of the target jdk |
|
36506 | 794 |
ifneq ($(CREATE_BUILDJDK), true) |
37770 | 795 |
ifeq ($(EXTERNAL_BUILDJDK), false) |
796 |
product-images: generate-summary |
|
797 |
endif |
|
36506 | 798 |
endif |
25854 | 799 |
|
27560 | 800 |
ifeq ($(OPENJDK_TARGET_OS), macosx) |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
801 |
product-images: mac-bundles |
27560 | 802 |
endif |
25854 | 803 |
|
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
804 |
# This target builds the documentation image |
37649
3809534d4531
8154841: Let different Jib profiles have different default make targets
erikj
parents:
37407
diff
changeset
|
805 |
docs-image: docs-javadoc docs-jvmtidoc |
25854 | 806 |
|
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
807 |
# This target builds the test image |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
808 |
test-image: prepare-test-image test-image-hotspot-jtreg-native \ |
37967
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
809 |
test-image-jdk-jtreg-native test-image-failure-handler test-image-hotspot-gtest |
28285 | 810 |
|
37972 | 811 |
# all-images builds all our deliverables as images. |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
812 |
all-images: product-images test-image docs-image |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
813 |
|
37972 | 814 |
# all-bundles packages all our deliverables as tar.gz bundles. |
815 |
all-bundles: product-bundles test-bundles docs-bundles |
|
816 |
||
36506 | 817 |
ALL_TARGETS += buildtools gensrc gendata copy java rmic libs launchers jmods \ |
34102
c0a98357f847
8143141: Bring in minor build changes from the jigsaw/jake forest
erikj
parents:
33722
diff
changeset
|
818 |
jdk.jdwp.agent-gensrc $(ALL_MODULES) demos samples exploded-image \ |
37972 | 819 |
create-buildjdk mac-bundles product-images docs-image test-image all-images \ |
820 |
all-bundles |
|
25854 | 821 |
|
822 |
################################################################################ |
|
823 |
||
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
824 |
# Traditional targets typically run by users. |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
825 |
# These can be considered aliases for the targets now named by a more |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
826 |
# "modern" naming scheme. |
34491 | 827 |
default: $(DEFAULT_MAKE_TARGET) |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
828 |
jdk: exploded-image |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
829 |
images: product-images |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
830 |
docs: docs-image |
37972 | 831 |
bundles: all-bundles |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
832 |
all: all-images |
25854 | 833 |
|
37972 | 834 |
ALL_TARGETS += default jdk images docs bundles all |
25854 | 835 |
|
836 |
################################################################################ |
|
837 |
################################################################################ |
|
838 |
# |
|
839 |
# Clean targets |
|
840 |
# |
|
841 |
################################################################################ |
|
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
842 |
# Clean targets are automatically run serially by the Makefile calling this |
26398
ca1f84f97e20
8057537: Serialize reconfigure and fix make clean-foo foo
erikj
parents:
26285
diff
changeset
|
843 |
# file. |
25854 | 844 |
|
27560 | 845 |
CLEAN_DIRS += hotspot jdk bootcycle-build test buildtools support \ |
36506 | 846 |
images make-support test-make bundles buildjdk |
27560 | 847 |
CLEAN_DIR_TARGETS := $(addprefix clean-, $(CLEAN_DIRS)) |
33437 | 848 |
CLEAN_SUPPORT_DIRS += demos |
849 |
CLEAN_SUPPORT_DIR_TARGETS := $(addprefix clean-, $(CLEAN_SUPPORT_DIRS)) |
|
32562
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
850 |
CLEAN_TESTS += hotspot-jtreg-native jdk-jtreg-native lib |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
851 |
CLEAN_TEST_TARGETS += $(addprefix clean-test-, $(CLEAN_TESTS)) |
29790 | 852 |
CLEAN_PHASES := gensrc java native include docs |
27560 | 853 |
CLEAN_PHASE_TARGETS := $(addprefix clean-, $(CLEAN_PHASES)) |
854 |
CLEAN_MODULE_TARGETS := $(addprefix clean-, $(ALL_MODULES)) |
|
855 |
# Construct targets of the form clean-$module-$phase |
|
856 |
CLEAN_MODULE_PHASE_TARGETS := $(addprefix clean-, $(foreach m, $(ALL_MODULES), \ |
|
857 |
$(addprefix $m-, $(CLEAN_PHASES)))) |
|
14111 | 858 |
|
859 |
# Remove everything, except the output from configure. |
|
27560 | 860 |
clean: $(CLEAN_DIR_TARGETS) |
29790 | 861 |
($(CD) $(OUTPUT_ROOT) && $(RM) -r build*.log*) |
25854 | 862 |
$(ECHO) Cleaned all build artifacts. |
863 |
||
27560 | 864 |
$(CLEAN_DIR_TARGETS): |
865 |
$(call CleanDir,$(patsubst clean-%, %, $@)) |
|
866 |
||
33437 | 867 |
$(CLEAN_SUPPORT_DIR_TARGETS): |
868 |
$(call CleanSupportDir,$(patsubst clean-%, %, $@)) |
|
869 |
||
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
870 |
$(CLEAN_TEST_TARGETS): |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
871 |
$(call CleanTest,$(patsubst clean-test-%, %, $@)) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
872 |
|
27560 | 873 |
$(CLEAN_PHASE_TARGETS): |
874 |
$(call Clean-$(patsubst clean-%,%, $@)) |
|
875 |
||
876 |
$(CLEAN_MODULE_TARGETS): |
|
877 |
$(call CleanModule,$(patsubst clean-%, %, $@)) |
|
878 |
||
879 |
$(CLEAN_MODULE_PHASE_TARGETS): |
|
880 |
$(call Clean-$(word 3, $(subst -,$(SPACE),$@)), \ |
|
881 |
$(word 2, $(subst -,$(SPACE),$@))) |
|
882 |
||
883 |
# When removing the support dir, we must also remove jdk. Building classes has |
|
884 |
# the side effect of generating native headers. The headers end up in support |
|
885 |
# while classes and touch files end up in jdk. |
|
886 |
clean-support: clean-jdk |
|
25854 | 887 |
|
29790 | 888 |
# Remove everything, including configure configuration. If the output |
889 |
# directory was created by configure and now becomes empty, remove it as well. |
|
14111 | 890 |
dist-clean: clean |
29790 | 891 |
($(CD) $(OUTPUT_ROOT) && \ |
892 |
$(RM) -r *spec.gmk $(CONFIGURESUPPORT_OUTPUTDIR) Makefile compare.sh ide) |
|
25854 | 893 |
$(if $(filter $(CONF_NAME),$(notdir $(OUTPUT_ROOT))), \ |
20363 | 894 |
if test "x`$(LS) $(OUTPUT_ROOT)`" != x; then \ |
895 |
$(ECHO) "Warning: Not removing non-empty configuration directory for '$(CONF_NAME)'" ; \ |
|
896 |
else \ |
|
25854 | 897 |
($(CD) $(SRC_ROOT) && $(ECHO) "Removing configuration directory for '$(CONF_NAME)'" \ |
898 |
&& $(RM) -r $(OUTPUT_ROOT)) \ |
|
20363 | 899 |
fi \ |
900 |
) |
|
25854 | 901 |
$(ECHO) Cleaned everything, you will have to re-run configure. |
902 |
||
33437 | 903 |
ALL_TARGETS += clean dist-clean $(CLEAN_DIR_TARGETS) $(CLEAN_SUPPORT_DIR_TARGETS) \ |
904 |
$(CLEAN_TEST_TARGETS) $(CLEAN_PHASE_TARGETS) $(CLEAN_MODULE_TARGETS) \ |
|
905 |
$(CLEAN_MODULE_PHASE_TARGETS) |
|
25854 | 906 |
|
907 |
################################################################################ |
|
908 |
# Declare *-only targets for each normal target |
|
909 |
$(foreach t, $(ALL_TARGETS), $(eval $(t)-only: $(t))) |
|
14111 | 910 |
|
29662 | 911 |
ALL_TARGETS += $(addsuffix -only, $(filter-out dist-clean clean%, $(ALL_TARGETS))) |
912 |
||
913 |
################################################################################ |
|
914 |
||
915 |
# Include JPRT targets |
|
916 |
include $(SRC_ROOT)/make/Jprt.gmk |
|
917 |
||
918 |
################################################################################ |
|
919 |
||
29788 | 920 |
# The following targets are intentionally not added to ALL_TARGETS since they |
921 |
# are internal only, to support Init.gmk. |
|
922 |
||
29662 | 923 |
print-targets: |
924 |
@$(ECHO) $(sort $(ALL_TARGETS)) |
|
925 |
||
926 |
print-modules: |
|
927 |
@$(ECHO) $(sort $(ALL_MODULES)) |
|
928 |
||
29788 | 929 |
create-main-targets-include: |
35008 | 930 |
$(call LogInfo, Generating main target list) |
29788 | 931 |
@$(ECHO) ALL_MAIN_TARGETS := $(sort $(ALL_TARGETS)) > \ |
932 |
$(MAKESUPPORT_OUTPUTDIR)/main-targets.gmk |
|
25854 | 933 |
|
934 |
################################################################################ |
|
935 |
||
936 |
.PHONY: $(ALL_TARGETS) |
|
937 |
||
14111 | 938 |
FRC: # Force target |