author | fyuan |
Wed, 28 Aug 2019 11:00:55 +0800 | |
changeset 57896 | 48f52ad5a2c3 |
parent 57544 | 99d2dd7b84a8 |
child 58269 | 7a8de392f9e1 |
permissions | -rw-r--r-- |
14111 | 1 |
# |
53295
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
2 |
# Copyright (c) 2011, 2019, 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 |
||
47217 | 41 |
include $(TOPDIR)/make/MainSupport.gmk |
25854 | 42 |
|
20363 | 43 |
# Load the vital tools for all the makefiles. |
47217 | 44 |
include $(TOPDIR)/make/common/MakeBase.gmk |
45 |
include $(TOPDIR)/make/common/Modules.gmk |
|
46 |
include $(TOPDIR)/make/common/FindTests.gmk |
|
14111 | 47 |
|
25854 | 48 |
# 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
|
49 |
# valid top level targets. It's used to declare them all as PHONY and to |
25854 | 50 |
# generate the -only targets. |
51 |
ALL_TARGETS := |
|
52 |
||
22714
a752920c4317
8034191: Move relevant parts of build system to new closed repo
ihse
parents:
22031
diff
changeset
|
53 |
# Hook to include the corresponding custom file, if present. |
47314 | 54 |
$(eval $(call IncludeCustomExtension, Main.gmk)) |
14111 | 55 |
|
25854 | 56 |
# 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
|
57 |
ALL_MODULES := $(call FindAllModules) |
25854 | 58 |
|
59 |
################################################################################ |
|
60 |
################################################################################ |
|
61 |
# |
|
62 |
# Recipes for all targets. Only recipes, dependencies are declared later. |
|
63 |
# |
|
64 |
################################################################################ |
|
65 |
||
66 |
################################################################################ |
|
67 |
# Interim/build tools targets, compiling tools used during the build |
|
68 |
||
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
69 |
buildtools-langtools: |
47217 | 70 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ToolsLangtools.gmk) |
27560 | 71 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
72 |
interim-langtools: |
47217 | 73 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileInterimLangtools.gmk) |
25854 | 74 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
75 |
interim-rmic: |
47217 | 76 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileInterimRmic.gmk) |
25854 | 77 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
78 |
interim-cldrconverter: |
47217 | 79 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CopyInterimCLDRConverter.gmk) |
57544 | 80 |
|
81 |
interim-tzdb: |
|
82 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CopyInterimTZDB.gmk) |
|
83 |
||
31948 | 84 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
85 |
buildtools-jdk: |
47217 | 86 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileToolsJdk.gmk) |
41171 | 87 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
88 |
buildtools-modules: |
47217 | 89 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileModuleTools.gmk) |
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
90 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
91 |
buildtools-hotspot: |
47217 | 92 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileToolsHotspot.gmk) |
25854 | 93 |
|
32806 | 94 |
ALL_TARGETS += buildtools-langtools interim-langtools \ |
57544 | 95 |
interim-rmic interim-cldrconverter interim-tzdb buildtools-jdk buildtools-modules \ |
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
96 |
buildtools-hotspot |
25854 | 97 |
|
98 |
################################################################################ |
|
99 |
# Special targets for certain modules |
|
100 |
||
33562
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
101 |
generate-exported-symbols: |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
102 |
+($(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
|
103 |
|
50312 | 104 |
ALL_TARGETS += generate-exported-symbols |
14111 | 105 |
|
25854 | 106 |
################################################################################ |
107 |
# 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
|
108 |
# |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
109 |
$(eval $(call DeclareRecipesForPhase, GENSRC, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
110 |
TARGET_SUFFIX := gensrc-src, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
111 |
FILE_PREFIX := Gensrc, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
112 |
MAKE_SUBDIR := gensrc, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
113 |
CHECK_MODULES := $(ALL_MODULES), \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
114 |
)) |
47217 | 115 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
116 |
$(foreach m, $(GENSRC_MODULES), $(eval $m-gensrc: $m-gensrc-src)) |
14111 | 117 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
118 |
LANGTOOLS_GENSRC_TARGETS := $(filter $(addsuffix -%, $(LANGTOOLS_MODULES)), $(GENSRC_TARGETS)) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
119 |
INTERIM_LANGTOOLS_GENSRC_TARGETS := $(filter $(addsuffix -%, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
120 |
$(INTERIM_LANGTOOLS_BASE_MODULES)), $(GENSRC_TARGETS)) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
121 |
HOTSPOT_GENSRC_TARGETS := $(filter $(addsuffix -%, $(HOTSPOT_MODULES)), $(GENSRC_TARGETS)) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
122 |
JDK_GENSRC_TARGETS := $(filter-out $(LANGTOOLS_GENSRC_TARGETS) \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
123 |
$(HOTSPOT_GENSRC_TARGETS), $(GENSRC_TARGETS)) |
15053
64278cb83950
8005549: build-infra: Merge NewMakefile.gmk and common/makefiles/Makefile
erikj
parents:
14466
diff
changeset
|
124 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
125 |
GENSRC_MODULEINFO_MODULES := $(ALL_MODULES) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
126 |
GENSRC_MODULEINFO_TARGETS := $(addsuffix -gensrc-moduleinfo, \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
127 |
$(GENSRC_MODULEINFO_MODULES)) |
36506 | 128 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
129 |
GENSRC_MODULES := $(GENSRC_MODULEINFO_MODULES) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
130 |
GENSRC_TARGETS += $(sort $(GENSRC_MODULEINFO_TARGETS) \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
131 |
$(addsuffix -gensrc, $(GENSRC_MODULES))) |
36506 | 132 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
133 |
define DeclareModuleInfoRecipe |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
134 |
$1-gensrc-moduleinfo: |
47217 | 135 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) \ |
36506 | 136 |
-f GensrcModuleInfo.gmk MODULE=$1) |
137 |
||
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
138 |
$1-gensrc: $1-gensrc-moduleinfo |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
139 |
endef |
36506 | 140 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
141 |
$(foreach m, $(GENSRC_MODULEINFO_MODULES), $(eval $(call DeclareModuleInfoRecipe,$m))) |
36506 | 142 |
|
25854 | 143 |
ALL_TARGETS += $(GENSRC_TARGETS) |
144 |
||
145 |
################################################################################ |
|
146 |
# Generate data targets |
|
27560 | 147 |
$(eval $(call DeclareRecipesForPhase, GENDATA, \ |
148 |
TARGET_SUFFIX := gendata, \ |
|
149 |
FILE_PREFIX := Gendata, \ |
|
150 |
MAKE_SUBDIR := gendata, \ |
|
151 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
152 |
USE_WRAPPER := true)) |
|
25854 | 153 |
|
154 |
ALL_TARGETS += $(GENDATA_TARGETS) |
|
155 |
||
156 |
################################################################################ |
|
157 |
# Copy files targets |
|
27560 | 158 |
$(eval $(call DeclareRecipesForPhase, COPY, \ |
159 |
TARGET_SUFFIX := copy, \ |
|
160 |
FILE_PREFIX := Copy, \ |
|
161 |
MAKE_SUBDIR := copy, \ |
|
162 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
33045
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
163 |
USE_WRAPPER := true, \ |
47217 | 164 |
)) |
25854 | 165 |
|
36506 | 166 |
ALL_COPY_MODULES += $(COPY_MODULES) |
167 |
ALL_COPY_TARGETS += $(COPY_TARGETS) |
|
168 |
||
169 |
IMPORT_COPY_MODULES := $(call FindImportedModules) |
|
170 |
IMPORT_COPY_TARGETS := $(addsuffix -copy, $(IMPORT_COPY_MODULES)) |
|
171 |
ALL_COPY_MODULES += $(IMPORT_COPY_MODULES) |
|
172 |
ALL_COPY_TARGETS += $(IMPORT_COPY_TARGETS) |
|
173 |
||
174 |
define DeclareImportCopyRecipe |
|
175 |
$1-copy: |
|
47217 | 176 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) \ |
36506 | 177 |
-f CopyImportModules.gmk MODULE=$1) |
178 |
endef |
|
179 |
||
180 |
$(foreach m, $(IMPORT_COPY_MODULES), $(eval $(call DeclareImportCopyRecipe,$m))) |
|
181 |
||
182 |
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
|
183 |
|
25854 | 184 |
################################################################################ |
50313 | 185 |
# Targets for compiling all java modules. |
36506 | 186 |
JAVA_MODULES := $(ALL_MODULES) |
25854 | 187 |
JAVA_TARGETS := $(addsuffix -java, $(JAVA_MODULES)) |
14111 | 188 |
|
25854 | 189 |
define DeclareCompileJavaRecipe |
190 |
$1-java: |
|
47217 | 191 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) \ |
34102
c0a98357f847
8143141: Bring in minor build changes from the jigsaw/jake forest
erikj
parents:
33722
diff
changeset
|
192 |
-f CompileJavaModules.gmk MODULE=$1) |
25854 | 193 |
endef |
194 |
||
50313 | 195 |
$(foreach m, $(JAVA_MODULES), $(eval $(call DeclareCompileJavaRecipe,$m))) |
14111 | 196 |
|
25854 | 197 |
ALL_TARGETS += $(JAVA_TARGETS) |
198 |
||
199 |
################################################################################ |
|
200 |
# Targets for running rmic. |
|
27560 | 201 |
$(eval $(call DeclareRecipesForPhase, RMIC, \ |
202 |
TARGET_SUFFIX := rmic, \ |
|
203 |
FILE_PREFIX := Rmic, \ |
|
204 |
MAKE_SUBDIR := rmic, \ |
|
205 |
CHECK_MODULES := $(ALL_MODULES))) |
|
25854 | 206 |
|
207 |
ALL_TARGETS += $(RMIC_TARGETS) |
|
208 |
||
209 |
################################################################################ |
|
210 |
# Targets for compiling native libraries |
|
27560 | 211 |
$(eval $(call DeclareRecipesForPhase, LIBS, \ |
212 |
TARGET_SUFFIX := libs, \ |
|
213 |
FILE_PREFIX := Lib, \ |
|
214 |
MAKE_SUBDIR := lib, \ |
|
215 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
216 |
USE_WRAPPER := true)) |
|
14111 | 217 |
|
27560 | 218 |
ALL_TARGETS += $(LIBS_TARGETS) |
14111 | 219 |
|
25854 | 220 |
################################################################################ |
221 |
# Targets for compiling native executables |
|
27560 | 222 |
$(eval $(call DeclareRecipesForPhase, LAUNCHER, \ |
223 |
TARGET_SUFFIX := launchers, \ |
|
224 |
FILE_PREFIX := Launcher, \ |
|
225 |
MAKE_SUBDIR := launcher, \ |
|
226 |
CHECK_MODULES := $(ALL_MODULES), \ |
|
227 |
USE_WRAPPER := true)) |
|
25854 | 228 |
|
229 |
ALL_TARGETS += $(LAUNCHER_TARGETS) |
|
230 |
||
231 |
################################################################################ |
|
232 |
# Build hotspot target |
|
14111 | 233 |
|
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
234 |
HOTSPOT_VARIANT_TARGETS := $(addprefix hotspot-, $(JVM_VARIANTS)) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
235 |
HOTSPOT_VARIANT_GENSRC_TARGETS := $(addsuffix -gensrc, $(HOTSPOT_VARIANT_TARGETS)) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
236 |
HOTSPOT_VARIANT_LIBS_TARGETS := $(addsuffix -libs, $(HOTSPOT_VARIANT_TARGETS)) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
237 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
238 |
define DeclareHotspotGensrcRecipe |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
239 |
hotspot-$1-gensrc: |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
240 |
$$(call LogInfo, Building JVM variant '$1' with features '$(JVM_FEATURES_$1)') |
47217 | 241 |
+($(CD) $(TOPDIR)/make/hotspot && $(MAKE) $(MAKE_ARGS) -f gensrc/GenerateSources.gmk \ |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
242 |
JVM_VARIANT=$1) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
243 |
endef |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
244 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
245 |
$(foreach v, $(JVM_VARIANTS), $(eval $(call DeclareHotspotGensrcRecipe,$v))) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
246 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
247 |
define DeclareHotspotLibsRecipe |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
248 |
hotspot-$1-libs: |
47217 | 249 |
+($(CD) $(TOPDIR)/make/hotspot && $(MAKE) $(MAKE_ARGS) -f lib/CompileLibraries.gmk \ |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
250 |
JVM_VARIANT=$1) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
251 |
endef |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
252 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
253 |
$(foreach v, $(JVM_VARIANTS), $(eval $(call DeclareHotspotLibsRecipe,$v))) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
254 |
|
37402 | 255 |
hotspot-ide-project: |
47217 | 256 |
+($(CD) $(TOPDIR)/make/hotspot && $(MAKE) $(MAKE_ARGS) -f ide/CreateVSProject.gmk) |
37402 | 257 |
|
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
258 |
ALL_TARGETS += $(HOTSPOT_VARIANT_TARGETS) $(HOTSPOT_VARIANT_GENSRC_TARGETS) \ |
49423 | 259 |
$(HOTSPOT_VARIANT_LIBS_TARGETS) hotspot-ide-project |
15903 | 260 |
|
25854 | 261 |
################################################################################ |
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
262 |
# Generate libs and launcher targets for creating compile_commands.json fragments |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
263 |
define DeclareCompileCommandsRecipe |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
264 |
$1-compile-commands: |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
265 |
$$(call LogInfo, Generating compile_commands.json fragments for $1) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
266 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Main.gmk $1-only \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
267 |
GENERATE_COMPILE_COMMANDS_ONLY=true) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
268 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
269 |
COMPILE_COMMANDS_TARGETS_$2 += $1-compile-commands |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
270 |
endef |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
271 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
272 |
$(foreach t, $(HOTSPOT_VARIANT_LIBS_TARGETS), \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
273 |
$(eval $(call DeclareCompileCommandsRecipe,$t,HOTSPOT)) \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
274 |
) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
275 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
276 |
$(foreach t, $(LIBS_TARGETS) $(LAUNCHER_TARGETS), \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
277 |
$(eval $(call DeclareCompileCommandsRecipe,$t,JDK)) \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
278 |
) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
279 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
280 |
compile-commands compile-commands-hotspot: |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
281 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileCommands.gmk) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
282 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
283 |
ALL_TARGETS += $(COMPILE_COMMANDS_TARGETS_HOTSPOT) $(COMPILE_COMMANDS_TARGETS_JDK) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
284 |
ALL_TARGETS += compile-commands compile-commands-hotspot |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
285 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
286 |
################################################################################ |
55166
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
287 |
# VS Code projects |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
288 |
vscode-project: |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
289 |
+($(CD) $(TOPDIR)/make/vscode && $(MAKE) $(MAKE_ARGS) -f CreateVSCodeProject.gmk \ |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
290 |
VSCODE_INDEXER=cpptools) |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
291 |
|
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
292 |
vscode-project-clangd: |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
293 |
+($(CD) $(TOPDIR)/make/vscode && $(MAKE) $(MAKE_ARGS) -f CreateVSCodeProject.gmk \ |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
294 |
VSCODE_INDEXER=clangd) |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
295 |
|
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
296 |
vscode-project-rtags: |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
297 |
+($(CD) $(TOPDIR)/make/vscode && $(MAKE) $(MAKE_ARGS) -f CreateVSCodeProject.gmk \ |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
298 |
VSCODE_INDEXER=rtags) |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
299 |
|
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
300 |
vscode-project-ccls: |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
301 |
+($(CD) $(TOPDIR)/make/vscode && $(MAKE) $(MAKE_ARGS) -f CreateVSCodeProject.gmk \ |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
302 |
VSCODE_INDEXER=ccls) |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
303 |
|
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
304 |
ALL_TARGETS += vscode-project vscode-project-clangd vscode-project-rtags \ |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
305 |
vscode-project-ccls |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
306 |
|
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
307 |
################################################################################ |
44724
8efb5c82a573
8173801: Modify makefiles to not build demos and samples bundles.
shurailine
parents:
44397
diff
changeset
|
308 |
# Build demos targets |
14111 | 309 |
|
31310 | 310 |
demos-jdk: |
47217 | 311 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileDemos.gmk) |
14111 | 312 |
|
45096 | 313 |
test-image-demos-jdk: |
47217 | 314 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CompileDemos.gmk images) |
45096 | 315 |
|
316 |
ALL_TARGETS += demos-jdk test-image-demos-jdk |
|
14111 | 317 |
|
25854 | 318 |
################################################################################ |
36506 | 319 |
# Jigsaw specific data and analysis targets. |
320 |
||
321 |
generate-summary: |
|
47217 | 322 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f GenerateModuleSummary.gmk) |
36506 | 323 |
|
324 |
ALL_TARGETS += generate-summary |
|
325 |
||
326 |
################################################################################ |
|
327 |
# Jmod targets |
|
328 |
||
329 |
JMOD_MODULES := $(ALL_MODULES) |
|
330 |
JMOD_TARGETS := $(addsuffix -jmod, $(JMOD_MODULES)) |
|
331 |
||
332 |
define DeclareJmodRecipe |
|
333 |
$1-jmod: |
|
47217 | 334 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CreateJmods.gmk \ |
36506 | 335 |
MODULE=$1) |
336 |
endef |
|
337 |
||
338 |
$(foreach m, $(JMOD_MODULES), $(eval $(call DeclareJmodRecipe,$m))) |
|
339 |
||
340 |
ALL_TARGETS += $(JMOD_TARGETS) |
|
341 |
||
342 |
################################################################################ |
|
343 |
# Images targets |
|
14111 | 344 |
|
42282
faf3b6722c44
8031567: Better model for storing source revision information
ihse
parents:
41874
diff
changeset
|
345 |
store-source-revision: |
47217 | 346 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f SourceRevision.gmk store-source-revision) |
39110
712f29ba8708
8136771: Implement the license-swap logic as a make target
erikj
parents:
38844
diff
changeset
|
347 |
|
42282
faf3b6722c44
8031567: Better model for storing source revision information
ihse
parents:
41874
diff
changeset
|
348 |
create-source-revision-tracker: |
47217 | 349 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f SourceRevision.gmk create-source-revision-tracker) |
14111 | 350 |
|
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
351 |
BOOTCYCLE_TARGET := product-images |
25854 | 352 |
bootcycle-images: |
37980
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
353 |
ifneq ($(COMPILE_TYPE), cross) |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
354 |
$(call LogWarn, Boot cycle build step 2: Building a new JDK image using previously built image) |
54426 | 355 |
$(call MakeDir, $(OUTPUTDIR)/bootcycle-build) |
47217 | 356 |
+$(MAKE) $(MAKE_ARGS) -f $(TOPDIR)/make/Init.gmk PARALLEL_TARGETS=$(BOOTCYCLE_TARGET) \ |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
357 |
LOG_PREFIX="[bootcycle] " JOBS= SPEC=$(dir $(SPEC))bootcycle-spec.gmk main |
37980
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
358 |
else |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
359 |
$(call LogWarn, Boot cycle build disabled when cross compiling) |
b2d5f366a9ba
8157506: Disable bootcycle build when cross compiling
erikj
parents:
37975
diff
changeset
|
360 |
endif |
27560 | 361 |
|
362 |
zip-security: |
|
47217 | 363 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ZipSecurity.gmk) |
27560 | 364 |
|
365 |
zip-source: |
|
47217 | 366 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ZipSource.gmk) |
27560 | 367 |
|
368 |
jrtfs-jar: |
|
47217 | 369 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f JrtfsJar.gmk) |
27560 | 370 |
|
41260 | 371 |
jdk-image: |
47217 | 372 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Images.gmk jdk) |
41260 | 373 |
|
50490 | 374 |
legacy-jre-image: |
47217 | 375 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Images.gmk jre) |
41260 | 376 |
|
377 |
symbols-image: |
|
47217 | 378 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Images.gmk symbols) |
27560 | 379 |
|
50490 | 380 |
mac-jdk-bundle: |
381 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f MacBundles.gmk jdk-bundle) |
|
382 |
||
383 |
mac-legacy-jre-bundle: |
|
384 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f MacBundles.gmk jre-bundle) |
|
27560 | 385 |
|
42292 | 386 |
release-file: |
47217 | 387 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ReleaseFile.gmk) |
42292 | 388 |
|
41171 | 389 |
exploded-image-optimize: |
47217 | 390 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f ExplodedImageOptimize.gmk) |
41171 | 391 |
|
52774
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
392 |
ifeq ($(JCOV_ENABLED), true) |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
393 |
jcov-image: |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
394 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Coverage.gmk jcov-image) |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
395 |
endif |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
396 |
|
42282
faf3b6722c44
8031567: Better model for storing source revision information
ihse
parents:
41874
diff
changeset
|
397 |
ALL_TARGETS += store-source-revision create-source-revision-tracker bootcycle-images zip-security \ |
50490 | 398 |
zip-source jrtfs-jar jdk-image legacy-jre-image \ |
399 |
symbols-image mac-jdk-bundle mac-legacy-jre-bundle \ |
|
52774
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
400 |
release-file exploded-image-optimize jcov-image |
25854 | 401 |
|
402 |
################################################################################ |
|
403 |
# Docs targets |
|
404 |
||
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
405 |
# If building full docs, to complete docs-*-api we need both the javadoc and |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
406 |
# modulegraph targets. |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
407 |
docs-jdk-api-javadoc: |
47217 | 408 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-jdk-api-javadoc) |
44397
f932d6b9f7fe
8173303: Add module-subgraph images to main platform documentation
mchung
parents:
44078
diff
changeset
|
409 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
410 |
docs-jdk-api-modulegraph: |
47217 | 411 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-jdk-api-modulegraph) |
25854 | 412 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
413 |
docs-javase-api-javadoc: |
47217 | 414 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-javase-api-javadoc) |
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
415 |
|
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
416 |
docs-javase-api-modulegraph: |
47217 | 417 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-javase-api-modulegraph) |
44725
8747b14eb49c
8172312: Update docs target and image for new combined docs
ihse
parents:
44724
diff
changeset
|
418 |
|
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
419 |
docs-reference-api-javadoc: |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
420 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-reference-api-javadoc) |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
421 |
|
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
422 |
docs-reference-api-modulegraph: |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
423 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-reference-api-modulegraph) |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
424 |
|
44733 | 425 |
docs-jdk-specs: |
47217 | 426 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-jdk-specs) |
25854 | 427 |
|
45105 | 428 |
docs-jdk-index: |
47217 | 429 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-jdk-index) |
45105 | 430 |
|
41652
a0664e2b49a1
8168772: Convert javadoc generation to build-infra standards
ihse
parents:
41461
diff
changeset
|
431 |
docs-zip: |
47217 | 432 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-zip) |
37034
b63fd4af003e
8154313: Generated javadoc scattered all over the place
neugens
parents:
37031
diff
changeset
|
433 |
|
55447
95794e32352e
8226325: Support building of filtered spec bundles
dlsmith
parents:
55292
diff
changeset
|
434 |
docs-specs-zip: |
95794e32352e
8226325: Support building of filtered spec bundles
dlsmith
parents:
55292
diff
changeset
|
435 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Docs.gmk docs-specs-zip) |
95794e32352e
8226325: Support building of filtered spec bundles
dlsmith
parents:
55292
diff
changeset
|
436 |
|
44078
673240c54c2e
8176509: Use pandoc for converting build readme to html
ihse
parents:
44027
diff
changeset
|
437 |
update-build-docs: |
47217 | 438 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f UpdateBuildDocs.gmk) |
44078
673240c54c2e
8176509: Use pandoc for converting build readme to html
ihse
parents:
44027
diff
changeset
|
439 |
|
49133 | 440 |
update-x11wrappers: |
441 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f UpdateX11Wrappers.gmk) |
|
442 |
||
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
443 |
ALL_TARGETS += docs-jdk-api-javadoc docs-jdk-api-modulegraph \ |
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
444 |
docs-javase-api-javadoc docs-javase-api-modulegraph \ |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
445 |
docs-reference-api-javadoc docs-reference-api-modulegraph docs-jdk-specs \ |
55447
95794e32352e
8226325: Support building of filtered spec bundles
dlsmith
parents:
55292
diff
changeset
|
446 |
docs-jdk-index docs-zip docs-specs-zip update-build-docs update-x11wrappers |
25854 | 447 |
|
448 |
################################################################################ |
|
36506 | 449 |
# Cross compilation support |
450 |
||
37770 | 451 |
ifeq ($(CREATING_BUILDJDK), true) |
36506 | 452 |
# This target is only called by the recursive call below. |
37770 | 453 |
create-buildjdk-interim-image-helper: interim-image jdk.jlink-launchers \ |
454 |
java.base-copy jdk.jdeps-launchers |
|
36506 | 455 |
endif |
456 |
||
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
457 |
BUILDJDK_MODULES := $(sort $(foreach m, jdk.jlink $(INTERIM_IMAGE_MODULES), \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
458 |
$(call FindTransitiveDepsForModule, $m) $m)) |
36506 | 459 |
|
37770 | 460 |
create-buildjdk-interim-image: |
47217 | 461 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Main.gmk \ |
36506 | 462 |
$@-helper \ |
463 |
SPEC=$(dir $(SPEC))buildjdk-spec.gmk \ |
|
464 |
HOTSPOT_SPEC=$(dir $(SPEC))buildjdk-spec.gmk \ |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
465 |
CREATING_BUILDJDK=true \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
466 |
LOG_PREFIX="[buildjdk] " \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
467 |
JAVA_MODULES="$(BUILDJDK_MODULES)" \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
468 |
) |
36506 | 469 |
|
37770 | 470 |
ALL_TARGETS += create-buildjdk-copy create-buildjdk-interim-image |
471 |
||
472 |
################################################################################ |
|
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
473 |
# The interim-image is a small jlinked image that is used to generate artifacts |
37770 | 474 |
# at build time for use when linking the real images. |
475 |
||
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
476 |
INTERIM_JMOD_TARGETS := $(addsuffix -interim-jmod, $(INTERIM_IMAGE_MODULES)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
477 |
|
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
478 |
define DeclareInterimJmodRecipe |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
479 |
$1-interim-jmod: |
47217 | 480 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f CreateJmods.gmk \ |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
481 |
MODULE=$1 \ |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
482 |
JMODS_DIR=$(INTERIM_JMODS_DIR) \ |
53995 | 483 |
JMODS_SUPPORT_DIR=$(INTERIM_JMODS_DIR)/support \ |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
484 |
INTERIM_JMOD=true \ |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
485 |
) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
486 |
endef |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
487 |
|
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
488 |
$(foreach m, $(INTERIM_IMAGE_MODULES), $(eval $(call DeclareInterimJmodRecipe,$m))) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
489 |
|
37770 | 490 |
interim-image: |
47217 | 491 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f InterimImage.gmk) |
37770 | 492 |
|
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
493 |
ifeq ($(ENABLE_GENERATE_CLASSLIST), true) |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
494 |
generate-link-opt-data: |
47217 | 495 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f GenerateLinkOptData.gmk) |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
496 |
endif |
37770 | 497 |
|
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
498 |
ALL_TARGETS += $(INTERIM_JMOD_TARGETS) interim-image generate-link-opt-data |
36506 | 499 |
|
500 |
################################################################################ |
|
44027 | 501 |
# Generate test names for all JTReg test groups |
502 |
# |
|
503 |
||
504 |
define DeclareRunTestRecipe |
|
52342 | 505 |
test-$1: |
53465
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
506 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f RunTests.gmk \ |
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
507 |
TEST="$1") |
44027 | 508 |
|
52342 | 509 |
exploded-test-$1: |
53465
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
510 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f RunTests.gmk \ |
45266
29347d0c7122
8180651: Make target to run tests on exploded image
erikj
parents:
45105
diff
changeset
|
511 |
TEST="$1" JDK_IMAGE_DIR=$(JDK_OUTPUTDIR)) |
44027 | 512 |
endef |
513 |
||
514 |
# ALL_NAMED_TESTS is defined in FindTests.gmk |
|
515 |
$(foreach t, $(ALL_NAMED_TESTS), $(eval $(call DeclareRunTestRecipe,$t))) |
|
52342 | 516 |
ALL_TEST_TARGETS := $(addprefix test-, $(ALL_NAMED_TESTS)) |
52446
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
517 |
|
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
518 |
# We only support the "exploded-test-gtest" shortcut |
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
519 |
ALL_EXPLODED_TESTS := gtest |
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
520 |
ALL_EXPLODED_TEST_TARGETS := $(addprefix exploded-test-, $(ALL_EXPLODED_TESTS)) |
44027 | 521 |
|
53465
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
522 |
ALL_TARGETS += $(ALL_TEST_TARGETS) $(ALL_EXPLODED_TEST_TARGETS) |
44027 | 523 |
|
524 |
################################################################################ |
|
52595
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
525 |
# Build tests and microbenchmarks |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
526 |
# |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
527 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
528 |
prepare-test-image: |
47984 | 529 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f TestImage.gmk prepare-test-image) |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
530 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
531 |
build-test-hotspot-jtreg-native: |
47217 | 532 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNativeHotspot.gmk \ |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
533 |
build-test-hotspot-jtreg-native) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
534 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
535 |
test-image-hotspot-jtreg-native: |
47217 | 536 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNativeHotspot.gmk \ |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
537 |
test-image-hotspot-jtreg-native) |
25854 | 538 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
539 |
build-test-jdk-jtreg-native: |
47217 | 540 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNativeJdk.gmk \ |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
541 |
build-test-jdk-jtreg-native) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
542 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
543 |
test-image-jdk-jtreg-native: |
47217 | 544 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregNativeJdk.gmk \ |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
545 |
test-image-jdk-jtreg-native) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
546 |
|
50908 | 547 |
build-test-hotspot-jtreg-graal: |
548 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregGraalUnit.gmk \ |
|
549 |
build-test-hotspot-jtreg-graal) |
|
550 |
||
551 |
test-image-hotspot-jtreg-graal: |
|
552 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f JtregGraalUnit.gmk \ |
|
553 |
test-image-hotspot-jtreg-graal) |
|
554 |
||
37967
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
555 |
ifeq ($(BUILD_GTEST), true) |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
556 |
test-image-hotspot-gtest: |
47217 | 557 |
+($(CD) $(TOPDIR)/make/hotspot/test && $(MAKE) $(MAKE_ARGS) -f GtestImage.gmk) |
37967
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
558 |
endif |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
559 |
|
32562
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
560 |
build-test-lib: |
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
561 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) -f BuildTestLib.gmk) |
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
562 |
|
37035
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
563 |
ifeq ($(BUILD_FAILURE_HANDLER), true) |
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
564 |
# Builds the failure handler jtreg extension |
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
565 |
build-test-failure-handler: |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
566 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) \ |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
567 |
-f BuildFailureHandler.gmk build) |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
568 |
|
37035
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
569 |
# 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
|
570 |
test-image-failure-handler: |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
571 |
+($(CD) $(TOPDIR)/make/test && $(MAKE) $(MAKE_ARGS) \ |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
572 |
-f BuildFailureHandler.gmk images) |
37035
08e00f202d7a
8154292: jdk9-dev: All SE builds failed on 2016-04-14
erikj
parents:
37034
diff
changeset
|
573 |
endif |
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
574 |
|
52595
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
575 |
build-microbenchmark: |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
576 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f test/BuildMicrobenchmark.gmk) |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
577 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
578 |
ALL_TARGETS += prepare-test-image build-test-hotspot-jtreg-native \ |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
579 |
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
|
580 |
test-image-jdk-jtreg-native build-test-lib build-test-failure-handler \ |
44027 | 581 |
test-failure-handler test-image-failure-handler test-image-hotspot-gtest \ |
52595
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
582 |
test-image-hotspot-jtreg-graal build-test-hotspot-jtreg-graal \ |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
583 |
build-microbenchmark |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
584 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
585 |
################################################################################ |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
586 |
# Run tests |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
587 |
|
25854 | 588 |
test: |
53465
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
589 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f RunTests.gmk \ |
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
590 |
TEST="$(TEST)") |
37974 | 591 |
|
52342 | 592 |
exploded-test: |
53465
d982794784f1
8217626: Add setup/teardown functionality to RunTest
ihse
parents:
53295
diff
changeset
|
593 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f RunTests.gmk \ |
52342 | 594 |
TEST="$(TEST)" JDK_IMAGE_DIR=$(JDK_OUTPUTDIR)) |
25854 | 595 |
|
53295
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
596 |
jcov-test: |
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
597 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f RunTests.gmk \ |
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
598 |
TEST="$(TEST)" TEST_OPTS_JCOV=true) |
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
599 |
|
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
600 |
ALL_TARGETS += test exploded-test jcov-test |
25854 | 601 |
|
602 |
################################################################################ |
|
37972 | 603 |
# Bundles |
604 |
||
605 |
product-bundles: |
|
606 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk product-bundles) |
|
607 |
||
54348 | 608 |
legacy-bundles: |
609 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk legacy-bundles) |
|
610 |
||
37972 | 611 |
test-bundles: |
612 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk test-bundles) |
|
613 |
||
614 |
docs-bundles: |
|
615 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk docs-bundles) |
|
616 |
||
52774
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
617 |
ifeq ($(JCOV_ENABLED), true) |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
618 |
jcov-bundles: |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
619 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Bundles.gmk jcov-bundles) |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
620 |
endif |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
621 |
|
54348 | 622 |
ALL_TARGETS += product-bundles legacy-bundles test-bundles docs-bundles jcov-bundles |
37972 | 623 |
|
624 |
################################################################################ |
|
25854 | 625 |
# Install targets |
626 |
||
627 |
install: |
|
47217 | 628 |
+($(CD) $(TOPDIR)/make && $(MAKE) $(MAKE_ARGS) -f Install.gmk) |
25854 | 629 |
|
630 |
ALL_TARGETS += install |
|
631 |
||
632 |
################################################################################ |
|
633 |
# |
|
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
634 |
# Dependency declarations between targets. |
25854 | 635 |
# |
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
636 |
# These are declared in two groups. First all dependencies between targets that |
25854 | 637 |
# have recipes above as these dependencies may be disabled. Then the aggregator |
638 |
# targets that do not have recipes of their own, which will never have their |
|
639 |
# dependencies disabled. |
|
640 |
# |
|
641 |
################################################################################ |
|
642 |
# Targets with recipes above |
|
643 |
||
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
644 |
# If running an *-only target, parallel execution and dependencies between |
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
645 |
# recipe targets are disabled. This makes it possible to run a select set of |
25854 | 646 |
# 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
|
647 |
# all prerequisites are fulfilled. |
25854 | 648 |
ifneq ($(findstring -only, $(MAKECMDGOALS)), ) |
649 |
.NOTPARALLEL: |
|
650 |
else |
|
27560 | 651 |
$(LANGTOOLS_GENSRC_TARGETS): buildtools-langtools |
652 |
||
47364 | 653 |
interim-langtools: $(INTERIM_LANGTOOLS_GENSRC_TARGETS) |
25854 | 654 |
|
57544 | 655 |
buildtools-jdk: interim-langtools interim-cldrconverter interim-tzdb |
25854 | 656 |
|
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
657 |
buildtools-hotspot: interim-langtools |
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
658 |
|
41171 | 659 |
buildtools-modules: exploded-image-base |
660 |
||
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
661 |
$(HOTSPOT_GENSRC_TARGETS): interim-langtools buildtools-hotspot |
33045
00f484891bcf
8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents:
32806
diff
changeset
|
662 |
|
27560 | 663 |
$(JDK_GENSRC_TARGETS): interim-langtools buildtools-jdk |
25854 | 664 |
|
36506 | 665 |
$(GENSRC_MODULEINFO_TARGETS): buildtools-jdk |
666 |
||
27560 | 667 |
$(GENDATA_TARGETS): interim-langtools buildtools-jdk |
25854 | 668 |
|
669 |
interim-rmic: interim-langtools |
|
670 |
||
32806 | 671 |
$(RMIC_TARGETS): interim-langtools interim-rmic |
25854 | 672 |
|
31310 | 673 |
$(JAVA_TARGETS): interim-langtools |
674 |
||
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
675 |
# Declare dependencies between hotspot-<variant>* targets |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
676 |
$(foreach v, $(JVM_VARIANTS), \ |
52802 | 677 |
$(eval hotspot-$v-gensrc: java.base-copy) \ |
48355 | 678 |
$(eval hotspot-$v-libs: hotspot-$v-gensrc java.base-copy) \ |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
679 |
) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
680 |
|
37402 | 681 |
hotspot-ide-project: hotspot exploded-image |
682 |
||
33562
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
683 |
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
|
684 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
685 |
# If not already set, set the JVM variant target so that the JVM will be built. |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
686 |
JVM_MAIN_LIB_TARGETS ?= hotspot-$(JVM_VARIANT_MAIN)-libs |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
687 |
|
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
688 |
# Building one JVM variant is enough to start building the other libs |
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
689 |
$(LIBS_TARGETS): $(JVM_MAIN_LIB_TARGETS) |
25854 | 690 |
|
691 |
$(LAUNCHER_TARGETS): java.base-libs |
|
692 |
||
33562
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
693 |
ifeq ($(STATIC_BUILD), true) |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
694 |
$(LAUNCHER_TARGETS): generate-exported-symbols |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
695 |
endif |
c76b2fa11486
8136556: Add the ability to perform static builds of MacOSX x64 binaries
bobv
parents:
32806
diff
changeset
|
696 |
|
26115
7a9dc384f3c8
8055188: General cleanup of minor issues from source restructure
erikj
parents:
25883
diff
changeset
|
697 |
# 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
|
698 |
# 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
|
699 |
# aren't built until after libjava and libjvm are available to link to. |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
700 |
demos-jdk: java.base-libs exploded-image |
45096 | 701 |
test-image-demos-jdk: demos-jdk |
25854 | 702 |
|
703 |
# Declare dependency from <module>-java to <module>-gensrc |
|
704 |
$(foreach m, $(GENSRC_MODULES), $(eval $m-java: $m-gensrc)) |
|
705 |
||
706 |
# Declare dependencies between java modules |
|
707 |
$(foreach m, $(JAVA_MODULES), \ |
|
708 |
$(eval $m-java: $(addsuffix -java, $(filter $(JAVA_MODULES), \ |
|
709 |
$(call FindDepsForModule,$m))))) |
|
710 |
||
711 |
# Declare dependencies between <module>-rmic to <module>-java |
|
712 |
$(foreach m, $(RMIC_MODULES), $(eval $m-rmic: $m-java)) |
|
713 |
||
714 |
# Declare dependencies from <module>-lib to <module>-java |
|
37770 | 715 |
# Skip modules that do not have java source. |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
716 |
$(foreach m, $(filter $(JAVA_MODULES), $(LIBS_MODULES)), $(eval $m-libs: $m-java)) |
25854 | 717 |
|
718 |
# Declare dependencies from all other <module>-lib to java.base-lib |
|
27560 | 719 |
$(foreach t, $(filter-out java.base-libs, $(LIBS_TARGETS)), \ |
25854 | 720 |
$(eval $t: java.base-libs)) |
721 |
||
29851
81a61a04e2fe
8076182: Open Source Java Access Bridge - Create Patch for JEP C127 8055831
ptbrunet
parents:
29305
diff
changeset
|
722 |
# jdk.accessibility depends on java.desktop |
81a61a04e2fe
8076182: Open Source Java Access Bridge - Create Patch for JEP C127 8055831
ptbrunet
parents:
29305
diff
changeset
|
723 |
jdk.accessibility-libs: java.desktop-libs |
81a61a04e2fe
8076182: Open Source Java Access Bridge - Create Patch for JEP C127 8055831
ptbrunet
parents:
29305
diff
changeset
|
724 |
|
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
725 |
# This dependency needs to be explicitly declared. jdk.jdi-gensrc generates a |
27560 | 726 |
# header file used by jdk.jdwp.agent-libs. The jdk.jdwp.agent-gensrc is a |
727 |
# virtual target. |
|
728 |
jdk.jdwp.agent-libs: jdk.jdwp.agent-gensrc |
|
729 |
||
26672
528d9d6614e5
8047933: Race between jdk/make/scripts/genExceptions.sh and com.sun.tools.javadoc.Main
erikj
parents:
26398
diff
changeset
|
730 |
# The swing beans need to have java base properly generated to avoid errors |
48355 | 731 |
# in javadoc. The X11 wrappers need the java.base include files to have been |
732 |
# copied and processed. |
|
733 |
java.desktop-gensrc-src: java.base-gensrc java.base-copy |
|
26672
528d9d6614e5
8047933: Race between jdk/make/scripts/genExceptions.sh and com.sun.tools.javadoc.Main
erikj
parents:
26398
diff
changeset
|
734 |
|
52464
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
735 |
# The annotation processing for jdk.internal.vm.compiler |
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
736 |
# and jdk.internal.vm.compiler.management needs classes from the current JDK. |
47217 | 737 |
jdk.internal.vm.compiler-gensrc-src: $(addsuffix -java, \ |
43925 | 738 |
$(call FindTransitiveDepsForModule, jdk.internal.vm.compiler)) |
52464
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
739 |
jdk.internal.vm.compiler.management-gensrc-src: $(addsuffix -java, \ |
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
740 |
$(call FindTransitiveDepsForModule, jdk.internal.vm.compiler.management)) |
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
741 |
|
52464
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
742 |
# For these modules, the gensrc step is generating a module-info.java.extra |
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
743 |
# file to be processed by the gensrc-moduleinfo target. |
47217 | 744 |
jdk.internal.vm.compiler-gensrc-moduleinfo: jdk.internal.vm.compiler-gensrc-src |
52464
c139884bd80e
8213348: jdk.internal.vm.compiler.management service providers missing in module descriptor
dlong
parents:
52446
diff
changeset
|
745 |
jdk.internal.vm.compiler.management-gensrc-moduleinfo: jdk.internal.vm.compiler.management-gensrc-src |
42531
37ee95196b17
8166417: Integrate Graal-core into JDK for AOT compiler
kvn
parents:
42529
diff
changeset
|
746 |
|
30742 | 747 |
jdk.jdeps-gendata: java rmic |
26132
11df1233e1e8
8055856: checkdeps build target doesn't work for cross-compilation builds
mchung
parents:
26128
diff
changeset
|
748 |
|
45873
94940d8e375b
8181298: Assertion failure in com.sun.tools.javac.comp.Modules
jlahoda
parents:
45555
diff
changeset
|
749 |
# The ct.sym generation uses all the moduleinfos as input |
94940d8e375b
8181298: Assertion failure in com.sun.tools.javac.comp.Modules
jlahoda
parents:
45555
diff
changeset
|
750 |
jdk.compiler-gendata: $(GENSRC_MODULEINFO_TARGETS) |
94940d8e375b
8181298: Assertion failure in com.sun.tools.javac.comp.Modules
jlahoda
parents:
45555
diff
changeset
|
751 |
|
42285
864475e2cf63
8169816: Move src.zip and jrt-fs.jar under the lib directory
mchung
parents:
42282
diff
changeset
|
752 |
# Declare dependencies between jmod targets. |
864475e2cf63
8169816: Move src.zip and jrt-fs.jar under the lib directory
mchung
parents:
42282
diff
changeset
|
753 |
# java.base jmod needs jrt-fs.jar and access to the other jmods to be built. |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
754 |
# When creating the BUILDJDK, we don't need to add hashes to java.base, thus |
37770 | 755 |
# we don't need to depend on all other jmods |
756 |
ifneq ($(CREATING_BUILDJDK), true) |
|
43655 | 757 |
java.base-jmod: jrtfs-jar $(filter-out java.base-jmod, $(JMOD_TARGETS)) |
37770 | 758 |
endif |
36506 | 759 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
760 |
# If not already set, set the JVM target so that the JVM will be built. |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
761 |
JVM_MAIN_TARGETS ?= hotspot |
49133 | 762 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
763 |
# Building java.base-jmod requires all of VM (ie hotspot) to be built. |
49133 | 764 |
java.base-jmod: $(JVM_MAIN_TARGETS) |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
765 |
|
36506 | 766 |
# Declare dependencies from <module>-jmod to all other module targets |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
767 |
$(foreach m, $(JAVA_MODULES), $(eval $m_JMOD_DEPS += $m-java)) |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
768 |
$(foreach m, $(GENDATA_MODULES), $(eval $m_JMOD_DEPS += $m-gendata)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
769 |
$(foreach m, $(RMIC_MODULES), $(eval $m_JMOD_DEPS += $m-rmic)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
770 |
$(foreach m, $(LIBS_MODULES), $(eval $m_JMOD_DEPS += $m-libs)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
771 |
$(foreach m, $(LAUNCHER_MODULES), $(eval $m_JMOD_DEPS += $m-launchers)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
772 |
$(foreach m, $(COPY_MODULES), $(eval $m_JMOD_DEPS += $m-copy)) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
773 |
$(foreach m, $(ALL_MODULES), $(eval $m-jmod: $($(m)_JMOD_DEPS))) |
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
774 |
$(foreach m, $(INTERIM_IMAGE_MODULES), $(eval $m-interim-jmod: $($(m)_JMOD_DEPS))) |
36506 | 775 |
|
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
776 |
# Setup the minimal set of generated native source dependencies for hotspot |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
777 |
$(foreach v, $(JVM_VARIANTS), \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
778 |
$(eval hotspot-$v-libs-compile-commands: hotspot-$v-gensrc) \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
779 |
$(foreach m, $(filter java.desktop jdk.hotspot.agent, $(GENSRC_MODULES)), \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
780 |
$(eval hotspot-$v-libs-compile-commands: $m-gensrc)) \ |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
781 |
) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
782 |
|
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
783 |
# For the full JDK compile commands, create all possible generated sources |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
784 |
$(foreach m, $(GENSRC_MODULES), $(eval $m-libs-compile-commands: $m-gensrc)) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
785 |
$(foreach m, $(filter $(JAVA_MODULES), $(LIBS_MODULES)), $(eval $m-libs-compile-commands: $m-java)) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
786 |
|
53736
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
787 |
$(COMPILE_COMMANDS_TARGETS_HOTSPOT): clean-compile-commands |
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
788 |
$(COMPILE_COMMANDS_TARGETS_JDK): clean-compile-commands |
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
789 |
compile-commands-hotspot: $(COMPILE_COMMANDS_TARGETS_HOTSPOT) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
790 |
compile-commands: $(COMPILE_COMMANDS_TARGETS_HOTSPOT) $(COMPILE_COMMANDS_TARGETS_JDK) |
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
791 |
|
55166
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
792 |
vscode-project: compile-commands |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
793 |
vscode-project-clangd: compile-commands |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
794 |
vscode-project-rtags: compile-commands |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
795 |
vscode-project-ccls: compile-commands |
2ae056696b15
8223678: Add Visual Studio Code workspace generation support (for native code)
rwestberg
parents:
55112
diff
changeset
|
796 |
|
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
797 |
# Jmods cannot be created until we have the jmod tool ready to run. During |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
798 |
# a normal build we run it from the exploded image, but when cross compiling |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
799 |
# it's run from the buildjdk, which is either created at build time or user |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
800 |
# supplied. |
36506 | 801 |
ifeq ($(CREATE_BUILDJDK), true) |
37770 | 802 |
ifneq ($(CREATING_BUILDJDK), true) |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
803 |
# When cross compiling and buildjdk is to be created, simply depend on |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
804 |
# creating the buildjdk. |
37770 | 805 |
$(JMOD_TARGETS): create-buildjdk |
41171 | 806 |
buildtools-modules: create-buildjdk |
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
807 |
else |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
808 |
# While actually creating the buildjdk, we need to list the bare |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
809 |
# minimum dependencies needed before running jmod, to avoid building |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
810 |
# more than necessary. This includes: |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
811 |
# * all java modules |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
812 |
# * jdk.jlink-launchers |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
813 |
# * copy jvm.cfg (done in java.base-copy) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
814 |
# * tzdb.dat (done in java.base-gendata) |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
815 |
# Without all of these jimage, jlink and jmod won't start. |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
816 |
$(JMOD_TARGETS) $(INTERIM_JMOD_TARGETS): java.base-libs java.base-copy \ |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
817 |
java.base-gendata jdk.jlink-launchers java |
37770 | 818 |
endif |
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
819 |
else |
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
820 |
# The normal non cross compilation case uses needs to wait for the full |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
821 |
# exploded-image to avoid a race with the optimize target. |
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
822 |
$(JMOD_TARGETS) $(INTERIM_JMOD_TARGETS): exploded-image |
36506 | 823 |
endif |
824 |
||
42505
11439b0c0792
8169925: Organize licenses by module in source, JMOD file, and run-time image
mchung
parents:
42292
diff
changeset
|
825 |
# All modules include the main license files from java.base. |
11439b0c0792
8169925: Organize licenses by module in source, JMOD file, and run-time image
mchung
parents:
42292
diff
changeset
|
826 |
$(JMOD_TARGETS): java.base-copy |
11439b0c0792
8169925: Organize licenses by module in source, JMOD file, and run-time image
mchung
parents:
42292
diff
changeset
|
827 |
|
27560 | 828 |
zip-security: java.base-java java.security.jgss-java java.security.jgss-libs \ |
829 |
$(filter jdk.crypto%, $(JAVA_TARGETS)) |
|
25854 | 830 |
|
27560 | 831 |
zip-source: gensrc rmic |
832 |
||
36506 | 833 |
jrtfs-jar: interim-langtools |
25854 | 834 |
|
52607
da785658408b
8214045: Missing explicit dependencies of build-microbenchmark cause intermittent build failure
redestad
parents:
52595
diff
changeset
|
835 |
build-microbenchmark: interim-langtools exploded-image |
52595
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
836 |
|
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
837 |
ifeq ($(ENABLE_GENERATE_CLASSLIST), true) |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
838 |
ifeq ($(CREATE_BUILDJDK), true) |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
839 |
# If creating a buildjdk, the interim image needs to be based on that. |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
840 |
generate-link-opt-data: create-buildjdk |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
841 |
else ifeq ($(EXTERNAL_BUILDJDK), false) |
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
842 |
# 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
|
843 |
# 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
|
844 |
# classlist. |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
845 |
generate-link-opt-data: interim-image |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
846 |
endif |
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
847 |
generate-link-opt-data: buildtools-jdk |
38546
91a5c3430d4f
8157336: Generation of classlists at build time should be configurable
erikj
parents:
37980
diff
changeset
|
848 |
|
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
849 |
# The generated classlist needs to go into java.base-jmod. |
50490 | 850 |
java.base-jmod jdk.jlink-jmod jdk-image legacy-jre-image: generate-link-opt-data |
37770 | 851 |
endif |
852 |
||
42292 | 853 |
release-file: create-source-revision-tracker |
25854 | 854 |
|
44724
8efb5c82a573
8173801: Modify makefiles to not build demos and samples bundles.
shurailine
parents:
44397
diff
changeset
|
855 |
jdk-image: jmods zip-source demos release-file |
50490 | 856 |
legacy-jre-image: jmods release-file |
42506
54b0b4fffab5
8170878: JDK 9 fails to build when enabling Hotspot code coverage
erikj
parents:
42505
diff
changeset
|
857 |
symbols-image: $(LIBS_TARGETS) $(LAUNCHER_TARGETS) |
42292 | 858 |
|
50490 | 859 |
mac-jdk-bundle: jdk-image |
860 |
mac-legacy-jre-bundle: legacy-jre-image |
|
25854 | 861 |
|
52774
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
862 |
ifeq ($(JCOV_INPUT_JDK), ) |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
863 |
jcov-image: jdk-image |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
864 |
endif |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
865 |
|
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
866 |
# The optimize target can run as soon as the modules dir has been completely |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
867 |
# populated (java, copy and gendata targets) and the basic libs and launchers |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
868 |
# have been built. |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
869 |
exploded-image-optimize: java copy gendata java.base-libs java.base-launchers \ |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
870 |
buildtools-modules |
41171 | 871 |
|
41260 | 872 |
bootcycle-images: jdk-image |
25854 | 873 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
874 |
docs-jdk-api-javadoc: $(GENSRC_TARGETS) rmic |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
875 |
|
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
876 |
docs-javase-api-javadoc: $(GENSRC_TARGETS) rmic |
44397
f932d6b9f7fe
8173303: Add module-subgraph images to main platform documentation
mchung
parents:
44078
diff
changeset
|
877 |
|
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
878 |
docs-reference-api-javadoc: $(GENSRC_TARGETS) rmic |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
879 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
880 |
docs-jdk-api-modulegraph: exploded-image buildtools-modules |
25854 | 881 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
882 |
docs-javase-api-modulegraph: exploded-image buildtools-modules |
44725
8747b14eb49c
8172312: Update docs target and image for new combined docs
ihse
parents:
44724
diff
changeset
|
883 |
|
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
884 |
docs-reference-api-modulegraph: exploded-image buildtools-modules |
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
885 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
886 |
# If not already set, then set the JVM specific docs targets |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
887 |
JVM_DOCS_TARGETS ?= hotspot-$(JVM_VARIANT_MAIN)-gensrc |
49133 | 888 |
|
44733 | 889 |
# The gensrc steps for hotspot and jdk.jdi create html spec files. |
55112 | 890 |
docs-jdk-specs: buildtools-jdk $(JVM_DOCS_TARGETS) jdk.jdi-gensrc \ |
45229
88a3fab6006f
8180426: Use standard css file for new docs bundle index.html page
ihse
parents:
45105
diff
changeset
|
891 |
docs-jdk-index |
25854 | 892 |
|
44733 | 893 |
docs-zip: docs-jdk |
37649
3809534d4531
8154841: Let different Jib profiles have different default make targets
erikj
parents:
37407
diff
changeset
|
894 |
|
55447
95794e32352e
8226325: Support building of filtered spec bundles
dlsmith
parents:
55292
diff
changeset
|
895 |
docs-specs-zip: docs-jdk-specs |
95794e32352e
8226325: Support building of filtered spec bundles
dlsmith
parents:
55292
diff
changeset
|
896 |
|
52342 | 897 |
# Tests |
41260 | 898 |
test: jdk-image test-image |
25854 | 899 |
|
52342 | 900 |
exploded-test: exploded-image test-image |
901 |
||
53295
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
902 |
jcov-test: jcov-image test-image |
520f8e2041bb
8215729: Enhance makefiles to allow collecting code coverage with JCov
shurailine
parents:
52986
diff
changeset
|
903 |
|
52342 | 904 |
test-make: clean-test-make compile-commands |
905 |
||
906 |
test-make-compile-commands: compile-commands |
|
44027 | 907 |
|
908 |
# Declare dependency for all generated test targets |
|
52342 | 909 |
$(foreach t, $(filter-out test-make%, $(ALL_TEST_TARGETS)), $(eval $t: jdk-image test-image)) |
52446
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
910 |
$(foreach t, $(ALL_EXPLODED_TEST_TARGETS), $(eval $t: exploded-image test-image)) |
44027 | 911 |
|
41874
07c3c4f1eb63
8168108: lib/classlist should be packaged in java.base.jmod
erikj
parents:
41660
diff
changeset
|
912 |
interim-image: $(INTERIM_JMOD_TARGETS) |
25854 | 913 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
914 |
build-test-lib: exploded-image |
33436 | 915 |
|
37031
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
916 |
build-test-failure-handler: interim-langtools |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
917 |
|
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
918 |
test-image-failure-handler: build-test-failure-handler |
e90042bf422d
8149777: Enable enhanced failure handler for "make test"
erikj
parents:
36789
diff
changeset
|
919 |
|
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
920 |
build-test-hotspot-jtreg-native: buildtools-jdk \ |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
921 |
hotspot-$(JVM_VARIANT_MAIN)-libs |
29159
7fed45c53518
8074072: Race condition in build since JDK-8072842 can cause failed builds on Solaris
erikj
parents:
29156
diff
changeset
|
922 |
|
45555
9b00774291d5
8181147: JNU_GetStringPlatformChars should have a fast path for UTF-8
redestad
parents:
45271
diff
changeset
|
923 |
build-test-jdk-jtreg-native: buildtools-jdk java.base-libs |
29159
7fed45c53518
8074072: Race condition in build since JDK-8072842 can cause failed builds on Solaris
erikj
parents:
29156
diff
changeset
|
924 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
925 |
build-test-hotspot-jtreg-graal: exploded-image |
50908 | 926 |
|
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
927 |
test-image-hotspot-jtreg-native: build-test-hotspot-jtreg-native |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
928 |
|
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
929 |
test-image-jdk-jtreg-native: build-test-jdk-jtreg-native |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
930 |
|
50908 | 931 |
test-image-hotspot-jtreg-graal: build-test-hotspot-jtreg-graal |
932 |
||
37967
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
933 |
test-image-hotspot-gtest: hotspot |
8dd54c3bf02a
8148244: Finalize and integrate GTest implementation
iignatyev
parents:
37965
diff
changeset
|
934 |
|
33722
f82c74b7f2db
8143036: Make install target does not depend on images
erikj
parents:
33571
diff
changeset
|
935 |
install: product-images |
f82c74b7f2db
8143036: Make install target does not depend on images
erikj
parents:
33571
diff
changeset
|
936 |
|
37972 | 937 |
product-bundles: product-images |
938 |
||
54348 | 939 |
legacy-bundles: legacy-images |
940 |
||
37972 | 941 |
test-bundles: test-image |
942 |
||
943 |
docs-bundles: docs-image |
|
944 |
||
52774
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
945 |
jcov-bundles: jcov-image |
56ca125c973b
8214309: Enhance makefiles to allow generating JCov instrumented build
shurailine
parents:
52607
diff
changeset
|
946 |
|
41171 | 947 |
generate-summary: jmods buildtools-modules |
36506 | 948 |
|
49133 | 949 |
update-x11wrappers: java.base-copy buildtools-jdk |
950 |
||
25854 | 951 |
endif |
952 |
||
953 |
################################################################################ |
|
954 |
# Virtual targets without recipes |
|
955 |
||
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
956 |
# If not already set, set the JVM specific tools targets |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
957 |
JVM_TOOLS_TARGETS ?= buildtools-hotspot |
32806 | 958 |
buildtools: buildtools-langtools interim-langtools interim-rmic \ |
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
959 |
buildtools-jdk $(JVM_TOOLS_TARGETS) |
27560 | 960 |
|
54422
f562f8318ebd
8217728: Speed up incremental rerun of "make hotspot"
erikj
parents:
54348
diff
changeset
|
961 |
# Declare dependencies from hotspot-<variant> targets |
f562f8318ebd
8217728: Speed up incremental rerun of "make hotspot"
erikj
parents:
54348
diff
changeset
|
962 |
$(foreach v, $(JVM_VARIANTS), \ |
f562f8318ebd
8217728: Speed up incremental rerun of "make hotspot"
erikj
parents:
54348
diff
changeset
|
963 |
$(eval hotspot-$v: hotspot-$v-gensrc hotspot-$v-libs) \ |
f562f8318ebd
8217728: Speed up incremental rerun of "make hotspot"
erikj
parents:
54348
diff
changeset
|
964 |
) |
49423 | 965 |
hotspot: $(HOTSPOT_VARIANT_TARGETS) |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
966 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
967 |
# Create targets hotspot-libs and hotspot-gensrc. |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
968 |
$(foreach v, $(JVM_VARIANTS), \ |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
969 |
$(eval hotspot-libs: hotspot-$v-libs) \ |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
970 |
$(eval hotspot-gensrc: hotspot-$v-gensrc) \ |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
971 |
) |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
972 |
|
25854 | 973 |
gensrc: $(GENSRC_TARGETS) |
974 |
||
975 |
gendata: $(GENDATA_TARGETS) |
|
976 |
||
36506 | 977 |
copy: $(ALL_COPY_TARGETS) |
25854 | 978 |
|
979 |
java: $(JAVA_TARGETS) |
|
980 |
||
981 |
rmic: $(RMIC_TARGETS) |
|
982 |
||
27560 | 983 |
libs: $(LIBS_TARGETS) |
25854 | 984 |
|
985 |
launchers: $(LAUNCHER_TARGETS) |
|
986 |
||
36506 | 987 |
jmods: $(JMOD_TARGETS) |
988 |
||
27560 | 989 |
# Explicitly declare dependency for virtual target jdk.jdwp.agent-gensrc which |
990 |
# is actually handled by jdk.jdi-gensrc |
|
991 |
jdk.jdwp.agent-gensrc: jdk.jdi-gensrc |
|
25854 | 992 |
|
993 |
# 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
|
994 |
# to that module <module>-*, that are needed for the exploded image. |
25854 | 995 |
$(foreach m, $(GENSRC_MODULES), $(eval $m: $m-gensrc)) |
996 |
$(foreach m, $(JAVA_MODULES), $(eval $m: $m-java)) |
|
997 |
$(foreach m, $(GENDATA_MODULES), $(eval $m: $m-gendata)) |
|
998 |
$(foreach m, $(RMIC_MODULES), $(eval $m: $m-rmic)) |
|
27560 | 999 |
$(foreach m, $(LIBS_MODULES), $(eval $m: $m-libs)) |
25854 | 1000 |
$(foreach m, $(LAUNCHER_MODULES), $(eval $m: $m-launchers)) |
36506 | 1001 |
$(foreach m, $(ALL_COPY_MODULES), $(eval $m: $m-copy)) |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
1002 |
|
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
1003 |
# Building java.base includes building all of hotspot. |
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1004 |
java.base: $(JVM_MAIN_TARGETS) |
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
1005 |
|
31310 | 1006 |
demos: demos-jdk |
1007 |
||
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1008 |
# The "exploded image" is a locally runnable JDK in $(OUTPUTDIR)/jdk. |
41171 | 1009 |
exploded-image-base: $(ALL_MODULES) |
42292 | 1010 |
exploded-image: exploded-image-base release-file |
41275
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
1011 |
# When cross compiling, no need to optimize the exploded image since it won't |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
1012 |
# be runnable on the host platform anyway. |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
1013 |
ifneq ($(COMPILE_TYPE), cross) |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
1014 |
exploded-image: exploded-image-optimize |
0ffcfee0d9a9
8167195: VM fails to initialize intermittently when running jmod to create some images
erikj
parents:
41260
diff
changeset
|
1015 |
endif |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1016 |
|
55292
f4b2d5b83ebf
8217739: Cannot reuse java.base UnixConstants.java from target in BuildJDK when cross compiling
erikj
parents:
55166
diff
changeset
|
1017 |
create-buildjdk: create-buildjdk-interim-image |
36506 | 1018 |
|
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1019 |
docs-jdk-api: docs-jdk-api-javadoc |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1020 |
docs-javase-api: docs-javase-api-javadoc |
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
1021 |
docs-reference-api: docs-reference-api-javadoc |
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1022 |
|
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1023 |
# If we're building full docs, we must also generate the module graphs to |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1024 |
# get non-broken api documentation. |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1025 |
ifeq ($(ENABLE_FULL_DOCS), true) |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1026 |
docs-jdk-api: docs-jdk-api-modulegraph |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1027 |
docs-javase-api: docs-javase-api-modulegraph |
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
1028 |
docs-reference-api: docs-reference-api-modulegraph |
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1029 |
endif |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1030 |
|
45105 | 1031 |
docs-jdk: docs-jdk-api docs-jdk-specs docs-jdk-index |
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1032 |
docs-javase: docs-javase-api |
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
1033 |
docs-reference: docs-reference-api |
44726
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1034 |
|
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1035 |
# alias for backwards compatibility |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1036 |
docs-javadoc: docs-jdk-api |
04aa2c065f5c
8176785: Add build support to generate PNG file from .dot file
ihse
parents:
44725
diff
changeset
|
1037 |
|
50490 | 1038 |
mac-bundles: mac-jdk-bundle |
31310 | 1039 |
|
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1040 |
# The $(OUTPUTDIR)/images directory contain the resulting deliverables, |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1041 |
# and in line with this, our targets for creating these are named *-image[s]. |
25854 | 1042 |
|
50490 | 1043 |
# This target builds the product images, e.g. the JDK image |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1044 |
# (and possibly other, more specific versions) |
50490 | 1045 |
product-images: jdk-image symbols-image exploded-image |
41260 | 1046 |
|
54348 | 1047 |
# This target builds the legacy images, e.g. the legacy JRE image |
1048 |
legacy-images: legacy-jre-image |
|
1049 |
||
41260 | 1050 |
# zip-security is actually a bundle, but for now it needs to be considered |
1051 |
# an image until this can be cleaned up properly. |
|
1052 |
product-images: zip-security |
|
36506 | 1053 |
|
37770 | 1054 |
# The module summary cannot be run when: |
1055 |
# * Cross compiling and building a partial BUILDJDK for the build host |
|
1056 |
# * An external buildjdk has been supplied since it may not match the |
|
1057 |
# module selection of the target jdk |
|
36506 | 1058 |
ifneq ($(CREATE_BUILDJDK), true) |
37770 | 1059 |
ifeq ($(EXTERNAL_BUILDJDK), false) |
1060 |
product-images: generate-summary |
|
1061 |
endif |
|
36506 | 1062 |
endif |
25854 | 1063 |
|
53683 | 1064 |
ifeq ($(call isTargetOs, macosx), true) |
50490 | 1065 |
product-images: mac-jdk-bundle |
54348 | 1066 |
|
1067 |
legacy-images: mac-legacy-jre-bundle |
|
27560 | 1068 |
endif |
25854 | 1069 |
|
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1070 |
# This target builds the documentation image |
44733 | 1071 |
docs-image: docs-jdk |
25854 | 1072 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1073 |
# If not already set, set the JVM specific targets to build the test image |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1074 |
JVM_TEST_IMAGE_TARGETS ?= test-image-hotspot-jtreg-native test-image-hotspot-gtest |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1075 |
|
50908 | 1076 |
ifeq ($(INCLUDE_GRAAL), true) |
1077 |
JVM_TEST_IMAGE_TARGETS += test-image-hotspot-jtreg-graal |
|
1078 |
endif |
|
1079 |
||
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1080 |
# This target builds the test image |
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1081 |
test-image: prepare-test-image \ |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1082 |
test-image-jdk-jtreg-native test-image-failure-handler \ |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1083 |
test-image-demos-jdk $(JVM_TEST_IMAGE_TARGETS) |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1084 |
|
52595
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
1085 |
ifneq ($(JMH_CORE_JAR), ) |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
1086 |
test-image: build-microbenchmark |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
1087 |
endif |
16609197022c
8061281: Microbenchmark suite build support, directory layout and sample benchmarks
redestad
parents:
52464
diff
changeset
|
1088 |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1089 |
################################################################################ |
28285 | 1090 |
|
37972 | 1091 |
# all-images builds all our deliverables as images. |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1092 |
all-images: product-images test-image docs-image |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1093 |
|
37972 | 1094 |
# all-bundles packages all our deliverables as tar.gz bundles. |
1095 |
all-bundles: product-bundles test-bundles docs-bundles |
|
1096 |
||
42510
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
1097 |
ALL_TARGETS += buildtools hotspot hotspot-libs hotspot-gensrc gensrc gendata \ |
406dfb60de57
8170284: Move fine granular hotspot make targets to top level
erikj
parents:
41874
diff
changeset
|
1098 |
copy java rmic libs launchers jmods \ |
44724
8efb5c82a573
8173801: Modify makefiles to not build demos and samples bundles.
shurailine
parents:
44397
diff
changeset
|
1099 |
jdk.jdwp.agent-gensrc $(ALL_MODULES) demos \ |
41171 | 1100 |
exploded-image-base exploded-image \ |
47432
28d6070f5f2f
8189056: javadoc target for stable specdiff comparisons
ihse
parents:
47364
diff
changeset
|
1101 |
create-buildjdk docs-jdk-api docs-javase-api docs-reference-api docs-jdk \ |
54348 | 1102 |
docs-javase docs-reference docs-javadoc mac-bundles product-images legacy-images \ |
43043
bf14e07c9075
8172241: Cleanup mistakes in jib publish support change
erikj
parents:
42981
diff
changeset
|
1103 |
docs-image test-image all-images \ |
37972 | 1104 |
all-bundles |
25854 | 1105 |
|
1106 |
################################################################################ |
|
1107 |
||
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1108 |
# Traditional targets typically run by users. |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1109 |
# 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
|
1110 |
# "modern" naming scheme. |
34491 | 1111 |
default: $(DEFAULT_MAKE_TARGET) |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1112 |
jdk: exploded-image |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1113 |
images: product-images |
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1114 |
docs: docs-image |
37972 | 1115 |
bundles: all-bundles |
28811
65cf1b4087cf
8071767: Improve names and dependencies for image targets
ihse
parents:
28809
diff
changeset
|
1116 |
all: all-images |
25854 | 1117 |
|
37972 | 1118 |
ALL_TARGETS += default jdk images docs bundles all |
25854 | 1119 |
|
52342 | 1120 |
# Aliases used for running tests. |
1121 |
||
1122 |
# Let "run-test" be an alias for "test" |
|
1123 |
$(foreach t, $(ALL_NAMED_TESTS), $(eval run-test-$t: test-$t)) |
|
52446
187d16766a63
8213338: Reduce the number of generated make targets
ihse
parents:
52342
diff
changeset
|
1124 |
RUN_TEST_TARGETS := $(addprefix run-test-, $(ALL_NAMED_TESTS)) |
52342 | 1125 |
|
1126 |
run-test: test |
|
1127 |
exploded-run-test: exploded-test |
|
1128 |
||
1129 |
# "make check" is a common idiom for running basic testing |
|
1130 |
check: test-tier1 |
|
1131 |
||
1132 |
# Keep some old names as aliases |
|
1133 |
test-hotspot-jtreg: test-hotspot_all |
|
1134 |
test-hotspot-jtreg-native: test-hotspot_native_sanity |
|
1135 |
test-hotspot-gtest: exploded-test-gtest |
|
1136 |
test-jdk-jtreg-native: test-jdk_native_sanity |
|
1137 |
||
1138 |
ALL_TARGETS += $(RUN_TEST_TARGETS) run-test exploded-run-test check \ |
|
1139 |
test-hotspot-jtreg test-hotspot-jtreg-native test-hotspot-gtest \ |
|
1140 |
test-jdk-jtreg-native |
|
1141 |
||
25854 | 1142 |
################################################################################ |
1143 |
################################################################################ |
|
1144 |
# |
|
1145 |
# Clean targets |
|
1146 |
# |
|
1147 |
################################################################################ |
|
27595
cff167b3bfa2
8065914: Various improvements and cleanup of build system
ihse
parents:
27329
diff
changeset
|
1148 |
# 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
|
1149 |
# file. |
25854 | 1150 |
|
27560 | 1151 |
CLEAN_DIRS += hotspot jdk bootcycle-build test buildtools support \ |
53995 | 1152 |
images make-support test-make bundles buildjdk test-results test-support \ |
1153 |
support/images |
|
27560 | 1154 |
CLEAN_DIR_TARGETS := $(addprefix clean-, $(CLEAN_DIRS)) |
33437 | 1155 |
CLEAN_SUPPORT_DIRS += demos |
1156 |
CLEAN_SUPPORT_DIR_TARGETS := $(addprefix clean-, $(CLEAN_SUPPORT_DIRS)) |
|
32562
b4ed30cd962e
8136378: Build test libs using properly integrated makefile
ihse
parents:
31948
diff
changeset
|
1157 |
CLEAN_TESTS += hotspot-jtreg-native jdk-jtreg-native lib |
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
1158 |
CLEAN_TEST_TARGETS += $(addprefix clean-test-, $(CLEAN_TESTS)) |
41652
a0664e2b49a1
8168772: Convert javadoc generation to build-infra standards
ihse
parents:
41461
diff
changeset
|
1159 |
CLEAN_PHASES := gensrc java native include |
27560 | 1160 |
CLEAN_PHASE_TARGETS := $(addprefix clean-, $(CLEAN_PHASES)) |
1161 |
CLEAN_MODULE_TARGETS := $(addprefix clean-, $(ALL_MODULES)) |
|
1162 |
# Construct targets of the form clean-$module-$phase |
|
1163 |
CLEAN_MODULE_PHASE_TARGETS := $(addprefix clean-, $(foreach m, $(ALL_MODULES), \ |
|
1164 |
$(addprefix $m-, $(CLEAN_PHASES)))) |
|
14111 | 1165 |
|
1166 |
# Remove everything, except the output from configure. |
|
27560 | 1167 |
clean: $(CLEAN_DIR_TARGETS) |
52022
804792ce736f
8210459: Add support for generating compile_commands.json
rwestberg
parents:
51994
diff
changeset
|
1168 |
($(CD) $(OUTPUTDIR) && $(RM) -r build*.log* compile_commands.json) |
25854 | 1169 |
$(ECHO) Cleaned all build artifacts. |
1170 |
||
41652
a0664e2b49a1
8168772: Convert javadoc generation to build-infra standards
ihse
parents:
41461
diff
changeset
|
1171 |
clean-docs: |
a0664e2b49a1
8168772: Convert javadoc generation to build-infra standards
ihse
parents:
41461
diff
changeset
|
1172 |
$(call CleanDocs) |
a0664e2b49a1
8168772: Convert javadoc generation to build-infra standards
ihse
parents:
41461
diff
changeset
|
1173 |
|
53736
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1174 |
clean-compile-commands: |
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1175 |
$(call CleanMakeSupportDir,compile-commands) |
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1176 |
|
27560 | 1177 |
$(CLEAN_DIR_TARGETS): |
1178 |
$(call CleanDir,$(patsubst clean-%, %, $@)) |
|
1179 |
||
33437 | 1180 |
$(CLEAN_SUPPORT_DIR_TARGETS): |
1181 |
$(call CleanSupportDir,$(patsubst clean-%, %, $@)) |
|
1182 |
||
29156
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
1183 |
$(CLEAN_TEST_TARGETS): |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
1184 |
$(call CleanTest,$(patsubst clean-test-%, %, $@)) |
bd932374081c
8072842: Add support for building native JTReg tests
ihse
parents:
28899
diff
changeset
|
1185 |
|
27560 | 1186 |
$(CLEAN_PHASE_TARGETS): |
1187 |
$(call Clean-$(patsubst clean-%,%, $@)) |
|
1188 |
||
1189 |
$(CLEAN_MODULE_TARGETS): |
|
1190 |
$(call CleanModule,$(patsubst clean-%, %, $@)) |
|
1191 |
||
1192 |
$(CLEAN_MODULE_PHASE_TARGETS): |
|
1193 |
$(call Clean-$(word 3, $(subst -,$(SPACE),$@)), \ |
|
1194 |
$(word 2, $(subst -,$(SPACE),$@))) |
|
1195 |
||
1196 |
# When removing the support dir, we must also remove jdk. Building classes has |
|
1197 |
# the side effect of generating native headers. The headers end up in support |
|
1198 |
# while classes and touch files end up in jdk. |
|
1199 |
clean-support: clean-jdk |
|
25854 | 1200 |
|
47940 | 1201 |
clean-test: clean-test-results clean-test-support |
1202 |
||
53995 | 1203 |
# When cleaning images, also clean the support/images directory. |
1204 |
clean-images: clean-support/images |
|
1205 |
||
29790 | 1206 |
# Remove everything, including configure configuration. If the output |
1207 |
# directory was created by configure and now becomes empty, remove it as well. |
|
14111 | 1208 |
dist-clean: clean |
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1209 |
($(CD) $(OUTPUTDIR) && \ |
51678
2fdfe34f7262
8081858: make dist-clean does not delete all log files
ihse
parents:
50908
diff
changeset
|
1210 |
$(RM) -r *spec.gmk $(CONFIGURESUPPORT_OUTPUTDIR) Makefile compare.sh ide \ |
2fdfe34f7262
8081858: make dist-clean does not delete all log files
ihse
parents:
50908
diff
changeset
|
1211 |
configure.log* build.log*) |
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1212 |
$(if $(filter $(CONF_NAME),$(notdir $(OUTPUTDIR))), \ |
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1213 |
if test "x`$(LS) $(OUTPUTDIR)`" != x; then \ |
20363 | 1214 |
$(ECHO) "Warning: Not removing non-empty configuration directory for '$(CONF_NAME)'" ; \ |
1215 |
else \ |
|
47217 | 1216 |
($(CD) $(TOPDIR) && $(ECHO) "Removing configuration directory for '$(CONF_NAME)'" \ |
47253
92fd0e04e0e1
8187544: Replace BUILD_OUTPUT and OUTPUT_ROOT with OUTPUTDIR
ihse
parents:
47217
diff
changeset
|
1217 |
&& $(RM) -r $(OUTPUTDIR)) \ |
20363 | 1218 |
fi \ |
1219 |
) |
|
25854 | 1220 |
$(ECHO) Cleaned everything, you will have to re-run configure. |
1221 |
||
53736
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1222 |
ALL_TARGETS += clean clean-docs clean-compile-commands dist-clean $(CLEAN_DIR_TARGETS) \ |
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1223 |
$(CLEAN_SUPPORT_DIR_TARGETS) $(CLEAN_TEST_TARGETS) $(CLEAN_PHASE_TARGETS) \ |
81767abf7e6a
8218807: Compilation database (compile_commands.json) may contain obsolete items
rwestberg
parents:
53683
diff
changeset
|
1224 |
$(CLEAN_MODULE_TARGETS) $(CLEAN_MODULE_PHASE_TARGETS) |
25854 | 1225 |
|
1226 |
################################################################################ |
|
1227 |
# Declare *-only targets for each normal target |
|
1228 |
$(foreach t, $(ALL_TARGETS), $(eval $(t)-only: $(t))) |
|
14111 | 1229 |
|
29662 | 1230 |
ALL_TARGETS += $(addsuffix -only, $(filter-out dist-clean clean%, $(ALL_TARGETS))) |
1231 |
||
1232 |
################################################################################ |
|
1233 |
||
29788 | 1234 |
# The following targets are intentionally not added to ALL_TARGETS since they |
1235 |
# are internal only, to support Init.gmk. |
|
1236 |
||
29662 | 1237 |
print-targets: |
1238 |
@$(ECHO) $(sort $(ALL_TARGETS)) |
|
1239 |
||
1240 |
print-modules: |
|
1241 |
@$(ECHO) $(sort $(ALL_MODULES)) |
|
1242 |
||
44027 | 1243 |
print-tests: |
1244 |
@$(ECHO) $(sort $(ALL_NAMED_TESTS)) |
|
1245 |
||
29788 | 1246 |
create-main-targets-include: |
35008 | 1247 |
$(call LogInfo, Generating main target list) |
29788 | 1248 |
@$(ECHO) ALL_MAIN_TARGETS := $(sort $(ALL_TARGETS)) > \ |
1249 |
$(MAKESUPPORT_OUTPUTDIR)/main-targets.gmk |
|
25854 | 1250 |
|
1251 |
################################################################################ |
|
48918
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1252 |
# Hook to include the corresponding custom file, if present. |
18debf414948
8198425: make/Main.gmk Add extra extension/override points to the make file
erikj
parents:
48841
diff
changeset
|
1253 |
$(eval $(call IncludeCustomExtension, Main-post.gmk)) |
25854 | 1254 |
|
1255 |
.PHONY: $(ALL_TARGETS) |
|
1256 |
||
14111 | 1257 |
FRC: # Force target |